Skip to main content
summaryrefslogtreecommitdiffstats
blob: a65cd3b6bdf1ecd497db635a255a94fd3aa3a8b0 (plain) (blame)
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
package org.eclipse.jdt.internal.core.index.impl;
/*
 * (c) Copyright IBM Corp. 2000, 2001.
 * All Rights Reserved.
 */
import org.eclipse.jdt.core.*;

public final class ObjectVector {
	static int INITIAL_SIZE= 10;

	public int size;
	int maxSize;
	Object[] elements;
	public ObjectVector() {
		maxSize= INITIAL_SIZE;
		size= 0;
		elements= new Object[maxSize];
	}
	public void add(Object newElement) {
		if (size == maxSize) // knows that size starts <= maxSize
			System.arraycopy(elements, 0, (elements= new Object[maxSize *= 2]), 0, size);
		elements[size++]= newElement;
	}
	public void addAll(Object[] newElements) {
		if (size + newElements.length >= maxSize) {
			maxSize= size + newElements.length; // assume no more elements will be added
			System.arraycopy(elements, 0, (elements= new Object[maxSize]), 0, size);
		}
		System.arraycopy(newElements, 0, elements, size, newElements.length);
		size += newElements.length;
	}
	public boolean contains(Object element) {
		for (int i= size; --i >= 0;)
			if (element == elements[i])
				return true;
		return false;
	}
	public Object elementAt(int index) {
		return elements[index];
	}
	public Object find(Object element) {
		for (int i= size; --i >= 0;)
			if (element == elements[i])
				return elements[i];
		return null;
	}
	public Object remove(Object element) {
		// assumes only one occurrence of the element exists
		for (int i= size; --i >= 0;)
			if (element == elements[i]) {
				// shift the remaining elements down one spot
				System.arraycopy(elements, i + 1, elements, i, --size - i);
				elements[size]= null;
				return element;
			}
		return null;
	}
	public void removeAll() {
		for (int i= size; --i >= 0;)
			elements[i]= null;
		size= 0;
	}
	public String toString() {
		String s= ""/*nonNLS*/;
		for (int i= 0; i < size; i++)
			s += elements[i].toString() + "\n"/*nonNLS*/;
		return s;
	}
}

Back to the top