|
|
@ -3,8 +3,8 @@ |
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef BITCOIN_BITCOINCONSENSUS_H |
|
|
|
#define BITCOIN_BITCOINCONSENSUS_H |
|
|
|
#ifndef BITCOIN_ZCASHCONSENSUS_H |
|
|
|
#define BITCOIN_ZCASHCONSENSUS_H |
|
|
|
|
|
|
|
#if defined(BUILD_BITCOIN_INTERNAL) && defined(HAVE_CONFIG_H) |
|
|
|
#include "config/bitcoin-config.h" |
|
|
@ -19,7 +19,7 @@ |
|
|
|
#elif defined(HAVE_FUNC_ATTRIBUTE_VISIBILITY) |
|
|
|
#define EXPORT_SYMBOL __attribute__ ((visibility ("default"))) |
|
|
|
#endif |
|
|
|
#elif defined(MSC_VER) && !defined(STATIC_LIBBITCOINCONSENSUS) |
|
|
|
#elif defined(MSC_VER) && !defined(STATIC_LIBZCASHCONSENSUS) |
|
|
|
#define EXPORT_SYMBOL __declspec(dllimport) |
|
|
|
#endif |
|
|
|
|
|
|
@ -31,34 +31,34 @@ |
|
|
|
extern "C" { |
|
|
|
#endif |
|
|
|
|
|
|
|
#define BITCOINCONSENSUS_API_VER 0 |
|
|
|
#define ZCASHCONSENSUS_API_VER 0 |
|
|
|
|
|
|
|
typedef enum bitcoinconsensus_error_t |
|
|
|
typedef enum zcashconsensus_error_t |
|
|
|
{ |
|
|
|
bitcoinconsensus_ERR_OK = 0, |
|
|
|
bitcoinconsensus_ERR_TX_INDEX, |
|
|
|
bitcoinconsensus_ERR_TX_SIZE_MISMATCH, |
|
|
|
bitcoinconsensus_ERR_TX_DESERIALIZE, |
|
|
|
} bitcoinconsensus_error; |
|
|
|
zcashconsensus_ERR_OK = 0, |
|
|
|
zcashconsensus_ERR_TX_INDEX, |
|
|
|
zcashconsensus_ERR_TX_SIZE_MISMATCH, |
|
|
|
zcashconsensus_ERR_TX_DESERIALIZE, |
|
|
|
} zcashconsensus_error; |
|
|
|
|
|
|
|
/** Script verification flags */ |
|
|
|
enum |
|
|
|
{ |
|
|
|
bitcoinconsensus_SCRIPT_FLAGS_VERIFY_NONE = 0, |
|
|
|
bitcoinconsensus_SCRIPT_FLAGS_VERIFY_P2SH = (1U << 0), // evaluate P2SH (BIP16) subscripts
|
|
|
|
bitcoinconsensus_SCRIPT_FLAGS_VERIFY_DERSIG = (1U << 2), // enforce strict DER (BIP66) compliance
|
|
|
|
bitcoinconsensus_SCRIPT_FLAGS_VERIFY_CHECKLOCKTIMEVERIFY = (1U << 9), // enable CHECKLOCKTIMEVERIFY (BIP65)
|
|
|
|
zcashconsensus_SCRIPT_FLAGS_VERIFY_NONE = 0, |
|
|
|
zcashconsensus_SCRIPT_FLAGS_VERIFY_P2SH = (1U << 0), // evaluate P2SH (BIP16) subscripts
|
|
|
|
zcashconsensus_SCRIPT_FLAGS_VERIFY_DERSIG = (1U << 2), // enforce strict DER (BIP66) compliance
|
|
|
|
zcashconsensus_SCRIPT_FLAGS_VERIFY_CHECKLOCKTIMEVERIFY = (1U << 9), // enable CHECKLOCKTIMEVERIFY (BIP65)
|
|
|
|
}; |
|
|
|
|
|
|
|
/// Returns 1 if the input nIn of the serialized transaction pointed to by
|
|
|
|
/// txTo correctly spends the scriptPubKey pointed to by scriptPubKey under
|
|
|
|
/// the additional constraints specified by flags.
|
|
|
|
/// If not NULL, err will contain an error/success code for the operation
|
|
|
|
EXPORT_SYMBOL int bitcoinconsensus_verify_script(const unsigned char *scriptPubKey, unsigned int scriptPubKeyLen, |
|
|
|
EXPORT_SYMBOL int zcashconsensus_verify_script(const unsigned char *scriptPubKey, unsigned int scriptPubKeyLen, |
|
|
|
const unsigned char *txTo , unsigned int txToLen, |
|
|
|
unsigned int nIn, unsigned int flags, bitcoinconsensus_error* err); |
|
|
|
unsigned int nIn, unsigned int flags, zcashconsensus_error* err); |
|
|
|
|
|
|
|
EXPORT_SYMBOL unsigned int bitcoinconsensus_version(); |
|
|
|
EXPORT_SYMBOL unsigned int zcashconsensus_version(); |
|
|
|
|
|
|
|
#ifdef __cplusplus |
|
|
|
} // extern "C"
|
|
|
@ -66,4 +66,4 @@ EXPORT_SYMBOL unsigned int bitcoinconsensus_version(); |
|
|
|
|
|
|
|
#undef EXPORT_SYMBOL |
|
|
|
|
|
|
|
#endif // BITCOIN_BITCOINCONSENSUS_H
|
|
|
|
#endif // BITCOIN_ZCASHCONSENSUS_H
|