From 2d81c8f0b167ad962eeb8c4c55e5ee2a14eb98e6 Mon Sep 17 00:00:00 2001 From: bsbds <69835502+bsbds@users.noreply.github.com> Date: Tue, 30 Jul 2024 18:51:50 +0800 Subject: [PATCH] refactor: use a custom `OptionalU64` to replace optional uint64 Signed-off-by: bsbds <69835502+bsbds@users.noreply.github.com> --- src/curp-command.proto | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/src/curp-command.proto b/src/curp-command.proto index 9195e3b..09e479f 100644 --- a/src/curp-command.proto +++ b/src/curp-command.proto @@ -10,6 +10,12 @@ option java_package = "com.curp.protobuf"; option java_outer_classname = "CommandProto"; option java_multiple_files = true; +// For compatibility of gRPC implementations that do not support the `optional` +// keyword +message OptionalU64 { + uint64 value = 1; +} + message ProposeId { uint64 client_id = 1; uint64 seq_num = 2; @@ -50,8 +56,8 @@ message CmdResult { // Please add comments above your error if you want to extend more :) message CurpError { message Redirect { - optional uint64 leader_id = 1; - uint64 term = 2; + OptionalU64 leader_id = 1; + uint64 term = 2; } oneof err { // When a command conflicts with the server SP. @@ -128,11 +134,11 @@ message FetchClusterRequest { } message FetchClusterResponse { - optional uint64 leader_id = 1; - uint64 term = 2; - uint64 cluster_id = 3; - repeated Member members = 4; - uint64 cluster_version = 5; + OptionalU64 leader_id = 1; + uint64 term = 2; + uint64 cluster_id = 3; + repeated Member members = 4; + uint64 cluster_version = 5; } message FetchReadStateRequest {