Add support for protoc plugins am: fe17f6f0e8
am: 91c063cfdc
am: 7299e418df
Change-Id: I30e57f6678343f57233831775b62afa1f043a450
This commit is contained in:
@@ -118,7 +118,7 @@ func (j *Module) genSources(ctx android.ModuleContext, srcFiles android.Paths,
|
||||
javaFile := genLogtags(ctx, srcFile)
|
||||
outSrcFiles = append(outSrcFiles, javaFile)
|
||||
case ".proto":
|
||||
srcJarFile := genProto(ctx, srcFile, flags)
|
||||
srcJarFile := genProto(ctx, srcFile, flags.proto)
|
||||
outSrcFiles = append(outSrcFiles, srcJarFile)
|
||||
case ".sysprop":
|
||||
srcJarFile := genSysprop(ctx, srcFile)
|
||||
|
@@ -481,6 +481,7 @@ func (j *Module) deps(ctx android.BottomUpMutatorContext) {
|
||||
{Mutator: "arch", Variation: ctx.Config().BuildOsCommonVariant},
|
||||
}, pluginTag, j.properties.Plugins...)
|
||||
|
||||
android.ProtoDeps(ctx, &j.protoProperties)
|
||||
if j.hasSrcExt(".proto") {
|
||||
protoDeps(ctx, &j.protoProperties)
|
||||
}
|
||||
@@ -768,12 +769,6 @@ func (j *Module) collectDeps(ctx android.ModuleContext) deps {
|
||||
deps.classpath = append(deps.classpath, dep.Srcs()...)
|
||||
deps.staticJars = append(deps.staticJars, dep.Srcs()...)
|
||||
deps.staticHeaderJars = append(deps.staticHeaderJars, dep.Srcs()...)
|
||||
case android.DefaultsDepTag, android.SourceDepTag:
|
||||
// Nothing to do
|
||||
case publicApiFileTag, systemApiFileTag, testApiFileTag:
|
||||
// Nothing to do
|
||||
default:
|
||||
ctx.ModuleErrorf("dependency on genrule %q may only be in srcs, libs, or static_libs", otherName)
|
||||
}
|
||||
default:
|
||||
switch tag {
|
||||
|
@@ -18,7 +18,7 @@ import (
|
||||
"android/soong/android"
|
||||
)
|
||||
|
||||
func genProto(ctx android.ModuleContext, protoFile android.Path, flags javaBuilderFlags) android.Path {
|
||||
func genProto(ctx android.ModuleContext, protoFile android.Path, flags android.ProtoFlags) android.Path {
|
||||
srcJarFile := android.GenPathWithExt(ctx, "proto", protoFile, "srcjar")
|
||||
|
||||
outDir := srcJarFile.ReplaceExtension(ctx, "tmp")
|
||||
@@ -29,7 +29,7 @@ func genProto(ctx android.ModuleContext, protoFile android.Path, flags javaBuild
|
||||
rule.Command().Text("rm -rf").Flag(outDir.String())
|
||||
rule.Command().Text("mkdir -p").Flag(outDir.String())
|
||||
|
||||
android.ProtoRule(ctx, rule, protoFile, flags.proto, nil, outDir, depFile, nil)
|
||||
android.ProtoRule(ctx, rule, protoFile, flags, flags.Deps, outDir, depFile, nil)
|
||||
|
||||
// Proto generated java files have an unknown package name in the path, so package the entire output directory
|
||||
// into a srcjar.
|
||||
@@ -48,22 +48,24 @@ func genProto(ctx android.ModuleContext, protoFile android.Path, flags javaBuild
|
||||
}
|
||||
|
||||
func protoDeps(ctx android.BottomUpMutatorContext, p *android.ProtoProperties) {
|
||||
switch String(p.Proto.Type) {
|
||||
case "micro":
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-micro")
|
||||
case "nano":
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-nano")
|
||||
case "lite", "":
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-lite")
|
||||
case "full":
|
||||
if ctx.Host() {
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-full")
|
||||
} else {
|
||||
ctx.PropertyErrorf("proto.type", "full java protos only supported on the host")
|
||||
if String(p.Proto.Plugin) == "" {
|
||||
switch String(p.Proto.Type) {
|
||||
case "micro":
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-micro")
|
||||
case "nano":
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-nano")
|
||||
case "lite", "":
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-lite")
|
||||
case "full":
|
||||
if ctx.Host() {
|
||||
ctx.AddVariationDependencies(nil, staticLibTag, "libprotobuf-java-full")
|
||||
} else {
|
||||
ctx.PropertyErrorf("proto.type", "full java protos only supported on the host")
|
||||
}
|
||||
default:
|
||||
ctx.PropertyErrorf("proto.type", "unknown proto type %q",
|
||||
String(p.Proto.Type))
|
||||
}
|
||||
default:
|
||||
ctx.PropertyErrorf("proto.type", "unknown proto type %q",
|
||||
String(p.Proto.Type))
|
||||
}
|
||||
}
|
||||
|
||||
@@ -72,19 +74,21 @@ func protoFlags(ctx android.ModuleContext, j *CompilerProperties, p *android.Pro
|
||||
|
||||
flags.proto = android.GetProtoFlags(ctx, p)
|
||||
|
||||
switch String(p.Proto.Type) {
|
||||
case "micro":
|
||||
flags.proto.OutTypeFlag = "--javamicro_out"
|
||||
case "nano":
|
||||
flags.proto.OutTypeFlag = "--javanano_out"
|
||||
case "lite":
|
||||
flags.proto.OutTypeFlag = "--java_out"
|
||||
flags.proto.OutParams = append(flags.proto.OutParams, "lite")
|
||||
case "full", "":
|
||||
flags.proto.OutTypeFlag = "--java_out"
|
||||
default:
|
||||
ctx.PropertyErrorf("proto.type", "unknown proto type %q",
|
||||
String(p.Proto.Type))
|
||||
if String(p.Proto.Plugin) == "" {
|
||||
switch String(p.Proto.Type) {
|
||||
case "micro":
|
||||
flags.proto.OutTypeFlag = "--javamicro_out"
|
||||
case "nano":
|
||||
flags.proto.OutTypeFlag = "--javanano_out"
|
||||
case "lite":
|
||||
flags.proto.OutTypeFlag = "--java_out"
|
||||
flags.proto.OutParams = append(flags.proto.OutParams, "lite")
|
||||
case "full", "":
|
||||
flags.proto.OutTypeFlag = "--java_out"
|
||||
default:
|
||||
ctx.PropertyErrorf("proto.type", "unknown proto type %q",
|
||||
String(p.Proto.Type))
|
||||
}
|
||||
}
|
||||
|
||||
flags.proto.OutParams = append(flags.proto.OutParams, j.Proto.Output_params...)
|
||||
|
Reference in New Issue
Block a user