diff options
author | 2018-02-21 02:10:29 -0800 | |
---|---|---|
committer | 2018-05-07 16:21:59 -0700 | |
commit | 4339853a20bc300968d0389f4f9307ec415d540d (patch) | |
tree | 3258e9b29d26cafc74123ad21cc557f28cf0c9b1 /cc/proto.go | |
parent | 470969df19079ad1c2eeb94fcc984ca2ce5e68ab (diff) |
Add a dependency fixer for proto deps
protoc dependency files, at least for C++ outputs, uses the form of:
a/b.c \
a/b.h: <dep1> <dep2>...
Ninja will fail the command when it parses a dep file and there's more
than one output file (even though it doesn't care what the output file
name is). So this tool will parse the original file, and output a
version with only a single output file.
Bug: 67329638
Test: NINJA_ARGS="-t deps ...pb.c" m
Test: NINJA_ARGS="-t deps ...srcjar" m
Test: NINJA_ARGS="-t deps ...srcszip" m
Test: Run dep_fixer across all of taimen's dep files, no failures.
Test: Run dep_fixer against the processed files, no changes.
Test: Run androidmk across all of our Android.mk files, inspect the diffs
Change-Id: I4263b7d5faea37285afa6b24dedf5964aa7d19dc
Diffstat (limited to 'cc/proto.go')
-rw-r--r-- | cc/proto.go | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/cc/proto.go b/cc/proto.go index 22e50ab48..6e6f95ee9 100644 --- a/cc/proto.go +++ b/cc/proto.go @@ -25,13 +25,17 @@ import ( func init() { pctx.HostBinToolVariable("protocCmd", "aprotoc") + pctx.HostBinToolVariable("depFixCmd", "dep_fixer") } var ( proto = pctx.AndroidStaticRule("protoc", blueprint.RuleParams{ - Command: "$protocCmd --cpp_out=$protoOutParams:$outDir -I $protoBase $protoFlags $in", - CommandDeps: []string{"$protocCmd"}, + Command: "$protocCmd --cpp_out=$protoOutParams:$outDir --dependency_out=$out.d -I $protoBase $protoFlags $in && " + + `$depFixCmd $out.d`, + CommandDeps: []string{"$protocCmd", "$depFixCmd"}, + Depfile: "${out}.d", + Deps: blueprint.DepsGCC, }, "protoFlags", "protoOutParams", "protoBase", "outDir") ) @@ -53,10 +57,11 @@ func genProto(ctx android.ModuleContext, protoFile android.Path, } ctx.Build(pctx, android.BuildParams{ - Rule: proto, - Description: "protoc " + protoFile.Rel(), - Outputs: android.WritablePaths{ccFile, headerFile}, - Input: protoFile, + Rule: proto, + Description: "protoc " + protoFile.Rel(), + Output: ccFile, + ImplicitOutput: headerFile, + Input: protoFile, Args: map[string]string{ "outDir": android.ProtoDir(ctx).String(), "protoFlags": protoFlags, |