core/InternetComputer
Low-level interface to the Internet Computer.
Function call
func call(canister : Principal, name : Text, data : Blob) : async (reply : Blob)
Calls canister's update or query function, name, with the binary contents of data as IC argument.
Returns the response to the call, an IC reply or reject, as a Motoko future:
- The message data of an IC reply determines the binary contents of reply.
- The error code and textual message data of an IC reject determines the future's Errorvalue.
Note: call is an asynchronous function and can only be applied in an asynchronous context.
Example:
import IC "mo:core/InternetComputer";
import Principal "mo:core/Principal";
persistent actor {
  type OutputType = { decimals : Nat32 };
  public func example() : async ?OutputType {
    let ledger = Principal.fromText("ryjl3-tyaaa-aaaaa-aaaba-cai");
    let method = "decimals";
    let input = ();
    let rawReply = await IC.call(ledger, method, to_candid (input)); // serialized Candid
    let output : ?OutputType = from_candid (rawReply);
    assert output == ?{ decimals = 8 };
    output
  }
}
Learn more about Candid serialization
Function isReplicated
func isReplicated() : Bool
isReplicated is true for update messages and for queries that passed through consensus.
Function countInstructions
func countInstructions(comp : () -> ()) : Nat64
Given computation, comp, counts the number of actual and (for IC system calls) notional WebAssembly
instructions performed during the execution of comp().
More precisely, returns the difference between the state of the IC instruction counter (performance counter 0) before and after executing comp()
(see Performance Counter).
NB: countInstructions(comp) will not account for any deferred garbage collection costs incurred by comp().
Example:
import IC "mo:core/InternetComputer";
let count = IC.countInstructions(func() {
  // ...
});
Function performanceCounter
func performanceCounter(counter : Nat32) : (value : Nat64)
Returns the current value of IC performance counter counter.
- Counter - 0is the current execution instruction counter, counting instructions only since the beginning of the current IC message. This counter is reset to value- 0on shared function entry and every- await. It is therefore only suitable for measuring the cost of synchronous code.
- Counter - 1is the call context instruction counter for the current shared function call. For replicated message executing, this excludes the cost of nested IC calls (even to the current canister). For non-replicated messages, such as composite queries, it includes the cost of nested calls. The current value of this counter is preserved across- awaits(unlike counter- 0).
- The function (currently) traps if - counter>= 2.
Consult Performance Counter for details.
Example:
import IC "mo:core/InternetComputer";
let c1 = IC.performanceCounter(1);
// ...
let diff : Nat64 = IC.performanceCounter(1) - c1;
Function replyDeadline
func replyDeadline() : ?Nat
Returns the time (in nanoseconds from the epoch start) by when the update message should reply to the best effort message so that it can be received by the requesting canister. Queries and unbounded-time update messages return null.