Lines 1-167
Link Here
|
1 |
/* |
|
|
2 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. |
3 |
* |
4 |
* Copyright 1997-2010 Oracle and/or its affiliates. All rights reserved. |
5 |
* |
6 |
* Oracle and Java are registered trademarks of Oracle and/or its affiliates. |
7 |
* Other names may be trademarks of their respective owners. |
8 |
* |
9 |
* The contents of this file are subject to the terms of either the GNU |
10 |
* General Public License Version 2 only ("GPL") or the Common |
11 |
* Development and Distribution License("CDDL") (collectively, the |
12 |
* "License"). You may not use this file except in compliance with the |
13 |
* License. You can obtain a copy of the License at |
14 |
* http://www.netbeans.org/cddl-gplv2.html |
15 |
* or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the |
16 |
* specific language governing permissions and limitations under the |
17 |
* License. When distributing the software, include this License Header |
18 |
* Notice in each file and include the License file at |
19 |
* nbbuild/licenses/CDDL-GPL-2-CP. Oracle designates this |
20 |
* particular file as subject to the "Classpath" exception as provided |
21 |
* by Oracle in the GPL Version 2 section of the License file that |
22 |
* accompanied this code. If applicable, add the following below the |
23 |
* License Header, with the fields enclosed by brackets [] replaced by |
24 |
* your own identifying information: |
25 |
* "Portions Copyrighted [year] [name of copyright owner]" |
26 |
* |
27 |
* Contributor(s): |
28 |
* |
29 |
* The Original Software is NetBeans. The Initial Developer of the Original |
30 |
* Software is Sun Microsystems, Inc. Portions Copyright 2004-2007 Sun |
31 |
* Microsystems, Inc. All Rights Reserved. |
32 |
* |
33 |
* If you wish your version of this file to be governed by only the CDDL |
34 |
* or only the GPL Version 2, indicate your decision by adding |
35 |
* "[Contributor] elects to include this software in this distribution |
36 |
* under the [CDDL or GPL Version 2] license." If you do not indicate a |
37 |
* single choice of license, a recipient has the option to distribute |
38 |
* your version of this file under either the CDDL, the GPL Version 2 or |
39 |
* to extend the choice of license to its licensees as provided above. |
40 |
* However, if you add GPL Version 2 code and therefore, elected the GPL |
41 |
* Version 2 license, then the option applies only if the new code is |
42 |
* made subject to such option by the copyright holder. |
43 |
*/ |
44 |
package org.netbeans.api.search.provider.impl; |
45 |
|
46 |
import java.util.Iterator; |
47 |
import java.util.NoSuchElementException; |
48 |
import java.util.concurrent.atomic.AtomicBoolean; |
49 |
import org.netbeans.api.search.SearchScopeOptions; |
50 |
import org.netbeans.api.search.provider.SearchInfo; |
51 |
import org.netbeans.api.search.provider.SearchListener; |
52 |
import org.openide.filesystems.FileObject; |
53 |
|
54 |
/** |
55 |
* |
56 |
* @author Marian Petras |
57 |
*/ |
58 |
public class CompoundSearchIterator extends AbstractFileObjectIterator { |
59 |
|
60 |
/** |
61 |
* |
62 |
*/ |
63 |
private final SearchInfo[] elements; |
64 |
/** |
65 |
* |
66 |
*/ |
67 |
private int elementIndex; |
68 |
/** |
69 |
* |
70 |
*/ |
71 |
private Iterator<FileObject> elementIterator = null; |
72 |
/** |
73 |
* |
74 |
*/ |
75 |
private FileObject nextObject; |
76 |
/** |
77 |
* |
78 |
*/ |
79 |
private boolean upToDate; |
80 |
private SearchScopeOptions options; |
81 |
private SearchListener listener; |
82 |
private AtomicBoolean terminated; |
83 |
|
84 |
/** |
85 |
* Creates a new instance of |
86 |
* <code>CompoundSearchIterator</code>. |
87 |
* |
88 |
* @param elements elements of the compound iterator |
89 |
* @exception java.lang.IllegalArgumentException if the argument is |
90 |
* <code>null</code> |
91 |
*/ |
92 |
public CompoundSearchIterator(SearchInfo[] elements, |
93 |
SearchScopeOptions options, SearchListener listener, |
94 |
AtomicBoolean terminated) { |
95 |
|
96 |
if (elements == null) { |
97 |
throw new IllegalArgumentException("Elements are null"); //NOI18N |
98 |
} else if (options == null) { |
99 |
throw new IllegalArgumentException("Options are null"); //NOI18N |
100 |
} |
101 |
|
102 |
this.options = options; |
103 |
|
104 |
if (elements.length == 0) { |
105 |
this.elements = null; |
106 |
elementIndex = 0; |
107 |
upToDate = true; //hasNext() returns always false |
108 |
} else { |
109 |
this.elements = elements; |
110 |
upToDate = false; |
111 |
} |
112 |
this.listener = listener; |
113 |
this.terminated = terminated; |
114 |
} |
115 |
|
116 |
/** |
117 |
*/ |
118 |
@Override |
119 |
public boolean hasNext() { |
120 |
if (!upToDate) { |
121 |
update(); |
122 |
} |
123 |
return (elements != null) && (elementIndex < elements.length); |
124 |
} |
125 |
|
126 |
/** |
127 |
*/ |
128 |
@Override |
129 |
public FileObject next() { |
130 |
if (!hasNext()) { |
131 |
throw new NoSuchElementException(); |
132 |
} |
133 |
|
134 |
upToDate = false; |
135 |
return nextObject; |
136 |
} |
137 |
|
138 |
/** |
139 |
*/ |
140 |
private void update() { |
141 |
assert upToDate == false; |
142 |
|
143 |
if (elementIterator == null) { |
144 |
elementIterator = elements[elementIndex = 0].getFilesToSearch(options, |
145 |
listener, terminated).iterator(); |
146 |
} |
147 |
|
148 |
while (!elementIterator.hasNext()) { |
149 |
elements[elementIndex] = null; |
150 |
|
151 |
if (++elementIndex == elements.length) { |
152 |
break; |
153 |
} |
154 |
elementIterator = elements[elementIndex].getFilesToSearch(options, |
155 |
listener, terminated).iterator(); |
156 |
} |
157 |
|
158 |
if (elementIndex < elements.length) { |
159 |
nextObject = elementIterator.next(); |
160 |
} else { |
161 |
elementIterator = null; |
162 |
nextObject = null; |
163 |
} |
164 |
|
165 |
upToDate = true; |
166 |
} |
167 |
} |