annotate servlet/src/digilib/io/DocuDirCache.java @ 270:b21915a3fc24

Servlet version 1.21b3 - searching in directories got faster (real binarySearch now!) - cached file lists get disposed - some code cleaning (Map types instead of HashMap)
author robcast
date Tue, 12 Oct 2004 16:06:43 +0200
parents beed92ee6022
children 87dca7119596
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
1 /*
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
2 * DocuDirCache.java
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
3 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
4 * Digital Image Library servlet components
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
5 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
6 * Copyright (C) 2003 Robert Casties (robcast@mail.berlios.de)
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
7 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
8 * This program is free software; you can redistribute it and/or modify it
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
9 * under the terms of the GNU General Public License as published by the Free
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
10 * Software Foundation; either version 2 of the License, or (at your option)
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
11 * any later version.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
12 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
13 * Please read license.txt for the full details. A copy of the GPL may be found
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
14 * at http://www.gnu.org/copyleft/lgpl.html
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
15 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
16 * You should have received a copy of the GNU General Public License along with
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
17 * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
18 * Place, Suite 330, Boston, MA 02111-1307 USA
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
19 *
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
20 * Created on 03.03.2003
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
21 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
22
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
23 package digilib.io;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
24
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
25 import java.io.File;
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
26 import java.util.HashMap;
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
27 import java.util.Iterator;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
28 import java.util.LinkedList;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
29 import java.util.List;
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
30 import java.util.Map;
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
31
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
32 import org.apache.log4j.Logger;
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
33
259
beed92ee6022 Servlet version 1.21b1
robcast
parents: 246
diff changeset
34 import digilib.servlet.DigilibConfiguration;
beed92ee6022 Servlet version 1.21b1
robcast
parents: 246
diff changeset
35
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
36 /**
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
37 * @author casties
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
38 */
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
39 public class DocuDirCache {
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
40
181
afe7ff98bb71 Servlet version 1.18b1
robcast
parents: 176
diff changeset
41 /** general logger for this class */
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
42 Logger logger = Logger.getLogger(this.getClass());
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
43 /** HashMap of directories */
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
44 Map map = null;
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
45 /** names of base directories */
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
46 String[] baseDirNames = null;
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
47 /** array of allowed file classes (image/text) */
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
48 private int[] fileClasses = null;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
49 /** number of files in the whole cache (approximate) */
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
50 long numFiles = 0;
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
51 /** number of cache hits */
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
52 long hits = 0;
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
53 /** number of cache misses */
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
54 long misses = 0;
259
beed92ee6022 Servlet version 1.21b1
robcast
parents: 246
diff changeset
55 /** use safe (but slow) indexing */
beed92ee6022 Servlet version 1.21b1
robcast
parents: 246
diff changeset
56 boolean safeDirIndex = false;
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
57 /** the root directory element */
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
58 public static Directory ROOT = null;
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
59
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
60 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
61 * Constructor with array of base directory names and file classes.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
62 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
63 * @param bd
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
64 * base directory names
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
65 */
259
beed92ee6022 Servlet version 1.21b1
robcast
parents: 246
diff changeset
66 public DocuDirCache(String[] bd, int[] fileClasses, DigilibConfiguration dlConfig) {
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
67 baseDirNames = bd;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
68 map = new HashMap();
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
69 this.fileClasses = fileClasses;
259
beed92ee6022 Servlet version 1.21b1
robcast
parents: 246
diff changeset
70 safeDirIndex = dlConfig.getAsBoolean("safe-dir-index");
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
71 }
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
72 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
73 * Constructor with array of base directory names.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
74 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
75 * @param bd
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
76 * base directory names
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
77 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
78 public DocuDirCache(String[] bd) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
79 baseDirNames = bd;
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
80 map = new HashMap();
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
81 // default file class is CLASS_IMAGE
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
82 fileClasses = new int[1];
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
83 fileClasses[0] = FileOps.CLASS_IMAGE;
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
84 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
85
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
86 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
87 * The number of directories in the cache.
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
88 *
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
89 * @return
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
90 */
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
91 public int size() {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
92 return (map != null) ? map.size() : 0;
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
93 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
94
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
95 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
96 * Add a DocuDirectory to the cache.
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
97 *
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
98 * @param newdir
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
99 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
100 public void put(DocuDirectory newdir) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
101 String s = newdir.getDirName();
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
102 if (map.containsKey(s)) {
197
bb4ed821d06e Servlet version 1.18b6
robcast
parents: 187
diff changeset
103 logger.warn("Duplicate key in DocuDirCache.put -- ignoring!");
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
104 } else {
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
105 map.put(s, newdir);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
106 numFiles += newdir.size();
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
107 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
108 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
109
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
110 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
111 * Add a directory to the cache and check its parents.
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
112 *
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
113 * @param newDir
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
114 */
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
115 public void putDir(DocuDirectory newDir) {
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
116 put(newDir);
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
117 String parent = FileOps.parent(newDir.getDirName());
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
118 if (parent != "") {
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
119 // check the parent in the cache
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
120 DocuDirectory pd = (DocuDirectory) map.get(parent);
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
121 if (pd == null) {
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
122 // the parent is unknown
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
123 pd = new DocuDirectory(parent, this);
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
124 putDir(pd);
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
125 }
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
126 newDir.setParent(pd);
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
127 }
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
128 }
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
129
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
130 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
131 * Get a list with all children of a directory.
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
132 *
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
133 * Returns a List of DocuDirectory's. Returns an empty List if the
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
134 * directory has no children. If recurse is false then only direct children
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
135 * are returned.
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
136 *
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
137 * @param dirname
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
138 * @param recurse
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
139 * find all children and their children.
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
140 * @return
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
141 */
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
142 public List getChildren(String dirname, boolean recurse) {
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
143 List l = new LinkedList();
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
144 for (Iterator i = map.keySet().iterator(); i.hasNext();) {
209
f8c82fea551a Servlet version 1.18b9 -- cleanup and bugfixes
robcast
parents: 197
diff changeset
145 String n = (String) i.next();
f8c82fea551a Servlet version 1.18b9 -- cleanup and bugfixes
robcast
parents: 197
diff changeset
146 DocuDirectory dd = (DocuDirectory) map.get(n);
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
147 if (recurse) {
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
148 if (dd.getDirName().startsWith(dirname)) {
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
149 l.add(dd);
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
150 }
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
151 } else {
270
b21915a3fc24 Servlet version 1.21b3
robcast
parents: 259
diff changeset
152 if (FileOps.parent(dd.getDirName()).equals(dirname)) {
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
153 l.add(dd);
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
154 }
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
155 }
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
156 }
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
157 return l;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
158 }
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
159
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
160 /**
187
b3f9a7f646c5 Servlet version 1.18b3 new Raster servlet
robcast
parents: 181
diff changeset
161 * Returns the DocuDirent with the pathname <code>fn</code> and the
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
162 * index <code>in</code> and the class <code>fc</code>.
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
163 *
187
b3f9a7f646c5 Servlet version 1.18b3 new Raster servlet
robcast
parents: 181
diff changeset
164 * If <code>fn</code> is a file then the corresponding DocuDirent is
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
165 * returned and the index is ignored.
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
166 *
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
167 * @param fn
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
168 * digilib pathname
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
169 * @param in
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
170 * file index
246
aaf6eace011d Servlet version 1.19b4
robcast
parents: 209
diff changeset
171 * @param fc
aaf6eace011d Servlet version 1.19b4
robcast
parents: 209
diff changeset
172 * file class
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
173 * @return
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
174 */
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
175 public DocuDirent getFile(String fn, int in, int fc) {
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
176 DocuDirectory dd;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
177 // file number is 1-based, vector index is 0-based
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
178 int n = in - 1;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
179 // first, assume fn is a directory and look in the cache
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
180 dd = (DocuDirectory) map.get(fn);
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
181 if (dd == null) {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
182 // cache miss
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
183 misses++;
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
184 /*
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
185 * see if it's a directory
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
186 */
152
f4a5cfe37469 Servlet version 1.16a1
robcast
parents: 151
diff changeset
187 File f = new File(baseDirNames[0], fn);
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
188 if (f.isDirectory()) {
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
189 dd = new DocuDirectory(fn, this);
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
190 if (dd.isValid()) {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
191 // add to the cache
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
192 putDir(dd);
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
193 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
194 } else {
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
195 /*
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
196 * maybe it's a file
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
197 */
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
198 // get the parent directory string (like we store it in the
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
199 // cache)
246
aaf6eace011d Servlet version 1.19b4
robcast
parents: 209
diff changeset
200 String d = FileOps.parent(fn);
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
201 // try it in the cache
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
202 dd = (DocuDirectory) map.get(d);
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
203 if (dd == null) {
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
204 // try to read from disk
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
205 dd = new DocuDirectory(d, this);
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
206 if (dd.isValid()) {
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
207 // add to the cache
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
208 putDir(dd);
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
209 } else {
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
210 // invalid path
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
211 return null;
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
212 }
99
226624784fe3 Small bug lead to null pointer exception when directory doesn't exist.
robcast
parents: 91
diff changeset
213 } else {
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
214 // it was not a real cache miss
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
215 misses--;
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
216 }
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
217 // get the file's index
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
218 n = dd.indexOf(f.getName(), fc);
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
219 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
220 } else {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
221 // cache hit
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
222 hits++;
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
223 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
224 dd.refresh();
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
225 if (dd.isValid()) {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
226 try {
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
227 return dd.get(n, fc);
187
b3f9a7f646c5 Servlet version 1.18b3 new Raster servlet
robcast
parents: 181
diff changeset
228 } catch (IndexOutOfBoundsException e) {
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
229 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
230 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
231 return null;
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
232 }
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
233
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
234 /**
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
235 * Returns the DocuDirectory indicated by the pathname <code>fn</code>.
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
236 *
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
237 * If <code>fn</code> is a file then its parent directory is returned.
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
238 *
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
239 * @param fn
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
240 * digilib pathname
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
241 * @return
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
242 */
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
243 public DocuDirectory getDirectory(String fn) {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
244 DocuDirectory dd;
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
245 // first, assume fn is a directory and look in the cache
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
246 dd = (DocuDirectory) map.get(fn);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
247 if (dd == null) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
248 // cache miss
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
249 misses++;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
250 // see if it's a directory
152
f4a5cfe37469 Servlet version 1.16a1
robcast
parents: 151
diff changeset
251 File f = new File(baseDirNames[0], fn);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
252 if (f.isDirectory()) {
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
253 dd = new DocuDirectory(fn, this);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
254 if (dd.isValid()) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
255 // add to the cache
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
256 putDir(dd);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
257 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
258 } else {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
259 // maybe it's a file
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
260 if (f.canRead()) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
261 // try the parent directory in the cache
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
262 dd = (DocuDirectory) map.get(f.getParent());
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
263 if (dd == null) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
264 // try to read from disk
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
265 dd = new DocuDirectory(f.getParent(), this);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
266 if (dd.isValid()) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
267 // add to the cache
151
bc8df0133c04 Servlet version 1.15b1
robcast
parents: 116
diff changeset
268 putDir(dd);
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
269 } else {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
270 // invalid path
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
271 return null;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
272 }
91
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
273 } else {
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
274 // not a real cache miss then
a398fc09ba71 New version 1.8b4.
robcast
parents: 86
diff changeset
275 misses--;
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
276 }
99
226624784fe3 Small bug lead to null pointer exception when directory doesn't exist.
robcast
parents: 91
diff changeset
277 } else {
226624784fe3 Small bug lead to null pointer exception when directory doesn't exist.
robcast
parents: 91
diff changeset
278 // it's not even a file :-(
226624784fe3 Small bug lead to null pointer exception when directory doesn't exist.
robcast
parents: 91
diff changeset
279 return null;
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
280 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
281 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
282 } else {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
283 // cache hit
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
284 hits++;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
285 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
286 dd.refresh();
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
287 if (dd.isValid()) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
288 return dd;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
289 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
290 return null;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
291 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
292
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
293 /**
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
294 * @return String[]
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
295 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
296 public String[] getBaseDirNames() {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
297 return baseDirNames;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
298 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
299
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
300 /**
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
301 * @return long
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
302 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
303 public long getNumFiles() {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
304 return numFiles;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
305 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
306
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
307 /**
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
308 * Sets the baseDirNames.
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
309 *
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
310 * @param baseDirNames
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
311 * The baseDirNames to set
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
312 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
313 public void setBaseDirNames(String[] baseDirNames) {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
314 this.baseDirNames = baseDirNames;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
315 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
316
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
317 /**
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
318 * @return long
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
319 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
320 public long getHits() {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
321 return hits;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
322 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
323
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
324 /**
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
325 * @return long
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
326 */
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
327 public long getMisses() {
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
328 return misses;
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
329 }
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
330
159
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
331 /**
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
332 * @return
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
333 */
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
334 public int[] getFileClasses() {
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
335 return fileClasses;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
336 }
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
337
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
338 /**
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
339 * @param fileClasses
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
340 */
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
341 public void setFileClasses(int[] fileClasses) {
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
342 this.fileClasses = fileClasses;
e743b853efca servlet version 1.16a4
robcast
parents: 152
diff changeset
343 }
176
67ff8c7fecb9 Servlet version 1.17b2
robcast
parents: 159
diff changeset
344
86
997ba69afb81 New version 1.8b1.
robcast
parents:
diff changeset
345 }