An Overview of the ToolTalk Service
As computer users increasingly demand that independently developed applications work together, inter-operability is becoming an important theme for software developers. By cooperatively using each other's facilities, inter-operating applications offer users capabilities that would be difficult to provide in a single application. The ToolTalk service is designed to facilitate the development of inter-operating applications that serve individuals and work groups.
ToolTalk Architecture
The following ToolTalk service components work together to provide inter-application communication and object information management:
ttsession is the ToolTalk communication process.
This process joins together senders and receivers that are either using the same X server or interested in the same file. One ttsession communicates with other ttsessions when a message needs to be delivered to an application in another session.
rpc.ttdbserverd is the ToolTalk database server process.
One rpc.ttdbserverd is installed on each machine which contains a disk partition that stores files of interest to ToolTalk clients or files that contain ToolTalk objects.
File and ToolTalk object information is stored in a records database managed by rpc.ttdbserverd.
libtt is the ToolTalk application programming interface (API) library.
Applications include the API library in their program and call the ToolTalk functions in the library.
The ToolTalk service uses the Remote Procedure Call (RPC) to communicate between these ToolTalk components.
Applications provide the ToolTalk service with process and object type information. This information is stored in an XDR format file, which is referred to as the ToolTalk Types Database in this manual.
Starting a ToolTalk Session
The ToolTalk message server ttsession automatically starts when you open communication with the ToolTalk server. This background process must be running before any messages can be sent or received. Each message server defines a session.
Note - A session can have more than one session identifier.
To manually start a session, enter the following command on the command line:
ttsession [-a level][-d display][-spStvh][-{-E|X}][-c command]
See Table 2-1 for a description of the ttsession command line options.
Table 2-1 ttsession Command Line Options
Note - If neither the -c, -d, or -p options are specified, ttsession starts an X session for the display specified in the $DISPLAY environment variable.
ttsession responds to two signals.
Background and Batch Sessions
Run your application as its own session if it runs as a background job, in a batch session, or in a session bound to a character terminal. To run your application in its own session, use the -c parameter with the ttsession command, as follows:
ttsession -c [ command-to-non-in-batch ] |
This command will fork off a shell from which you can run your application.
Note - The -c parameter must be the last option on the command line; any characters placed after the -c parameter on the command line are taken as the command to be executed.
X Window System
To establish a session under the X Window System, execute ttsession either without arguments (which takes the display from the $DISPLAY environment variable) or specify the display with the -d parameter as follows:
ttsession -d :0 |
When ttsession is invoked, it immediately forks and the parent copy exits; the process managing the session executes in the background. The session is registered as a property, named by TT_SESSION on the root window of screen 0; the host and port number is given for communication with the process managing the session.
Locating ttsession
To display the sessid of the session for the Xdisplay:
xprop -root | grep TT_SESSION |
Maintaining ToolTalk Files and Databases
The ToolTalk package contains a special set of shell commands you can use to copy, move, and remove ToolTalk files (that is, files mentioned in messages and files that contain ToolTalk objects). After a standard shell command (such as cp, mv, or rm) is performed, the ToolTalk service is notified that a file location has changed.
The ToolTalk package also contains a database check and repair utility for the ToolTalk database, ttdbck, that you can use to check and repair your ToolTalk databases.
Demonstration Programs
The ToolTalk service source files contain two Motif-based demonstration programs: