All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.gwt.core.client.JsArrayUtils Maven / Gradle / Ivy

/*
 * Copyright 2012 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;

/**
 * Utility class for manipulating JS arrays.  These methods are not on other
 * JavaScriptObject subclasses, such as JsArray, because adding new methods might
 * break existing subtypes.
 */
public class JsArrayUtils {

  /**
   * Take a Java array, and produce a JS array that is only used for reading.  As
   * this is actually a reference to the original array in prod mode, the source
   * must not be modified while this copy is in use or you will get different
   * behavior between DevMode and prod mode.
   * 
   * @param array source array
   * @return JS array, which may be a copy or an alias of the input array
   */
  public static JsArrayInteger readOnlyJsArray(byte[] array) {
    if (GWT.isScript()) {
      return arrayAsJsArrayForProdMode(array).cast();
    }
    JsArrayInteger dest = JsArrayInteger.createArray().cast();
    for (int i = 0; i < array.length; ++i) {
      dest.push(array[i]);
    }
    return dest;
  }

  /**
   * Take a Java array, and produce a JS array that is only used for reading.  As
   * this is actually a reference to the original array in prod mode, the source
   * must not be modified while this copy is in use or you will get different
   * behavior between DevMode and prod mode.
   * 
   * @param array source array
   * @return JS array, which may be a copy or an alias of the input array
   */
  public static JsArrayNumber readOnlyJsArray(double[] array) {
    if (GWT.isScript()) {
      return arrayAsJsArrayForProdMode(array).cast();
    }
    JsArrayNumber dest = JsArrayNumber.createArray().cast();
    for (int i = 0; i < array.length; ++i) {
      dest.push(array[i]);
    }
    return dest;
  }

  /**
   * Take a Java array, and produce a JS array that is only used for reading.  As
   * this is actually a reference to the original array in prod mode, the source
   * must not be modified while this copy is in use or you will get different
   * behavior between DevMode and prod mode.
   * 
   * @param array source array
   * @return JS array, which may be a copy or an alias of the input array
   */
  public static JsArrayNumber readOnlyJsArray(float[] array) {
    if (GWT.isScript()) {
      return arrayAsJsArrayForProdMode(array).cast();
    }
    JsArrayNumber dest = JsArrayNumber.createArray().cast();
    for (int i = 0; i < array.length; ++i) {
      dest.push(array[i]);
    }
    return dest;
  }

  /**
   * Take a Java array, and produce a JS array that is only used for reading.  As
   * this is actually a reference to the original array in prod mode, the source
   * must not be modified while this copy is in use or you will get different
   * behavior between DevMode and prod mode.
   * 
   * @param array source array
   * @return JS array, which may be a copy or an alias of the input array
   */
  public static JsArrayInteger readOnlyJsArray(int[] array) {
    if (GWT.isScript()) {
      return arrayAsJsArrayForProdMode(array).cast();
    }
    JsArrayInteger dest = JsArrayInteger.createArray().cast();
    for (int i = 0; i < array.length; ++i) {
      dest.push(array[i]);
    }
    return dest;
  }

  /**
   * Take a Java array, and produce a JS array that is only used for reading.  As
   * this is actually a reference to the original array in prod mode, the source
   * must not be modified while this copy is in use or you will get different
   * behavior between DevMode and prod mode.
   * 

* NOTE: long values are not supported in JS, so long emulation is slow * and this method assumes that all the values can be safely stored in a * double. * * @param array source array - its values are assumed to be in the valid range * for doubles -- if the values exceed 2^53, low-order bits will be lost * @return JS array, which may be a copy or an alias of the input array */ public static JsArrayNumber readOnlyJsArray(long[] array) { if (GWT.isScript()) { return arrayAsJsArrayForProdMode(array).cast(); } JsArrayNumber dest = JsArrayNumber.createArray().cast(); for (int i = 0; i < array.length; ++i) { dest.push(array[i]); } return dest; } /** * Take a Java array, and produce a JS array that is only used for reading. As * this is actually a reference to the original array in prod mode, the source * must not be modified while this copy is in use or you will get different * behavior between DevMode and prod mode. * * @param array source array * @return JS array, which may be a copy or an alias of the input array */ public static JsArrayInteger readOnlyJsArray(short[] array) { if (GWT.isScript()) { return arrayAsJsArrayForProdMode(array).cast(); } JsArrayInteger dest = JsArrayInteger.createArray().cast(); for (int i = 0; i < array.length; ++i) { dest.push(array[i]); } return dest; } /** * Take a Java array, and produce a JS array that is only used for reading. As * this is actually a reference to the original array in prod mode, the source * must not be modified while this copy is in use or you will get different * behavior between DevMode and prod mode. * * @param array source array * @return JS array, which may be a copy or an alias of the input array */ public static JsArray readOnlyJsArray(T[] array) { if (GWT.isScript()) { return arrayAsJsArrayForProdMode(array).cast(); } JsArray dest = JavaScriptObject.createArray().cast(); for (int i = 0; i < array.length; ++i) { dest.push(array[i]); } return dest; } /** * In production mode, Java arrays really are JS arrays, so just return it. * * @param array must be a Java array of some type * @return a JavaScriptObject, which should be used as the appropriate type of * JS array depending on the input array type */ private static native JavaScriptObject arrayAsJsArrayForProdMode(Object array) /*-{ return array; }-*/; private JsArrayUtils() { } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy