| /* |
| * Copyright 2000-2014 JetBrains s.r.o. |
| * |
| * 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.intellij.psi.search.searches; |
| |
| import com.intellij.openapi.components.ServiceManager; |
| import com.intellij.openapi.util.TextRange; |
| import com.intellij.psi.PsiFile; |
| import com.intellij.psi.search.IndexPattern; |
| import com.intellij.psi.search.IndexPatternOccurrence; |
| import com.intellij.psi.search.IndexPatternProvider; |
| import com.intellij.util.Query; |
| import com.intellij.util.QueryFactory; |
| import org.jetbrains.annotations.NotNull; |
| |
| /** |
| * Allows to search for occurrences of specified regular expressions in the comments |
| * of Java source files. |
| * |
| * @author yole |
| * @since 5.1 |
| * @see IndexPatternProvider |
| * @see com.intellij.psi.search.PsiTodoSearchHelper#findFilesWithTodoItems() |
| */ |
| public abstract class IndexPatternSearch extends QueryFactory<IndexPatternOccurrence, IndexPatternSearch.SearchParameters> { |
| public static IndexPatternSearch INDEX_PATTERN_SEARCH_INSTANCE = ServiceManager.getService(IndexPatternSearch.class); |
| |
| public static class SearchParameters { |
| private final PsiFile myFile; |
| private final IndexPattern myPattern; |
| private final IndexPatternProvider myPatternProvider; |
| private final TextRange myRange; |
| |
| public SearchParameters(@NotNull PsiFile file, @NotNull IndexPattern pattern) { |
| this(file, pattern,null); |
| } |
| public SearchParameters(@NotNull PsiFile file, @NotNull IndexPattern pattern, TextRange range) { |
| myFile = file; |
| myRange = range; |
| myPatternProvider = null; |
| myPattern = pattern; |
| } |
| |
| public SearchParameters(@NotNull PsiFile file, @NotNull IndexPatternProvider patternProvider) { |
| this(file, patternProvider,null); |
| } |
| public SearchParameters(@NotNull PsiFile file, @NotNull IndexPatternProvider patternProvider, TextRange range) { |
| myFile = file; |
| myPatternProvider = patternProvider; |
| myRange = range; |
| myPattern = null; |
| } |
| |
| @NotNull |
| public PsiFile getFile() { |
| return myFile; |
| } |
| |
| public IndexPattern getPattern() { |
| return myPattern; |
| } |
| |
| public IndexPatternProvider getPatternProvider() { |
| return myPatternProvider; |
| } |
| |
| public TextRange getRange() { |
| return myRange; |
| } |
| } |
| |
| protected IndexPatternSearch() { |
| } |
| |
| /** |
| * Returns a query which can be used to process occurrences of the specified pattern |
| * in the specified file. The query is executed by parsing the contents of the file. |
| * |
| * @param file the file in which occurrences should be searched. |
| * @param pattern the pattern to search for. |
| * @return the query instance. |
| */ |
| @NotNull |
| public static Query<IndexPatternOccurrence> search(@NotNull PsiFile file, @NotNull IndexPattern pattern) { |
| final SearchParameters parameters = new SearchParameters(file, pattern); |
| return INDEX_PATTERN_SEARCH_INSTANCE.createQuery(parameters); |
| } |
| |
| /** |
| * Returns a query which can be used to process occurrences of the specified pattern |
| * in the specified text range. The query is executed by parsing the contents of the file. |
| * |
| * @param file the file in which occurrences should be searched. |
| * @param pattern the pattern to search for. |
| * @param startOffset the start offset of the range to search. |
| * @param endOffset the end offset of the range to search. |
| * @return the query instance. |
| */ |
| @NotNull |
| public static Query<IndexPatternOccurrence> search(@NotNull PsiFile file, |
| @NotNull IndexPattern pattern, |
| int startOffset, |
| int endOffset) { |
| final SearchParameters parameters = new SearchParameters(file, pattern, new TextRange(startOffset, endOffset)); |
| return INDEX_PATTERN_SEARCH_INSTANCE.createQuery(parameters); |
| } |
| |
| /** |
| * Returns a query which can be used to process occurrences of any pattern from the |
| * specified provider in the specified file. The query is executed by parsing the |
| * contents of the file. |
| * |
| * @param file the file in which occurrences should be searched. |
| * @param patternProvider the provider the patterns from which are searched. |
| * @return the query instance. |
| */ |
| @NotNull |
| public static Query<IndexPatternOccurrence> search(@NotNull PsiFile file, @NotNull IndexPatternProvider patternProvider) { |
| final SearchParameters parameters = new SearchParameters(file, patternProvider); |
| return INDEX_PATTERN_SEARCH_INSTANCE.createQuery(parameters); |
| } |
| |
| /** |
| * Returns a query which can be used to process occurrences of any pattern from the |
| * specified provider in the specified text range. The query is executed by parsing the |
| * contents of the file. |
| * |
| * @param file the file in which occurrences should be searched. |
| * @param patternProvider the provider the patterns from which are searched. |
| * @param startOffset the start offset of the range to search. |
| * @param endOffset the end offset of the range to search. |
| * @return the query instance. |
| */ |
| @NotNull |
| public static Query<IndexPatternOccurrence> search(@NotNull PsiFile file, @NotNull IndexPatternProvider patternProvider, |
| int startOffset, int endOffset) { |
| final SearchParameters parameters = new SearchParameters(file, patternProvider, new TextRange(startOffset, endOffset)); |
| return INDEX_PATTERN_SEARCH_INSTANCE.createQuery(parameters); |
| } |
| |
| /** |
| * Returns the number of occurrences of any pattern from the specified provider |
| * in the specified file. The returned value is taken from the index, and the file |
| * is not parsed. |
| * |
| * @param file the file in which occurrences should be searched. |
| * @param patternProvider the provider the patterns from which are searched. |
| * @return the number of pattern occurrences. |
| */ |
| public static int getOccurrencesCount(@NotNull PsiFile file, @NotNull IndexPatternProvider patternProvider) { |
| return INDEX_PATTERN_SEARCH_INSTANCE.getOccurrencesCountImpl(file, patternProvider); |
| } |
| |
| /** |
| * Returns the number of occurrences of the specified pattern |
| * in the specified file. The returned value is taken from the index, and the file |
| * is not parsed. |
| * |
| * @param file the file in which occurrences should be searched. |
| * @param pattern the pattern to search for. |
| * @return the number of pattern occurrences. |
| */ |
| public static int getOccurrencesCount(@NotNull PsiFile file, @NotNull IndexPattern pattern) { |
| return INDEX_PATTERN_SEARCH_INSTANCE.getOccurrencesCountImpl(file, pattern); |
| } |
| |
| protected abstract int getOccurrencesCountImpl(@NotNull PsiFile file, @NotNull IndexPatternProvider provider); |
| protected abstract int getOccurrencesCountImpl(@NotNull PsiFile file, @NotNull IndexPattern pattern); |
| } |