err
Constructing error responses in Clarity smart contracts.
Function signature
- Input:
value
- Any type A - Output:
(response A B)
where A is the type of the input value
Why it matters
The err
function is crucial for:
- Creating standardized error responses in public functions.
- Indicating that a function execution has failed.
- Providing meaningful error information to callers.
- Triggering automatic rollback of any database changes during function execution.
When to use it
Use err
when you need to:
- Return an error state from a public function.
- Indicate that a condition or operation has failed.
- Provide specific error information or codes to the caller.
- Ensure that any state changes are reverted due to a failure condition.
Best practices
- Use descriptive error values that help diagnose the issue.
- Consider using standardized error codes across your contract.
- Pair
err
withok
to create comprehensive response handling. - Remember that returning an
err
will cause all state changes in the current function to be rolled back.
Practical example: Token transfer with error handling
Let's implement a simple token transfer function with error handling:
This example demonstrates:
- Using
err
to return an error when the sender has insufficient balance. - Pairing
err
withok
to handle both success and failure cases. - Using a simple error code (u1) to indicate the type of error.
Common pitfalls
- Forgetting that returning an
err
will revert all state changes in the current function. - Using non-descriptive error values that make debugging difficult.
- Inconsistent error handling across different functions in the contract.
Related functions
ok
: Used to construct successful responses in public functions.asserts!
: Often used witherr
for condition checking and error reporting.try!
: Used to propagate errors up the call stack.
Conclusion
The err
function is a fundamental tool for error handling and response construction in Clarity smart contracts. By providing a standardized way to indicate and communicate errors, it enables robust and predictable contract behavior. When used effectively in combination with ok
and other error-handling mechanisms, err
contributes to creating more reliable and maintainable smart contracts.