1. 01 Oct, 2013 1 commit
  2. 17 Sep, 2013 1 commit
  3. 24 Aug, 2013 2 commits
  4. 31 Jul, 2013 1 commit
  5. 24 Jun, 2013 1 commit
  6. 19 Jun, 2013 1 commit
    • Mike Hearn's avatar
      Introduce a CChainParameters singleton class and regtest mode. · d4d533e0
      Mike Hearn authored
      The new class is accessed via the Params() method and holds
      most things that vary between main, test and regtest networks.
      The regtest mode has two purposes, one is to run the
      bitcoind/bitcoinj comparison tool which compares two separate
      implementations of the Bitcoin protocol looking for divergence.
      
      The other is that when run, you get a local node which can mine
      a single block instantly, which is highly convenient for testing
      apps during development as there's no need to wait 10 minutes for
      a block on the testnet.
      d4d533e0
  7. 06 Jun, 2013 1 commit
  8. 01 Jun, 2013 1 commit
  9. 30 May, 2013 1 commit
    • Wladimir J. van der Laan's avatar
      Move pMiningKey init out of StartRPCThreads · 9ed3ae50
      Wladimir J. van der Laan authored
      This commit decouples the pMiningKey initialization and shutdown from the RPC
      threads.
      
      `getwork` and `getblocktemplate` rely on pMiningKey, and can also be ran
      from the debug window in the UI even when the RPC server is not running.
      
      Solves issue #2706.
      9ed3ae50
  10. 23 May, 2013 1 commit
  11. 07 Feb, 2013 1 commit
  12. 30 Jan, 2013 1 commit
  13. 04 Jan, 2013 1 commit
  14. 19 Dec, 2012 2 commits
  15. 24 Oct, 2012 1 commit
  16. 20 Oct, 2012 2 commits
    • Pieter Wuille's avatar
      Batch block connection during IBD · 6088b917
      Pieter Wuille authored
      During the initial block download (or -loadblock), delay connection
      of new blocks a bit, and perform them in a single action. This reduces
      the load on the database engine, as subsequent blocks often update an
      earlier block's transaction already.
      6088b917
    • Pieter Wuille's avatar
      Ultraprune · f4f73a94
      Pieter Wuille authored
      This switches bitcoin's transaction/block verification logic to use a
      "coin database", which contains all unredeemed transaction output scripts,
      amounts and heights.
      
      The name ultraprune comes from the fact that instead of a full transaction
      index, we only (need to) keep an index with unspent outputs. For now, the
      blocks themselves are kept as usual, although they are only necessary for
      serving, rescanning and reorganizing.
      
      The basic datastructures are CCoins (representing the coins of a single
      transaction), and CCoinsView (representing a state of the coins database).
      There are several implementations for CCoinsView. A dummy, one backed by
      the coins database (coins.dat), one backed by the memory pool, and one
      that adds a cache on top of it. FetchInputs, ConnectInputs, ConnectBlock,
      DisconnectBlock, ... now operate on a generic CCoinsView.
      
      The block switching logic now builds a single cached CCoinsView with
      changes to be committed to the database before any changes are made.
      This means no uncommitted changes are ever read from the database, and
      should ease the transition to another database layer which does not
      support transactions (but does support atomic writes), like LevelDB.
      
      For the getrawtransaction() RPC call, access to a txid-to-disk index
      would be preferable. As this index is not necessary or even useful
      for any other part of the implementation, it is not provided. Instead,
      getrawtransaction() uses the coin database to find the block height,
      and then scans that block to find the requested transaction. This is
      slow, but should suffice for debug purposes.
      f4f73a94
  17. 04 Oct, 2012 1 commit
  18. 01 Sep, 2012 1 commit
  19. 21 Aug, 2012 3 commits