is-eq
Comparing values for equality in Clarity smart contracts.
Function signature
- Input:
A, A, ...
- Output:
bool
Why it matters
The is-eq
function is crucial for:
- Comparing values to check for equality.
- Implementing conditional logic based on value comparisons.
- Ensuring data integrity by verifying that values match expected results.
- Simplifying equality checks in smart contract code.
When to use it
Use is-eq
when you need to:
- Compare multiple values for equality.
- Implement logic that depends on whether values are equal.
- Verify that input values match expected constants or variables.
- Simplify equality checks in your contract.
Best practices
- Ensure all values being compared are of the same type to avoid type errors.
- Use
is-eq
for simple equality checks and combine with other logical functions for complex conditions. - Be aware that
is-eq
does not short-circuit; all values are evaluated. - Use meaningful variable names for better readability.
Practical example: Check user role
Let's implement a function that checks if a user has a specific role:
This example demonstrates:
- Using
is-eq
to compare a user's role with the constantADMIN_ROLE
. - Handling the case where the user role is not set by providing a default value.
- Implementing a read-only function to check if a user is an admin.
Common pitfalls
- Comparing values of different types, leading to type errors.
- Assuming
is-eq
short-circuits likeand
oror
(it does not). - Using
is-eq
for complex conditions where other logical functions might be more appropriate. - Not handling cases where values might be
none
or unset.
Related functions
is-some
: Checks if an optional value issome
.is-none
: Checks if an optional value isnone
.asserts!
: Asserts a condition and throws an error if it is false.
Conclusion
The is-eq
function is a fundamental tool for comparing values in Clarity smart contracts. It provides a straightforward way to check for equality, enabling developers to implement conditional logic and verify data integrity. When used effectively, is-eq
simplifies equality checks and enhances the readability and maintainability of your smart contract code.