2015-04-03 00:51:08 +02:00
|
|
|
Dash Core staging tree 0.12
|
2014-12-12 13:05:25 +01:00
|
|
|
===============================
|
2012-12-13 03:27:58 +01:00
|
|
|
|
2015-04-03 00:51:08 +02:00
|
|
|
https://www.dashpay.io
|
2012-12-13 03:27:58 +01:00
|
|
|
|
2016-01-28 23:31:50 +01:00
|
|
|
Copyright (c) 2009-2016 Bitcoin Core Developers
|
2014-12-12 13:05:25 +01:00
|
|
|
|
2016-01-28 23:31:50 +01:00
|
|
|
Copyright (c) 2014-2016 Dash Core Developers
|
2012-12-13 03:27:58 +01:00
|
|
|
|
2014-12-12 12:09:19 +01:00
|
|
|
|
2015-03-18 00:06:58 +01:00
|
|
|
What is Dash?
|
2012-12-13 03:27:58 +01:00
|
|
|
----------------
|
|
|
|
|
2015-03-18 00:06:58 +01:00
|
|
|
Dash is an experimental new digital currency that enables anonymous, instant
|
|
|
|
payments to anyone, anywhere in the world. Dash uses peer-to-peer technology
|
2014-12-12 12:09:19 +01:00
|
|
|
to operate with no central authority: managing transactions and issuing money
|
2015-03-18 00:06:58 +01:00
|
|
|
are carried out collectively by the network. Dash Core is the name of open
|
2014-12-12 12:09:19 +01:00
|
|
|
source software which enables the use of this currency.
|
2012-12-13 03:27:58 +01:00
|
|
|
|
|
|
|
For more information, as well as an immediately useable, binary version of
|
2015-04-03 00:51:08 +02:00
|
|
|
the Dash Core software, see https://www.dashpay.io/downloads.
|
2014-12-12 12:09:19 +01:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
|
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
2015-03-18 00:06:58 +01:00
|
|
|
Dash Core is released under the terms of the MIT license. See [COPYING](COPYING) for more
|
2012-12-13 03:27:58 +01:00
|
|
|
information or see http://opensource.org/licenses/MIT.
|
2010-09-23 20:06:50 +02:00
|
|
|
|
2011-01-21 16:52:48 +01:00
|
|
|
Development process
|
2012-12-13 03:27:58 +01:00
|
|
|
-------------------
|
2011-09-27 04:22:19 +02:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
Developers work in their own trees, then submit pull requests when they think
|
|
|
|
their feature or bug fix is ready.
|
2013-01-09 21:55:47 +01:00
|
|
|
|
2015-04-03 00:51:08 +02:00
|
|
|
If it is a simple/trivial/non-controversial change, then one of the Dash
|
2012-12-13 03:27:58 +01:00
|
|
|
development team members simply pulls it.
|
2013-01-09 21:55:47 +01:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
If it is a *more complicated or potentially controversial* change, then the patch
|
|
|
|
submitter will be asked to start a discussion (if they haven't already) on the
|
2015-06-22 08:52:11 +02:00
|
|
|
[mailing list](https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev)
|
2013-01-09 21:55:47 +01:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
The patch will be accepted if there is broad consensus that it is a good thing.
|
|
|
|
Developers should expect to rework and resubmit patches if the code doesn't
|
2013-10-12 16:45:25 +02:00
|
|
|
match the project's coding conventions (see [doc/coding.md](doc/coding.md)) or are
|
2012-12-13 03:27:58 +01:00
|
|
|
controversial.
|
2014-04-09 20:11:08 +02:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
The `master` branch is regularly built and tested, but is not guaranteed to be
|
2015-04-03 00:51:08 +02:00
|
|
|
completely stable. [Tags](https://github.com/dashpay/dash/tags) are created
|
|
|
|
regularly to indicate new official, stable release versions of Dash. ***TODO***
|
2014-04-09 20:11:08 +02:00
|
|
|
|
2013-01-09 21:55:47 +01:00
|
|
|
Testing
|
2012-12-13 03:27:58 +01:00
|
|
|
-------
|
|
|
|
|
|
|
|
Testing and code review is the bottleneck for development; we get more pull
|
2014-05-23 09:49:01 +02:00
|
|
|
requests than we can review and test on short notice. Please be patient and help out by testing
|
|
|
|
other people's pull requests, and remember this is a security-critical project where any mistake might cost people
|
2012-12-13 03:27:58 +01:00
|
|
|
lots of money.
|
|
|
|
|
|
|
|
### Automated Testing
|
2011-09-27 04:22:19 +02:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
Developers are strongly encouraged to write unit tests for new code, and to
|
2013-10-12 16:45:25 +02:00
|
|
|
submit new unit tests for old code. Unit tests can be compiled and run (assuming they weren't disabled in configure) with: `make check`
|
2013-01-09 21:55:47 +01:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
Every pull request is built for both Windows and Linux on a dedicated server,
|
|
|
|
and unit and sanity tests are automatically run. The binaries produced may be
|
2013-05-05 22:32:35 +02:00
|
|
|
used for manual QA testing — a link to them will appear in a comment on the
|
2015-04-03 00:51:08 +02:00
|
|
|
pull request posted by [DashPullTester](https://github.com/dashpay/PullTester). See https://github.com/TheBlueMatt/test-scripts
|
|
|
|
for the build/test scripts. ***TODO***
|
2013-01-09 21:55:47 +01:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
### Manual Quality Assurance (QA) Testing
|
2013-01-09 21:55:47 +01:00
|
|
|
|
2012-12-13 03:27:58 +01:00
|
|
|
Large changes should have a test plan, and should be tested by somebody other
|
|
|
|
than the developer who wrote the code.
|
2015-04-03 00:51:08 +02:00
|
|
|
See https://github.com/dashpay/QA/ for how to create a test plan. ***TODO***
|
2014-04-09 20:11:08 +02:00
|
|
|
|
|
|
|
Translations
|
|
|
|
------------
|
|
|
|
|
|
|
|
Changes to translations as well as new translations can be submitted to
|
2015-04-03 00:51:08 +02:00
|
|
|
[Bitcoin Core's Transifex page](https://www.transifex.com/projects/p/dash/).
|
2014-04-09 20:11:08 +02:00
|
|
|
|
2014-07-07 10:32:38 +02:00
|
|
|
Translations are periodically pulled from Transifex and merged into the git repository. See the
|
2014-04-09 20:11:08 +02:00
|
|
|
[translation process](doc/translation_process.md) for details on how this works.
|
|
|
|
|
2014-07-07 10:32:38 +02:00
|
|
|
**Important**: We do not accept translation changes as GitHub pull requests because the next
|
2014-04-09 20:11:08 +02:00
|
|
|
pull from Transifex would automatically overwrite them again.
|
|
|
|
|
2015-04-03 00:51:08 +02:00
|
|
|
Translators should also subscribe to the [mailing list](https://groups.google.com/forum/#!forum/dash-translators). ***TODO***
|
2014-05-23 16:30:38 +02:00
|
|
|
|
|
|
|
Development tips and tricks
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
**compiling for debugging**
|
|
|
|
|
|
|
|
Run configure with the --enable-debug option, then make. Or run configure with
|
|
|
|
CXXFLAGS="-g -ggdb -O0" or whatever debug flags you need.
|
|
|
|
|
|
|
|
**debug.log**
|
|
|
|
|
|
|
|
If the code is behaving strangely, take a look in the debug.log file in the data directory;
|
2014-09-22 08:13:18 +02:00
|
|
|
error and debugging messages are written there.
|
2014-05-23 16:30:38 +02:00
|
|
|
|
|
|
|
The -debug=... command-line option controls debugging; running with just -debug will turn
|
|
|
|
on all categories (and give you a very large debug.log file).
|
|
|
|
|
|
|
|
The Qt code routes qDebug() output to debug.log under category "qt": run with -debug=qt
|
|
|
|
to see it.
|
|
|
|
|
|
|
|
**testnet and regtest modes**
|
|
|
|
|
2015-04-03 00:51:08 +02:00
|
|
|
Run with the -testnet option to run with "play dash" on the test network, if you
|
2014-05-23 16:30:38 +02:00
|
|
|
are testing multi-machine code that needs to operate across the internet.
|
|
|
|
|
|
|
|
If you are testing something that can run on one machine, run with the -regtest option.
|
2014-09-22 08:13:18 +02:00
|
|
|
In regression test mode, blocks can be created on-demand; see qa/rpc-tests/ for tests
|
2015-02-25 09:37:47 +01:00
|
|
|
that run in -regtest mode.
|
2014-05-23 16:30:38 +02:00
|
|
|
|
|
|
|
**DEBUG_LOCKORDER**
|
|
|
|
|
2015-03-18 00:06:58 +01:00
|
|
|
Dash Core is a multithreaded application, and deadlocks or other multithreading bugs
|
2014-05-23 16:30:38 +02:00
|
|
|
can be very difficult to track down. Compiling with -DDEBUG_LOCKORDER (configure
|
2014-09-22 08:13:18 +02:00
|
|
|
CXXFLAGS="-DDEBUG_LOCKORDER -g") inserts run-time checks to keep track of which locks
|
|
|
|
are held, and adds warnings to the debug.log file if inconsistencies are detected.
|