2021-10-30 13:21:59 +00:00
|
|
|
@0xb299d30dc02d72bc;
|
|
|
|
# Schema representing all the structs that are used to comunicate with
|
|
|
|
# the plugins.
|
|
|
|
# This schema, together with the command capnp proto is used to generate
|
|
|
|
# the rust file that defines the serialization/deserialization objects
|
|
|
|
# required to comunicate with the plugins created for nushell
|
2021-11-01 07:56:10 +00:00
|
|
|
#
|
2021-11-01 07:20:33 +00:00
|
|
|
# If you modify the schema remember to compile it to generate the corresponding
|
2021-11-01 07:56:10 +00:00
|
|
|
# rust file and place that file into the main nu-plugin folder.
|
|
|
|
# After compiling, you may need to run cargo fmt on the file so it passes the CI
|
2021-10-30 13:21:59 +00:00
|
|
|
|
|
|
|
# Generic structs used as helpers for the encoding
|
2021-10-31 08:17:01 +00:00
|
|
|
struct Option(T) {
|
2021-10-30 13:21:59 +00:00
|
|
|
union {
|
|
|
|
none @0 :Void;
|
2021-10-31 08:17:01 +00:00
|
|
|
some @1 :T;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Err(T) {
|
|
|
|
union {
|
|
|
|
err @0 :Text;
|
|
|
|
ok @1 :T;
|
2021-10-30 13:21:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Map(Key, Value) {
|
|
|
|
struct Entry {
|
|
|
|
key @0 :Key;
|
|
|
|
value @1 :Value;
|
|
|
|
}
|
|
|
|
entries @0 :List(Entry);
|
|
|
|
}
|
|
|
|
|
|
|
|
# Main plugin structures
|
|
|
|
struct Span {
|
|
|
|
start @0 :UInt64;
|
|
|
|
end @1 :UInt64;
|
|
|
|
}
|
|
|
|
|
2021-10-31 08:17:01 +00:00
|
|
|
# Resulting value from plugin
|
2021-10-30 13:21:59 +00:00
|
|
|
struct Value {
|
|
|
|
span @0: Span;
|
|
|
|
|
|
|
|
union {
|
|
|
|
void @1 :Void;
|
|
|
|
bool @2 :Bool;
|
|
|
|
int @3 :Int64;
|
|
|
|
float @4 :Float64;
|
|
|
|
string @5 :Text;
|
|
|
|
list @6 :List(Value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-31 08:17:01 +00:00
|
|
|
# Structs required to define the plugin signature
|
2021-10-30 13:21:59 +00:00
|
|
|
struct Signature {
|
|
|
|
name @0 :Text;
|
|
|
|
usage @1 :Text;
|
|
|
|
extraUsage @2 :Text;
|
|
|
|
requiredPositional @3 :List(Argument);
|
|
|
|
optionalPositional @4 :List(Argument);
|
|
|
|
rest @5 :Option(Argument);
|
|
|
|
named @6 :List(Flag);
|
|
|
|
isFilter @7 :Bool;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Flag {
|
|
|
|
long @0 :Text;
|
|
|
|
short @1 :Option(Text);
|
|
|
|
arg @2 :Shape;
|
|
|
|
required @3 :Bool;
|
|
|
|
desc @4 :Text;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Argument {
|
|
|
|
name @0 :Text;
|
|
|
|
desc @1 :Text;
|
|
|
|
shape @2 :Shape;
|
|
|
|
}
|
|
|
|
|
|
|
|
# If we require more complex signatures for the plugins this could be
|
|
|
|
# changed to a union
|
|
|
|
enum Shape {
|
|
|
|
none @0;
|
|
|
|
any @1;
|
|
|
|
string @2;
|
|
|
|
number @3;
|
|
|
|
int @4;
|
|
|
|
boolean @5;
|
|
|
|
}
|
|
|
|
|
2021-10-31 08:17:01 +00:00
|
|
|
# The next structs define the call information sent to th plugin
|
2021-10-30 13:21:59 +00:00
|
|
|
struct Expression {
|
|
|
|
union {
|
|
|
|
garbage @0 :Void;
|
|
|
|
bool @1 :Bool;
|
|
|
|
int @2 :Int64;
|
|
|
|
float @3 :Float64;
|
|
|
|
string @4 :Text;
|
|
|
|
list @5 :List(Expression);
|
|
|
|
# The expression list can be exteded based on the user need
|
|
|
|
# If a plugin requires something from the expression object, it
|
|
|
|
# will need to be added to this list
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Call {
|
|
|
|
head @0: Span;
|
|
|
|
positional @1 :List(Expression);
|
|
|
|
named @2 :Map(Text, Option(Expression));
|
|
|
|
}
|
|
|
|
|
|
|
|
struct CallInfo {
|
|
|
|
call @0: Call;
|
|
|
|
input @1: Value;
|
|
|
|
}
|
2021-10-31 08:17:01 +00:00
|
|
|
|
|
|
|
# Main communication structs with the plugin
|
|
|
|
struct PluginCall {
|
|
|
|
union {
|
|
|
|
signature @0 :Void;
|
|
|
|
callInfo @1 :CallInfo;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct PluginResponse {
|
|
|
|
union {
|
2021-11-01 07:20:33 +00:00
|
|
|
error @0 :Text;
|
|
|
|
signature @1 :Signature;
|
|
|
|
value @2 :Value;
|
2021-10-31 08:17:01 +00:00
|
|
|
}
|
|
|
|
}
|