2014-04-23 00:46:19 +02:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2015-12-13 14:51:43 +01:00
|
|
|
// Copyright (c) 2009-2015 The Bitcoin Core developers
|
2014-10-02 11:25:21 +02:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
2014-04-23 00:46:19 +02:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef BITCOIN_AMOUNT_H
|
|
|
|
#define BITCOIN_AMOUNT_H
|
|
|
|
|
2017-05-09 09:11:09 +02:00
|
|
|
#include <stdint.h>
|
2014-04-23 00:46:19 +02:00
|
|
|
|
2016-04-14 11:40:11 +02:00
|
|
|
/** Amount in satoshis (Can be negative) */
|
2014-04-23 00:46:19 +02:00
|
|
|
typedef int64_t CAmount;
|
|
|
|
|
2014-10-23 02:05:11 +02:00
|
|
|
static const CAmount COIN = 100000000;
|
|
|
|
static const CAmount CENT = 1000000;
|
|
|
|
|
2015-05-28 03:02:04 +02:00
|
|
|
/** No amount larger than this (in satoshi) is valid.
|
|
|
|
*
|
|
|
|
* Note that this constant is *not* the total money supply, which in Bitcoin
|
|
|
|
* currently happens to be less than 21,000,000 BTC for various reasons, but
|
|
|
|
* rather a sanity check. As this sanity check is used by consensus-critical
|
|
|
|
* validation code, the exact value of the MAX_MONEY constant is consensus
|
|
|
|
* critical; in unusual circumstances like a(nother) overflow bug that allowed
|
|
|
|
* for the creation of coins out of thin air modification could lead to a fork.
|
|
|
|
* */
|
2014-10-23 02:05:11 +02:00
|
|
|
static const CAmount MAX_MONEY = 21000000 * COIN;
|
|
|
|
inline bool MoneyRange(const CAmount& nValue) { return (nValue >= 0 && nValue <= MAX_MONEY); }
|
|
|
|
|
2014-10-02 11:25:21 +02:00
|
|
|
#endif // BITCOIN_AMOUNT_H
|