Version: 1.1.0
Execution Table
The following table details the execution of ServerRpc
and ClientRpc
functions:
Function | Server | Client | Host (Server+Client) |
---|---|---|---|
ServerRpc Send | |||
ServerRpc Execute | |||
ClientRpc Send | |||
ClientRpc Execute |
An RPC function typically doesn't execute its body immediately since the function call is a stand-in for a network transmission. Since the host is both a client and a server, local RPCs targeting the host-server or host-client are invoked immediately. As such, avoid nesting RPCs when running in host mode as a ServerRpc method that invokes a ClientRpc method that invokes the same ServerRpc method (and repeat...) can cause a stack overflow.
Structure of a typical ServerRpc
:
[ServerRpc]
void MyServerRpc(int somenumber, string somestring)
{
// Network Send Block (framework-code)
// Network Return Block (framework-code)
// RPC Method Body (user-code)
}
Pseudo-code sample of a ServerRpc
:
[ServerRpc]
void MyServerRpc(int somenumber, string somestring)
{
// --- begin: injected framework-code
if (NetworkSend())
{
// this block will be executed if:
// - called from user-code on client
// - called from user-code on host
var writer = NetworkCreateWriter();
writer.WriteInt32(1234567890); // RPC method signature hash
writer.WriteInt32(somenumber);
writer.WriteChars(somestring);
NetworkSendRpc(writer);
}
if (NetworkReturn())
{
// this block will be executed if:
// - called from user-code
// - called from framework-code on client
return;
}
// --- end: injected framework-code
print($"MyServerRpc: {somenumber}");
}
data:image/s3,"s3://crabby-images/922cb/922cbe5a12623b30ca6d2c8b74c35e0220427ab1" alt=""
data:image/s3,"s3://crabby-images/6dad8/6dad8f984c01f2ca4e0c3a1841844b48cacef73d" alt=""
data:image/s3,"s3://crabby-images/cddc9/cddc99f819e200321a1d15bd2e488026febd6ec3" alt=""
data:image/s3,"s3://crabby-images/01d28/01d28ffe875fe8bf8ce7917afd11e0e801dc0af0" alt=""
data:image/s3,"s3://crabby-images/ee511/ee511162cda5bc9aefb5ba1190037af9edd10b3d" alt=""
data:image/s3,"s3://crabby-images/025f8/025f843b50ac7ec7ff2d35a0687ac5c3d9be9d4c" alt=""
data:image/s3,"s3://crabby-images/637d1/637d16a623d08ee2f857cba251551dce935a25a2" alt=""
data:image/s3,"s3://crabby-images/70357/70357f6abcff23f37180320960e2a68eb12bc142" alt=""
data:image/s3,"s3://crabby-images/3d2cf/3d2cf49ebfa3f75bc60f1ec8f03093c344e443af" alt=""
data:image/s3,"s3://crabby-images/941b9/941b9aeb4deb201cc95bc24309c8e33830afbe09" alt=""