Version: 1.4.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/40351/403510eebc631410d6f6395f70e622fc4b351efd" alt=""
data:image/s3,"s3://crabby-images/ba630/ba6300c7627306343aece63e194270174a9391fc" alt=""
data:image/s3,"s3://crabby-images/5ff80/5ff80635fe4e92589842dc7089146bcc3cb62a6c" alt=""
data:image/s3,"s3://crabby-images/98cbe/98cbe3c75ffad264a64d4189a3abbacc11fa48b3" alt=""
data:image/s3,"s3://crabby-images/0412b/0412ba3ec6a2408dff6cedb8d491da3d4be5a726" alt=""
data:image/s3,"s3://crabby-images/6cc43/6cc43005bad6134669520d7878bccc432e9b898b" alt=""
data:image/s3,"s3://crabby-images/73c4f/73c4f8e55d93a095b12ed1f5796ea3493273b4bf" alt=""
data:image/s3,"s3://crabby-images/97da1/97da11a8c4e8d6ed21c2aa65de42f7824acc175f" alt=""
data:image/s3,"s3://crabby-images/6e075/6e07548434b7a2e3335be48b07b9914c2196b201" alt=""
data:image/s3,"s3://crabby-images/84bcd/84bcd6d421d0d25537316c31105c2a9b4e4d3d1a" alt=""