// Copyright 2015 The Bazel Authors. 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. syntax = "proto2"; package devtools.xcode; option java_outer_classname = "BundleMergeProtos"; option java_package = "com.google.devtools.build.xcode.bundlemerge.proto"; // Contains all the arguments necessary to drive the BundleMerge tool, // including the path to the output file and extra files to include in the // bundle. // Next Id: 17 message Control { // Previously used fields. reserved 1, 3, 9, 11, 13; // The single info.plist file to be bundled into the archive. This plist will // not be modified by bundlemerge. optional string bundle_info_plist_file = 16; // Path to the .ipa file to write. This is the final application bundle. Note // this is ignored for nested bundles. optional string out_file = 2; // One of the symbols in the com.google.devtools.build.xcode.common.Platform // (e.g. "DEVICE", "SIMULATOR"). optional string platform = 4; // The version of the SDK used to build the app. optional string sdk_version = 5; // Earliest iOS version on which the app will run. optional string minimum_os_version = 6; // The directory inside which all files are placed in the final bundle. // For the top-most bundle, this is generally "Payload/{app_name}.app". If // this bundle is nested, then this bundle_root is relative to to the parent's // bundle_root. optional string bundle_root = 7; // All files to put in the bundle besides automatically-generated files such // as Info.plist and PkgInfo. This should include the application binary. repeated BundleFile bundle_file = 8; // Zip files to merge with the final zip. Note that bundle_root is ignored // when merging zips, so to place items in the bundle root, you should do one // of the following: // 1. make the merge_zips have entries that are named "{bundle_root}/foo" // rather than just "foo" // 2. set the root property on the MergeZip protobuf to {bundle_root} // Note that the paths of these zips are always relative to the zip file root // - they are not relative to the containing bundle. repeated MergeZip merge_zip = 10; // Bundles that are nested within this one. bundle_root in these bundles is // relative to the containing bundle's bundle_root. repeated Control nested_bundle = 12; // A reverse-DNS string identifier for this bundle. optional string primary_bundle_identifier = 14; // A fallback bundle identifier used when primary is not filled. optional string fallback_bundle_identifier = 15; } // Represents a zip file to merge with the final zip. message MergeZip { // The prefix to prepend to every entry name before putting it in the final // zip. For instance, "Payload/Foo.app/" (notice the final slash). optional string entry_name_prefix = 1; // The path to the source file to merge. optional string source_path = 2; } message BundleFile { // The path of the file to put in the bundle. optional string source_file = 1; // The path of the file in the bundle, relative to the bundle root. optional string bundle_path = 2; // The external file attribute field in the central directory record in the // .zip file. If omitted, the ZipInputEntry.DEFAULT_EXTERNAL_FILE_ATTRIBUTE // constant is used. optional int32 external_file_attribute = 3; }