| /* |
| * Copyright 2007 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 java.lang; |
| |
| import java.io.PrintStream; |
| |
| /** |
| * General-purpose low-level utility methods. GWT only supports a limited subset |
| * of these methods due to browser limitations. Only the documented methods are |
| * available. |
| */ |
| public final class System { |
| |
| /** |
| * Does nothing in web mode. To get output in web mode, subclass PrintStream |
| * and call {@link #setErr(PrintStream)}. |
| */ |
| public static final PrintStream err = new PrintStream(null); |
| |
| /** |
| * Does nothing in web mode. To get output in web mode, subclass |
| * {@link PrintStream} and call {@link #setOut(PrintStream)}. |
| */ |
| public static final PrintStream out = new PrintStream(null); |
| |
| public static void arraycopy(Object src, int srcOfs, Object dest, |
| int destOfs, int len) { |
| if (src == null || dest == null) { |
| throw new NullPointerException(); |
| } |
| |
| // TODO: use Class objects when Class.getComponentType() is supported. |
| String srcTypeName = src.getClass().getName(); |
| String destTypeName = dest.getClass().getName(); |
| if (srcTypeName.charAt(0) != '[' || destTypeName.charAt(0) != '[') { |
| throw new ArrayStoreException("Must be array types"); |
| } |
| if (srcTypeName.charAt(1) != destTypeName.charAt(1)) { |
| throw new ArrayStoreException("Array types must match"); |
| } |
| int srclen = getArrayLength(src); |
| int destlen = getArrayLength(dest); |
| if (srcOfs < 0 || destOfs < 0 || len < 0 || srcOfs + len > srclen |
| || destOfs + len > destlen) { |
| throw new IndexOutOfBoundsException(); |
| } |
| /* |
| * If the arrays are not references or if they are exactly the same type, we |
| * can copy them in native code for speed. Otherwise, we have to copy them |
| * in Java so we get appropriate errors. |
| */ |
| if ((srcTypeName.charAt(1) == 'L' || srcTypeName.charAt(1) == '[') |
| && !srcTypeName.equals(destTypeName)) { |
| // copy in Java to make sure we get ArrayStoreExceptions if the values |
| // aren't compatible |
| Object[] srcArray = (Object[]) src; |
| Object[] destArray = (Object[]) dest; |
| if (src == dest && srcOfs < destOfs) { |
| // TODO(jat): how does backward copies handle failures in the middle? |
| // copy backwards to avoid destructive copies |
| srcOfs += len; |
| for (int destEnd = destOfs + len; destEnd-- > destOfs;) { |
| destArray[destEnd] = srcArray[--srcOfs]; |
| } |
| } else { |
| for (int destEnd = destOfs + len; destOfs < destEnd;) { |
| destArray[destOfs++] = srcArray[srcOfs++]; |
| } |
| } |
| } else { |
| nativeArraycopy(src, srcOfs, dest, destOfs, len); |
| } |
| } |
| |
| public static native long currentTimeMillis() /*-{ |
| return (new Date()).getTime(); |
| }-*/; |
| |
| /** |
| * Has no effect; just here for source compatibility. |
| * |
| * @skip |
| */ |
| public static native void gc() /*-{ |
| }-*/; |
| |
| public static native int identityHashCode(Object o) /*-{ |
| return (o == null) ? 0 : @com.google.gwt.core.client.Impl::getHashCode(Ljava/lang/Object;)(o); |
| }-*/; |
| |
| public static native void setErr(PrintStream err) /*-{ |
| @java.lang.System::err = err; |
| }-*/; |
| |
| public static native void setOut(PrintStream out) /*-{ |
| @java.lang.System::out = out; |
| }-*/; |
| |
| /** |
| * Returns the length of an array via Javascript. |
| */ |
| private static native int getArrayLength(Object array) /*-{ |
| return array.length; |
| }-*/; |
| |
| /** |
| * Copy an array using native Javascript. The destination array must be a real |
| * Java array (ie, already has the GWT type info on it). No error checking is |
| * performed -- the caller is expected to have verified everything first. |
| * |
| * @param src source array for copy |
| * @param srcOfs offset into source array |
| * @param dest destination array for copy |
| * @param destOfs offset into destination array |
| * @param len number of elements to copy |
| */ |
| private static native void nativeArraycopy(Object src, int srcOfs, Object dest, int destOfs, |
| int len) /*-{ |
| Array.prototype.splice.apply(dest, [destOfs, len].concat(src.slice(srcOfs, srcOfs + len))); |
| }-*/; |
| |
| } |