/* * Copyright 2010 Google Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ package com.google.gwt.core.client; /** * A simple wrapper around an heterogeneous native array of values. * * This class may not be directly instantiated, and can only be returned from a * native method. For example, * * <code> * native JsArrayMixed getNativeArray() /*-{ * return [ * { x: 0, y: 1}, * "apple", * 12345, * ]; * }-* /; * </code> */ public class JsArrayMixed extends JavaScriptObject { protected JsArrayMixed() { } /** * Gets the boolean at a given index. * * @param index the index to be retrieved * @return the object at the given index, or <code>null</code> if none exists */ public final native boolean getBoolean(int index) /*-{ return Boolean(this[index]); }-*/; /** * Gets the double at a given index. * * @param index the index to be retrieved * @return the object at the given index, or <code>null</code> if none exists */ public final native double getNumber(int index) /*-{ return Number(this[index]); }-*/; /** * Gets the {@link JavaScriptObject} at a given index. * * @param index the index to be retrieved * @return the {@code JavaScriptObject} at the given index, or * <code>null</code> if none exists */ public final native <T extends JavaScriptObject> T getObject(int index) /*-{ return this[index] != null ? Object(this[index]) : null; }-*/; /** * Gets the String at a given index. * * @param index the index to be retrieved * @return the object at the given index, or <code>null</code> if none exists */ public final native String getString(int index) /*-{ return String(this[index]); }-*/; /** * Convert each element of the array to a String and join them with a comma * separator. The value returned from this method may vary between browsers * based on how JavaScript values are converted into strings. */ public final String join() { // As per JS spec return join(","); } /** * Convert each element of the array to a String and join them with a comma * separator. The value returned from this method may vary between browsers * based on how JavaScript values are converted into strings. */ public final native String join(String separator) /*-{ return this.join(separator); }-*/; /** * Gets the length of the array. * * @return the array length */ public final native int length() /*-{ return this.length; }-*/; /** * Pushes the given boolean onto the end of the array. */ public final native void push(boolean value) /*-{ this[this.length] = value; }-*/; /** * Pushes the given double onto the end of the array. */ public final native void push(double value) /*-{ this[this.length] = value; }-*/; /** * Pushes the given {@link JavaScriptObject} onto the end of the array. */ public final native void push(JavaScriptObject value) /*-{ this[this.length] = value; }-*/; /** * Pushes the given String onto the end of the array. */ public final native void push(String value) /*-{ this[this.length] = value; }-*/; /** * Sets the boolean value at a given index. * * If the index is out of bounds, the value will still be set. The array's * length will be updated to encompass the bounds implied by the added value. * * @param index the index to be set * @param value the boolean to be stored */ public final native void set(int index, boolean value) /*-{ this[index] = value; }-*/; /** * Sets the double value at a given index. * * If the index is out of bounds, the value will still be set. The array's * length will be updated to encompass the bounds implied by the added value. * * @param index the index to be set * @param value the double to be stored */ public final native void set(int index, double value) /*-{ this[index] = value; }-*/; /** * Sets the object value at a given index. * * If the index is out of bounds, the value will still be set. The array's * length will be updated to encompass the bounds implied by the added object. * * @param index the index to be set * @param value the {@link JavaScriptObject} to be stored */ public final native void set(int index, JavaScriptObject value) /*-{ this[index] = value; }-*/; /** * Sets the String value at a given index. * * If the index is out of bounds, the value will still be set. The array's * length will be updated to encompass the bounds implied by the added String. * * @param index the index to be set * @param value the String to be stored */ public final native void set(int index, String value) /*-{ this[index] = value; }-*/; /** * Reset the length of the array. * * @param newLength the new length of the array */ public final native void setLength(int newLength) /*-{ this.length = newLength; }-*/; /** * Shifts the first value off the array. * * @return the shifted boolean */ public final native boolean shiftBoolean() /*-{ return Boolean(this.shift()); }-*/; /** * Shifts the first value off the array. * * @return the shifted double */ public final native double shiftNumber() /*-{ return Number(this.shift()); }-*/; /** * Shifts the first value off the array. * * @return the shifted {@link JavaScriptObject} */ public final native <T extends JavaScriptObject> T shiftObject() /*-{ return Object(this.shift()); }-*/; /** * Shifts the first value off the array. * * @return the shifted String */ public final native String shiftString() /*-{ return String(this.shift()); }-*/; /** * Shifts a boolean onto the beginning of the array. * * @param value the value to the stored */ public final native void unshift(boolean value) /*-{ this.unshift(value); }-*/; /** * Shifts a double onto the beginning of the array. * * @param value the value to store */ public final native void unshift(double value) /*-{ this.unshift(value); }-*/; /** * Shifts a {@link JavaScriptObject} onto the beginning of the array. * * @param value the value to store */ public final native void unshift(JavaScriptObject value) /*-{ this.unshift(value); }-*/; /** * Shifts a String onto the beginning of the array. * * @param value the value to store */ public final native void unshift(String value) /*-{ this.unshift(value); }-*/; }