- Add opcode support for ECDSA verify, decompress, and recover (#307).
- Fix bug where
Continue
skipsWhile
condition check (#332). - Fix
If
construction using builder syntax (#329).
- Resolve PyPi upload issue introduced in v0.12.0 (#317).
- Introduce a utility for increasing opcode budget referred to as OpUp (#274).
- Introduce dryrun testing facilities referred to as blackbox testing (#249).
- Introduce optional compiler optimization to remove redundant sequential
ScratchSlot
store/load invocations (#247). The optimization is disabled by default. - Expose
DynamicScratchVar
to reference arbitraryScratchVar
instances (#198).
- Bump minimum supported Python version to v3.10 (#269).
- Add
@Subroutine
support forScratchVar
parameters (#198). - Make minor doc updates (#248) and (#265).
- Remove outdated Jupyter notebook demo (#268).
- Fix docs warning about multiple OptimizeOptions targets (#271).
- Fixed a bug which caused incorrect TEAL code to be produced for mutually recursive subroutines with different argument counts (#234)
- Minor docs updates (#211, #210, #229)
- Support for new TEAL 6 features:
- Increase maximum TEAL version (#146)
- New
Gitxn
expression, inner transaction group creation withInnerTxnBuilder.Next()
, inner transaction array field setting, and allow using dynamic slot IDs withImportScratchValue
(#149) - New
BytesSqrt
expression (#163) - New
Global
fieldsopcode_budget
,caller_app_id
, andcaller_app_address
(#168) - New
AccountParam
expressions for getting information about accounts (#165) - New
Divw
expression, new transaction fieldslast_log
andstate_proof_pk
, and dynamic index support forInnerTxn
array fields (#174)
- Added a new
MethodSignature
expression (#153) - Added a new
Suffix
expression and optimized existingSubstring
andExtract
expressions (#126) - Added the
MultiValue
class as an alternative toMaybeValue
(#196)
- Various documentation fixes (#140, #142, #191, #202, #207)
- Clearer error messages when non-PyTeal expressions are present (#151)
- WARNING: Due to code generation improvements, programs compiled with this version will likely produce different TEAL code than previous versions, but their functionality will be the same. Be aware that even small differences in generated TEAL code will change the address associated with escrow LogicSig contracts.
- Optimized constant assembly for small integers (#128)
- Generated TEAL code for subroutines is more human-readable (#148)
- Subroutine argument and return type annotations, if present, MUST be
Expr
(#182) - Transaction field documentation now separates fields by transaction type (#204)
- Added documentation about how to generate the documentation (#205)
- Fixed use of wildcard import in Pylance (#133)
- Support for new TEAL 5 features:
AppParam
expressions (#107, #123)- New
nonparticipation
transaction field (#106) - Inner transactions, zero-element
Seq
expressions, dynamic transaction array access (#115) - Logs, dynamic LogicSig argument indexes, single-element
NaryExpr
s, and creatingBytes
frombytes
andbytearray
(#117) - Extract expressions (#118)
- More efficient implementation of recursive subroutines in TEAL 5+ (#114)
- Add
WideRatio
, an expression which exposesmulw
anddivmodw
(#121, #122)
- WARNING: Due to code generation improvements, programs compiled with this version will likely produce different TEAL code than previous versions, but their functionality will be the same. Be aware that even small differences in generated TEAL code will change the address associated with escrow LogicSig contracts.
- Some unnecessary branch conditions have been removed (#120)
- Support for new TEAL 4 features:
- New logo (#88, #91)
- Added the
assembleConstants
option tocompileTeal
. When enabled, the compiler will assemble int and byte constants in the most efficient way to reduce program size (#57, #61, #66). - Added an alternative syntax for constructing
If
statements (#77, #82). - Align
Seq
with the rest of the API (#96).
- Fixed
NaryExpr.__str__
method (#102).
- WARNING: Due to code generation changes required to support TEAL 4 loops and subroutines, programs compiled with this version will likely produce different TEAL code than previous versions, but their functionality will be the same. Be aware that even small differences in generated TEAL code will change the address associated with escrow LogicSig contracts.
- Improved crypto cost docs (#81).
- Applied code formatter (#100).
- Support for new TEAL 3 features:
- Added the ability to specify the TEAL version target when using
compileTeal
(#45). - Added
ScratchVar
, an interface for storing and loading values from scratch space (#33). - Added a warning when scratch slots are loaded before anything has been stored (#47).
- Rewrote internal code generation to produce smaller programs and make future optimization easier (#26). Programs compiled with this version will likely produce different TEAL code than previous versions, but their functionality will be the same.
- Corrected documentation and examples that incorrectly used the
Txn.accounts
array (#42). - Fixed improper base32 validation and allow the use of padding (#34 and #37).
- An application deployment example,
vote_deploy.py
.
- Internal modules no longer pollute the global namespace when importing with
from pyteal import *
(#29). - Fixed several documentation typos.
- Moved signature and application mode examples into separate folders.
- TEAL v2
Txn
andGtxn
fields - TEAL v2
Global
fields TxnType
enumPop
expressionNot
expressionBitwiseNot
expressionBitwiseAnd
expressionBitwiseOr
expressionBitwiseXor
expressionNeq
(not equal) expressionAssert
expressionAssetHolding
expressionsAssetParam
expressions- State manipulation with
App
expressions Concat
expressionSubstring
expressionBytes
constructor now accepts UTF-8 stringsIf
expression now allows single branches
- Compiling a PyTeal program must now be done with the
compileTeal(program, mode)
function. The.teal()
method no longer exists. - The API for group transactions has changed from
Gtxn.field(transaction_index)
toGtxn[transaction_index].field()
. Tmpl
syntax has changed fromType(Tmpl("TMPL_NAME"))
toTmpl.Type("TMPL_NAME")
.