annotate src/main/java/org/msgpack/unpacker/UnpackerStack.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.unpacker;
cb825acd883a first commit
sugi
parents:
diff changeset
19
cb825acd883a first commit
sugi
parents:
diff changeset
20 import org.msgpack.MessageTypeException;
cb825acd883a first commit
sugi
parents:
diff changeset
21
cb825acd883a first commit
sugi
parents:
diff changeset
22 public final class UnpackerStack {
cb825acd883a first commit
sugi
parents:
diff changeset
23 private int top;
cb825acd883a first commit
sugi
parents:
diff changeset
24 private byte[] types;
cb825acd883a first commit
sugi
parents:
diff changeset
25 private int[] counts;
cb825acd883a first commit
sugi
parents:
diff changeset
26
cb825acd883a first commit
sugi
parents:
diff changeset
27 public static final int MAX_STACK_SIZE = 128;
cb825acd883a first commit
sugi
parents:
diff changeset
28
cb825acd883a first commit
sugi
parents:
diff changeset
29 private static final byte TYPE_INVALID = 0;
cb825acd883a first commit
sugi
parents:
diff changeset
30 private static final byte TYPE_ARRAY = 1;
cb825acd883a first commit
sugi
parents:
diff changeset
31 private static final byte TYPE_MAP = 2;
cb825acd883a first commit
sugi
parents:
diff changeset
32
cb825acd883a first commit
sugi
parents:
diff changeset
33 public UnpackerStack() {
cb825acd883a first commit
sugi
parents:
diff changeset
34 this.top = 0;
cb825acd883a first commit
sugi
parents:
diff changeset
35 this.types = new byte[MAX_STACK_SIZE];
cb825acd883a first commit
sugi
parents:
diff changeset
36 this.counts = new int[MAX_STACK_SIZE];
cb825acd883a first commit
sugi
parents:
diff changeset
37 this.types[0] = TYPE_INVALID;
cb825acd883a first commit
sugi
parents:
diff changeset
38 }
cb825acd883a first commit
sugi
parents:
diff changeset
39
cb825acd883a first commit
sugi
parents:
diff changeset
40 public void pushArray(int size) {
cb825acd883a first commit
sugi
parents:
diff changeset
41 top++;
cb825acd883a first commit
sugi
parents:
diff changeset
42 types[top] = TYPE_ARRAY;
cb825acd883a first commit
sugi
parents:
diff changeset
43 counts[top] = size;
cb825acd883a first commit
sugi
parents:
diff changeset
44 }
cb825acd883a first commit
sugi
parents:
diff changeset
45
cb825acd883a first commit
sugi
parents:
diff changeset
46 public void pushMap(int size) {
cb825acd883a first commit
sugi
parents:
diff changeset
47 top++;
cb825acd883a first commit
sugi
parents:
diff changeset
48 types[top] = TYPE_MAP;
cb825acd883a first commit
sugi
parents:
diff changeset
49 counts[top] = size * 2;
cb825acd883a first commit
sugi
parents:
diff changeset
50 }
cb825acd883a first commit
sugi
parents:
diff changeset
51
cb825acd883a first commit
sugi
parents:
diff changeset
52 /**
cb825acd883a first commit
sugi
parents:
diff changeset
53 * throws MessageTypeException if stack is invalid
cb825acd883a first commit
sugi
parents:
diff changeset
54 */
cb825acd883a first commit
sugi
parents:
diff changeset
55 public void checkCount() {
cb825acd883a first commit
sugi
parents:
diff changeset
56 if (counts[top] > 0) {
cb825acd883a first commit
sugi
parents:
diff changeset
57 return;
cb825acd883a first commit
sugi
parents:
diff changeset
58 }
cb825acd883a first commit
sugi
parents:
diff changeset
59
cb825acd883a first commit
sugi
parents:
diff changeset
60 if (types[top] == TYPE_ARRAY) {
cb825acd883a first commit
sugi
parents:
diff changeset
61 throw new MessageTypeException(
cb825acd883a first commit
sugi
parents:
diff changeset
62 "Array is end but readArrayEnd() is not called");
cb825acd883a first commit
sugi
parents:
diff changeset
63 } else if (types[top] == TYPE_MAP) {
cb825acd883a first commit
sugi
parents:
diff changeset
64 throw new MessageTypeException(
cb825acd883a first commit
sugi
parents:
diff changeset
65 "Map is end but readMapEnd() is not called");
cb825acd883a first commit
sugi
parents:
diff changeset
66 } else { // empty
cb825acd883a first commit
sugi
parents:
diff changeset
67 return;
cb825acd883a first commit
sugi
parents:
diff changeset
68 }
cb825acd883a first commit
sugi
parents:
diff changeset
69 }
cb825acd883a first commit
sugi
parents:
diff changeset
70
cb825acd883a first commit
sugi
parents:
diff changeset
71 public void reduceCount() {
cb825acd883a first commit
sugi
parents:
diff changeset
72 counts[top]--;
cb825acd883a first commit
sugi
parents:
diff changeset
73 }
cb825acd883a first commit
sugi
parents:
diff changeset
74
cb825acd883a first commit
sugi
parents:
diff changeset
75 public void pop() {
cb825acd883a first commit
sugi
parents:
diff changeset
76 top--;
cb825acd883a first commit
sugi
parents:
diff changeset
77 }
cb825acd883a first commit
sugi
parents:
diff changeset
78
cb825acd883a first commit
sugi
parents:
diff changeset
79 public int getDepth() {
cb825acd883a first commit
sugi
parents:
diff changeset
80 return top;
cb825acd883a first commit
sugi
parents:
diff changeset
81 }
cb825acd883a first commit
sugi
parents:
diff changeset
82
cb825acd883a first commit
sugi
parents:
diff changeset
83 public int getTopCount() {
cb825acd883a first commit
sugi
parents:
diff changeset
84 return counts[top];
cb825acd883a first commit
sugi
parents:
diff changeset
85 }
cb825acd883a first commit
sugi
parents:
diff changeset
86
cb825acd883a first commit
sugi
parents:
diff changeset
87 public boolean topIsArray() {
cb825acd883a first commit
sugi
parents:
diff changeset
88 return types[top] == TYPE_ARRAY;
cb825acd883a first commit
sugi
parents:
diff changeset
89 }
cb825acd883a first commit
sugi
parents:
diff changeset
90
cb825acd883a first commit
sugi
parents:
diff changeset
91 public boolean topIsMap() {
cb825acd883a first commit
sugi
parents:
diff changeset
92 return types[top] == TYPE_MAP;
cb825acd883a first commit
sugi
parents:
diff changeset
93 }
cb825acd883a first commit
sugi
parents:
diff changeset
94
cb825acd883a first commit
sugi
parents:
diff changeset
95 public void clear() {
cb825acd883a first commit
sugi
parents:
diff changeset
96 top = 0;
cb825acd883a first commit
sugi
parents:
diff changeset
97 }
cb825acd883a first commit
sugi
parents:
diff changeset
98 }