summaryrefslogtreecommitdiffstats
path: root/java/rasj/odmg/RasBag.java
blob: 5ed1843d23ae811acc229f870f66264068d8466b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
/*
* This file is part of rasdaman community.
*
* Rasdaman community is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Rasdaman community is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with rasdaman community.  If not, see <http://www.gnu.org/licenses/>.
*
* Copyright 2003, 2004, 2005, 2006, 2007, 2008, 2009 Peter Baumann /
rasdaman GmbH.
*
* For more information please see <http://www.rasdaman.org>
* or contact Peter Baumann via <baumann@rasdaman.com>.
*/
/** ***********************************************************
 * <pre>
 *
 * PURPOSE:
 *
 *
 *
 * COMMENTS:
 *
 * </pre>
 *********************************************************** */

package rasj.odmg;

import org.odmg.*;
import rasj.global.*;
import java.util.*;

/**
 * This class implements the ODMG DBag interface.
 * @version $Revision: 1.3 $
 */
public class RasBag extends RasCollection implements DBag
  {
    static final String rcsid = "@(#)Package rasj.odmg, class RasBag: $Header: /home/rasdev/CVS-repository/rasdaman/java/rasj/odmg/RasBag.java,v 1.3 2003/12/19 15:42:56 rasdev Exp $";

    List content;

    /**
     * constructor
     */
    public RasBag()
      {
        Debug.enterVerbose( "RasBag.constructor start." );
        content = new ArrayList();
        Debug.leaveVerbose( "RasBag.constructor done." );
      }

    /**
     * Appends the specified element to this Bag.
     */
    public boolean add(Object o)
      {
        boolean result = content.add(o);
        Debug.talkVerbose( "RasBag.add: result=" + result );
        return result;
      }

    /**
     * This method returns the number of occurrences of the object obj in the DBag collection.
     */
    public int occurrences(java.lang.Object obj)
      {
        Debug.enterVerbose( "RasBag.occurrences start." );

        DBag tmpBag = new RasBag();
        tmpBag.addAll(content);
        int count = 0;
        while(tmpBag.contains(obj))
          {
            count++;
            tmpBag.remove(obj);
          }

        Debug.leaveVerbose( "RasBag.occurrences done. count=" + count );
        return count;
      }

    /**
     * A new DBag instance is created that contains the difference of this object and the DBag instance referenced by otherBag.
     */
    public DBag difference(DBag otherBag)
      {
        Debug.enterVerbose( "RasBag.difference start." );

        DBag diffBag = new RasBag();
        diffBag.addAll(otherBag);
        DBag retBag = new RasBag();
        Iterator it = content.iterator();
        Object tmp;
        while(it.hasNext())
          {
            tmp = it.next();
            if(!diffBag.contains(tmp))
                retBag.add(tmp);
            else
                diffBag.remove(tmp);
          }
        retBag.addAll(diffBag);

        Debug.leaveVerbose( "RasBag.difference done." );
        return retBag;
      }

    /**
     * A new DBag instance is created that contains the intersection of this object and the DBag referenced by otherBag.
     */
    public DBag intersection(DBag otherBag)
      {
        Debug.enterVerbose( "RasBag.intersection start." );

        DBag intBag = new RasBag();
        intBag.addAll(otherBag);
        DBag retBag = new RasBag();
        Iterator it = content.iterator();
        Object tmp;
        while(it.hasNext())
          {
            tmp = it.next();
            if(intBag.contains(tmp))
              {
                retBag.add(tmp);
                intBag.remove(tmp);
              }
          }

        Debug.leaveVerbose( "RasBag.intersection done." );
        return retBag;
      }

    /**
     * A new DBag instance is created that is the union of this object and otherBag.
     */
    public DBag union(DBag otherBag)
      {
        Debug.enterVerbose( "RasBag.union start." );

        DBag retBag = new RasBag();
        retBag.addAll(content);
        retBag.addAll(otherBag);

        Debug.leaveVerbose( "RasBag.union done." );
        return retBag;
      }

    /**
     * Returns an iterator over the elements in this Bag in proper sequence.
     */
    public Iterator iterator()
      {
        Debug.talkVerbose( "RasBag.iterator." );
        return content.iterator();
      }

    /**
     * Returns the number of elements in this Bag.
     */
    public int size()
      {
        int result = content.size();
        Debug.talkVerbose( "RasBag.size: size=" + result );
        return result;
      }

} // RasBag