#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style,
clippy::empty_structs_with_brackets
)]
pub mod IERC721Errors {
use super::*;
use alloy::sol_types as alloy_sol_types;
#[rustfmt::skip]
#[allow(clippy::all)]
pub static BYTECODE: alloy_sol_types::private::Bytes = alloy_sol_types::private::Bytes::from_static(
b"",
);
#[rustfmt::skip]
#[allow(clippy::all)]
pub static DEPLOYED_BYTECODE: alloy_sol_types::private::Bytes = alloy_sol_types::private::Bytes::from_static(
b"",
);
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721IncorrectOwner {
#[allow(missing_docs)]
pub sender: alloy::sol_types::private::Address,
#[allow(missing_docs)]
pub tokenId: alloy::sol_types::private::primitives::aliases::U256,
#[allow(missing_docs)]
pub owner: alloy::sol_types::private::Address,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (
alloy::sol_types::sol_data::Address,
alloy::sol_types::sol_data::Uint<256>,
alloy::sol_types::sol_data::Address,
);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (
alloy::sol_types::private::Address,
alloy::sol_types::private::primitives::aliases::U256,
alloy::sol_types::private::Address,
);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721IncorrectOwner> for UnderlyingRustTuple<'_> {
fn from(value: ERC721IncorrectOwner) -> Self {
(value.sender, value.tokenId, value.owner)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721IncorrectOwner {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self {
sender: tuple.0,
tokenId: tuple.1,
owner: tuple.2,
}
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721IncorrectOwner {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721IncorrectOwner(address,uint256,address)";
const SELECTOR: [u8; 4] = [100u8, 40u8, 61u8, 123u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.sender,
),
<alloy::sol_types::sol_data::Uint<
256,
> as alloy_sol_types::SolType>::tokenize(&self.tokenId),
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.owner,
),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721InsufficientApproval {
#[allow(missing_docs)]
pub operator: alloy::sol_types::private::Address,
#[allow(missing_docs)]
pub tokenId: alloy::sol_types::private::primitives::aliases::U256,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (
alloy::sol_types::sol_data::Address,
alloy::sol_types::sol_data::Uint<256>,
);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (
alloy::sol_types::private::Address,
alloy::sol_types::private::primitives::aliases::U256,
);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721InsufficientApproval>
for UnderlyingRustTuple<'_> {
fn from(value: ERC721InsufficientApproval) -> Self {
(value.operator, value.tokenId)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>>
for ERC721InsufficientApproval {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self {
operator: tuple.0,
tokenId: tuple.1,
}
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721InsufficientApproval {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721InsufficientApproval(address,uint256)";
const SELECTOR: [u8; 4] = [23u8, 126u8, 128u8, 47u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.operator,
),
<alloy::sol_types::sol_data::Uint<
256,
> as alloy_sol_types::SolType>::tokenize(&self.tokenId),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721InvalidApprover {
#[allow(missing_docs)]
pub approver: alloy::sol_types::private::Address,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (alloy::sol_types::sol_data::Address,);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (alloy::sol_types::private::Address,);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721InvalidApprover> for UnderlyingRustTuple<'_> {
fn from(value: ERC721InvalidApprover) -> Self {
(value.approver,)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721InvalidApprover {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self { approver: tuple.0 }
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721InvalidApprover {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721InvalidApprover(address)";
const SELECTOR: [u8; 4] = [169u8, 251u8, 245u8, 31u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.approver,
),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721InvalidOperator {
#[allow(missing_docs)]
pub operator: alloy::sol_types::private::Address,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (alloy::sol_types::sol_data::Address,);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (alloy::sol_types::private::Address,);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721InvalidOperator> for UnderlyingRustTuple<'_> {
fn from(value: ERC721InvalidOperator) -> Self {
(value.operator,)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721InvalidOperator {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self { operator: tuple.0 }
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721InvalidOperator {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721InvalidOperator(address)";
const SELECTOR: [u8; 4] = [91u8, 8u8, 186u8, 24u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.operator,
),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721InvalidOwner {
#[allow(missing_docs)]
pub owner: alloy::sol_types::private::Address,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (alloy::sol_types::sol_data::Address,);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (alloy::sol_types::private::Address,);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721InvalidOwner> for UnderlyingRustTuple<'_> {
fn from(value: ERC721InvalidOwner) -> Self {
(value.owner,)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721InvalidOwner {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self { owner: tuple.0 }
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721InvalidOwner {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721InvalidOwner(address)";
const SELECTOR: [u8; 4] = [137u8, 198u8, 43u8, 100u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.owner,
),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721InvalidReceiver {
#[allow(missing_docs)]
pub receiver: alloy::sol_types::private::Address,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (alloy::sol_types::sol_data::Address,);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (alloy::sol_types::private::Address,);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721InvalidReceiver> for UnderlyingRustTuple<'_> {
fn from(value: ERC721InvalidReceiver) -> Self {
(value.receiver,)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721InvalidReceiver {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self { receiver: tuple.0 }
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721InvalidReceiver {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721InvalidReceiver(address)";
const SELECTOR: [u8; 4] = [100u8, 160u8, 174u8, 146u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.receiver,
),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721InvalidSender {
#[allow(missing_docs)]
pub sender: alloy::sol_types::private::Address,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (alloy::sol_types::sol_data::Address,);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (alloy::sol_types::private::Address,);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721InvalidSender> for UnderlyingRustTuple<'_> {
fn from(value: ERC721InvalidSender) -> Self {
(value.sender,)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721InvalidSender {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self { sender: tuple.0 }
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721InvalidSender {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721InvalidSender(address)";
const SELECTOR: [u8; 4] = [115u8, 198u8, 172u8, 110u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Address as alloy_sol_types::SolType>::tokenize(
&self.sender,
),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Default, Debug, PartialEq, Eq, Hash)]
#[allow(non_camel_case_types, non_snake_case, clippy::pub_underscore_fields)]
#[derive(Clone)]
pub struct ERC721NonexistentToken {
#[allow(missing_docs)]
pub tokenId: alloy::sol_types::private::primitives::aliases::U256,
}
#[allow(
non_camel_case_types,
non_snake_case,
clippy::pub_underscore_fields,
clippy::style
)]
const _: () = {
use alloy::sol_types as alloy_sol_types;
#[doc(hidden)]
#[allow(dead_code)]
type UnderlyingSolTuple<'a> = (alloy::sol_types::sol_data::Uint<256>,);
#[doc(hidden)]
type UnderlyingRustTuple<'a> = (
alloy::sol_types::private::primitives::aliases::U256,
);
#[cfg(test)]
#[allow(dead_code, unreachable_patterns)]
fn _type_assertion(
_t: alloy_sol_types::private::AssertTypeEq<UnderlyingRustTuple>,
) {
match _t {
alloy_sol_types::private::AssertTypeEq::<
<UnderlyingSolTuple as alloy_sol_types::SolType>::RustType,
>(_) => {}
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<ERC721NonexistentToken> for UnderlyingRustTuple<'_> {
fn from(value: ERC721NonexistentToken) -> Self {
(value.tokenId,)
}
}
#[automatically_derived]
#[doc(hidden)]
impl ::core::convert::From<UnderlyingRustTuple<'_>> for ERC721NonexistentToken {
fn from(tuple: UnderlyingRustTuple<'_>) -> Self {
Self { tokenId: tuple.0 }
}
}
#[automatically_derived]
impl alloy_sol_types::SolError for ERC721NonexistentToken {
type Parameters<'a> = UnderlyingSolTuple<'a>;
type Token<'a> = <Self::Parameters<
'a,
> as alloy_sol_types::SolType>::Token<'a>;
const SIGNATURE: &'static str = "ERC721NonexistentToken(uint256)";
const SELECTOR: [u8; 4] = [126u8, 39u8, 50u8, 137u8];
#[inline]
fn new<'a>(
tuple: <Self::Parameters<'a> as alloy_sol_types::SolType>::RustType,
) -> Self {
tuple.into()
}
#[inline]
fn tokenize(&self) -> Self::Token<'_> {
(
<alloy::sol_types::sol_data::Uint<
256,
> as alloy_sol_types::SolType>::tokenize(&self.tokenId),
)
}
#[inline]
fn abi_decode_raw_validate(data: &[u8]) -> alloy_sol_types::Result<Self> {
<Self::Parameters<
'_,
> as alloy_sol_types::SolType>::abi_decode_sequence_validate(data)
.map(Self::new)
}
}
};
#[derive(Clone)]
#[derive(serde::Serialize, serde::Deserialize)]
#[derive(Debug, PartialEq, Eq, Hash)]
pub enum IERC721ErrorsErrors {
#[allow(missing_docs)]
ERC721IncorrectOwner(ERC721IncorrectOwner),
#[allow(missing_docs)]
ERC721InsufficientApproval(ERC721InsufficientApproval),
#[allow(missing_docs)]
ERC721InvalidApprover(ERC721InvalidApprover),
#[allow(missing_docs)]
ERC721InvalidOperator(ERC721InvalidOperator),
#[allow(missing_docs)]
ERC721InvalidOwner(ERC721InvalidOwner),
#[allow(missing_docs)]
ERC721InvalidReceiver(ERC721InvalidReceiver),
#[allow(missing_docs)]
ERC721InvalidSender(ERC721InvalidSender),
#[allow(missing_docs)]
ERC721NonexistentToken(ERC721NonexistentToken),
}
impl IERC721ErrorsErrors {
pub const SELECTORS: &'static [[u8; 4usize]] = &[
[23u8, 126u8, 128u8, 47u8],
[91u8, 8u8, 186u8, 24u8],
[100u8, 40u8, 61u8, 123u8],
[100u8, 160u8, 174u8, 146u8],
[115u8, 198u8, 172u8, 110u8],
[126u8, 39u8, 50u8, 137u8],
[137u8, 198u8, 43u8, 100u8],
[169u8, 251u8, 245u8, 31u8],
];
pub const VARIANT_NAMES: &'static [&'static str] = &[
::core::stringify!(ERC721InsufficientApproval),
::core::stringify!(ERC721InvalidOperator),
::core::stringify!(ERC721IncorrectOwner),
::core::stringify!(ERC721InvalidReceiver),
::core::stringify!(ERC721InvalidSender),
::core::stringify!(ERC721NonexistentToken),
::core::stringify!(ERC721InvalidOwner),
::core::stringify!(ERC721InvalidApprover),
];
pub const SIGNATURES: &'static [&'static str] = &[
<ERC721InsufficientApproval as alloy_sol_types::SolError>::SIGNATURE,
<ERC721InvalidOperator as alloy_sol_types::SolError>::SIGNATURE,
<ERC721IncorrectOwner as alloy_sol_types::SolError>::SIGNATURE,
<ERC721InvalidReceiver as alloy_sol_types::SolError>::SIGNATURE,
<ERC721InvalidSender as alloy_sol_types::SolError>::SIGNATURE,
<ERC721NonexistentToken as alloy_sol_types::SolError>::SIGNATURE,
<ERC721InvalidOwner as alloy_sol_types::SolError>::SIGNATURE,
<ERC721InvalidApprover as alloy_sol_types::SolError>::SIGNATURE,
];
#[inline]
pub fn signature_by_selector(
selector: [u8; 4usize],
) -> ::core::option::Option<&'static str> {
match Self::SELECTORS.binary_search(&selector) {
::core::result::Result::Ok(idx) => {
::core::option::Option::Some(Self::SIGNATURES[idx])
}
::core::result::Result::Err(_) => ::core::option::Option::None,
}
}
#[inline]
pub fn name_by_selector(
selector: [u8; 4usize],
) -> ::core::option::Option<&'static str> {
let sig = Self::signature_by_selector(selector)?;
sig.split_once('(').map(|(name, _)| name)
}
}
#[automatically_derived]
impl alloy_sol_types::SolInterface for IERC721ErrorsErrors {
const NAME: &'static str = "IERC721ErrorsErrors";
const MIN_DATA_LENGTH: usize = 32usize;
const COUNT: usize = 8usize;
#[inline]
fn selector(&self) -> [u8; 4] {
match self {
Self::ERC721IncorrectOwner(_) => {
<ERC721IncorrectOwner as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721InsufficientApproval(_) => {
<ERC721InsufficientApproval as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721InvalidApprover(_) => {
<ERC721InvalidApprover as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721InvalidOperator(_) => {
<ERC721InvalidOperator as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721InvalidOwner(_) => {
<ERC721InvalidOwner as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721InvalidReceiver(_) => {
<ERC721InvalidReceiver as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721InvalidSender(_) => {
<ERC721InvalidSender as alloy_sol_types::SolError>::SELECTOR
}
Self::ERC721NonexistentToken(_) => {
<ERC721NonexistentToken as alloy_sol_types::SolError>::SELECTOR
}
}
}
#[inline]
fn selector_at(i: usize) -> ::core::option::Option<[u8; 4]> {
Self::SELECTORS.get(i).copied()
}
#[inline]
fn valid_selector(selector: [u8; 4]) -> bool {
Self::SELECTORS.binary_search(&selector).is_ok()
}
#[inline]
#[allow(non_snake_case)]
fn abi_decode_raw(
selector: [u8; 4],
data: &[u8],
) -> alloy_sol_types::Result<Self> {
static DECODE_SHIMS: &[fn(
&[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors>] = &[
{
fn ERC721InsufficientApproval(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InsufficientApproval as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721InsufficientApproval)
}
ERC721InsufficientApproval
},
{
fn ERC721InvalidOperator(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidOperator as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidOperator)
}
ERC721InvalidOperator
},
{
fn ERC721IncorrectOwner(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721IncorrectOwner as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721IncorrectOwner)
}
ERC721IncorrectOwner
},
{
fn ERC721InvalidReceiver(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidReceiver as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidReceiver)
}
ERC721InvalidReceiver
},
{
fn ERC721InvalidSender(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidSender as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidSender)
}
ERC721InvalidSender
},
{
fn ERC721NonexistentToken(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721NonexistentToken as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721NonexistentToken)
}
ERC721NonexistentToken
},
{
fn ERC721InvalidOwner(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidOwner as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidOwner)
}
ERC721InvalidOwner
},
{
fn ERC721InvalidApprover(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidApprover as alloy_sol_types::SolError>::abi_decode_raw(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidApprover)
}
ERC721InvalidApprover
},
];
let Ok(idx) = Self::SELECTORS.binary_search(&selector) else {
return Err(
alloy_sol_types::Error::unknown_selector(
<Self as alloy_sol_types::SolInterface>::NAME,
selector,
),
);
};
DECODE_SHIMS[idx](data)
}
#[inline]
#[allow(non_snake_case)]
fn abi_decode_raw_validate(
selector: [u8; 4],
data: &[u8],
) -> alloy_sol_types::Result<Self> {
static DECODE_VALIDATE_SHIMS: &[fn(
&[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors>] = &[
{
fn ERC721InsufficientApproval(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InsufficientApproval as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721InsufficientApproval)
}
ERC721InsufficientApproval
},
{
fn ERC721InvalidOperator(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidOperator as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidOperator)
}
ERC721InvalidOperator
},
{
fn ERC721IncorrectOwner(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721IncorrectOwner as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721IncorrectOwner)
}
ERC721IncorrectOwner
},
{
fn ERC721InvalidReceiver(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidReceiver as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidReceiver)
}
ERC721InvalidReceiver
},
{
fn ERC721InvalidSender(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidSender as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidSender)
}
ERC721InvalidSender
},
{
fn ERC721NonexistentToken(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721NonexistentToken as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721NonexistentToken)
}
ERC721NonexistentToken
},
{
fn ERC721InvalidOwner(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidOwner as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidOwner)
}
ERC721InvalidOwner
},
{
fn ERC721InvalidApprover(
data: &[u8],
) -> alloy_sol_types::Result<IERC721ErrorsErrors> {
<ERC721InvalidApprover as alloy_sol_types::SolError>::abi_decode_raw_validate(
data,
)
.map(IERC721ErrorsErrors::ERC721InvalidApprover)
}
ERC721InvalidApprover
},
];
let Ok(idx) = Self::SELECTORS.binary_search(&selector) else {
return Err(
alloy_sol_types::Error::unknown_selector(
<Self as alloy_sol_types::SolInterface>::NAME,
selector,
),
);
};
DECODE_VALIDATE_SHIMS[idx](data)
}
#[inline]
fn abi_encoded_size(&self) -> usize {
match self {
Self::ERC721IncorrectOwner(inner) => {
<ERC721IncorrectOwner as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721InsufficientApproval(inner) => {
<ERC721InsufficientApproval as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721InvalidApprover(inner) => {
<ERC721InvalidApprover as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721InvalidOperator(inner) => {
<ERC721InvalidOperator as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721InvalidOwner(inner) => {
<ERC721InvalidOwner as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721InvalidReceiver(inner) => {
<ERC721InvalidReceiver as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721InvalidSender(inner) => {
<ERC721InvalidSender as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
Self::ERC721NonexistentToken(inner) => {
<ERC721NonexistentToken as alloy_sol_types::SolError>::abi_encoded_size(
inner,
)
}
}
}
#[inline]
fn abi_encode_raw(&self, out: &mut alloy_sol_types::private::Vec<u8>) {
match self {
Self::ERC721IncorrectOwner(inner) => {
<ERC721IncorrectOwner as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721InsufficientApproval(inner) => {
<ERC721InsufficientApproval as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721InvalidApprover(inner) => {
<ERC721InvalidApprover as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721InvalidOperator(inner) => {
<ERC721InvalidOperator as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721InvalidOwner(inner) => {
<ERC721InvalidOwner as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721InvalidReceiver(inner) => {
<ERC721InvalidReceiver as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721InvalidSender(inner) => {
<ERC721InvalidSender as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
Self::ERC721NonexistentToken(inner) => {
<ERC721NonexistentToken as alloy_sol_types::SolError>::abi_encode_raw(
inner,
out,
)
}
}
}
}
use alloy::contract as alloy_contract;
#[inline]
pub const fn new<
P: alloy_contract::private::Provider<N>,
N: alloy_contract::private::Network,
>(
address: alloy_sol_types::private::Address,
__provider: P,
) -> IERC721ErrorsInstance<P, N> {
IERC721ErrorsInstance::<P, N>::new(address, __provider)
}
#[inline]
pub fn deploy<
P: alloy_contract::private::Provider<N>,
N: alloy_contract::private::Network,
>(
__provider: P,
) -> impl ::core::future::Future<
Output = alloy_contract::Result<IERC721ErrorsInstance<P, N>>,
> {
IERC721ErrorsInstance::<P, N>::deploy(__provider)
}
#[inline]
pub fn deploy_builder<
P: alloy_contract::private::Provider<N>,
N: alloy_contract::private::Network,
>(__provider: P) -> alloy_contract::RawCallBuilder<P, N> {
IERC721ErrorsInstance::<P, N>::deploy_builder(__provider)
}
#[derive(Clone)]
pub struct IERC721ErrorsInstance<P, N = alloy_contract::private::Ethereum> {
address: alloy_sol_types::private::Address,
provider: P,
_network: ::core::marker::PhantomData<N>,
}
#[automatically_derived]
impl<P, N> ::core::fmt::Debug for IERC721ErrorsInstance<P, N> {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter<'_>) -> ::core::fmt::Result {
f.debug_tuple("IERC721ErrorsInstance").field(&self.address).finish()
}
}
impl<
P: alloy_contract::private::Provider<N>,
N: alloy_contract::private::Network,
> IERC721ErrorsInstance<P, N> {
#[inline]
pub const fn new(
address: alloy_sol_types::private::Address,
__provider: P,
) -> Self {
Self {
address,
provider: __provider,
_network: ::core::marker::PhantomData,
}
}
#[inline]
pub async fn deploy(
__provider: P,
) -> alloy_contract::Result<IERC721ErrorsInstance<P, N>> {
let call_builder = Self::deploy_builder(__provider);
let contract_address = call_builder.deploy().await?;
Ok(Self::new(contract_address, call_builder.provider))
}
#[inline]
pub fn deploy_builder(__provider: P) -> alloy_contract::RawCallBuilder<P, N> {
alloy_contract::RawCallBuilder::new_raw_deploy(
__provider,
::core::clone::Clone::clone(&BYTECODE),
)
}
#[inline]
pub const fn address(&self) -> &alloy_sol_types::private::Address {
&self.address
}
#[inline]
pub fn set_address(&mut self, address: alloy_sol_types::private::Address) {
self.address = address;
}
pub fn at(mut self, address: alloy_sol_types::private::Address) -> Self {
self.set_address(address);
self
}
#[inline]
pub const fn provider(&self) -> &P {
&self.provider
}
}
impl<P: ::core::clone::Clone, N> IERC721ErrorsInstance<&P, N> {
#[inline]
pub fn with_cloned_provider(self) -> IERC721ErrorsInstance<P, N> {
IERC721ErrorsInstance {
address: self.address,
provider: ::core::clone::Clone::clone(&self.provider),
_network: ::core::marker::PhantomData,
}
}
}
impl<
P: alloy_contract::private::Provider<N>,
N: alloy_contract::private::Network,
> IERC721ErrorsInstance<P, N> {
pub fn call_builder<C: alloy_sol_types::SolCall>(
&self,
call: &C,
) -> alloy_contract::SolCallBuilder<&P, C, N> {
alloy_contract::SolCallBuilder::new_sol(&self.provider, &self.address, call)
}
}
impl<
P: alloy_contract::private::Provider<N>,
N: alloy_contract::private::Network,
> IERC721ErrorsInstance<P, N> {
pub fn event_filter<E: alloy_sol_types::SolEvent>(
&self,
) -> alloy_contract::Event<&P, E, N> {
alloy_contract::Event::new_sol(&self.provider, &self.address)
}
}
}