The contract folder
The base for smart contract support in Blockchain Development Kit (BDK).
Last updated
The base for smart contract support in Blockchain Development Kit (BDK).
Last updated
This subchapter contains a brief overview of each one of the components inside the src/contract
folder.
The abi.h
file contains the ABI namespace - helper functions for handling Solidity ABI types and data natively, as well as the encoding and decoding of said data, also used for C++ <-> EVM inter-operability.
The calltracer.h
file contains the Call struct and the CallTracer class respectively, both under the trace namespace - those are used specifically for debugging purposes, tracing the flux of a contract call and collecting specific details about it, such as the call type, the sender and receiver addresses, the value sent, the gas used, inputs and outputs, errors and any related subcalls.
The contract.h
file contains the BaseContract class - the base from which all smart contracts are derived - as well as the ContractGlobals and ContractLocals helper classes that provide access to global and local variables, respectively, for those contracts to work.
The contractfactory.h
file contains the ContractFactory namespace - helper functions for aiding contract creation, typically used by ContractManager.
The contracthost.h
file contains the ContractHost class - responsible for managing a single chain of contract execution from beginning to end (including nested calls), including the EVMC host implementation for EVM contracts, holding the execution stack and commit/revert during or at the end of the call (via ContractStack), and allowing both C++ and EVM contract calls and inter-operability.
The contractmanager.h
contains the ContractManager class - responsible solely for creating and deploying contracts, passing their ownership to State when done.
The contractstack.h
file contains the ContractStack class - responsible for managing temporary data from contract nested call chains, such as used SafeVariables and altered balances, acting as the one who effectively decides whether those changes are committed or reverted during a contract call. Only one instance of ContractStack is spawned per ContractHost during a call - this ensures the contract call lifecycle is properly contained and state data doesn't spill over other calls.
The customcontracts.h
file contains a tuple that holds all the registered contracts within the blockchain. It is also used as a reference for generating the ABI of said contracts.
The dynamiccontract.h
file contains the DynamicContract class - the base from which all Dynamic Contracts are derived (while BaseContract is mainly used for Protocol Contracts).
The event.h
file contains the Event class - an abstraction of a Solidity event's structure and data, used extensively by contracts. Events are managed within the blockchain by the Storage class and are supported for both C++ and EVM contracts.
The variables
subfolder contains implementations for SafeVariables - special classes that abstract safe versions of variables used within contracts.
The templates
subfolder contains several contracts used as templates, examples and for internal testing purposes. It's also meant to be the folder where user-coded contracts are stored.