Statistics
| Revision:

root / branches / v2_0_0_prep / libraries / libFMap_data / src / org / gvsig / fmap / data / feature / spi / index / FeatureIndexProvider.java @ 24248

History | View | Annotate | Download (3.07 KB)

1
/* gvSIG. Geographic Information System of the Valencian Government
2
*
3
* Copyright (C) 2007-2008 Infrastructures and Transports Department
4
* of the Valencian Government (CIT)
5
* 
6
* This program is free software; you can redistribute it and/or
7
* modify it under the terms of the GNU General Public License
8
* as published by the Free Software Foundation; either version 2
9
* of the License, or (at your option) any later version.
10
* 
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
* GNU General Public License for more details.
15
* 
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, write to the Free Software
18
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, 
19
* MA  02110-1301, USA.
20
* 
21
*/
22

    
23
/*
24
* AUTHORS (In addition to CIT):
25
* 2008 {{Company}}   {{Task}}
26
*/
27
 
28

    
29
package org.gvsig.fmap.data.feature.spi.index;
30

    
31
import java.util.List;
32

    
33
import org.gvsig.fmap.data.exceptions.InitializeException;
34
import org.gvsig.fmap.data.feature.exceptions.FeatureIndexException;
35
import org.gvsig.fmap.data.feature.spi.FeatureReferenceProviderServices;
36

    
37

    
38
public interface FeatureIndexProvider {
39
        
40
        /** Sets the IndexProviderServices that will provide application services to this index provider */
41
        public void setFeatureIndexProviderServices(FeatureIndexProviderServices services);
42
        
43
        /** Initializes this provider */
44
        public void initialize() throws InitializeException;
45

    
46
        /** Inserts a value into the index */
47
        public void insert(Object value, FeatureReferenceProviderServices fref);
48

    
49
        /** Deletes a value from the index, given its reference */
50
        public void delete(Object value, FeatureReferenceProviderServices fref);
51
        
52
        /** Performs a search in the index and returns a list with all the values that match the given value 
53
         * @throws FeatureIndexException TODO*/
54
        public List match(Object value) throws FeatureIndexException;
55
        
56
        /** Performs a search in the index and returns a list with the values that intersect with the given interval 
57
         * @throws FeatureIndexException TODO*/
58
        public List range(Object value1, Object value2) throws FeatureIndexException;
59
        
60
        /** Performs a search in the index and returns the list of up to n values which are nearest to the given value. */
61
        public List nearest(int count, Object value) throws FeatureIndexException;        
62

    
63
        /** Performs a search in the index and returns the list of up to n values which are nearest to the given value and within the distance specified by tolerance. */
64
        public List nearest(int count, Object value, double tolerance) throws FeatureIndexException;        
65
        
66
        
67
        /** Returns true if the provider supports the match function */
68
        public boolean isMatchSupported();
69
        /** Returns true if the provider supports the range function */
70
        public boolean isRangeSupported();
71
        /** Returns true if the provider supports the nearest function */
72
        public boolean isNearestSupported();
73
        /** Returns true if the provider supports the nearest with tolerance function */
74
        public boolean isNearestToleranceSupported();
75

    
76
}
77