Solidity type string parsing.
We do not recommend most users use this crate directly. This library provides a
simple parser for working with Solidity type encoded as strings. It is
primarily a dependency for the user-facing APIs in [alloy-json-abi
] and
[alloy-dyn-abi
]. Please see the documentation for those crates for
more information.
This parser generally follows the [solidity spec], however, it supports only a subset of possible types, chosen to support ABI coding.
The TypeSpecifier
is the top-level type in this crate. It is a wrapper around
a section of a string (called a span
). It progressively breaks the strings
down into subspans, and adds metadata about the type. E.g. it tracks the stem
type as well as the sizes of array dimensions. A TypeSpecifier
is expected to
handle any valid Solidity type string.
```rust use alloysoltype_parser::TypeSpecifier; use core::num::NonZeroUsize;
// Parse a type specifier from a string let mytype = TypeSpecifier::tryfrom("uint8[2][]").unwrap();
// Read the total span asserteq!( mytype.span(), "uint8[2][]" );
// A type specifier has a stem type. This is the type string, stripped of its // array dimensions. asserteq!(mytype.stem.span(), "uint8");
// Arrays are represented as a vector of sizes. This allows for deep nesting.
asserteq!(
mytype.sizes,
// None
is used for dynamic sizes. This is equivalent to [2][]
vec![NonZeroUsize::new(2), None]
);
// Type specifiers also work for complex tuples! let mytuple = TypeSpecifier::tryfrom("(uint8, (uint8[], bool))[39]").unwrap(); asserteq!( mytuple.stem.span(), "(uint8, (uint8[], bool))" );
// Types are NOT resolved, so you can parse custom structs just by name. let mystruct = TypeSpecifier::tryfrom("MyStruct").unwrap(); ```
parse()
?The core::str::FromStr
trait is not implemented for TypeSpecifier
because
of lifetime constraints. Unfortunately, it is impossible to implement this for
a type with a lifetime dependent on the input str. Instead, we recommend using
TryFrom::try_from
.
syn
?This is NOT a full syntax library, and is not intended to be used as a
replacement for [alloy-syn-solidity
]. This crate is intended to be used for
parsing type strings present in existing ecosystem tooling, and nothing else.
It is not intended to be used for parsing Solidity source code.
This crate is useful for:
alloy-dyn-abi
]It is NOT useful for: