BALZaC is a statically typed language, i.e. the type of each variable is determined at compile time.

The table below shows the list of types

List of types and examples
Type Description Example
int 64-bit signed number 42
string A string of characters



boolean Either true or false value true false
hash A string of bytes in hexadecimal representation hash:c51b66bced5e4491001bd702669770dccf440982
key A Bitcoin private key in the Wallet Input Format [1] wif:KzKP2XkH93yuXTLFPMYE89WvviHSmgKF3CjYKfpkZn6qij1pWuMW
address A Bitcoin address in the Wallet Input Format [1] wif:1GT4D2wfwu7gJguvEdZXAKcENyPxinQqpz
pubkey A raw public key as hexadecimal string pubkey:032b6cb7aa033a063dd01e20a971d6d4f85eb27ad0793b...
signature A raw signature as hexadecimal string sig:30450221008319289238e5ddb1aefa26db06a5f40b8a212d1...
transaction A Bitcoin transaction, as hex payload or txid




Tipe Coercion

Type coercion is an automatic type conversion by the compiler. In other words, some types can be safely converted to other ones:

  • key can be used within expressions/statements where a type pubkey or address is expected;
  • pubkey can be used where a type address is expected.


Tipe Inference

The type can be declared explicitly (left box) or it can be omitted (right box) if the type checker can statically infer the expression type.

const n:int = 42
const n = 42


[1](1, 2) https://bitcoin.org/en/glossary/wallet-import-format