// Copyright 2016 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. package com.google.devtools.build.lib.rules.objc; import com.google.common.collect.ImmutableMap; import com.google.devtools.build.lib.actions.Artifact; import com.google.devtools.build.lib.analysis.TransitiveInfoProvider; import com.google.devtools.build.lib.packages.ClassObjectConstructor; import com.google.devtools.build.lib.packages.NativeClassObjectConstructor; import com.google.devtools.build.lib.packages.SkylarkClassObject; /** * Provider containing the executable binary output that was built using an apple_binary target with * the 'executable' type. This provider contains: * <ul> * <li>'binary': The dylib artifact output by apple_binary</li> * <li>'objc': An {@link ObjcProvider} which contains information about the transitive * dependencies linked into the binary, (intended so that bundle loaders depending on this * executable may avoid relinking symbols included in the loadable binary</li> * </ul> */ public final class AppleExecutableBinaryProvider extends SkylarkClassObject implements TransitiveInfoProvider { /** Skylark name for the AppleExecutableBinaryProvider. */ public static final String SKYLARK_NAME = "AppleExecutableBinary"; /** Skylark constructor and identifier for AppleExecutableBinaryProvider. */ public static final ClassObjectConstructor SKYLARK_CONSTRUCTOR = new NativeClassObjectConstructor(SKYLARK_NAME) { }; private final Artifact appleExecutableBinary; private final ObjcProvider depsObjcProvider; /** * Creates a new AppleExecutableBinaryProvider provider that propagates the given apple_binary * configured as an executable. */ public AppleExecutableBinaryProvider(Artifact appleExecutableBinary, ObjcProvider depsObjcProvider) { super(SKYLARK_CONSTRUCTOR, ImmutableMap.<String, Object>of( "binary", appleExecutableBinary, "objc", depsObjcProvider)); this.appleExecutableBinary = appleExecutableBinary; this.depsObjcProvider = depsObjcProvider; } /** * Returns the multi-architecture executable binary that apple_binary created. */ public Artifact getAppleExecutableBinary() { return appleExecutableBinary; } /** * Returns the {@link ObjcProvider} which contains information about the transitive dependencies * linked into the dylib. */ public ObjcProvider getDepsObjcProvider() { return depsObjcProvider; } }