// FIXME: should be a File()
public static synchronized MailTree getFileBasedMailbox(String path, boolean create) {
+ if (path.endsWith(".sqlite")) path = path.substring(0, path.length()-".sqlite".length());
try {
MailTree ret = instances.get(path);
if (ret == null) {
- if (!create && !(new File(path).exists())) return null;
- ret = new FileBasedMailbox(new File(path));
- instances.put(path, (FileBasedMailbox)ret);
+ Log.error("n", "no match for " + path + " in " + instances.hashCode());
+ if (new File(path+".sqlite").exists())
+ ret = new SqliteMailbox(path+".sqlite");
+ else {
+ if (!create && !(new File(path).exists())) return null;
+ ret = new FileBasedMailbox(new File(path));
+ }
+ instances.put(path, (MailTree)ret);
+ Log.error("n", "filling " + path + " with " + instances.get(path));
}
return ret;
} catch (Exception e) {
try {
if (files[i].indexOf('.') <= 0) continue;
files[i] = files[i].substring(0, files[i].indexOf('.'));
- int n = Integer.parseInt(files[i]);
- if (n>=uidNext) uidNext = n;
+ try {
+ int n = Integer.parseInt(files[i]);
+ if (n>=uidNext) uidNext = n;
+ } catch (NumberFormatException nfe) { continue; }
} catch(Exception e) { Log.error(this, e); }
}
}
for(int i=0; i<list.length; i++) {
File f = new File(path.getAbsolutePath() + slash + list[i]);
if (f.isDirectory() && f.getName().charAt(0) != '.') vec.addElement(list[i]);
+ if (!f.isDirectory() && f.getName().endsWith(".sqlite"))
+ vec.addElement(list[i].substring(0, list[i].length()-".sqlite".length()));
}
return (String[])vec.copyInto(new String[vec.size()]);
}
if ((flags & Mailbox.Flag.SEEN) == 0) f.setLastModified(MAGIC_DATE);
else if (f.lastModified()==MAGIC_DATE) f.setLastModified(System.currentTimeMillis());
// FIXME: other flags?
+ // FIXME: definitely need DELETED flag in order to do message moves!
}
public Headers head() { return done() ? null : new Headers(new Fountain.File(file())); }
public Message cur() { return Message.newMessage(new Fountain.File(file())); }