| // Copyright 2017 Google Inc. All rights reserved. | 
 | // | 
 | // Licensed under the Apache License, Version 2.0 (the "License"); | 
 | // you may not use this file except in compliance with the License. | 
 | // You may obtain a copy of the License at | 
 | // | 
 | //     http://www.apache.org/licenses/LICENSE-2.0 | 
 | // | 
 | // Unless required by applicable law or agreed to in writing, software | 
 | // distributed under the License is distributed on an "AS IS" BASIS, | 
 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | // See the License for the specific language governing permissions and | 
 | // limitations under the License. | 
 |  | 
 | package android | 
 |  | 
 | // TODO(ccross): protos are often used to communicate between multiple modules.  If the only | 
 | // way to convert a proto to source is to reference it as a source file, and external modules cannot | 
 | // reference source files in other modules, then every module that owns a proto file will need to | 
 | // export a library for every type of external user (lite vs. full, c vs. c++ vs. java).  It would | 
 | // be better to support a proto module type that exported a proto file along with some include dirs, | 
 | // and then external modules could depend on the proto module but use their own settings to | 
 | // generate the source. | 
 |  | 
 | func ProtoFlags(ctx ModuleContext, p *ProtoProperties) []string { | 
 | 	protoFlags := []string{} | 
 |  | 
 | 	if len(p.Proto.Local_include_dirs) > 0 { | 
 | 		localProtoIncludeDirs := PathsForModuleSrc(ctx, p.Proto.Local_include_dirs) | 
 | 		protoFlags = append(protoFlags, JoinWithPrefix(localProtoIncludeDirs.Strings(), "-I")) | 
 | 	} | 
 | 	if len(p.Proto.Include_dirs) > 0 { | 
 | 		rootProtoIncludeDirs := PathsForSource(ctx, p.Proto.Include_dirs) | 
 | 		protoFlags = append(protoFlags, JoinWithPrefix(rootProtoIncludeDirs.Strings(), "-I")) | 
 | 	} | 
 |  | 
 | 	return protoFlags | 
 | } | 
 |  | 
 | func ProtoCanonicalPathFromRoot(ctx ModuleContext, p *ProtoProperties) bool { | 
 | 	if p.Proto.Canonical_path_from_root == nil { | 
 | 		return true | 
 | 	} | 
 | 	return *p.Proto.Canonical_path_from_root | 
 | } | 
 |  | 
 | // ProtoDir returns the module's "gen/proto" directory | 
 | func ProtoDir(ctx ModuleContext) ModuleGenPath { | 
 | 	return PathForModuleGen(ctx, "proto") | 
 | } | 
 |  | 
 | // ProtoSubDir returns the module's "gen/proto/path/to/module" directory | 
 | func ProtoSubDir(ctx ModuleContext) ModuleGenPath { | 
 | 	return PathForModuleGen(ctx, "proto", ctx.ModuleDir()) | 
 | } | 
 |  | 
 | type ProtoProperties struct { | 
 | 	Proto struct { | 
 | 		// Proto generator type.  C++: full or lite.  Java: micro, nano, stream, or lite. | 
 | 		Type *string `android:"arch_variant"` | 
 |  | 
 | 		// list of directories that will be added to the protoc include paths. | 
 | 		Include_dirs []string | 
 |  | 
 | 		// list of directories relative to the bp file that will | 
 | 		// be added to the protoc include paths. | 
 | 		Local_include_dirs []string | 
 |  | 
 | 		// whether to identify the proto files from the root of the | 
 | 		// source tree (the original method in Android, useful for | 
 | 		// android-specific protos), or relative from where they were | 
 | 		// specified (useful for external/third party protos). | 
 | 		// | 
 | 		// This defaults to true today, but is expected to default to | 
 | 		// false in the future. | 
 | 		Canonical_path_from_root *bool | 
 | 	} `android:"arch_variant"` | 
 | } |