2 * Back 2 Browser Bytecode Translator
3 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, version 2 of the License.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. Look for COPYING file in the top folder.
16 * If not, see http://opensource.org/licenses/GPL-2.0.
18 package org.apidesign.javap;
20 /** A JavaScript optimized replacement for Hashtable.
22 * @author Jaroslav Tulach <jtulach@netbeans.org>
24 final class Hashtable {
25 private Object[] keys;
26 private Object[] values;
32 Hashtable(int i, double d) {
39 synchronized void put(Object key, Object val) {
40 int[] where = { -1, -1 };
41 Object found = get(key, where);
44 values[where[0]] = val;
49 values[where[1]] = val;
52 keys = new Object[11];
53 values = new Object[11];
57 Object[] newKeys = new Object[keys.length * 2];
58 Object[] newValues = new Object[values.length * 2];
59 for (int i = 0; i < keys.length; i++) {
61 newValues[i] = values[i];
63 newKeys[keys.length] = key;
64 newValues[keys.length] = val;
72 Object get(Object key) {
73 return get(key, null);
75 private synchronized Object get(Object key, int[] foundAndNull) {
79 for (int i = 0; i < keys.length; i++) {
80 if (keys[i] == null) {
81 if (foundAndNull != null) {
84 } else if (keys[i].equals(key)) {
85 if (foundAndNull != null) {