sv::msg attribute

Use the sv::msg attribute to mark methods as specific message types.

Macros

List of macros supporting the sv::msg attribute:

💡

interface macro supports the sv::msg attribute only with exec, query or sudo value.

Usage

use cosmwasm_schema::cw_serde;
use cosmwasm_std::{Reply, Response, StdResult};
 
use sylvia::contract;
use sylvia::types::{ExecCtx, InstantiateCtx, MigrateCtx, QueryCtx, ReplyCtx, SudoCtx};
 
pub struct CounterContract;
 
#[cw_serde]
pub struct SomeResponse;
 
#[cfg_attr(feature = "library", sylvia::entry_points)]
#[contract]
impl CounterContract {
    pub const fn new() -> Self {
        Self
    }
 
    #[sv::msg(instantiate)]
    fn instantiate(&self, ctx: InstantiateCtx) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(exec)]
    fn some_exec(&self, ctx: ExecCtx) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(query)]
    fn some_query(&self, ctx: QueryCtx) -> StdResult<SomeResponse> {
        Ok(SomeResponse)
    }
 
    #[sv::msg(sudo)]
    fn some_sudo(&self, ctx: SudoCtx) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(migrate)]
    fn some_migrate(&self, ctx: MigrateCtx) -> StdResult<Response> {
        Ok(Response::new())
    }
 
    #[sv::msg(reply)]
    fn some_reply(&self, ctx: ReplyCtx, reply: Reply) -> StdResult<Response> {
        Ok(Response::new())
    }
}

Notice that each message type has its context type, like InstantiateCtx (opens in a new tab). You are required to use the appropriate type. Otherwise, the dispatch will fail to compile.

Each message type except for query expects the result type generic over Response (opens in a new tab).

Aliasing

It is possible to use aliases for types in message signatures. In case of query return type it requires however additional action. Due to QueryResponses (opens in a new tab) macro derive on generated query message, we have to explicitly provide the return type, as the macro wouldn't be able to deduce that from the alias.

    #[sv::msg(query, resp=SomeResponse)]
    fn some_query(&self, ctx: QueryCtx) -> SomeResult {
        Ok(SomeResponse)
    }