Statistics
| Revision:

svn-gvsig-desktop / trunk / libraries / libFMap / src / com / iver / cit / gvsig / fmap / edition / MemoryExpansionFile.java @ 3996

History | View | Annotate | Download (4.18 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 *
19
 * For more information, contact:
20
 *
21
 *  Generalitat Valenciana
22
 *   Conselleria d'Infraestructures i Transport
23
 *   Av. Blasco Ib??ez, 50
24
 *   46010 VALENCIA
25
 *   SPAIN
26
 *
27
 *      +34 963862235
28
 *   gvsig@gva.es
29
 *      www.gvsig.gva.es
30
 *
31
 *    or
32
 *
33
 *   IVER T.I. S.A
34
 *   Salamanca 50
35
 *   46005 Valencia
36
 *   Spain
37
 *
38
 *   +34 963163400
39
 *   dac@iver.es
40
 */
41
package com.iver.cit.gvsig.fmap.edition;
42

    
43
import com.iver.cit.gvsig.fmap.core.IFeature;
44
import com.iver.cit.gvsig.fmap.core.IGeometry;
45
import com.iver.cit.gvsig.fmap.core.IRow;
46

    
47
import java.io.IOException;
48

    
49
import java.util.ArrayList;
50
import java.util.BitSet;
51
import java.util.HashMap;
52
import java.util.Iterator;
53

    
54

    
55
/**
56
 * Implementaci?n de prueba en memoria de ExpansionFile.
57
 *
58
 * @author Vicente Caballero Navarro
59
 */
60
public class MemoryExpansionFile implements ExpansionFile {
61
        ArrayList rows = new ArrayList();
62
        //BitSet invalidRows = new BitSet();
63
        /**
64
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#addRow(IRow)
65
         */
66
        public int addRow(IRow row) throws IOException {
67
                IRowEdited edRow = new DefaultRowEdited(row,
68
                                IRowEdited.STATUS_ADDED);
69
                rows.add(edRow);
70

    
71
                return rows.size() - 1;
72
        }
73

    
74
        /**
75
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#modifyRow(int,
76
         *                 IRow)
77
         */
78
        public int modifyRow(int index, IRow row) throws IOException {
79
                /*if (invalidRows.get(index)) {
80
                        throw new RuntimeException(
81
                                "Se ha intentado modificar una geometr?a que ha sido borrada anteriormente");
82
                }
83
*/
84
                //invalidateRow(index);
85
                IRowEdited edRow = new DefaultRowEdited(row,
86
                                IRowEdited.STATUS_MODIFIED);
87

    
88
                rows.add(edRow);
89

    
90
                return rows.size() - 1;
91
        }
92

    
93
        /**
94
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#getRow(int)
95
         */
96
        public IRowEdited getRow(int index) throws IOException {
97
                /*if (invalidRows.get(index)) {
98
                        return null;
99
                }
100
*/
101
                return (IRowEdited) rows.get(index);
102
        }
103

    
104
        /**
105
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#invalidateRow(int)
106
         */
107
        /*public void invalidateRow(int index) {
108
                invalidRows.set(index, true);
109
        }
110
*/
111
        /**
112
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#compact()
113
         */
114
        public void compact(HashMap relations) {
115
        /*        ArrayList geoAux = new ArrayList();
116
                Iterator iter = relations.keySet().iterator();
117
                HashMap aux = new HashMap();
118
                int n = 0;
119

120
                while (iter.hasNext()) {
121
                        Integer virtualIndex = (Integer) iter.next();
122
                        Integer expansionIndex = (Integer) relations.get(virtualIndex);
123

124
                        if (!invalidRows.get(expansionIndex.intValue())){
125
                                geoAux.add(rows.get(expansionIndex.intValue()));
126
                                aux.put(new Integer(n), new Integer(geoAux.size()-1));
127
                                n++;
128
                        }
129
                }
130

131
                invalidRows.clear();
132
                rows = geoAux;
133
                relations.clear();
134
                relations.putAll(aux);
135
*/
136

    
137
        }
138

    
139
        /**
140
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#getRowCount()
141
         */
142
        /*public int getRowCount() {
143
                return rows.size() - invalidRows.cardinality();
144
        }
145
*/
146
        public void deleteLastRow() {
147
                //invalidRows.set(rows.size()-1,false);
148
                rows.remove(rows.size()-1);
149

    
150
        }
151

    
152
        public void open() throws IOException {
153
                // TODO Auto-generated method stub
154

    
155
        }
156

    
157
        public void close() throws IOException {
158
                // TODO Auto-generated method stub
159

    
160
        }
161

    
162
        /* (non-Javadoc)
163
         * @see com.iver.cit.gvsig.fmap.edition.ExpansionFile#validateRow(int)
164
         */
165
        /*public void validateRow(int previousExpansionFileIndex) {
166
                invalidRows.set(previousExpansionFileIndex, false);
167
        }
168

169
        public BitSet getInvalidRows() {
170
                return invalidRows;
171
        }*/
172
}