Table of Contents Previous Section
The WebObjects Java Extensions enable communication between WebScript, Objective-C, and Java objects. From either WebScript or Objective-C, the Extensions provide access to Java objects as follows:
However the Java object is accessed, exceptions raised within the Java code are caught and transformed into NSExceptions, which can then be handled by your code on the Objective-C side.
The previous section discussed how the WebObjects Java Extensions allow Objective-C objects to message Java objects. In a similar fashion, the Extensions also allow Java objects to message Objective-C objects. From the Java side, the Extensions represent Objective-C objects as custom Java objects which inherit from the Java class next.util.NextObject. The Extensions use a combination of native methods and stub code to call from Java into Objective-C.
The WebObjects Java Extensions provide a number of useful Java classes in the next.util, next.eo, and next.wo packages (see "The Java Packages" for more information). These classes encapsulate the functionality of some of NeXT's more useful Objective-C classes and can be used by your Java code as-is.
To access an Objective-C object from Java, you simply create a Java "wrapper" around the Objective-C object using "bridget," a tool provided with the WebObjects Java Extensions for this purpose. The Java wrapper contains native stub functions that transform the Java arguments and dispatch an Objective-C method to the wrapped object, along with initialization code for the wrapped object. Note that these wrappers only work for method invocations: you cannot directly access the instance variables of an Objective-C object from its wrapped Java counterpart. The Objective-C object must either provide accessor functions, or you must us the next.util.KeyValueCoding interface (which is implemented by next.util.NextObject). For information on how to use "bridget," see "Wrapping Your Objective-C Classes."
You build a Java subclass of a wrapped class quite naturally by simply extending the Java wrapper class as you would any ordinary Java class. This works because the Java Extensions search the superclass chain of every new class of Java object that crosses from Java to the Objective-C side. If a wrapped class is discovered (such as next.eo.CustomObject) the Extensions dynamically build an Objective-C "shadow" class for this custom Java subclass. The shadow class mirrors every Java method discovered with a corresponding selector and a common implementation function. The implementation function dynamically looks up the Java method signature for guidance in transforming the stack into a Java call frame, giving the Java side the first chance at any invocation from the Objective-C side.
As expected, calling super from a Java subclass of an Objective-C class messages the Objective-C class's implementation of the method.
Constructors of subclasses pose special problems since Java constructors have only a type signature. This means that the Extensions can't distinguish -initWithReversedArray: from -initWithArray:. Because of this, bridget
requires you to specify the name of the init method that should map to a Java constructor with a corresponding type signature.