major simplifications to Iterator api
[org.ibex.mail.git] / src / org / ibex / mail / target / Mailbox.java
index dbc91bf..8ad3c14 100644 (file)
@@ -28,8 +28,8 @@ public abstract class Mailbox extends JS.Obj implements Target {
     /** phantom mailboxes merely contain others; like the alt.binaries in alt.binaries.warez */
     public abstract boolean          phantom();
     public abstract Mailbox.Iterator iterator(Query q);
-    public abstract void             add(Message message);
-    public abstract void             add(Message message, int flags);
+
+    public abstract void             insert(Message message, int flags);
     public abstract void             move(Query q, Mailbox dest);
     public abstract void             copy(Query q, Mailbox dest);
     public abstract int              count(Query q);
@@ -39,10 +39,9 @@ public abstract class Mailbox extends JS.Obj implements Target {
     public abstract Mailbox          slash(String name, boolean create);
     public abstract String[]         children();
 
-
     // Thunks ////////////////////////////////////////////////////////////////////////////
 
-    public          void             accept(Message m) { add(m); }
+    public          void             accept(Message m) { insert(m, Flag.RECENT); }
     public          Mailbox.Iterator iterator() { return iterator(Query.all()); }
 
 
@@ -55,60 +54,20 @@ public abstract class Mailbox extends JS.Obj implements Target {
     public static abstract class Default extends Mailbox {
         public Mailbox.Iterator iterator(Query q) { return new Mailbox.Iterator.QueryIterator(q, this); }
         public boolean phantom() { return false; }
-        public void copy(Query q, Mailbox dest) { for(Mailbox.Iterator it = iterator(q); it.next();) dest.add(it.cur()); }
+        public void copy(Query q, Mailbox dest) { for(Mailbox.Iterator it = iterator(q); it.next();) dest.insert(it.cur(), it.getFlags()); }
         public int count(Query q) { int count = 0; for(Mailbox.Iterator it = iterator(q); it.next();) count++; return count; }
         public void rename(String newName) { throw new MailException("not supported"); }
         public void  destroy(boolean recursive) { throw new MailException("not supported"); }
         public Mailbox slash(String name, boolean create) { return null; }
         public String[] children() { return new String[] { }; }
         public void move(Query q, Mailbox dest) {
-            for(Mailbox.Iterator it = iterator(q);it.next();) { dest.add(it.cur()); it.delete(); }
+            for(Mailbox.Iterator it = iterator(q);it.next();) { dest.insert(it.cur(), it.getFlags()); it.delete(); }
         }
         public static abstract class Iterator implements Mailbox.Iterator {
-            public boolean seen() { return false; }
-            public boolean deleted() { return false; }
-            public boolean flagged() { return false; }
-            public boolean draft() { return false; }
-            public boolean answered() { return false; }
-            public boolean recent() { return false; }
-            public void    seen(boolean on) { }
-            public void    deleted(boolean on) { }
-            public void    flagged(boolean on) { }
-            public void    draft(boolean on) { }
-            public void    answered(boolean on) { }
-            public void    recent(boolean on) { }
-            public void    set(String key, String val) { throw new MailException("not supported"); }
-            public String  get(String key) { throw new MailException("not supported"); }
             public int     nntpNumber() { throw new MailException("not supported"); }
-            public int flags() {
-                return 
-                    (deleted() ? Flag.DELETED : 0) |
-                    (seen() ? Flag.SEEN : 0) |
-                    (answered() ? Flag.ANSWERED : 0) |
-                    (draft() ? Flag.DRAFT : 0) |
-                    (recent() ? Flag.RECENT : 0);
-            }
-            public void addFlags(int flags) {
-                if ((flags & Flag.DELETED) == Flag.DELETED) deleted(true);
-                if ((flags & Flag.SEEN) == Flag.SEEN) seen(true);
-                if ((flags & Flag.FLAGGED) == Flag.FLAGGED) flagged(true);
-                if ((flags & Flag.DRAFT) == Flag.DRAFT) draft(true);
-                if ((flags & Flag.RECENT) == Flag.RECENT) recent(true);
-            }
-            public void removeFlags(int flags) {
-                if ((flags & Flag.DELETED) == Flag.DELETED) deleted(false);
-                if ((flags & Flag.SEEN) == Flag.SEEN) seen(false);
-                if ((flags & Flag.FLAGGED) == Flag.FLAGGED) flagged(false);
-                if ((flags & Flag.DRAFT) == Flag.DRAFT) draft(false);
-                if ((flags & Flag.RECENT) == Flag.RECENT) recent(false);
-            }
-            public void setFlags(int flags) {
-                if ((flags & Flag.DELETED) == Flag.DELETED) deleted(true); else deleted(false);
-                if ((flags & Flag.SEEN) == Flag.SEEN) seen(true); else seen(false);
-                if ((flags & Flag.FLAGGED) == Flag.FLAGGED) flagged(true); else flagged(false);
-                if ((flags & Flag.DRAFT) == Flag.DRAFT) draft(true); else draft(false);
-                if ((flags & Flag.RECENT) == Flag.RECENT) recent(true); else recent(false);
-            }
+            public int     getFlags() { return 0; }
+            public boolean getFlag(int flag) { return false; }
+            public void    setFlag(int flag, boolean set) { throw new RuntimeException("not implemented"); }
         }
     }
 
@@ -141,27 +100,9 @@ public abstract class Mailbox extends JS.Obj implements Target {
          */
         public abstract int     nntpNumber();
 
-        public abstract void    set(String key, String val);
-        public abstract String  get(String key);
-
-        public abstract boolean seen();
-        public abstract boolean deleted();
-        public abstract boolean flagged();
-        public abstract boolean draft();
-        public abstract boolean answered();
-        public abstract boolean recent();
-
-        public abstract void    seen(boolean on);
-        public abstract void    deleted(boolean on);
-        public abstract void    flagged(boolean on);
-        public abstract void    draft(boolean on);
-        public abstract void    answered(boolean on);
-        public abstract void    recent(boolean on);
-
-        public abstract int     flags();
-        public abstract void    addFlags(int flags);
-        public abstract void    removeFlags(int flags);
-        public abstract void    setFlags(int flags);
+        public abstract int     getFlags();
+        public abstract boolean getFlag(int flag);
+        public abstract void    setFlag(int flag, boolean set);
 
         public static class Wrapper implements Iterator {
             private Iterator it;
@@ -170,27 +111,12 @@ public abstract class Mailbox extends JS.Obj implements Target {
             public Headers head() { return it.head(); }
             public boolean next() { return it.next(); }
             public int     uid() { return it.uid(); }
-            public int     flags() { return it.flags(); }
             public int     nntpNumber() { return it.nntpNumber(); }
             public int     imapNumber() { return it.imapNumber(); }
-            public void    set(String key, String val) { it.set(key, val); }
-            public String  get(String key) { return it.get(key); }
             public void    delete() { it.delete(); }
-            public boolean seen() { return it.seen(); }
-            public boolean deleted() { return it.deleted(); }
-            public boolean flagged() { return it.flagged(); }
-            public boolean draft() { return it.draft(); }
-            public boolean answered() { return it.answered(); }
-            public boolean recent() { return it.recent(); }
-            public void    seen(boolean on) { it.seen(on); }
-            public void    deleted(boolean on) { it.deleted(on); }
-            public void    flagged(boolean on) { it.flagged(on); }
-            public void    draft(boolean on) { it.draft(on); }
-            public void    answered(boolean on) { it.answered(on); }
-            public void    recent(boolean on) { it.recent(on); }
-            public void    addFlags(int flags) { it.addFlags(flags); }
-            public void    removeFlags(int flags) { it.removeFlags(flags); }
-            public void    setFlags(int flags) { it.setFlags(flags); }
+            public int     getFlags() { return it.getFlags(); }
+            public boolean getFlag(int flag) { return it.getFlag(flag); }
+            public void    setFlag(int flag, boolean set) { it.setFlag(flag, set); }
         }
 
         class QueryIterator extends Mailbox.Iterator.Wrapper {
@@ -207,24 +133,9 @@ public abstract class Mailbox extends JS.Obj implements Target {
             public Headers head() { return null; }
             public boolean next() { return false; }
             public int     uid() { return 0; }
-            public int     flags() { return 0; }
+            public void    delete() { }
             public int     imapNumber() { return 0; }
             public int     nntpNumber() { throw new RuntimeException("this mailbox does not keep article numbers"); }
-            public void    set(String key, String val) { }
-            public String  get(String key) { return null; }
-            public void    delete() { }
-            public boolean seen() { return false; }
-            public boolean deleted() { return false; }
-            public boolean flagged() { return false; }
-            public boolean draft() { return false; }
-            public boolean answered() { return false; }
-            public boolean recent() { return false; }
-            public void    seen(boolean on) { }
-            public void    deleted(boolean on) { }
-            public void    flagged(boolean on) { }
-            public void    draft(boolean on) { }
-            public void    answered(boolean on) { }
-            public void    recent(boolean on) { }
         }
     }
 
@@ -236,6 +147,8 @@ public abstract class Mailbox extends JS.Obj implements Target {
         public static final int DRAFT    = 0x0008;
         public static final int ANSWERED = 0x0010;
         public static final int RECENT   = 0x0020;
+        public static final int[] all = new int[] { DELETED, SEEN, FLAGGED, DRAFT, ANSWERED, RECENT };
+        public static final int defaultFlags = RECENT;
     }
 
     public static class MailboxWrapper extends Mailbox {
@@ -245,8 +158,7 @@ public abstract class Mailbox extends JS.Obj implements Target {
 
         public boolean          phantom() { return m.phantom(); }
         public Mailbox.Iterator iterator(Query q) { return m.iterator(q); }
-        public void             add(Message message) { m.add(message); }
-        public void             add(Message message, int flags) { m.add(message, flags); }
+        public void             insert(Message message, int flags) { m.insert(message, flags); }
         public void             move(Query q, Mailbox dest) { m.move(q, dest); }
         public void             copy(Query q, Mailbox dest) { m.copy(q, dest); }
         public int              count(Query q) { return m.count(q); }