Skip to content

Latest commit

 

History

History
55 lines (39 loc) · 1.3 KB

README.md

File metadata and controls

55 lines (39 loc) · 1.3 KB

Rpc-Lib

Rpc-Lib compiles a definition of RPC-Functions in the SUN-RPC format into Rust-code and provides necessary network-code to run the application. It follows the standard RFC-5531.

Setup

  • Write the RPC-Definition in the SUN-RPC Format
  • Create the server-application. This can be done in C with rpcgen
  • Make sure the Portmapper-service is installed and running before starting the server-application

Example

The following example shows how to use Rpc-Lib.

# Cargo.toml
[package]
name = "rpc-math"
version = "0.1.0"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
rpc-lib = { git = "https://git.rwth-aachen.de/acs/public/virtualization/rpc-lib/rpc-lib"}
/* math.x */
program MATH {
    version VERS_1 {
        int ADD(int, int) = 1;
    } = 1;
} = 67908;
// src/main.rs
use rpc_lib::include_rpcl;

#[include_rpcl("math.x")]
struct RPCStruct;

fn main() {
    let mut rpc = RPCStruct::new("127.0.0.1").expect("Server not available");

    let result = rpc.ADD(&1, &2).expect("Rpc call failed");

    assert!(result == 3, "Add failed");
}

Build-Instructions:

Build with cargo build. Additional documentation can be generated with cargo doc.