// Copyright 2017 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.devtools.build.lib.actions.Artifact; import com.google.devtools.build.lib.packages.NativeInfo; import com.google.devtools.build.lib.packages.NativeProvider; import com.google.devtools.build.lib.skylarkinterface.SkylarkCallable; import com.google.devtools.build.lib.skylarkinterface.SkylarkModule; import com.google.devtools.build.lib.skylarkinterface.SkylarkModuleCategory; /** * Provider containing information regarding multi-architecture Apple static libraries, as is * propagated by the {@code apple_static_library} rule. * *

This provider contains: * *

*/ @SkylarkModule( name = "AppleStaticLibrary", category = SkylarkModuleCategory.PROVIDER, doc = "A provider containing information regarding multi-architecture Apple static libraries, " + "as is propagated by the apple_static_library rule." ) public final class AppleStaticLibraryInfo extends NativeInfo { /** Skylark name for the AppleStaticLibraryInfo. */ public static final String SKYLARK_NAME = "AppleStaticLibrary"; /** Skylark constructor and identifier for AppleStaticLibraryInfo. */ public static final NativeProvider SKYLARK_CONSTRUCTOR = new NativeProvider( AppleStaticLibraryInfo.class, SKYLARK_NAME) {}; private final Artifact multiArchArchive; private final ObjcProvider depsObjcProvider; /** * Creates a new AppleStaticLibraryInfo provider that propagates the given * {@code apple_static_library} information. */ public AppleStaticLibraryInfo(Artifact multiArchArchive, ObjcProvider depsObjcProvider) { super(SKYLARK_CONSTRUCTOR); this.multiArchArchive = multiArchArchive; this.depsObjcProvider = depsObjcProvider; } /** * Returns the multi-architecture archive that {@code apple_static_library} created. */ @SkylarkCallable(name = "archive", structField = true, doc = "The multi-arch archive (.a) output by apple_static_library." ) public Artifact getMultiArchArchive() { return multiArchArchive; } /** * Returns the {@link ObjcProvider} which contains information about the transitive dependencies * linked into the archive. */ @SkylarkCallable(name = "objc", structField = true, doc = "A provider which contains information about the transitive dependencies linked into " + "the archive." ) public ObjcProvider getDepsObjcProvider() { return depsObjcProvider; } }