KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > Yasna > forum > database > DbForumGroupIterator


1 /**
2  * Copyright (C) 2001 Yasna.com. All rights reserved.
3  *
4  * ===================================================================
5  * The Apache Software License, Version 1.1
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright
15  * notice, this list of conditions and the following disclaimer in
16  * the documentation and/or other materials provided with the
17  * distribution.
18  *
19  * 3. The end-user documentation included with the redistribution,
20  * if any, must include the following acknowledgment:
21  * "This product includes software developed by
22  * Yasna.com (http://www.yasna.com)."
23  * Alternately, this acknowledgment may appear in the software itself,
24  * if and wherever such third-party acknowledgments normally appear.
25  *
26  * 4. The names "Yazd" and "Yasna.com" must not be used to
27  * endorse or promote products derived from this software without
28  * prior written permission. For written permission, please
29  * contact yazd@yasna.com.
30  *
31  * 5. Products derived from this software may not be called "Yazd",
32  * nor may "Yazd" appear in their name, without prior written
33  * permission of Yasna.com.
34  *
35  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38  * DISCLAIMED. IN NO EVENT SHALL YASNA.COM OR
39  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46  * SUCH DAMAGE.
47  * ====================================================================
48  *
49  * This software consists of voluntary contributions made by many
50  * individuals on behalf of Yasna.com. For more information
51  * on Yasna.com, please see <http://www.yasna.com>.
52  */

53
54 package com.Yasna.forum.database;
55
56 import java.util.*;
57 //JDK1.1// import com.sun.java.util.collections.*;
58
import java.sql.*;
59
60 import com.Yasna.util.*;
61 import com.Yasna.forum.*;
62
63 /**
64  * Database implementation to iterate through forumGroups in a Category.
65  */

66 public class DbForumGroupIterator implements Iterator, ListIterator {
67
68     /** DATABASE QUERIES **/
69     private static final String JavaDoc GET_FORUM_GROUPS =
70         "SELECT forumGroupID, creationDate FROM yazdForumGroup WHERE categoryID=? " +
71         "ORDER BY grporder DESC";
72
73     //A reference to the Category object that the iterator was created from.
74
//This is used to load forumGroup objects.
75
private DbCategory category;
76     //maintain an array of forumgroup ids to iterator through.
77
private int [] forumGroups;
78     //points to the current forumgroup id that the user has iterated to.
79
private int currentIndex = -1;
80
81     DbForumFactory factory;
82
83     public DbForumGroupIterator(DbCategory category, DbForumFactory factory)
84     {
85         this.category = category;
86         this.factory = factory;
87         //We don't know how many results will be returned, so store them
88
//in an ArrayList.
89
ArrayList tempForumGroups = new ArrayList();
90         Connection con = null;
91         PreparedStatement pstmt = null;
92         try {
93             con = DbConnectionManager.getConnection();
94             pstmt = con.prepareStatement(GET_FORUM_GROUPS);
95             pstmt.setInt(1,category.getID());
96             ResultSet rs = pstmt.executeQuery();
97
98             while (rs.next()) {
99                 tempForumGroups.add(new Integer JavaDoc(rs.getInt("forumGroupID")));
100             }
101         }
102         catch( SQLException sqle ) {
103             System.err.println("Error in DbForumGroupIterator:constructor()-" + sqle);
104         }
105         finally {
106             try { pstmt.close(); }
107             catch (Exception JavaDoc e) { e.printStackTrace(); }
108             try { con.close(); }
109             catch (Exception JavaDoc e) { e.printStackTrace(); }
110         }
111         forumGroups = new int[tempForumGroups.size()];
112         for (int i=0; i<forumGroups.length; i++) {
113             forumGroups[i] = ((Integer JavaDoc)tempForumGroups.get(i)).intValue();
114         }
115     }
116
117     public void add(Object JavaDoc o) throws UnsupportedOperationException JavaDoc {
118         throw new UnsupportedOperationException JavaDoc();
119     }
120
121     public boolean hasNext() {
122         return (currentIndex+1 < forumGroups.length);
123     }
124
125     public boolean hasPrevious() {
126         return (currentIndex > 0);
127     }
128
129     public Object JavaDoc next() throws java.util.NoSuchElementException JavaDoc {
130         ForumGroup forumGroup = null;
131         currentIndex++;
132         if (currentIndex >= forumGroups.length) {
133             currentIndex--;
134             throw new java.util.NoSuchElementException JavaDoc();
135         }
136         try {
137             forumGroup = category.getForumGroup(forumGroups[currentIndex]);
138         }
139         catch (ForumGroupNotFoundException tnfe) {
140             System.err.println(tnfe);
141         }
142         return forumGroup;
143     }
144
145     public int nextIndex() {
146         return currentIndex+1;
147     }
148
149     public Object JavaDoc previous() throws java.util.NoSuchElementException JavaDoc {
150         ForumGroup forumGroup = null;
151         currentIndex--;
152         if (currentIndex < 0) {
153             currentIndex++;
154             throw new java.util.NoSuchElementException JavaDoc();
155         }
156         try {
157             forumGroup = category.getForumGroup(forumGroups[currentIndex]);
158         }
159         catch (ForumGroupNotFoundException tnfe) {
160             System.err.println(tnfe);
161         }
162         return forumGroup;
163     }
164
165     public int previousIndex() {
166         return currentIndex-1;
167     }
168
169     public void remove() throws UnsupportedOperationException JavaDoc {
170         throw new UnsupportedOperationException JavaDoc();
171     }
172
173     public void set(Object JavaDoc o) throws UnsupportedOperationException JavaDoc {
174         throw new UnsupportedOperationException JavaDoc();
175     }
176 }
177
Popular Tags