/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- * * The contents of this file are subject to the Netscape Public * License Version 1.1 (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.mozilla.org/NPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is mozilla.org code. * * The Initial Developer of the Original Code is Netscape * Communications Corporation. Portions created by Netscape are * Copyright (C) 1998 Netscape Communications Corporation. All * Rights Reserved. * * Contributor(s): */ /* jband Sept 1998 - **NOT original file** - copied here for simplicity */ /* more doc todo: * threads * gc * * */ package netscape.javascript; import java.applet.Applet; /** * JSObject allows Java to manipulate objects that are * defined in JavaScript. * Values passed from Java to JavaScript are converted as * follows: * Values passed from JavaScript to Java are converted as follows: * This means that all JavaScript values show up as some kind * of java.lang.Object in Java. In order to make much use of them, * you will have to cast them to the appropriate subclass of Object, * e.g. (String) window.getMember("name"); or * (JSObject) window.getMember("document");. */ public final class JSObject { /* the internal object data */ private int internal; /** * initialize */ private static native void initClass(); static { String liveConnectLibrary = null; String OSName = System.getProperty("os.name", null); // On MRJ, this property won't exist, because the library is preloaded. liveConnectLibrary = System.getProperty("netscape.jsj.dll", null); // On Mac, native methods are statically linked and manually registered. if ((liveConnectLibrary == null) && (OSName.indexOf("Mac") == -1)) liveConnectLibrary = "LiveConnect"; if (liveConnectLibrary != null) { System.loadLibrary(liveConnectLibrary); initClass(); } } /** * it is illegal to construct a JSObject manually */ private JSObject(int jsobj_addr) { internal = jsobj_addr; } /** * Retrieves a named member of a JavaScript object. * Equivalent to "this.name" in JavaScript. */ public native Object getMember(String name); /** * Retrieves an indexed member of a JavaScript object. * Equivalent to "this[index]" in JavaScript. */ // public Object getMember(int index) { return getSlot(index); } public native Object getSlot(int index); /** * Sets a named member of a JavaScript object. * Equivalent to "this.name = value" in JavaScript. */ public native void setMember(String name, Object value); /** * Sets an indexed member of a JavaScript object. * Equivalent to "this[index] = value" in JavaScript. */ // public void setMember(int index, Object value) { // setSlot(index, value); // } public native void setSlot(int index, Object value); /** * Removes a named member of a JavaScript object. */ public native void removeMember(String name); /** * Calls a JavaScript method. * Equivalent to "this.methodName(args[0], args[1], ...)" in JavaScript. */ public native Object call(String methodName, Object args[]); /** * Evaluates a JavaScript expression. The expression is a string * of JavaScript source code which will be evaluated in the context * given by "this". */ public native Object eval(String s); /** * Converts a JSObject to a String. */ public native String toString(); // should use some sort of identifier rather than String // is "property" the right word? // native String[] listProperties(); /** * get a JSObject for the window containing the given applet */ public static native JSObject getWindow(Applet applet); /** * Finalization decrements the reference count on the corresponding * JavaScript object. */ protected native void finalize(); /** * Override java.lang.Object.equals() because identity is not preserved * with instances of JSObject. */ public native boolean equals(Object obj); }