Skip to content

Commit

Permalink
THRIFT-4914: Fix name redeclaration bug in compiled go code
Browse files Browse the repository at this point in the history
Client: go

This fixes the bug reported in
apache#2315 (comment).
  • Loading branch information
fishy committed Feb 18, 2021
1 parent ef98551 commit bc15861
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 8 deletions.
17 changes: 9 additions & 8 deletions compiler/cpp/src/thrift/generate/t_go_generator.cc
Original file line number Diff line number Diff line change
Expand Up @@ -2170,14 +2170,15 @@ void t_go_generator::generate_service_client(t_service* tservice) {
}

if (!(*f_iter)->is_oneway()) {
std::string metaName = tmp("_meta");
std::string resultName = tmp("_result");
std::string resultType = publicize(method + "_result", true);
f_types_ << indent() << "var " << resultName << " " << resultType << endl;
f_types_ << indent() << "var meta thrift.ResponseMeta" << endl;
f_types_ << indent() << "meta, err = p.Client_().Call(ctx, \""
f_types_ << indent() << "var " << metaName << " thrift.ResponseMeta" << endl;
f_types_ << indent() << metaName << ", _err = p.Client_().Call(ctx, \""
<< method << "\", &" << argsName << ", &" << resultName << ")" << endl;
f_types_ << indent() << "p.SetLastResponseMeta_(meta)" << endl;
f_types_ << indent() << "if err != nil {" << endl;
f_types_ << indent() << "p.SetLastResponseMeta_(" << metaName << ")" << endl;
f_types_ << indent() << "if _err != nil {" << endl;

indent_up();
f_types_ << indent() << "return" << endl;
Expand All @@ -2199,7 +2200,7 @@ void t_go_generator::generate_service_client(t_service* tservice) {
indent_up();

if (!(*f_iter)->get_returntype()->is_void()) {
f_types_ << indent() << "return r, " << field << endl;
f_types_ << indent() << "return _r, " << field << endl;
} else {
f_types_ << indent() << "return "<< field << endl;
}
Expand All @@ -2222,7 +2223,7 @@ void t_go_generator::generate_service_client(t_service* tservice) {
f_types_ << indent() << "p.SetLastResponseMeta_(thrift.ResponseMeta{})" << endl;
// TODO: would be nice to not to duplicate the call generation
f_types_ << indent() << "if _, err := p.Client_().Call(ctx, \""
<< method << "\", &"<< argsName << ", nil); err != nil {" << endl;
<< method << "\", &" << argsName << ", nil); err != nil {" << endl;

indent_up();
f_types_ << indent() << "return err" << endl;
Expand Down Expand Up @@ -3787,15 +3788,15 @@ string t_go_generator::function_signature_if(t_function* tfunction, string prefi
string errs = argument_list(exceptions);

if (!ret->is_void()) {
signature += "r " + type_to_go_type(ret);
signature += "_r " + type_to_go_type(ret);

if (addError || errs.size() == 0) {
signature += ", ";
}
}

if (addError) {
signature += "err error";
signature += "_err error";
}

signature += ")";
Expand Down
14 changes: 14 additions & 0 deletions test/ThriftTest.thrift
Original file line number Diff line number Diff line change
Expand Up @@ -411,3 +411,17 @@ struct StructB {
struct OptionalSetDefaultTest {
1: optional set<string> with_default = [ "test" ]
}

service ConflictingNamesTest {
/**
* Use some names that could conflict with the compiler code as args
* to make sure that the compiler handled them correctly.
*/
void testNameConflicts(
// 1: string args, // args is already a reserved keyword in thrift compiler
// 2: string result, // result will cause problems in compiled netstd code
3: string meta,
4: string r,
5: string err,
)
}

0 comments on commit bc15861

Please sign in to comment.