StaticStateChangeError
Represents an invalid bytecode/contract error that occurs when a state-changing operation is attempted in a static context. This error is typically encountered when a contract attempts to modify the state during a static call.
Static state change errors can occur due to:
- Attempting to modify the state in a static call.
- Executing state-changing operations in a read-only context.
- Bugs in the smart contract code leading to unintended state changes.
To debug a static state change error:
- Review Contract Logic: Ensure that state-changing operations are not executed in static calls or read-only contexts.
- Check Function Modifiers: Verify that the function modifiers and visibility settings are correctly applied to prevent state changes in static contexts.
- Use TEVM Tracing: Utilize TEVM tracing to step through the contract execution and identify where the state change is attempted in a static context.
- Inspect Contract Code: Manually inspect the contract code to ensure that state changes are correctly controlled and executed only in appropriate contexts.
Example
Param
A human-readable error message.
Param
Additional parameters for the BaseError.
Extends
Constructors
new StaticStateChangeError()
new StaticStateChangeError(
message
?,args
?,tag
?):StaticStateChangeError
Constructs a StaticStateChangeError. Represents an invalid bytecode/contract error that occurs when a state-changing operation is attempted in a static context. This error is typically encountered when a contract attempts to modify the state during a static call.
Static state change errors can occur due to:
- Attempting to modify the state in a static call.
- Executing state-changing operations in a read-only context.
- Bugs in the smart contract code leading to unintended state changes.
To debug a static state change error:
- Review Contract Logic: Ensure that state-changing operations are not executed in static calls or read-only contexts.
- Check Function Modifiers: Verify that the function modifiers and visibility settings are correctly applied to prevent state changes in static contexts.
- Use TEVM Tracing: Utilize TEVM tracing to step through the contract execution and identify where the state change is attempted in a static context.
- Inspect Contract Code: Manually inspect the contract code to ensure that state changes are correctly controlled and executed only in appropriate contexts.
Parameters
• message?: string
= 'Static state change error occurred.'
Human-readable error message.
• args?: StaticStateChangeErrorParameters
= {}
Additional parameters for the BaseError.
• tag?: string
= 'StaticStateChangeError'
The tag for the error.
Returns
Overrides
Defined in
packages/errors/src/ethereum/ethereumjs/StaticStateChangeError.js:76
Properties
_tag
_tag:
string
Same as name, used internally.
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:81
cause
cause:
any
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:113
code
code:
number
Error code, analogous to the code in JSON RPC error.
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:111
details
details:
string
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:90
docsPath
docsPath:
undefined
|string
Path to the documentation for this error.
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:95
message
message:
string
Human-readable error message.
Inherited from
Defined in
node_modules/.pnpm/typescript@5.5.4/node_modules/typescript/lib/lib.es5.d.ts:1077
metaMessages
metaMessages:
undefined
|string
[]
Additional meta messages for more context.
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:99
name
name:
string
The name of the error, used to discriminate errors.
Inherited from
Defined in
node_modules/.pnpm/typescript@5.5.4/node_modules/typescript/lib/lib.es5.d.ts:1076
shortMessage
shortMessage:
string
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:103
stack?
optional
stack:string
Inherited from
Defined in
node_modules/.pnpm/typescript@5.5.4/node_modules/typescript/lib/lib.es5.d.ts:1078
version
version:
string
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:107
EVMErrorMessage
static
EVMErrorMessage:EvmErrorMessage
=EVMErrorMessage.STATIC_STATE_CHANGE
Defined in
packages/errors/src/ethereum/ethereumjs/StaticStateChangeError.js:55
prepareStackTrace()?
static
optional
prepareStackTrace: (err
,stackTraces
) =>any
Optional override for formatting stack traces
See
https://v8.dev/docs/stack-trace-api#customizing-stack-traces
Parameters
• err: Error
• stackTraces: CallSite
[]
Returns
any
Inherited from
ExecutionError
.prepareStackTrace
Defined in
node_modules/.pnpm/@types+node@20.14.8/node_modules/@types/node/globals.d.ts:28
stackTraceLimit
static
stackTraceLimit:number
Inherited from
ExecutionError
.stackTraceLimit
Defined in
node_modules/.pnpm/@types+node@20.14.8/node_modules/@types/node/globals.d.ts:30
Methods
walk()
walk(
fn
?):unknown
Walks through the error chain.
Parameters
• fn?: Function
A function to execute on each error in the chain.
Returns
unknown
The first error that matches the function, or the original error.
Inherited from
Defined in
packages/errors/src/ethereum/BaseError.js:136
captureStackTrace()
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
ExecutionError
.captureStackTrace
Defined in
node_modules/.pnpm/@types+node@20.14.8/node_modules/@types/node/globals.d.ts:21
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
ExecutionError
.captureStackTrace
Defined in
node_modules/.pnpm/@types+node@22.5.1/node_modules/@types/node/globals.d.ts:67
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
ExecutionError
.captureStackTrace
Defined in
node_modules/.pnpm/@types+node@20.14.15/node_modules/@types/node/globals.d.ts:21
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
ExecutionError
.captureStackTrace
Defined in
node_modules/.pnpm/bun-types@1.1.22/node_modules/bun-types/globals.d.ts:1629
captureStackTrace(targetObject, constructorOpt)
static
captureStackTrace(targetObject
,constructorOpt
?):void
Create .stack property on a target object
Parameters
• targetObject: object
• constructorOpt?: Function
Returns
void
Inherited from
ExecutionError
.captureStackTrace
Defined in
node_modules/.pnpm/@types+node@20.12.14/node_modules/@types/node/globals.d.ts:21