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


Java ContainerUtil.intersection方法代碼示例

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


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

示例1: getMatchingHeads

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
@Nullable
private Set<Integer> getMatchingHeads(@NotNull VcsLogRefs refs, @NotNull Set<VirtualFile> roots, @NotNull VcsLogFilterCollection filters) {
  VcsLogBranchFilter branchFilter = filters.getBranchFilter();
  VcsLogRootFilter rootFilter = filters.getRootFilter();
  VcsLogStructureFilter structureFilter = filters.getStructureFilter();

  if (branchFilter == null && rootFilter == null && structureFilter == null) return null;

  Set<Integer> filteredByBranch = null;

  if (branchFilter != null) {
    filteredByBranch = getMatchingHeads(refs, branchFilter);
  }

  Set<Integer> filteredByFile = getMatchingHeads(refs, VcsLogUtil
    .getAllVisibleRoots(roots, rootFilter, structureFilter));

  if (filteredByBranch == null) return filteredByFile;
  if (filteredByFile == null) return filteredByBranch;

  return new HashSet<Integer>(ContainerUtil.intersection(filteredByBranch, filteredByFile));
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:23,代碼來源:VisiblePackBuilder.java

示例2: getAllVisibleRoots

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
@NotNull
public static Set<VirtualFile> getAllVisibleRoots(@NotNull Collection<VirtualFile> roots,
                                                  @Nullable VcsLogRootFilter rootFilter,
                                                  @Nullable VcsLogStructureFilter structureFilter) {
  if (rootFilter == null && structureFilter == null) return new HashSet<VirtualFile>(roots);

  Collection<VirtualFile> fromRootFilter;
  if (rootFilter != null) {
    fromRootFilter = rootFilter.getRoots();
  }
  else {
    fromRootFilter = roots;
  }

  Collection<VirtualFile> fromStructureFilter;
  if (structureFilter != null) {
    Pair<Set<VirtualFile>, MultiMap<VirtualFile, VirtualFile>> rootsAndFiles =
      collectRoots(structureFilter.getFiles(), new HashSet<VirtualFile>(roots));
    fromStructureFilter = ContainerUtil.union(rootsAndFiles.first, rootsAndFiles.second.keySet());
  }
  else {
    fromStructureFilter = roots;
  }

  return new HashSet<VirtualFile>(ContainerUtil.intersection(fromRootFilter, fromStructureFilter));
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:27,代碼來源:VcsLogUtil.java

示例3: getCommonBranches

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
/**
 * Only common hg heavy branches
 */
@NotNull
public static List<String> getCommonBranches(@NotNull Collection<HgRepository> repositories) {
  Collection<String> commonBranches = null;
  for (HgRepository repository : repositories) {
    Collection<String> names = repository.getOpenedBranches();
    if (commonBranches == null) {
      commonBranches = names;
    }
    else {
      commonBranches = ContainerUtil.intersection(commonBranches, names);
    }
  }
  if (commonBranches != null) {
    ArrayList<String> common = new ArrayList<String>(commonBranches);
    Collections.sort(common);
    return common;
  }
  else {
    return Collections.emptyList();
  }
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:25,代碼來源:HgBranchUtil.java

示例4: getCommonBookmarks

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
@NotNull
public static List<String> getCommonBookmarks(@NotNull Collection<HgRepository> repositories) {
  Collection<String> commonBookmarkNames = null;
  for (HgRepository repository : repositories) {
    Collection<HgNameWithHashInfo> bookmarksInfo = repository.getBookmarks();
    Collection<String> names = HgUtil.getSortedNamesWithoutHashes(bookmarksInfo);
    if (commonBookmarkNames == null) {
      commonBookmarkNames = names;
    }
    else {
      commonBookmarkNames = ContainerUtil.intersection(commonBookmarkNames, names);
    }
  }
  if (commonBookmarkNames != null) {
    ArrayList<String> common = new ArrayList<String>(commonBookmarkNames);
    Collections.sort(common);
    return common;
  }
  else {
    return Collections.emptyList();
  }
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:23,代碼來源:HgBranchUtil.java

示例5: getTrackingBranches

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
/**
 * Returns local branches which track the given remote branch. Usually there is 0 or 1 such branches.
 */
@NotNull
public Collection<String> getTrackingBranches(@NotNull String remoteBranch) {
  Collection<String> trackingBranches = null;
  for (GitRepository repository : myRepositories) {
    Collection<String> tb = getTrackingBranches(repository, remoteBranch);
    if (trackingBranches == null) {
      trackingBranches = tb;
    }
    else {
      trackingBranches = ContainerUtil.intersection(trackingBranches, tb);
    }
  }
  return trackingBranches == null ? Collections.<String>emptyList() : trackingBranches;
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:18,代碼來源:GitMultiRootBranchConfig.java

示例6: getMergedToBranches

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
@NotNull
private List<String> getMergedToBranches(String branchName) {
  List<String> mergedToBranches = null;
  for (GitRepository repository : getRemainingRepositories()) {
    List<String> branches = getMergedToBranches(repository, branchName);
    if (mergedToBranches == null) {
      mergedToBranches = branches;
    } 
    else {
      mergedToBranches = new ArrayList<String>(ContainerUtil.intersection(mergedToBranches, branches));
    }
  }
  return mergedToBranches != null ? mergedToBranches : new ArrayList<String>();
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:15,代碼來源:GitDeleteBranchOperation.java

示例7: getCommonBranches

import com.intellij.util.containers.ContainerUtil; //導入方法依賴的package包/類
@NotNull
public static Collection<String> getCommonBranches(Collection<GitRepository> repositories,
                                                   boolean local) {
  Collection<String> commonBranches = null;
  for (GitRepository repository : repositories) {
    GitBranchesCollection branchesCollection = repository.getBranches();

    Collection<String> names = local
                               ? convertBranchesToNames(branchesCollection.getLocalBranches())
                               : getBranchNamesWithoutRemoteHead(branchesCollection.getRemoteBranches());
    if (commonBranches == null) {
      commonBranches = names;
    }
    else {
      commonBranches = ContainerUtil.intersection(commonBranches, names);
    }
  }

  if (commonBranches != null) {
    ArrayList<String> common = new ArrayList<String>(commonBranches);
    Collections.sort(common);
    return common;
  }
  else {
    return Collections.emptyList();
  }
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:28,代碼來源:GitBranchUtil.java


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