Predicates in Sway are specific types of programs that return a boolean value, meaning they function like rules that a transaction must follow to be valid.
They don't have access to the information written on the blockchain – they make decisions based solely on the received parameters.
These predicates are pure functions, which means they don't cause any unintended side effects.
The key difference here is that instead of checking these rules directly on the blockchain, we check them 'off' the blockchain first. Once we're confident they're valid, we then record the transaction on the blockchain.
This method is not only more efficient but also helps to prevent traffic jams on the network and makes transactions cheaper. It does so by reducing the need for repetitive calculations on the blockchain.
Users can send assets to the predicate address as they would to any other address on the blockchain. To spend funds stored at the predicate address, users must provide the original byte code of the predicate and, if required, the predicate data.
The predicate data relates to the parameters received by the predicate's main
function. This data comes into play during the byte code's execution. If the main
function does not have any parameters then there is no data to be provided, therefore we do not provide the predicate data.
If the predicate is validated successfully, the funds will be accessible. Otherwise, the SDK will throw a validation error.
In the next section, we provide a step-by-step guide on how to interact with a predicate to validate your transactions.
Currently there is no way to debug a predicate yet. In the meantime, a practical workaround is to initially write, test, and debug your predicate as a script, which has more debugging tools available. Once it's working as expected, you can then convert it back into a predicate.