當前位置: 首頁>>代碼示例>>Java>>正文


Java Iterables.concat方法代碼示例

本文整理匯總了Java中com.google.common.collect.Iterables.concat方法的典型用法代碼示例。如果您正苦於以下問題:Java Iterables.concat方法的具體用法?Java Iterables.concat怎麽用?Java Iterables.concat使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.google.common.collect.Iterables的用法示例。


在下文中一共展示了Iterables.concat方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: collectDependencies

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
public static List<DependencySpec> collectDependencies(final BinarySpec binary, @Nullable final SourceComponentSpec owner, final Collection<DependencySpec>... specificDependencies) {
    List<DependencySpec> dependencies = Lists.newArrayList();
    if (specificDependencies!=null) {
        for (Collection<DependencySpec> deps : specificDependencies) {
            dependencies.addAll(deps);
        }
    }
    Collection<LanguageSourceSet> binarySources = binary.getSources().values();
    Iterable<LanguageSourceSet> sourceSets = owner != null ? Iterables.concat(owner.getSources().values(), binarySources) : binarySources;
    for (LanguageSourceSet sourceSet : sourceSets) {
        if (sourceSet instanceof DependentSourceSet) {
            dependencies.addAll(((DependentSourceSet) sourceSet).getDependencies().getDependencies());
        }
    }
    return dependencies;
}
 
開發者ID:lxxlxx888,項目名稱:Reer,代碼行數:17,代碼來源:DefaultJvmBinarySpec.java

示例2: ideaConfigurations

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
private Iterable<Configuration> ideaConfigurations(final IdeaModule ideaModule) {
    Set<Configuration> configurations = Sets.newLinkedHashSet(ideaModule.getProject().getConfigurations());
    for (Map<String, Collection<Configuration>> scopeMap : ideaModule.getScopes().values()) {
        for (Configuration cfg : Iterables.concat(scopeMap.values())) {
            configurations.add(cfg);
        }
    }
    return Iterables.filter(
            configurations,
            new Predicate<Configuration>() {
                @Override
                public boolean apply(Configuration input) {
                    return isMappedToIdeaScope(input, ideaModule);
                }
            });
}
 
開發者ID:lxxlxx888,項目名稱:Reer,代碼行數:17,代碼來源:IdeaDependenciesProvider.java

示例3: getAllAnnotations

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
/**
 * @param element the element
 * @return all annotations on the element and on the type of the element
 */
public static Iterable<? extends AnnotationMirror> getAllAnnotations(Element element) {
  // for methods, we care about annotations on the return type, not on the method type itself
  TypeMirror typeMirror =
      element instanceof Symbol.MethodSymbol
          ? ((Symbol.MethodSymbol) element).getReturnType()
          : element.asType();
  return Iterables.concat(element.getAnnotationMirrors(), typeMirror.getAnnotationMirrors());
}
 
開發者ID:uber,項目名稱:NullAway,代碼行數:13,代碼來源:NullabilityUtil.java

示例4: concat

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
/**
 * Return the concatenation of the {@link Iterables} in the given {@link Collection}.
 *
 * Result is equivalent to {@link Iterables#concat}, but there are some optimizations
 * for the cases where size == 0 and size == 1.
 */
public static <T> Iterable<T> concat(Collection<? extends Iterable<? extends T>> iterables) {
    switch(iterables.size()) {
        case 0: return emptyIterable();
        case 1: return (Iterable<T>) getFirst(iterables);
        default: return Iterables.concat(iterables);
    }
}
 
開發者ID:OvercastNetwork,項目名稱:ProjectAres,代碼行數:14,代碼來源:IterableUtils.java

示例5: unify

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
private ClassFileSource unify(final List<ClassFileSource> sources) {
    final Iterable<ClassFileLocation> concatenatedStreams = Iterables.concat(sources);
    return new ClassFileSource() {
        @Override
        public Iterator<ClassFileLocation> iterator() {
            return concatenatedStreams.iterator();
        }
    };
}
 
開發者ID:TNG,項目名稱:ArchUnit,代碼行數:10,代碼來源:ClassFileImporter.java

示例6: successfulSplitCRLF

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
@Test
public void successfulSplitCRLF() throws Exception {
    final NewlineChunkSplitter splitter = new NewlineChunkSplitter();

    final String logLines = "Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page\r\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:\r\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"\r\n";

    final ByteBuf buffer = Unpooled.copiedBuffer(logLines, UTF_8);
    final Iterable<String> firstTwoChunks = splitter.split(buffer, UTF_8);
    final Iterable<String> remainingChunk = splitter.splitRemaining(buffer, UTF_8);

    int messageNum = 0;
    for (String chunk : Iterables.concat(firstTwoChunks, remainingChunk)) {
        switch (++messageNum) {
            case 1:
                assertEquals("Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page", chunk);
                break;
            case 2:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:", chunk);
                break;
            case 3:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"", chunk);
                break;
        }
    }

    assertEquals("the last chunk should have triggered a message (no follow mode active)", 3, messageNum);
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:30,代碼來源:NewlineChunkSplitterTest.java

示例7: merge

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
@Override
public BlankLineWanted merge(BlankLineWanted other) {
    if (!(other instanceof ConditionalBlankLine)) {
        return other;
    }
    return new ConditionalBlankLine(
            Iterables.concat(this.tags, ((ConditionalBlankLine) other).tags));
}
 
開發者ID:tranleduy2000,項目名稱:javaide,代碼行數:9,代碼來源:OpsBuilder.java

示例8: get

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
@Override
public Iterable<? extends File> get() {
    Variant variant = buildConfig.getCurrentVariant();
    if (variant != null) {
        AndroidArtifact testArtifact = AndroidBuildVariants.instrumentTestArtifact(variant.getExtraAndroidArtifacts());
        Iterable<File> testCompileCPEntries
                = Collections.<File>singleton(variant.getMainArtifact().getClassesFolder());
        if (testArtifact != null) {
            List<File> javaLibs = new ArrayList<>();
            for (JavaLibrary lib : testArtifact.getDependencies().getJavaLibraries()) {
                collectJavaLibraries(javaLibs, lib);
            }
            testCompileCPEntries = Iterables.concat(
                    testCompileCPEntries,
                    Iterables.transform(
                            testArtifact.getDependencies().getLibraries(),
                            new Function<AndroidLibrary, File>() {
                        @Override
                        public File apply(AndroidLibrary f) {
                            return f.getJarFile();
                        }
                    }),
                    javaLibs);
        }
        return testCompileCPEntries;
    }
    return Collections.<File>emptyList();
}
 
開發者ID:NBANDROIDTEAM,項目名稱:NBANDROID-V2,代碼行數:29,代碼來源:GradleAndroidClassPathProvider.java

示例9: collectInstanceDataNodeContainers

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
/**
 * Collects Instance DataNode Containers.
 * @param potentialSchemaNodes - A list of possible DataSchemaNode values
 * @param container - DataNodeContainer
 * @param name - the Name of the data node
 */
private static void collectInstanceDataNodeContainers(final List<DataSchemaNode> potentialSchemaNodes,
        final DataNodeContainer container, final String name) {

    final Predicate<DataSchemaNode> filter = new Predicate<DataSchemaNode>() {
        @Override
        public boolean apply(final DataSchemaNode node) {
            return Objects.equal(node.getQName().getLocalName(), name);
        }
    };

    final Iterable<DataSchemaNode> nodes = Iterables.filter(container.getChildNodes(), filter);

    // Can't combine this loop with the filter above because the filter is
    // lazily-applied by Iterables.filter.
    for (final DataSchemaNode potentialNode : nodes) {
        if (isInstantiatedDataSchema(potentialNode)) {
            potentialSchemaNodes.add(potentialNode);
        }
    }

    final Iterable<ChoiceSchemaNode> choiceNodes = Iterables.filter(container.getChildNodes(), ChoiceSchemaNode.class);
    final Iterable<Set<ChoiceCaseNode>> map = Iterables.transform(choiceNodes, CHOICE_FUNCTION);

    final Iterable<ChoiceCaseNode> allCases = Iterables.<ChoiceCaseNode> concat(map);
    for (final ChoiceCaseNode caze : allCases) {
        collectInstanceDataNodeContainers(potentialSchemaNodes, caze, name);
    }
}
 
開發者ID:opendaylight,項目名稱:fpc,代碼行數:35,代碼來源:NameResolver.java

示例10: DefaultTaskClassValidatorExtractor

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
public DefaultTaskClassValidatorExtractor(Iterable<? extends PropertyAnnotationHandler> customAnnotationHandlers) {
    Iterable<PropertyAnnotationHandler> allAnnotationHandlers = Iterables.concat(HANDLERS, customAnnotationHandlers);
    this.annotationHandlers = Maps.uniqueIndex(allAnnotationHandlers, new Function<PropertyAnnotationHandler, Class<? extends Annotation>>() {
        @Override
        public Class<? extends Annotation> apply(PropertyAnnotationHandler handler) {
            return handler.getAnnotationType();
        }
    });
    this.annotationOverrides = collectAnnotationOverrides(allAnnotationHandlers);
}
 
開發者ID:lxxlxx888,項目名稱:Reer,代碼行數:11,代碼來源:DefaultTaskClassValidatorExtractor.java

示例11: members

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
private Iterable<TMember> members(int source) {
	return hasSource(source) ? Iterables.concat(members(
			source, GETTER),
			members(source, SETTER),
			members(source, FIELD),
			members(source, METHOD)) : MemberList.emptyList();
}
 
開發者ID:eclipse,項目名稱:n4js,代碼行數:8,代碼來源:MemberMatrix.java

示例12: getGroupNames

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
/**
 * Returns the names of all counter classes.
 * @return Set of counter names.
 */
public synchronized Iterable<String> getGroupNames() {
  HashSet<String> deprecated = new HashSet<String>();
  for(Map.Entry<String, String> entry : legacyMap.entrySet()) {
    String newGroup = entry.getValue();
    boolean isFGroup = isFrameworkGroup(newGroup);
    if(isFGroup ? fgroups.containsKey(newGroup) : groups.containsKey(newGroup)) {
      deprecated.add(entry.getKey());
    }
  }
  return Iterables.concat(fgroups.keySet(), groups.keySet(), deprecated);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:16,代碼來源:AbstractCounters.java

示例13: successfulSplit

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
@Test
public void successfulSplit() {
    final PatternChunkSplitter splitter = new PatternChunkSplitter("^(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)");

    String logLines = "Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:\n" +
            "\t\tcom.google.Keystone.Daemon.UpdateEngine: 2 connection(s)\n" +
            "\t\tcom.google.Keystone.Daemon.Administration: 0 connection(s)\n" +
            "Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"\n";
    final ByteBuf buffer = Unpooled.copiedBuffer(logLines, UTF_8);
    final Iterable<String> firstTwoChunks = splitter.split(buffer, UTF_8);
    final Iterable<String> remainingChunk = splitter.splitRemaining(buffer, UTF_8);

    int messageNum = 0;
    for (String chunk : Iterables.concat(firstTwoChunks, remainingChunk)) {
        switch (++messageNum) {
            case 1:
                assertEquals("Feb 20 17:05:18 otter kernel[0]: CODE SIGNING: cs_invalid_page(0x1000): p=32696[GoogleSoftwareUp] final status 0x0, allow (remove VALID)ing page\n", chunk);
                break;
            case 2:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KeystoneDaemon logServiceState] GoogleSoftwareUpdate daemon (1.1.0.3659) vending:\n" +
                                "\t\tcom.google.Keystone.Daemon.UpdateEngine: 2 connection(s)\n" +
                                "\t\tcom.google.Keystone.Daemon.Administration: 0 connection(s)\n",
                        chunk);
                break;
            case 3:
                assertEquals("Feb 20 17:05:18 otter GoogleSoftwareUpdateDaemon[32697]: -[KSUpdateEngine updateProductID:] KSUpdateEngine updating product ID: \"com.google.Keystone\"\n", chunk);
                break;
        }
    }

    assertEquals("the last chunk should have triggered a message (no follow mode active)", 3, messageNum);
}
 
開發者ID:DevOpsStudio,項目名稱:Re-Collector,代碼行數:34,代碼來源:PatternChunkSplitterTest.java

示例14: getFileStatuses

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
/**
 * Start executing and return FileStatuses based on the parameters specified
 * @return fetched file statuses
 * @throws InterruptedException
 * @throws IOException
 */
public Iterable<FileStatus> getFileStatuses() throws InterruptedException,
    IOException {
  // Increment to make sure a race between the first thread completing and the
  // rest being scheduled does not lead to a termination.
  runningTasks.incrementAndGet();
  for (Path p : inputDirs) {
    runningTasks.incrementAndGet();
    ListenableFuture<ProcessInitialInputPathCallable.Result> future = exec
        .submit(new ProcessInitialInputPathCallable(p, conf, inputFilter));
    Futures.addCallback(future, processInitialInputPathCallback);
  }

  runningTasks.decrementAndGet();

  lock.lock();
  try {
    while (runningTasks.get() != 0 && unknownError == null) {
      condition.await();
    }
  } finally {
    lock.unlock();
  }
  this.exec.shutdownNow();
  if (this.unknownError != null) {
    if (this.unknownError instanceof Error) {
      throw (Error) this.unknownError;
    } else if (this.unknownError instanceof RuntimeException) {
      throw (RuntimeException) this.unknownError;
    } else if (this.unknownError instanceof IOException) {
      throw (IOException) this.unknownError;
    } else if (this.unknownError instanceof InterruptedException) {
      throw (InterruptedException) this.unknownError;
    } else {
      throw new IOException(this.unknownError);
    }
  }
  if (this.invalidInputErrors.size() != 0) {
    if (this.newApi) {
      throw new org.apache.hadoop.mapreduce.lib.input.InvalidInputException(
          invalidInputErrors);
    } else {
      throw new InvalidInputException(invalidInputErrors);
    }
  }
  return Iterables.concat(resultQueue);
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:53,代碼來源:LocatedFileStatusFetcher.java

示例15: configureSingle

import com.google.common.collect.Iterables; //導入方法依賴的package包/類
@Override
public StoragePluginConfig configureSingle(MongoConfig mongo) {
  // Authority
  StringBuilder connection = new StringBuilder("mongodb://");
  if (AuthenticationType.MASTER.equals(mongo.getAuthenticationType())) {
    String username = mongo.getUsername();
    if (username != null) {
      connection.append(urlEncode(username));
    }
    String password = mongo.getPassword();
    if (password != null) {
      connection.append(":").append(urlEncode(password));
    }
    connection.append("@");

    // host list
    appendHosts(connection, checkNotNull(mongo.getHostList(), "hostList missing"), ',').append("/");
    final String database = mongo.getAuthDatabase();
    if (database != null) {
      connection.append(database);
    }
  } else {
    // host list
    appendHosts(connection, checkNotNull(mongo.getHostList(), "hostList missing"), ',').append("/");
  }

  // Query string
  Iterable<Property> propertyList = checkNotNull(mongo.getUseSsl(), "useSSL missing")
      ? Iterables.concat(mongo.getPropertyList(), Collections.singleton(new Property().setName("ssl").setValue("true")))
      : mongo.getPropertyList();

  connection.append("?");
  appendProperties(connection, checkNotNull(propertyList, "propertyList missing"), '=', '&');

  // default 2s
  int authTimeoutMillis = mongo.getAuthenticationTimeoutMillis() == null ? 2000 : mongo.getAuthenticationTimeoutMillis().intValue();
  boolean secondaryReadsOnly = mongo.getSecondaryReadsOnly() == null ? false : mongo.getSecondaryReadsOnly().booleanValue();
  // 0 means disabled
  int subpartitionSize = mongo.getSubpartitionSize() == null ? 0 : mongo.getSubpartitionSize().intValue();
  MongoStoragePluginConfig config = new MongoStoragePluginConfig(
      authTimeoutMillis,
      connection.toString(),
      secondaryReadsOnly,
      subpartitionSize
      );
  return config;
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:48,代碼來源:MongoSourceConfigurator.java


注:本文中的com.google.common.collect.Iterables.concat方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。