aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java
diff options
context:
space:
mode:
authorGravatar michajlo <michajlo@google.com>2017-09-29 22:45:11 +0200
committerGravatar Klaus Aehlig <aehlig@google.com>2017-10-02 10:31:41 +0200
commitc8098d0e089d84268877bd30d4b1c0eae110deb3 (patch)
tree43868d1fb36c3c897b637402ff69284734e6239c /src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java
parent6ff77f8f7b6b1617b1c20e4c63d1b597a95813d4 (diff)
Only create builtins for rules once per PackageFactory
Previously we'd do this on demand. This simplifies a bit. PiperOrigin-RevId: 170526646
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java')
-rw-r--r--src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java b/src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java
index 0ff628e165..ba3608035a 100644
--- a/src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java
+++ b/src/main/java/com/google/devtools/build/lib/packages/RuleFactory.java
@@ -38,6 +38,8 @@ import javax.annotation.Nullable;
* performs a number of checks and associates the {@link Rule} and the owning {@link Package}
* with each other.
*
+ * <p>This class is immutable, once created the set of managed {@link RuleClass}es will not change.
+ *
* <p>Note: the code that actually populates the RuleClass map has been moved to {@link
* RuleClassProvider}.
*/
@@ -338,7 +340,7 @@ public class RuleFactory {
FuncallExpression generator = topCall.first;
BaseFunction function = topCall.second;
String name = generator.getNameArg();
-
+
ImmutableMap.Builder<String, Object> builder = ImmutableMap.builder();
for (Map.Entry<String, Object> attributeAccessor : args.getAttributeAccessors()) {
String attributeName = args.getName(attributeAccessor);