Skip to main content

Extra operations for PyTEAL

Project description

Pyteal Extensions

Additional useful operations for Python

Available Operations

  • MulDiv64: calculate m1*m2/d with no overflow on multiplication (TEAL 3+)
  • Uint64Array: for when you need convenient integer arrays.
  • Mul128, FastExp: Optimize operations that take uints and output bytes (big ints)
  • Min, Max: calculate minimum/maximum of 2 expressions, without using slots or evaluating arguments more than once (TEAL 4+)
  • LazyAnd, LazyOr: lazily evaluate arguments in And/Or operation
  • SaturatingAdd, SaturatingSub: saturating addition/subtraction
  • AutoLoadScratchVar: more convenient way to use scratch variables. Removes the need to use .load() everytime, adds .increment() method.
  • Inner Transactions: simplified making of inner transactions
    • MakeInnerPaymentTxn, MakeInnerAssetTransferTxn and more!
    • MakeInnerGroupTxn to execute inner atomic group transactions
  • SerializeIntegers, DeserializeIntegers, DeserializeIntegersToSlots: serialize/deserialize integers to/from bytes
  • GlobalState, LocalState, GlobalStateArray, LocalStateArray, GlobalStateArray2D, LocalStateArray2D: easily access global/local state

State manipulation

GlobalState and LocalState allow for manipulating global and local state respectively. They both have the same interface.

from pyteal import App, Bytes, Int, Seq, TealType
from pytealext import LocalState

user_counter = LocalState("UC", TealType.uint64)
program = Seq(
    # increment using pyteal local state
    App.localPut(Int(0), Bytes("UC"), App.localGet(Int(0), Bytes("UC")) + Int(1)),
    # increment using put/get
    user_counter.put(user_counter.get() + Int(1)),
    # increment using add_assign
    user_counter.add_assign(Int(1))
    # decrement
    user_counter.sub_assign(Int(1))
)

Want to simulate arrays in the global state? Use GlobalStateArray and LocalStateArray. Technically, the indexes can be any uint64 value and don't have to be sequential. Each array element takes one slot in the local/global state.

from pyteal import Assert, For, Int, Return, ScratchVar, Seq
from pytealext import LocalStateArray

user_counters = LocalStateArray("Counters")
    i = ScratchVar()
    accumulator = ScratchVar()
    program = Seq(
        user_counters[0].put(Int(10)),
        user_counters[0].add_assign(Int(1)),
        user_counters[0].sub_assign(Int(2)),
        Assert(user_counters[0].get() == Int(9)),
        # set some other indexes
        user_counters[1].put(Int(9)),
        user_counters[2].put(Int(9)),
        # Indexes can also be accessed with Exprs
        accumulator.store(Int(0)),
        For(i.store(Int(0)), i.load() < Int(3), i.store(i.load() + Int(1))).Do(
            accumulator.store(accumulator.load() + user_counters[i.load()].get())
        ),
        Return(accumulator.load() == Int(27)),
    )

Example usage

Example usage for LazyAnd:

from pyteal import Gtxn, TxnType, Bytes, Int
from pytealext import LazyAnd

# Evaluate fields of some transaction but don't panic if an argument down the line would panic
validation = LazyAnd(
    Gtxn[0].type_enum() == TxnType.ApplicationCall,
    Gtxn[0].application_args.length() == Int(1),
    Gtxn[0].application_args[0] == Bytes("AX"),
)

Installation

pip install pytealext

Testing

pytest


Created by Łukasz Ptak and Paweł Rejkowicz

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytealext-3.2.0.tar.gz (46.0 kB view details)

Uploaded Source

Built Distribution

pytealext-3.2.0-py3-none-any.whl (56.0 kB view details)

Uploaded Python 3

File details

Details for the file pytealext-3.2.0.tar.gz.

File metadata

  • Download URL: pytealext-3.2.0.tar.gz
  • Upload date:
  • Size: 46.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for pytealext-3.2.0.tar.gz
Algorithm Hash digest
SHA256 6f72748ecf6cb6fff883dad39b2e262367d09098fee1f2a486fdb101d782eff8
MD5 566738fb26a0c64c115ed0cac23a8816
BLAKE2b-256 d6c2327b617e82669fa274459500690635544125036f7cd1f2598b6a72a874a1

See more details on using hashes here.

File details

Details for the file pytealext-3.2.0-py3-none-any.whl.

File metadata

  • Download URL: pytealext-3.2.0-py3-none-any.whl
  • Upload date:
  • Size: 56.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for pytealext-3.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2a5858b33cd720655b187db9d90d0b9af405a9fee3bfb0b171954bbe377aa1e3
MD5 57d172ba455e2e6485ae8328278f929d
BLAKE2b-256 52b9100ee17c1442b535bc860a51eb55b80fb1dbc53a4a95273db5859b6e74f1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page