annotate src/main/java/org/msgpack/type/ArrayValueImpl.java @ 0:cb825acd883a

first commit
author sugi
date Sat, 18 Oct 2014 15:06:15 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
cb825acd883a first commit
sugi
parents:
diff changeset
1 //
cb825acd883a first commit
sugi
parents:
diff changeset
2 // MessagePack for Java
cb825acd883a first commit
sugi
parents:
diff changeset
3 //
cb825acd883a first commit
sugi
parents:
diff changeset
4 // Copyright (C) 2009 - 2013 FURUHASHI Sadayuki
cb825acd883a first commit
sugi
parents:
diff changeset
5 //
cb825acd883a first commit
sugi
parents:
diff changeset
6 // Licensed under the Apache License, Version 2.0 (the "License");
cb825acd883a first commit
sugi
parents:
diff changeset
7 // you may not use this file except in compliance with the License.
cb825acd883a first commit
sugi
parents:
diff changeset
8 // You may obtain a copy of the License at
cb825acd883a first commit
sugi
parents:
diff changeset
9 //
cb825acd883a first commit
sugi
parents:
diff changeset
10 // http://www.apache.org/licenses/LICENSE-2.0
cb825acd883a first commit
sugi
parents:
diff changeset
11 //
cb825acd883a first commit
sugi
parents:
diff changeset
12 // Unless required by applicable law or agreed to in writing, software
cb825acd883a first commit
sugi
parents:
diff changeset
13 // distributed under the License is distributed on an "AS IS" BASIS,
cb825acd883a first commit
sugi
parents:
diff changeset
14 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
cb825acd883a first commit
sugi
parents:
diff changeset
15 // See the License for the specific language governing permissions and
cb825acd883a first commit
sugi
parents:
diff changeset
16 // limitations under the License.
cb825acd883a first commit
sugi
parents:
diff changeset
17 //
cb825acd883a first commit
sugi
parents:
diff changeset
18 package org.msgpack.type;
cb825acd883a first commit
sugi
parents:
diff changeset
19
cb825acd883a first commit
sugi
parents:
diff changeset
20 import java.util.ListIterator;
cb825acd883a first commit
sugi
parents:
diff changeset
21 import java.io.IOException;
cb825acd883a first commit
sugi
parents:
diff changeset
22 import org.msgpack.packer.Packer;
cb825acd883a first commit
sugi
parents:
diff changeset
23
cb825acd883a first commit
sugi
parents:
diff changeset
24 class ArrayValueImpl extends AbstractArrayValue {
cb825acd883a first commit
sugi
parents:
diff changeset
25 private static ArrayValueImpl emptyInstance = new ArrayValueImpl(new Value[0], true);
cb825acd883a first commit
sugi
parents:
diff changeset
26
cb825acd883a first commit
sugi
parents:
diff changeset
27 public static ArrayValue getEmptyInstance() {
cb825acd883a first commit
sugi
parents:
diff changeset
28 return emptyInstance;
cb825acd883a first commit
sugi
parents:
diff changeset
29 }
cb825acd883a first commit
sugi
parents:
diff changeset
30
cb825acd883a first commit
sugi
parents:
diff changeset
31 private Value[] array;
cb825acd883a first commit
sugi
parents:
diff changeset
32
cb825acd883a first commit
sugi
parents:
diff changeset
33 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
34 public Value[] getElementArray() {
cb825acd883a first commit
sugi
parents:
diff changeset
35 return array;
cb825acd883a first commit
sugi
parents:
diff changeset
36 }
cb825acd883a first commit
sugi
parents:
diff changeset
37
cb825acd883a first commit
sugi
parents:
diff changeset
38 ArrayValueImpl(Value[] array, boolean gift) {
cb825acd883a first commit
sugi
parents:
diff changeset
39 if (gift) {
cb825acd883a first commit
sugi
parents:
diff changeset
40 this.array = array;
cb825acd883a first commit
sugi
parents:
diff changeset
41 } else {
cb825acd883a first commit
sugi
parents:
diff changeset
42 this.array = new Value[array.length];
cb825acd883a first commit
sugi
parents:
diff changeset
43 System.arraycopy(array, 0, this.array, 0, array.length);
cb825acd883a first commit
sugi
parents:
diff changeset
44 }
cb825acd883a first commit
sugi
parents:
diff changeset
45 }
cb825acd883a first commit
sugi
parents:
diff changeset
46
cb825acd883a first commit
sugi
parents:
diff changeset
47 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
48 public int size() {
cb825acd883a first commit
sugi
parents:
diff changeset
49 return array.length;
cb825acd883a first commit
sugi
parents:
diff changeset
50 }
cb825acd883a first commit
sugi
parents:
diff changeset
51
cb825acd883a first commit
sugi
parents:
diff changeset
52 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
53 public boolean isEmpty() {
cb825acd883a first commit
sugi
parents:
diff changeset
54 return array.length == 0;
cb825acd883a first commit
sugi
parents:
diff changeset
55 }
cb825acd883a first commit
sugi
parents:
diff changeset
56
cb825acd883a first commit
sugi
parents:
diff changeset
57 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
58 public Value get(int index) {
cb825acd883a first commit
sugi
parents:
diff changeset
59 if (index < 0 || array.length <= index) {
cb825acd883a first commit
sugi
parents:
diff changeset
60 throw new IndexOutOfBoundsException();
cb825acd883a first commit
sugi
parents:
diff changeset
61 }
cb825acd883a first commit
sugi
parents:
diff changeset
62 return array[index];
cb825acd883a first commit
sugi
parents:
diff changeset
63 }
cb825acd883a first commit
sugi
parents:
diff changeset
64
cb825acd883a first commit
sugi
parents:
diff changeset
65 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
66 public int indexOf(Object o) {
cb825acd883a first commit
sugi
parents:
diff changeset
67 if (o == null) {
cb825acd883a first commit
sugi
parents:
diff changeset
68 return -1; // FIXME NullPointerException?
cb825acd883a first commit
sugi
parents:
diff changeset
69 }
cb825acd883a first commit
sugi
parents:
diff changeset
70 for (int i = 0; i < array.length; i++) {
cb825acd883a first commit
sugi
parents:
diff changeset
71 if (array[i].equals(o)) {
cb825acd883a first commit
sugi
parents:
diff changeset
72 return i;
cb825acd883a first commit
sugi
parents:
diff changeset
73 }
cb825acd883a first commit
sugi
parents:
diff changeset
74 }
cb825acd883a first commit
sugi
parents:
diff changeset
75 return -1;
cb825acd883a first commit
sugi
parents:
diff changeset
76 }
cb825acd883a first commit
sugi
parents:
diff changeset
77
cb825acd883a first commit
sugi
parents:
diff changeset
78 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
79 public int lastIndexOf(Object o) {
cb825acd883a first commit
sugi
parents:
diff changeset
80 if (o == null) {
cb825acd883a first commit
sugi
parents:
diff changeset
81 return -1; // FIXME NullPointerException?
cb825acd883a first commit
sugi
parents:
diff changeset
82 }
cb825acd883a first commit
sugi
parents:
diff changeset
83 for (int i = array.length - 1; i >= 0; i--) {
cb825acd883a first commit
sugi
parents:
diff changeset
84 if (array[i].equals(o)) {
cb825acd883a first commit
sugi
parents:
diff changeset
85 return i;
cb825acd883a first commit
sugi
parents:
diff changeset
86 }
cb825acd883a first commit
sugi
parents:
diff changeset
87 }
cb825acd883a first commit
sugi
parents:
diff changeset
88 return -1;
cb825acd883a first commit
sugi
parents:
diff changeset
89 }
cb825acd883a first commit
sugi
parents:
diff changeset
90
cb825acd883a first commit
sugi
parents:
diff changeset
91 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
92 public void writeTo(Packer pk) throws IOException {
cb825acd883a first commit
sugi
parents:
diff changeset
93 pk.writeArrayBegin(array.length);
cb825acd883a first commit
sugi
parents:
diff changeset
94 for (int i = 0; i < array.length; i++) {
cb825acd883a first commit
sugi
parents:
diff changeset
95 array[i].writeTo(pk);
cb825acd883a first commit
sugi
parents:
diff changeset
96 }
cb825acd883a first commit
sugi
parents:
diff changeset
97 pk.writeArrayEnd();
cb825acd883a first commit
sugi
parents:
diff changeset
98 }
cb825acd883a first commit
sugi
parents:
diff changeset
99
cb825acd883a first commit
sugi
parents:
diff changeset
100 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
101 public boolean equals(Object o) {
cb825acd883a first commit
sugi
parents:
diff changeset
102 if (o == this) {
cb825acd883a first commit
sugi
parents:
diff changeset
103 return true;
cb825acd883a first commit
sugi
parents:
diff changeset
104 }
cb825acd883a first commit
sugi
parents:
diff changeset
105 if (!(o instanceof Value)) {
cb825acd883a first commit
sugi
parents:
diff changeset
106 return false;
cb825acd883a first commit
sugi
parents:
diff changeset
107 }
cb825acd883a first commit
sugi
parents:
diff changeset
108 Value v = (Value) o;
cb825acd883a first commit
sugi
parents:
diff changeset
109 if (!v.isArrayValue()) {
cb825acd883a first commit
sugi
parents:
diff changeset
110 return false;
cb825acd883a first commit
sugi
parents:
diff changeset
111 }
cb825acd883a first commit
sugi
parents:
diff changeset
112
cb825acd883a first commit
sugi
parents:
diff changeset
113 if (v.getClass() == ArrayValueImpl.class) {
cb825acd883a first commit
sugi
parents:
diff changeset
114 return equals((ArrayValueImpl) v);
cb825acd883a first commit
sugi
parents:
diff changeset
115 }
cb825acd883a first commit
sugi
parents:
diff changeset
116
cb825acd883a first commit
sugi
parents:
diff changeset
117 ListIterator<Value> oi = v.asArrayValue().listIterator();
cb825acd883a first commit
sugi
parents:
diff changeset
118 int i = 0;
cb825acd883a first commit
sugi
parents:
diff changeset
119 while (i < array.length) {
cb825acd883a first commit
sugi
parents:
diff changeset
120 if (!oi.hasNext() || !array[i].equals(oi.next())) {
cb825acd883a first commit
sugi
parents:
diff changeset
121 return false;
cb825acd883a first commit
sugi
parents:
diff changeset
122 }
cb825acd883a first commit
sugi
parents:
diff changeset
123 i++;
cb825acd883a first commit
sugi
parents:
diff changeset
124 }
cb825acd883a first commit
sugi
parents:
diff changeset
125 return !oi.hasNext();
cb825acd883a first commit
sugi
parents:
diff changeset
126 }
cb825acd883a first commit
sugi
parents:
diff changeset
127
cb825acd883a first commit
sugi
parents:
diff changeset
128 private boolean equals(ArrayValueImpl o) {
cb825acd883a first commit
sugi
parents:
diff changeset
129 if (array.length != o.array.length) {
cb825acd883a first commit
sugi
parents:
diff changeset
130 return false;
cb825acd883a first commit
sugi
parents:
diff changeset
131 }
cb825acd883a first commit
sugi
parents:
diff changeset
132 for (int i = 0; i < array.length; i++) {
cb825acd883a first commit
sugi
parents:
diff changeset
133 if (!array[i].equals(o.array[i])) {
cb825acd883a first commit
sugi
parents:
diff changeset
134 return false;
cb825acd883a first commit
sugi
parents:
diff changeset
135 }
cb825acd883a first commit
sugi
parents:
diff changeset
136 }
cb825acd883a first commit
sugi
parents:
diff changeset
137 return true;
cb825acd883a first commit
sugi
parents:
diff changeset
138 }
cb825acd883a first commit
sugi
parents:
diff changeset
139
cb825acd883a first commit
sugi
parents:
diff changeset
140 // TODO compareTo?
cb825acd883a first commit
sugi
parents:
diff changeset
141
cb825acd883a first commit
sugi
parents:
diff changeset
142 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
143 public int hashCode() {
cb825acd883a first commit
sugi
parents:
diff changeset
144 int h = 1;
cb825acd883a first commit
sugi
parents:
diff changeset
145 for (int i = 0; i < array.length; i++) {
cb825acd883a first commit
sugi
parents:
diff changeset
146 Value obj = array[i];
cb825acd883a first commit
sugi
parents:
diff changeset
147 h = 31 * h + obj.hashCode();
cb825acd883a first commit
sugi
parents:
diff changeset
148 }
cb825acd883a first commit
sugi
parents:
diff changeset
149 return h;
cb825acd883a first commit
sugi
parents:
diff changeset
150 }
cb825acd883a first commit
sugi
parents:
diff changeset
151
cb825acd883a first commit
sugi
parents:
diff changeset
152 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
153 public String toString() {
cb825acd883a first commit
sugi
parents:
diff changeset
154 return toString(new StringBuilder()).toString();
cb825acd883a first commit
sugi
parents:
diff changeset
155 }
cb825acd883a first commit
sugi
parents:
diff changeset
156
cb825acd883a first commit
sugi
parents:
diff changeset
157 @Override
cb825acd883a first commit
sugi
parents:
diff changeset
158 public StringBuilder toString(StringBuilder sb) {
cb825acd883a first commit
sugi
parents:
diff changeset
159 if (array.length == 0) {
cb825acd883a first commit
sugi
parents:
diff changeset
160 return sb.append("[]");
cb825acd883a first commit
sugi
parents:
diff changeset
161 }
cb825acd883a first commit
sugi
parents:
diff changeset
162 sb.append("[");
cb825acd883a first commit
sugi
parents:
diff changeset
163 sb.append(array[0]);
cb825acd883a first commit
sugi
parents:
diff changeset
164 for (int i = 1; i < array.length; i++) {
cb825acd883a first commit
sugi
parents:
diff changeset
165 sb.append(",");
cb825acd883a first commit
sugi
parents:
diff changeset
166 array[i].toString(sb);
cb825acd883a first commit
sugi
parents:
diff changeset
167 }
cb825acd883a first commit
sugi
parents:
diff changeset
168 sb.append("]");
cb825acd883a first commit
sugi
parents:
diff changeset
169 return sb;
cb825acd883a first commit
sugi
parents:
diff changeset
170 }
cb825acd883a first commit
sugi
parents:
diff changeset
171 }