// Copyright 2014 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.collect.nestedset.NestedSet; import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder; import com.google.devtools.build.lib.collect.nestedset.Order; /** * Contains information about storyboards for a single target. This does not include information * about the transitive closure. A storyboard: * * *

The {@link NestedSet}s stored in this class are only one level deep, and do not include the * storyboards in the transitive closure. This is to facilitate structural sharing between copies * of the sequences - the output zips can be added transitively to the inputs of the merge bundle * action, as well as to the files to build set, and only one instance of the sequence exists for * each set. */ final class Storyboards { private final NestedSet outputZips; private final NestedSet inputs; private Storyboards(NestedSet outputZips, NestedSet inputs) { this.outputZips = outputZips; this.inputs = inputs; } public NestedSet getOutputZips() { return outputZips; } public NestedSet getInputs() { return inputs; } static Storyboards empty() { return new Storyboards( NestedSetBuilder.emptySet(Order.STABLE_ORDER), NestedSetBuilder.emptySet(Order.STABLE_ORDER)); } /** * Generates a set of new instances given the raw storyboard inputs. * @param inputs the {@code .storyboard} files. * @param intermediateArtifacts the object used to determine the output zip {@link Artifact}s. */ static Storyboards fromInputs( Iterable inputs, IntermediateArtifacts intermediateArtifacts) { NestedSetBuilder outputZips = NestedSetBuilder.stableOrder(); for (Artifact input : inputs) { outputZips.add(intermediateArtifacts.compiledStoryboardZip(input)); } return new Storyboards(outputZips.build(), NestedSetBuilder.wrap(Order.STABLE_ORDER, inputs)); } }