|
|||||||||
PREV PACKAGE NEXT PACKAGE | FRAMES NO FRAMES |
See:
Description
Interface Summary | |
---|---|
OtpServerTransport | Server-side connection-oriented transport interface. |
OtpTransport | Client-side connection-oriented transport interface. |
OtpTransportFactory | Factory class used to create client- and server-side transport instances. |
Class Summary | |
---|---|
AbstractConnection | Maintains a connection between a Java process and a remote Erlang, Java or C node. |
AbstractNode | Represents an OTP node. |
GenericQueue | This class implements a generic FIFO queue. |
OtpConnection | Maintains a connection between a Java process and a remote Erlang, Java or C node. |
OtpCookedConnection | Maintains a connection between a Java process and a remote Erlang, Java or C node. |
OtpEpmd | Provides methods for registering, unregistering and looking up nodes with the Erlang portmapper daemon (Epmd). |
OtpErlangAtom | Provides a Java representation of Erlang atoms. |
OtpErlangBinary | Provides a Java representation of Erlang binaries. |
OtpErlangBitstr | Provides a Java representation of Erlang bitstrs. |
OtpErlangBoolean | Provides a Java representation of Erlang booleans, which are special cases of atoms with values 'true' and 'false'. |
OtpErlangByte | Provides a Java representation of Erlang integral types. |
OtpErlangChar | Provides a Java representation of Erlang integral types. |
OtpErlangDouble | Provides a Java representation of Erlang floats and doubles. |
OtpErlangExternalFun | |
OtpErlangFloat | Provides a Java representation of Erlang floats and doubles. |
OtpErlangFun | |
OtpErlangInt | Provides a Java representation of Erlang integral types. |
OtpErlangList | Provides a Java representation of Erlang lists. |
OtpErlangList.SubList | |
OtpErlangLong | Provides a Java representation of Erlang integral types. |
OtpErlangMap | Provides a Java representation of Erlang maps. |
OtpErlangObject | Base class of the Erlang data type classes. |
OtpErlangObject.Hash | |
OtpErlangPid | Provides a Java representation of Erlang PIDs. |
OtpErlangPort | Provides a Java representation of Erlang ports. |
OtpErlangRef | Provides a Java representation of Erlang refs. |
OtpErlangShort | Provides a Java representation of Erlang integral types. |
OtpErlangString | Provides a Java representation of Erlang strings. |
OtpErlangTuple | Provides a Java representation of Erlang tuples. |
OtpErlangUInt | Provides a Java representation of Erlang integral types. |
OtpErlangUShort | Provides a Java representation of Erlang integral types. |
OtpExternal | Provides a collection of constants used when encoding and decoding Erlang terms. |
OtpInputStream | Provides a stream for decoding Erlang terms from external format. |
OtpLocalNode | This class represents local node types. |
OtpMbox | Provides a simple mechanism for exchanging messages with Erlang processes or other instances of this class. |
OtpMsg | Provides a carrier for Erlang messages. |
OtpNode | Represents a local OTP node. |
OtpNodeStatus | Provides a callback mechanism for receiving status change information about other nodes in the system. |
OtpOutputStream | Provides a stream for encoding Erlang terms to external format, for transmission or storage. |
OtpPeer | Represents a remote OTP node. |
OtpSelf | Represents an OTP node. |
OtpServer | Deprecated. the functionality of this class has been moved to OtpSelf
. |
OtpServerSocketTransport | Default socket-based server transport |
OtpSocketTransport | Default socket-based client transport |
OtpSocketTransportFactory | Default socket-based transport factory |
Exception Summary | |
---|---|
OtpAuthException | Exception raised when a node attempts to establish a communication channel when it is not authorized to do so, or when a node sends a message containing an invalid cookie on an established channel. |
OtpErlangDecodeException | Exception raised when an attempt is made to create an Erlang term by decoding a sequence of bytes that does not represent the type of term that was requested. |
OtpErlangException | Base class for the other OTP erlang exception classes. |
OtpErlangExit | Exception raised when a communication channel is broken. |
OtpErlangRangeException | Exception raised when an attempt is made to create an Erlang term with data that is out of range for the term in question. |
OtpException | Base class for the other OTP exception classes. |
This package provides support for communication with Erlang and representation of Erlang datatypes.
Note: By default, jinterface
is only guaranteed
to be compatible with other Erlang/OTP components from the same release as
jinterface
itself. For example, jinterface
from the OTP R10 release is not compatible with an Erlang emulator from
the OTP R9 release by default. jinterface
can be set in
compatibility mode of an earlier release (not earlier that R7), though.
The compatibility mode is set by usage of the OtpCompatRel
property. By starting the jvm with the command-line argument
-DOtpCompatRel=9
, jinterface
will be compatible
with the R9 release of OTP. Warning! You may run into trouble if
this feature is used carelessly. Always make sure that all communicating
components are either from the same Erlang/OTP release, or from release
X and release Y where all components from release Y are in compatibility
mode of release X.
The classes
OtpErlangList
,
OtpErlangTuple
,
OtpErlangBinary
,
OtpErlangAtom
,
OtpErlangBoolean
,
OtpErlangByte
,
OtpErlangChar
,
OtpErlangDouble
,
OtpErlangFloat
,
OtpErlangLong
,
OtpErlangInt
,
OtpErlangUInt
,
OtpErlangShort
,
OtpErlangUShort
,
OtpErlangString
,
OtpErlangObject
,
OtpErlangPid
,
OtpErlangPort
,
and OtpErlangRef
represent the various Erlang datatypes.
There are two basic mechanisms for communicating with Erlang, described briefly here. Note that the two mechanisms are not intended to be used together. Which mechanism you choose depends on your application and the level of control it needs.
You can use OtpNode
, which can
manage incoming and outgoing connections for you. With OtpNode
a thread is automatically started to
listen for incoming connections, make necessary outgoing connections,
and dispatch messages to their recipients. OtpNode
supports the concept of mailboxes
, allowing you to have
several Java components communicating independently with Erlang.
OtpNode node = new OtpNode("bingo"); OtpMbox mbox = node.createMbox(); mbox.send("foo@localhost",new OtpErlangAtom("hej"));
If you need more control (but less support from the library), you
can manage connections yourself using the OtpSelf
and OtpConnection
classes, in which case you can
control explicitly which connections are made and which messages are
sent. Received messages are not dispatched by OtpConnection
.
The classes OtpPeer
, OtpSelf
and OtpServer
are used to represent OTP nodes and
are neccessary in order to set up communication between the Java
thread and a remote node. Once a connection has been established, it
is represented by an OtpConnection
,
through which all communication goes.
Setting up a connection with a remote node is straightforward. You
create objects representing the local and remote nodes, then call the
local node's connect()
method:
OtpSelf self = new OtpSelf("client","cookie"); OtpPeer other = new OtpPeer("server"); OtpConnection conn = self.connect(other);
If you wish to be able to accept incoming connections as well as make outgoing ones, you first must register the listen port with EPMD (described in the Erlang documentation). Once that is done, you can accept incoming connections:
OtpServer self = new OtpSelf("server","cookie"); self.publishPort(); OtpConnection conn = self.accept();
Once the connection is established by one of the above methods (connect()
or accept()
), you can use the resulting OtpConnection
to send and
receive messages:
OtpErlangAtom msg = new ErlangOtpAtom("hello"); conn.send("echoserver", msg); OtpErlangObject reply = conn.receive(); System.out.println("Received " + reply);
Finally, you can get an even greater level of control (and even
less support from the library) by subclassing AbstractConnection
and implementing the
communication primitives needed by your application.
|
|||||||||
PREV PACKAGE NEXT PACKAGE | FRAMES NO FRAMES |