Skip to content

Commit

Permalink
Fix import path behaviour when using full path
Browse files Browse the repository at this point in the history
This change makes protoc-gen-star conform to the behaviour
of protoc-gen-go in the presence of an import_path
parameter that contains slashes.

See https://github.com/golang/protobuf/blob/v1.4.2/protoc-gen-go/generator/generator.go#L637-L643
for evidence of this behaviour in protoc-gen-go.

Fixes lyft#77
  • Loading branch information
johanbrandhorst committed Aug 6, 2020
1 parent e86c55f commit 9a8e34b
Show file tree
Hide file tree
Showing 4 changed files with 10 additions and 0 deletions.
4 changes: 4 additions & 0 deletions lang/go/package.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,10 @@ func (c context) PackageName(node pgs.Node) pgs.Name {
// use import_path parameter ONLY if there is no go_package option in the file.
if ip := c.p.Str("import_path"); ip != "" &&
e.File().Descriptor().GetOptions().GetGoPackage() == "" {
// Remove anything before the last slash
if i := strings.LastIndex(ip, "/"); i >= 0 {
ip = ip[i+1:]
}
pkg = ip
}

Expand Down
1 change: 1 addition & 0 deletions lang/go/package_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ func TestPackageName(t *testing.T) {
{"import", "bar"}, // uses the basename if go_package contains a /
{"override", "baz"}, // if go_package contains ;, use everything to the right
{"import_path", "_package"}, // import_path param used if no go_package option
{"full_import_path", "buzz"}, // import_path param used if no go_package option. Should use last part of path.
{"mapped", "unaffected"}, // M mapped params are ignored for build targets
{"import_path_mapped", "go_package"}, // mixed import_path and M parameters should lose to go_package
{"transitive_package", "foobar"}, // go_option gets picked up from other files if present
Expand Down
4 changes: 4 additions & 0 deletions lang/go/testdata/names/full_import_path/import_path.proto
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
syntax="proto3";
package names.import_path;

message ImportPath {}
1 change: 1 addition & 0 deletions lang/go/testdata/names/full_import_path/params
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Mnames/import_path/import_path.proto=foobar,import_path=github.com/fizz/buzz

0 comments on commit 9a8e34b

Please sign in to comment.