KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > apache > commons > discovery > resource > names > NameDiscoverers


1 /*
2  * ====================================================================
3  *
4  * The Apache Software License, Version 1.1
5  *
6  * Copyright (c) 1999-2002 The Apache Software Foundation. All rights
7  * reserved.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright
14  * notice, this list of conditions and the following disclaimer.
15  *
16  * 2. Redistributions in binary form must reproduce the above copyright
17  * notice, this list of conditions and the following disclaimer in
18  * the documentation and/or other materials provided with the
19  * distribution.
20  *
21  * 3. The end-user documentation included with the redistribution, if
22  * any, must include the following acknowlegement:
23  * "This product includes software developed by the
24  * Apache Software Foundation (http://www.apache.org/)."
25  * Alternately, this acknowlegement may appear in the software itself,
26  * if and wherever such third-party acknowlegements normally appear.
27  *
28  * 4. The names "The Jakarta Project", "Commons", and "Apache Software
29  * Foundation" must not be used to endorse or promote products derived
30  * from this software without prior written permission. For written
31  * permission, please contact apache@apache.org.
32  *
33  * 5. Products derived from this software may not be called "Apache"
34  * nor may "Apache" appear in their names without prior written
35  * permission of the Apache Group.
36  *
37  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
38  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
39  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
40  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
41  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
42  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
43  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
44  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
45  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
46  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
47  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
48  * SUCH DAMAGE.
49  * ====================================================================
50  *
51  * This software consists of voluntary contributions made by many
52  * individuals on behalf of the Apache Software Foundation. For more
53  * information on the Apache Software Foundation, please see
54  * <http://www.apache.org/>.
55  *
56  */

57
58 package org.apache.commons.discovery.resource.names;
59
60 import java.util.Vector JavaDoc;
61
62 import org.apache.commons.discovery.ResourceNameDiscover;
63 import org.apache.commons.discovery.ResourceNameListener;
64 import org.apache.commons.discovery.log.DiscoveryLogFactory;
65 import org.apache.commons.logging.Log;
66
67
68 /**
69  * Holder for multiple ResourceNameDiscover instances.
70  * The result is the union of the results from each
71  * (not a chained sequence, where results feed the next in line.
72  *
73  * @author Richard A. Sitze
74  */

75 public class NameDiscoverers extends ResourceNameDiscoverImpl
76     implements ResourceNameDiscover, ResourceNameListener
77 {
78     private static Log log = DiscoveryLogFactory.newLog(NameDiscoverers.class);
79     public static void setLog(Log _log) {
80         log = _log;
81     }
82
83     private Vector JavaDoc discoverers = new Vector JavaDoc(); // ResourceNameDiscover
84

85     /**
86      * Construct a new resource name discoverer
87      */

88     public NameDiscoverers() {
89     }
90     
91     /**
92      * Specify an additional class loader to be used in searching.
93      * The order of loaders determines the order of the result.
94      * It is recommended to add the most specific loaders first.
95      */

96     public void addResourceNameDiscover(ResourceNameDiscover discover) {
97         if (discover != null) {
98             discover.setListener(getListener());
99             discoverers.addElement(discover);
100         }
101     }
102     
103     public void setListener(ResourceNameListener listener) {
104         super.setListener(listener);
105         for (int i = 0; i < discoverers.size(); i++) {
106             ((ResourceNameDiscover)discoverers.get(i)).setListener(listener);
107         }
108     }
109     
110     protected ResourceNameDiscover getResourceNameDiscover(int idx) {
111         return (ResourceNameDiscover)discoverers.get(idx);
112     }
113
114     protected int size() {
115         return discoverers.size();
116     }
117
118     /**
119      * Set of results of all discoverers.
120      *
121      * @return ResourceIterator
122      */

123     public boolean find(String JavaDoc resourceName) {
124         if (log.isDebugEnabled())
125             log.debug("find: resourceName='" + resourceName + "'");
126
127         for (int i = 0; i < discoverers.size(); i++) {
128             if (!((ResourceNameDiscover)discoverers.get(i)).find(resourceName)) {
129                 return false;
130             }
131         }
132         return true;
133     }
134     
135     public boolean found(String JavaDoc resourceName) {
136         return find(resourceName);
137     }
138 }
139
Popular Tags