Adds a provider that exports Java source information. Adds some testing support for Aspects.

--
MOS_MIGRATED_REVID=93547419
diff --git a/src/main/java/com/google/devtools/build/lib/analysis/BuildView.java b/src/main/java/com/google/devtools/build/lib/analysis/BuildView.java
index 8891b27..85c2664 100644
--- a/src/main/java/com/google/devtools/build/lib/analysis/BuildView.java
+++ b/src/main/java/com/google/devtools/build/lib/analysis/BuildView.java
@@ -931,6 +931,24 @@
   }
 
   /**
+   * For a configured target dependentTarget, returns the desired configured target
+   * that is depended upon. Useful for obtaining the a target with aspects
+   * required by the dependent.
+   */
+  @VisibleForTesting
+  public ConfiguredTarget getPrerequisiteConfiguredTargetForTesting(
+      ConfiguredTarget dependentTarget, ConfiguredTarget desiredTarget) {
+    Collection<ConfiguredTarget> configuredTargets =
+        getPrerequisiteMapForTesting(dependentTarget).values();
+    for (ConfiguredTarget ct : configuredTargets) {
+      if (ct.getLabel().equals(desiredTarget.getLabel())) {
+        return ct;
+      }
+    }
+    return null;
+  }
+
+  /**
    * Tests and clears the current thread's pending "interrupted" status, and
    * throws InterruptedException iff it was set.
    */
diff --git a/src/main/java/com/google/devtools/build/lib/rules/java/JavaImport.java b/src/main/java/com/google/devtools/build/lib/rules/java/JavaImport.java
index 2eabf3f..8183db2 100644
--- a/src/main/java/com/google/devtools/build/lib/rules/java/JavaImport.java
+++ b/src/main/java/com/google/devtools/build/lib/rules/java/JavaImport.java
@@ -27,6 +27,7 @@
 import com.google.devtools.build.lib.analysis.TransitiveInfoCollection;
 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;
 import com.google.devtools.build.lib.rules.RuleConfiguredTargetFactory;
 import com.google.devtools.build.lib.rules.cpp.CcLinkParams;
 import com.google.devtools.build.lib.rules.cpp.CcLinkParamsProvider;
@@ -127,6 +128,8 @@
         .add(JavaNativeLibraryProvider.class, new JavaNativeLibraryProvider(
             transitiveJavaNativeLibraries))
         .add(CppCompilationContext.class, transitiveCppDeps)
+        .add(JavaSourceInfoProvider.class, new JavaSourceInfoProvider(
+            NestedSetBuilder.wrap(Order.STABLE_ORDER, srcJars), /* Artifact bundledSrcJar = */null))
         .add(JavaSourceJarsProvider.class, new JavaSourceJarsProvider(
             transitiveJavaSourceJars, srcJars))
         .addOutputGroup(JavaSemantics.SOURCE_JARS_OUTPUT_GROUP, transitiveJavaSourceJars)
diff --git a/src/main/java/com/google/devtools/build/lib/rules/java/JavaLibrary.java b/src/main/java/com/google/devtools/build/lib/rules/java/JavaLibrary.java
index 326ac31..4400888 100644
--- a/src/main/java/com/google/devtools/build/lib/rules/java/JavaLibrary.java
+++ b/src/main/java/com/google/devtools/build/lib/rules/java/JavaLibrary.java
@@ -210,6 +210,9 @@
         ruleContext, common, ImmutableList.<String>of(), classJar, srcJar, gensrcJar,
         ImmutableMap.<Artifact, Artifact>of(), helper, filesBuilder, builder);
 
+    NestedSetBuilder<Artifact> sourceInfoBuilder = NestedSetBuilder.stableOrder();
+    sourceInfoBuilder.addAll(attributes.getSourceFiles()).addAll(attributes.getSourceJars());
+
     NestedSet<Artifact> filesToBuild = filesBuilder.build();
     common.addTransitiveInfoProviders(builder, filesToBuild, classJar);
 
@@ -224,6 +227,8 @@
         .add(CcLinkParamsProvider.class, new CcLinkParamsProvider(ccLinkParamsStore))
         .add(JavaNativeLibraryProvider.class, new JavaNativeLibraryProvider(
             transitiveJavaNativeLibraries))
+        .add(JavaSourceInfoProvider.class, new JavaSourceInfoProvider(
+            sourceInfoBuilder.build(), srcJar))
         .add(JavaSourceJarsProvider.class, new JavaSourceJarsProvider(
             transitiveSourceJars, ImmutableList.of(srcJar)))
         // TODO(bazel-team): this should only happen for java_plugin
diff --git a/src/main/java/com/google/devtools/build/lib/rules/java/JavaSourceInfoProvider.java b/src/main/java/com/google/devtools/build/lib/rules/java/JavaSourceInfoProvider.java
new file mode 100644
index 0000000..7a906f7
--- /dev/null
+++ b/src/main/java/com/google/devtools/build/lib/rules/java/JavaSourceInfoProvider.java
@@ -0,0 +1,56 @@
+// Copyright 2015 Google Inc. 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.java;
+
+import com.google.common.base.Preconditions;
+import com.google.devtools.build.lib.actions.Artifact;
+import com.google.devtools.build.lib.analysis.TransitiveInfoProvider;
+import com.google.devtools.build.lib.collect.nestedset.NestedSet;
+import com.google.devtools.build.lib.concurrent.ThreadSafety.Immutable;
+
+/**
+ * A Provider describing the java sources directly belonging to a java rule.
+ */
+@Immutable
+public final class JavaSourceInfoProvider implements TransitiveInfoProvider {
+
+  private final NestedSet<Artifact> sources;
+  private final Artifact bundledSrcJar;
+
+  public JavaSourceInfoProvider(NestedSet<Artifact> sources, Artifact bundledSrcJar) {
+    Preconditions.checkNotNull(sources);
+    this.sources = sources;
+    this.bundledSrcJar = bundledSrcJar;
+  }
+
+  /**
+   * Gets the source artifacts. They will be .java, .jar, or .srcjar
+   * files. These files must be the original Java sources,
+   * and must not include the bundled .jar artifact generated by those sources.
+   * The .jars and .srcjars should contain java sources, but may include other files also.
+   * @return the source artifacts for this JavaSourceInfoProvider.
+   */
+  public NestedSet<Artifact> getSources() {
+    return sources;
+  }
+
+  /**
+   * Gets the srcjar artifact created by bundling the sources in getSources().
+   * If the rule that created this provider does not create a bundled source jar, returns null.
+   * @return the created srcjar artifact
+   */
+  public Artifact getBundledSrcJar() {
+    return bundledSrcJar;
+  }
+}