CA2049125C - Methods and apparatus for implementing server functions in a distributed heterogeneous environment - Google Patents

Methods and apparatus for implementing server functions in a distributed heterogeneous environment

Info

Publication number
CA2049125C
CA2049125C CA002049125A CA2049125A CA2049125C CA 2049125 C CA2049125 C CA 2049125C CA 002049125 A CA002049125 A CA 002049125A CA 2049125 A CA2049125 A CA 2049125A CA 2049125 C CA2049125 C CA 2049125C
Authority
CA
Canada
Prior art keywords
server
class
software component
application
data base
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
CA002049125A
Other languages
French (fr)
Other versions
CA2049125A1 (en
Inventor
Neal F. Jacobson
Michael J. Renzullo
Paul A. Reilly
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Digital Equipment Corp
Original Assignee
Digital Equipment Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Digital Equipment Corp filed Critical Digital Equipment Corp
Publication of CA2049125A1 publication Critical patent/CA2049125A1/en
Application granted granted Critical
Publication of CA2049125C publication Critical patent/CA2049125C/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/547Remote procedure calls [RPC]; Web services
    • G06F9/548Object oriented; Remote method invocation [RMI]

Abstract

In distributed heterogeneous data processing networks, dispatcher and control server software components execute the code of a single application or of many portions of the code of one or more applications in response to a method object received from a client application. The method object includes a reference to the code to be executed.

Description

204~1 2~
I. RFLATED APPLICATIONS
This appllcatlon is related to U.S. Patent Number 5,280,610 entltled "METHODS AND APPARATUS FOR IMPLEMENTING
DATA BASES TO PROVIDE OBJECT-ORIENTED INVOCATION OF
APPLICATIONS", Canadlan Patent Appllcatlon Number 2,049,143 entltled "METHODS AND APPARATUS FOR PROVIDING A CLIENT
INTERFACE TO AN OBJECT-ORIENTED INVOCATION OF APPLICATIONS"
and Canadlan Patent Appllcatlon Number 2,049,121 entltled "METHODS AND APPARATUS FOR PROVIDING DYNAMIC INVOCATION OF
APPLICATIONS IN A DISTRIBUTED HETEROGENEOUS ENVIRONMENT", both flled the same date as thls appllcatlon.
II. BACKGROUND OF THE INVENTION
This lnventlon relates to the lnteractlon of computer appllcatlons across a heterogeneous data processlng network. Speclflcally, thls lnventlon relates to the organlzatlon of a data processlng network ln accordance wlth an ob~ect-orlented model and the lnteractlon of lndependent appllcatlons across such a heterogeneous network envlronment.
Computers communlcate wlth each other over data processlng networks. The computers themselves are referred to generally as "nodes", and a speclflc type of computer, that ls a speclflc type of hardware uslng a speclflc type of operatlng system, ls referred to as a "platform". Networks contalnlng dlfferent types of platforms are called "heterogeneous networks". One purpose for connectlng platforms ln a network ls to provlde dlfferent envlronments ln whlch to execute application programs (referred to a "appllcatlons" for brevlty) on shared data.

*

,~

204912~

1 In the typical data processing network, different platforms and applications running on different platforms store information in their own specific manner. For example, in a VAX.VMS platform, text editing tasks may be accomplished using a TPU text editor, while in a MIPS.ULTRIX platform, text editing tasks may be ;accomplished using an EMACS text editor. Users of a network having both platform~ may wish to use operation~ from the different text editors on the different platforms without having to know the details of those platforms and text editors.
I This compatibility has not previously been po~sible.
Instead, co.,ventional networks require u~ers of a heterogeneous network to employ the specific interface each application requires for operations on specific platforms. Conventional networks fail to provide users with a capability to communicate between application~ using a stAn~Ard interface.
A~ an example of the difficultie~ of interapplication communication on a conventional heterogeneous network, suppose ~that the user of a text editor application on one platform desired to access a multi-user data baæe retrieval service, such as DIALOG
Ifor scientific Articles or LEXIS for court opinions, on another platform. To do so on a conventional network, the text editor applic~tion's operation would have to be suspended, and the data base retrieval service would have to be invoked using commands and messages ~pecific to the data base retrieval service. The user would not only need to know the specific names of each service desired, but would also have to know the location of the service 204912a I
1 in the network and would have to be familiar with the different commands and command formats employed by each service.
As yet no stAn~rd interface has been developed to allow an application in one platform to invoke an application on a different platform in a heterogeneous network in an efficient and uncomplicated manner. Instead, conventional interapplication communication merely provides mechanisms for physically transporting messages and data between applications.
One example of a mechanism which is presently used to allow an application on one platform to communicate with an application on a different platform is a Remote Procedure Call (RPC) system.
An RPC system on one platform responds to queries from an '~'invoking" application by first translating that application~s ,messages into a network data format, and then transmitting the 'translated queries over the network to a receiving platform. At the receiving platform, another component of the RPC system decodes translated messages into queries in a data format acceptable to the application invoked. The original messages from the invoking platform, however, need to be consistent with a syntax dictated by the invoked application-.
Another difficulty with conventional networks occurs when the application on a remote node is not currently loaded and running.
Many RPC systems only allow remote invocation of applications that are already loaded and running. If this is not the case, the user of the client applications must find some way to load the server application on the remote platform before invoking it. This can be ~everely limiting.
2 ~
-One obstacle to lmplementlng a network-wlde system to facilltate lnterappllcatlon communlcatlon has been the large amount of system resources whlch had been thought to be requlred of a system ln order to handle all the dlfferent types of data, operatlons and appllcatlons ln a network. As a network expands, the systems, resources, and requlrements would lncrease as well, maklng many proposed lmplementatlons completely unwleldy.
There ls, therefore, a need for an efflclent and slmple manner for appllcatlons on dlfferent platforms to be lnvoked, such as through a unlform and conslstent envlronment.
There ls also a need for a dynamlc lnvocatlon envlronment for appllcatlons ln a dlstrlbuted heterogeneous envlronment. Thls lncludes provldlng the ablllty for appllcatlons that are not yet loaded and runnlng to be lnvoked as well as those whlch are.
III. SUMMARY OF THE INVENTION
To achleve these needs, the present lnventlon provldes for lnteractlon of processes ln an ob~ect-orlented manner by whlch a dlspatcher and a control server execute appllcatlons ln response to methods ob~ects, whlch are references to code to be executed, recelved from a cllent appllcatlon.
The lnventlon, ln lts broad form, resldes ln a network contalnlng a memory and processors connected to each other by a network bus, the memory storlng a context data base and a global data base, the global data base lncludlng methods and appllcatlons, the context data base lncludlng preferences, A

2Q4~1 2~
-the preferences for ldentlfylng the methods, the appllcatlons, and the processors accordlng to a predetermlned order, the processors havlng shared access to the context data base and the global data base, a process to execute the appllcatlons comprlslng the steps of: referenclng ln the global data base, by a cllent appllcatlon executlng on a cllent processor, a method and an appllcatlon to perform the method; ldentlfylng, ln response to the referenclng and uslng the preferences, a server appllcatlon to perform the method; determlnlng lf the server appllcatlon ls available ln the network; lf the server appllcatlon ls not avallable, ldentlfylng, uslng the preferences, a server processor, startlng the server appllcatlon on the server processor, and slgnalllng the cllent processor that the server appllcatlon ls avallable; and lf the server appllcatlon ls avallable ln the network, executlng the server appllcatlon to perform the method.
More partlcularly, ln a data processlng network contalnlng a plurallty of data processlng platforms for executlng appllcatlons, whereln a cllent one of the data processlng platforms generates a method ob~ect from a message sent by a cllent one of the appllcatlons executlng on the cllent data processlng platform, the method ob~ect lncludlng a reference to a flrst method, a process of performlng the flrst method on a server one of the data - 4a -1 I processing platforms according to this invention comprises several step~. These step~ include receiving the method ob~ect by the server data processing platform, extracting the reference to the lfirst method by the server data processing platform, analyzing the ,extracted reference to determine a server one of the applications to be executed to perform the first method and executing the server applicstion on the server data processing platform to perform the first method.
Alternatively, in a data proce~sing network cont~i~ing a Iplurality of data proces~ing platforms executing applications which include a client one of the data processing platforms for generating a method ob~ect from a message sent by a client one of the applications executing on the client data processing platform, Ithe method ob~ect including a reference to a first method, a Iserver one of the data processing platforms according to the pressent invention comprises means for receiving the method ob~ect; means, coupled to the receiving means, for extracting the reference to the first method; means, coupled to the extracting means, for analyzing the extracted reference to determine a server one of the applications to be executed to perform the first method; and mean~, coupled to the analyzing means, for executing the ~erver application to perform the first method.
The accompanying drawings which are incorporated in and which constitute part of this specification, illustrate an implementa-tion of the invention and, together with the description, explain the principles of the invention.

2 0 ~ 9 1 2 ~

-1 ( IV. BRIEF DESCRIPTION OF DRAWINGS
Figure 1 i8 a diagram of a network which can be used in a preferred implementation of the present invention.
Figure 2 i~ an illustration of the ma~or components of an ob~ect-oriented model of this invention in relationship to an application.
Figure 3 is an illustration of the relationships between the components of the ob~ect-oriented model of this implementation of ;;the present invention.
' Figure 4 is an illustration of the relationships between examples of the component~ of the ob~ect-oriented model of this invention.
Figure 5 is an illustration of a structure for a class data base according to the preferred implementation and consistent with the relationships illustrated in Figure 4.
Figure 6 i8 a diagram of the different components of the preferred implementation, and of the preferred flow of information between these components.
Figure 7 is a diagram showing the relationships of the different memory systems in the preferred implementation.
Figure 8 is a diagram of a preferred structure of a local class data bs8e.
Figure 9 is a diagram of a preferred implementation of a block in the local class data base shown in Figure 8.
Figure 10 i~ an illu~tration of the function of a loader/
unloader for a global data base, a local data base, and a node cache.

204912~

Figure llA is a diagram illustrating a preferred implementation of a context object data base.
Figure llB is a diagram illustrating a preferred implementation of a method override table in the context object data base shown in Figure llA.
Figure llC is a diagram illustrating a preferred storage structure for a server node table in the context object data base shown in Figure llA.
Figure llD is a diagram illustrating a preferred implementation of a class data base override table in the context object data base shown in Figure llA.
Figure 12 is a diagram of individual software components in the platforms of the network.
Figure 13 is a flow diagram of the general operation performed by the preferred implementation of this invention for remote invocation of apPlications.
Figure 14 is a more detailed diagram of components of the network and the flow of information.
Figures 15A through 15D are a flow diagram of the procedure performed by the invoker software component in Figure 14.
Figure 16 is an illustration of the steps performed by the invoker software component in Figure 14 to resolve a method.
Figures 17A and 17B are a flow diagram of the steps performed by the control server software component in Figure 14.
Figures 18A and 18B are a flow diagram of the steps performed by the dispatcher software component in Figure 14.

1 V. DE~AIT-~ DESCRIPTION OF THE PREFERRED IMPLEMENTATION
Reference will now be made in detail to preferred implementations of the invention as illustrated in the l'accompanying drawings.
This invention is preferably implemented by data processors organized in 8 conventional network architecture. The architecture for and procedures to implement application interoperability, however, are not conventional, as they provide for an ob~ect-oriented approach to the interactions between applications in the network.
A. The Ma~or comPonent~ of the Network ; Figure 1 illuQtrates a network 50 which can be used to ~implement the present invention. In Figure 1, network 50 contains Ithree independent platform~ 100, 200, and 300 which are connected by a network bus 55. Although platforms 100, 200, and 300 are ~hown a~ completely heterogeneous (i.e., platform 100 is shown as a VAX proceQsor using a VMS operating system, platform 200 is ghown 8~ a MIPS processor u~ing an ULTRIX operating system, and platform 300 is shown as an 80286 proce~sor using a MS-DOS
loperating system), this invention will operate in a homogeneous network a~ well. Also, the number of platforms is not important.
The composition and protocol of the network bus 55 is not important as long as it allows for communication of the information between platforms roo, 200, and 300. In addition, the specific network architecture is not crucial to this invention.
For example, another network architecture that could be used in accordance with thi~ invention would employ one platform as a .
1 network controller to which all the other platforms would be connected. It is believed, however, that the network 50 shown in Figure 1 enhances the advantages of the present invention.
I In the preferred implementation of network 50, platforms 100, 200, and 300 each include a central processing unit ("CPU") 110, 210, and 310 respectively, and a memory, 150, 250, 350, ~,reflfffffpectively.
Included within each central processing unit 110, 210, and 310, are application~ 120, 220, and 320, respectively, operating systems ("OP SYS") 140, 240, and 340, respectively, and the Application Control Architecture Services ("ACAS~) software components 130, 230, and 330, respectively.
~ ; Applications 120, 220, and 320 can be program-l that are either previously written and modified to work with the present 'invention, or that are specially written to take advantage of the services offered by the present invention. For purposes of this description, applications either invoke operations to be performed in accordance with this invention, or re~pond to the invocation by other applications.
1 ACAS ~oftware components, 130, 230, and 330 implement the ob~ect-oriented approach of this invention. Preferably, ACAS
software componentf~ 130, 230, and 330 consist of a number of fffffoftw~re module~ as described in grester detail below.
Operating systems 140, 240, and 340 are the standard operating systems which are tied to the corresponding CPUs 110, 210, and 310, respectively, of the platform 100, 200, and 300, respectively.

204912~

..
1 Nemories 150, 250, and 350 serve several functions. One of the function~ is, of course, to provide general storage for the associsted platform. Another function is to store applications ' 120, 220, and 320, ACAS software components 130, 230, and 330, and operating systems 140, 240, and 340 prior to their execution by the respective CPU 110, 310, and 310.
In addition, portions of memories 150, 250, and 350 contain information for a network wide, or "global,~ data base which is shared and available directly or indirectly by all of the platforms 100, 200, and 300 in network 50. The global data base is described in greater detail below.
B. Elements of the Oblect-Oriented Architecture (1) Definitions of the Element~
Ob~ect-oriented methods have been used in programming to 'separate the interface of data from actual implementation, but 'such method~ have not been applied to heterogeneous networks. In the present invention, ob~ect-oriented techniques are used to ~separate the actual applications and their data from the implementstion of operations on that data by other applications.
j The ob~ect-oriented architecture of this invention preferably includes certain key elements. Figure 2 explains the relationship between certain of tho~e elements and certain conventional features of ~pplicstion~. As shown in Figure 2, an application 260 can be described in two ways. First, that application has certain application definitions 265. For example, if the applicstion 260 i~ a word processing program, then the application definitions could include definitionq of what operations that word 20~9125 1 proce8~ing ~-oy~am can perform and what kind of data that word processLng sy~tem can operate upon.
In addition, application 260 includes application data 268.
~ Application data 268 is the specific data upon which application 260 operates.
In accordance with the present invention, the application data is not "handled" by the ob~ect-oriented architecture.
Instead, the present invention is organized around characterizing the application definitions and the application data in terms of ob~ect types, as referred to in the remainder of this description as ob~ects. Ob~ects are not shown in Figure 2, but they pervade the elements that are shown.
In the discussion which follows, the term "ob~ectl~ will refer Igenerally to several different kinds of elements, all of which have two characteristics in common. First, they refer to external capabilities, me~ning that ob~ects refer to or describe those ~portions of application definitions or application data which need to be communicated with other applications. Second, they are generic meAning that ob~ects are intended to be available to all applications, and as such have a universally recognized and unique name for all applications that have interfaces to the ob~ects.
The present invention involves the handling of objects rather than the hAn~l ~ng of specific data or applications.
I As shown in Figure 2, two~elements of the ob~ect-oriented architecture of this invention are developed from the application definitions 265. One is classes 270 and the other is methods 280.
Classes are ob~ects in the sense that the names of the classes and 204912~

I
l I the featurQs of the classes are both external and generic.
Furthermore, classes can be used as means for describing not only applications, but also the data used by the applications.
' In addition, one can derive certain types of operations from the application definitions 265 that are performed by that application, and these are specific examples of methods 280.
Again, however, the specific methods 280 are not managed by the system, but rather can be organized into classes. The classes for those methods (called method ob~ects) are generic and external, 'even through the specific commands or operations executed by the applications are not.
Instances 290, which are derived from the application data ~268, are items that may be manipulated or accessed by an application. Again, the instances are not ob~ects managed by this architecture. Instead, instances are organized into classes such that instances in the same classes share common characteristics.
For example, a specific DECwrite application, which is a compound document editor, may be operating on a specific file called MYFILE. This is a specific file, and it is not handled by the IACAS system. Instead, MYFILE may belong to a class of compatible files, such as ASCII FILE, which is generic and therefore a class ob~ect.
By the same token, a specific DECwrite application is not managed by the entire system. ~Instead, however, the specific DECwrite application may belong to a class called DECwrite which is generic and a class object.

20491~S

1 A~ can be seen from Figure 2, applications can then be chsracterized by the classes to which the applications belong, by ! the cla~ses (method ob~ects) which support the specific methods in I that application, and by the class ob~ects upon which the method ob~ects can operate.
One of the features of classes is that they may be hierarchically organized. This is explained in greater detail below, but may be understood preliminarily by considering the I concept of superclasses and subclasses. A superclass is a parent of its subclasses, and each subclass is a child of at least one superclass. The superclass/subclass relationship means that the attributes or shared characteri~tics of the superclass are inherited by the subclass. For example, a class of DATA_FILES may have as attributes the capability of being opened, read, and ~written. Two subclasses of the class DATA_FILES could be of S~Q~ IAL FILES and RANDOM ACC~SS FILES. In addition to the attributes of being able to be opened, read, and written, the subclass S~g~ IAL FILES could also have the attribute of being accessible sequentially, and the subclass RANDOM ACCESS_FILES
could have the attribute of being accessible directly by an address.
Another element of the ob~ect-oriented architecture of this invention not reflected in Figure 2 is messages. Messages are the interfaces between an application program and the methods, and are used in the application program to specify types of operations which can be performed on the instances identified in the client application. The messages are generally in the form of a selector 204912~

1 of an operation, such as PRINT, and ceveral parameters, which can be instances, C~trings, numbers, etc. The relationship between these element~ is described in the next section.
1 (2) RelationshiP of Elements I Figure 3 i8 a diagram showing the relationship of the different elements previously described. As Figure 3 demonqtrates, each instance 370 is associated with a class 380.
Another way of underst~n~ing this is to consider class 380 as a ~template" for the creation of ob~ects in that class, which can be inqtances, as well a~ for the manipulation of such ob~ects. The term ~template~ denotes the fact that the ob~ectq (be they data items, methods, or applications) in each class, ~hare certain - characteristics or attributes determined by that class.
I An instance 370 is manipulated by sending a message 360. The message 360 might be an action, such aa EDIT, READ or PRINT.
Messages are said to be "supported" by the class, which means that the interpretation of the message depends upon the classes to which the instances in that messagQ belong. For example, a PRINT
message may be interpreted differently if the instance is a text file in the class TEXT_FILE, as opposed to a color graphics file ¦ in a cla88 COLOR_GRAPHICS.
A mes~agQ 360 doQs not describe the implementation of a particular operation; it only represents the interface to the implementation of a particular-operation. Thu~, to find the particular operation that is called for by a particular message 360 (i.e., the method), one mu~t not only examine the message, but ~also the class of the instance. To cause a specific action to _ 14 -1 occur, the mQssage 360 must be mapped to actual executable program code. This mapping occurs by finding the particular message 360 which corresponds to the particular class 380 of the particular instance 370 and then finding the particular method 390 which corresponds to the message 360 supported by the class 380. The method 390 represents the actual executable program code to implement the desired operation of the message 360 on the instance 370.
~ (3) Or~anization I Figure 4 shows a representation of how the different object-oriented architecture elements can be organized preparatory to their specific representation in memory. As is apparent from Figure 4, there is a complex relationship involved between the classes and the methods. A hierarchy is used for both methods and lS classes in the preferred implementation to effect the object-oriented approach neces~sry to reflect the behavioral relationships which must exist among the applications. The specific example~ given, however, are merely illustrative, and other types of representations for these classes and methods may be apparent to those skilled in the art.
In the diagrammatic representation shown in Figure 4, there are essentially two branches of the hierarchy. One is headed by ! method ob~ect 400 and the other by class 450. The branches, hierarchies differ by what is inherited. In the class hierarchy, ~~ the inheritance is of behavior because such inheritance includes messages. In the method hierarchy the inheritance is only of attributes. The bridge between the class hierarchy and the method -1 hierarchy is by way of the messages, such as messages 490 and 495, and the method maps, such as maps 493 and 498. In the method hierarchy shown in Figure 4, method objects, 410, 415, and 420, I which are repre~ented as WORD_C CUT_MS-DOS, WORD C READ_VMS, and WORD C_READ_ULTRIX, respectively, inherit from method ob~ect 400.
For example, in Figure 4, method ob~ect 400 may have attributes (not shown) that indicate that the methods, use a certain interaction type, and have a certain server start-up type.
Method ob~ect 410 is representative of the CUT function in EMACS applications. Associated with method 410 is a set of attributes 430 which includes those inherited from method object 400. Briefly, the PlatformType attribute indicates the platform on which the method ob~ect can be executed. The InteractionType attribute describes the actual type of method which will ~e executed within a particular method server. Examples of values for this attribute which are explained below, are: BUILT IN, SCRIPT_SERVER and DYNAMIC_LOAD. The ServerStartupType attribute indicates an appropriate invocation mechanism to be used for the method ser~er. Examples of values for this attribute, which are also explained below, are: SHELL, DYNAMIC_LOAD and NAMED APPLICATION.
; The ~et of attributes 430 specify that the associated methods operate on platform~ which have an 80286 processor with the MS-DOS
loperating system, and have a BUILT IN, interaction type, and a NAMED_APPLICATION server start-up type.
Similarly, method ob~ect 415, which is representative of the READ function in EMACS applications. Associated with method 415 _ 16 --1 is a set of attributes 435 which include those inherited from method ob~ect 400, but which also specify that the associated methods operate on VAX platforms running the VMS operating system, ' and have an interaction type of ~UILT_IN, and a NAMED_AP~LICATION
server start-up type.
Method ob~ect 420 is a subclass of method object 400 representative of the READ function in EMACS applications. The attributes 440 for method class 420 have a platform type with a MIPS processor running the ULTRIX operating system with a BUILT_IN
interaction type, and a NAMED_APPLICATION server start-up type.
Class 450, on the other hand, i8 a superclass of class 460 called FILES, and a class 465 called APPLICATIONS. Class 460 refers to data ob~ects. As shown in Figure 4, class 460, which would have attributes (not shown), is a ~uperclass of class 470.
Class 470 iq called ASCII_FILE. For example, class 470 could represent all the files within network 50 (see Figure 1) having the common chsracteriqtics of ASCII files. The common characteristics can be described in the attributes for class 470, which are not shown in Figure 4.
The cla~8 470 would then be the class for several instances, but the instsnces are not shown in Figure 4 because they are not managed by the ob~ect-oriented architecture. What is shown in Figure 4 are the messages which the class 470 will support, and the only one shown for purposes of simplicity is the EDIT message 490.
A cla~ supporting a message means that when the message is used as an interface into this ob~ect-oriented architecture, it 20~912.~

1 can be u8ed with the class that 8upports it, and therefore instances within that class. Thus, in the example shown in Figure 4, an EDIT message, can be sent to all instances in the ~ ASCII FILE class.
APPLICATIONS class 465 is also a superclass, and one of its subclasses, EDITOR class 475, is shown. EDITOR class 475 is a ! superclass to specific applications classes 480, 483 and 485, corresponding to WORD A, WORD_B, or WORD_C. Each of the classes, such as WORD_C 485, represents a specific application, such as IEMACS or TPU. Thu~, each application is defined by one class. An application class may, however, refer to the implementation behavior of more than one application.
The application classes also support messages, which is shown by the message CUT 495 being supported by the application class 485. This reflects the fact that at the time of class definition, it was determined that any application repre~ented by the class 485 would have to support a message CUT.
A~ mentioned briefly above, in the preferred implementation, applications are organized into a hierarchy of classes with a parent class, referred to as a superclass, and child classes referred to as subclasses. In Figure 4, class 465 is a superclass called EDITOR. All subclasses of this superclass would have at lesst the same set of particular unique characteristics or attributes of the superclass. ~In Figure 4, the subclasses of super class 475 EDITOR are WORD_A 480, WORD_3 483, and WORD_C 485.
WORD_A might represent TPU applications, WORD_B 483 might represent all LSE applications, and WORD_C 485 might represent all 204912~

1 EMACS applications. Each of these subclaqses would have, in addition to the characteristics and attributes inherited from superclass 475, their own set of unique characteristics and attributes which differ in such a manner as to enable their S separation as subclasses within the superclass 475 EDITOR.
In the preferred implementation of this invention, specific rules of inheritance allow for multiple inheritance among classes.
This means that any subclass may have more than one superclass.
Because this type of inheritance may create ambiguities at definition time, the superclasses are con~idered to be "ordered~
at definition time to resolve potential inheritance conflicts.
For instance, at the time of the definition of a subclass described below, if any conflicts arise due to the duplicate definition of a message or attribute in more than one of the ,listed superclasses, the message or attribute defined in the highest ordered class is considered to be the one inherited by the subclass.
1 As mentioned above, the relation~hip between the method ;ob~ects and the class is by way of method maps. Figure 4 shows two method maps 493 and 498. Each of the classe~ has messages each of which refers to a specific method map. Thus, method map 493 is associated with EDIT me~sage 490, and method map 498 is associated with the CUT message 495.
Preferably, the method maps include the name of a method ^~ ob~ect associated with the messages. Method maps could also contain the name of another class and message. Thus, method map 493 includes the name of two method ob~ects. Method map 493 204912 ~
!
1 includes the n ~me of a method ob~ect WORD_C_READ NIPS.ULTRIX 494, which is a name for method ob~ect 420, and the name of a method ob~ect WORD_C_READ VMS 496, which is a name of method object 415.
I' In a similar manner, the meth'od map 498 for the message CUT
l495 contains the name WORD C_CUT 80286.MS-DOS 499, which is the name of the method ob~ect 410.
In this way, the method maps 493 and 498 can be used to locate the attribute sets 430, 435, and 440 corresponding to the ,method ob~ects 410,'415, and 420, respectively. The specific manner in which this type of order i8 used to locate methods is 'described in greater detail below.
C. Class Data Base Structure The classes and method ob~ects of the network architecture ' are stored in a claqs data base 500 depicted in Figure 5. The 'class data base 500 represents a nonredundant collection of interrelated data items that can be shared and used by the network 50.
In Figure 4, the cla~s data base 500 consists of two types of `ob~ects, similar to what is shown in Figure 4. The ob~ects are either classe~ 505 or methods 549. Each of the classes 505 corresponds to a generic external representation for the instances of the correspo~ g class. For example, in Figure 5, the class ob~ect ASCII_FILE 506 correspond~ to a generic external ~representation for all members of the set of instances that have the characteri~tics of the class ASCII FILE 506. The characteristics are represented by the corresponding set of attributes 510.

20~912~

1 i In the preferred implementation, the attributes 510 which correspond to the classes 505 may be used in whatever manner the system developer or user wishes. For example, the attributes Sll for the class ASCII_FILE 506 may include the name of an icon to represent class 506 on display.
Each of the claases 505 al~o supports a set of messages 520.
A message consists of a "verb" or message name, such as CUT, READ
or EDIT, called a selector, and parameters. Each of the parameters consists of a name and a type and a direction. The name is "typed" which means that the name is of a particular type, e.g., integer, character or string. The possible directions for each parameter may be "in," ~'out,~' and "in/out." When a parameter in a messsge has an "in" direction, thi~ mean-~ that the parameter ~is an input to a method to be invoked (discussed below). When a parameter in a message has an "out" direction, this means that the parameter is an output from a method. When a parameter in a message has an "in/out" direction, it means that the parameter is both an input to and output from a method.
The messages 520 are representations for the valid operations that each of the instsnces represented by the corresponding class 500 csn support. For example, in Figure 5, class object ASCII_FILF 506 supports the set of messages 520 which includes message~ 521 snd 525. The specific messages in message set 520 are OPEN (PARA 1, PARA_2...) 521 and EDIT (PARA_1, PARA_2...) 525.
;For example, in the message EDIT (PARA_1), PARA_1 might represent ~FileName: string, in/out," where FileName is the name of the ., .

!

. .
1 ; parameter, string is the parameter type, and in/out is the direction of the parameter.
Messages 521 and 525 each refers to respective method map 530 and 540. Each of the method maps 530 and 540 contains a set of S references to corresponding method ob~ects 549 in the class data base 500 or to the names of other classes and messages. For example, method map 530 contains references 531 and 533 each of which corresponds to a different method object (not shown).
Method map 540 also contains references 541 and 543, each of which corresponds to a different one of the method objects 549 in the class data base 500. The corresponding method ob~ect for the reference 541 i8 not shown in Figure 5. For purposes of this example, Figure 5 does show that the reference 543 on method map 540 refers to the method ob~ect 550 which is ED_3 READ.
As explained above, the method ob~ects 549 in the class data base 500 are also stored hierarchically. Each of the method objects 549 is representative of a reference to executable code - capable of performing a method.
In a network data processing system like the preferred implementation, there may be many instances of the executable code ! associated with each of the method ob~ects 549 and capable of perform~ng the functions identifie~ by each method ubject. By way of example, in each the memories 150, 250 and 350 (Figure 1) there may be an installation of the executable code associated with the : method ob~ect ED 3_ READ 550, with each of the executable codes being capable of performing the functions of the method object ED_ 3 READ 550 on a respective one of the platforms 100, 200, and , 2049125 1 300. The sy~tem according to the preferred implementation includes a proce~s which selects between the three executable ~codes.
I Unlike the attributes 510 associated with the classes, the method attributes 560 of the class data base 500 associated with method ob~ects 549 are used to locate and to execute an instance asqociated with a particular method ob~ect, such as method object 550, in the network. For purposes of simplicity, Figure 5 shows only one set of method attributes 561 in the class data base 500.
The set 561 is associated with the method object 550 of the method ob~ects 549 in the class data base 500. Although ~ome of the method attributes in set~ 560, can be arbitrarily specified by the users of the Qystem and used by the system during execution, certain attributes are critical to the operation.
A~ shown in Figure 5, the method attributes in set 561 includes PlatformType = 80286.MS-DOS, InteractionType = BUILT IN, and ServerStartupType = SHELL.
In the preferred implementation, two other method attributes are included in the method attribute set 561. One is an InvocationString attribute which defines an invocation string to be used in order to start the specified method server if it needs to be started. The value of this attribute must be a value appropriate for the particular platform specified in the first 'attribute. For example, if the value of the PlatformType ~~ attribute is MIPS.ULTRIX and the value of the ServerStartupType attribute is SHELL, then the value of this attribute should be an appropriate ULTRIX shell command.

.

204912~
, 1 1 D. Information Flow Before di~cu~sing the details of the preferred implementation ,of this invention, the flow of information throughout the entire l5y5tem will be explained with reference to Figure 6.
I Figure 6 includes a diagram 600 showing different components of the network 50 shown in Figure 1 and the information flowing ~between those components. Applications 610 and 670 in Figure 6 each correspond to any one of the applications 120, 220, or 320, respectively, and the ACAS software components 620 and 660 each I correspond to anyone of the ACAS software components 130, 230, or i330. The cla~ data bases 640 and the context ob~ect data bases 630 are stored in one or more of the memories 150, 250, and 350.
As expl~ineA in greater detail below, an application 610, which will be referred to a~ a ~client application,~ sends ' message~. The mes~ageq may include instance handles which are the 'mechanisms used to identify the client (or any other) application's instances. The messages are received by the ACAS
software component 620 in the client platform.
I ACAS software component 620 then uses the names of the ime~ages and the classe~ of the in~tances referred to by the instance handles to find the method maps in clas~ data bases 640.
ACAS software component 620 may also use context information from context ob~ect data bases 630 to select a method identifier from the method map which identifier represent~ the method to be executed. The context information i~ alqo used to select a platform, called the ~'server platform," on which to execute the 204912.S

1 selected method. The context information will be described in detail below.
ACAS software component 620 sends the method identifier lretrieved from the class data base 640 and the instance handles to an ACAS software component 660 in the server platform.
Thereafter, the ACAS software component 660 takes the appropriate steps to execute the identified method using a "server application" 670 or informs the ACAS software component 620 that the server platform contAi~ing ACAS software component 660 cannot ~respond to the reque~t. In thi~ latter case, the ACAS software component 620 then reviews the context information to select another platform in the network as a ~erver platform or else informs the client that the requeQt has failed.
' If the execution of the method identified in Figure 6 by the server application 670 generates a me~sage to be returned to the client application 610, then that message along with additional information i~ passed from server application 670 to ACAS software component 660 in the server platform. ACAS software component 660 ~in the server platform then sends reqpon~es to ACAS software component 620 in the client platform, which relays those responses to the client application 610 in the client platform.
All these tran~actions will be de~cribed in greater detail ~below.
E. MemorY SYstems (1) Global Class Data Base A diagram of the entire memory sy~tem 700 is ~hown in Figure 7. Memory system 700 include~ a global class data base 705 204912~

1 and local clas~ data base~ 710, 730 and 750. A network-wide memory 705 i8 al~o provided to make certain other information, described below, available to users of the network.
I Global class data base 705 contains information accessible by S all of the platforms. Preferably, global class data base 705 is distributed throughout the memories of the platforms. For example, in Figure 7, global class data base 705 is shown as being partially resident in each of memories lS0, 250, and 350. The remainder of the global class data base 705 would be resident in Iother memories which are not shown in Figure 7. The contents of the global clas~ data base 705 have already been described with regard to Figure~ 4 and 5.
Persons of ordinary skill in the art will recognize that the Idistributed memory arrangement shown in Figure 7 iQ not required to practice the present invention. For example, the entire global clas~ data base 705 could be stored in the memory of a single node or in a dedicated memory, without affecting the principles of this invention.
In addition, each of the memorie~ 150, 250, and 350, is shown ;as having a local cla~s data base 710, 730, and 750 as well as a node cache 720, 740, and 760, respectively. The information in the local class data bases is acce~sible only by u~ers on the corresponA~ng platform. Node caches 720, 740, and 760 are used to Ihold a copy of portion~ of global clas~ data base 705 which are acce~sed frequently by the corresponding platform.
The data base system used to implement the global class data base structure should support global uniquene~ of names within a 20991~

1 single data base, uniqueness of identifiers across data bases, access control mechanisms, and proper storage and retrieval mechanisms. Global name uniqueness is important for ob~ects because they are generic. Identifier uniqueness allows data bases to be combined, as explained below.
Access control mechanisms of the data base system must allow an authorized user on any platform in the network to store and retrieve objects and attributes, and mu~t provide security control and syntax checking to avoid compromising the integrity of global class data base 705. Some of the details of this control are discussed below. The remainder involve well-known data base ~management techniques.
The preferred implementation requires that each object in global class data base 705 can be assigned an ob~ect identifier which, like an object name, can be used to refer to an object.
Object identifiers are also preferably language neutral because they are binary code~.
Object identifiers are assigned based upon a "globally' agreed-upon scheme, and are unique throughout any number of class data bases. Object n~mes, on the other hsnd, need be unique only within a single class data base. The differences between the class n~mes and identifiers can be better appreciated by an example. Assuming two companies each have their own class data base and wish to merge those data bases. Those data bases may ~' have classes with the same names which should be different in the merged data base, and that difference can be maintained through the globally-unique identifiers. The data bases may also have two 204912~

1 ~I clas8es with different names which should be the same in the merged data base. Those classes can be set to have the same class identifier. Thus, the ob~ect identifiers also permit the same Iclass in the global class data base to be identified by more than one class name. For example, the class name EDITORS in the global class data base in the network may also be identified by the class name WPROCESSORS.
Another software component which is also included in each of the ACAS software components 130, 230, and 330, provides the mechanism to create a unique ob~ect identifier for use and storage `in the class data bases. Preferably, any storage scheme employed by an application which requires the persistent storage of object names should store the ob~ect identifiers rather than the object names to avoid naming conflicts between multiple global class data jbases.
The global class data base 705 is not meant to store application instance data because preferably applications completely manage their own sets of application instance data.
This allows existing applications to continue their current storage strategies, and does not restrict the storage options available for new applications.
The preferred implementation provides two mechanisms, however, ~torage classes and instance naming, which enable applications to link their privately managed instances with the global class data base 705 maintained by the preferred implementation.

204912~
!
-1 Storage classes are an abstraction that allow an application to speCify how privately managed instances are to be interpreted.
The storage classes give an alternative to identifying the class of each instance when the instance is used in a message. In the preferred implementation, storage clas~es identify storage systems, such as repositories or files, which contain names of instances. For example, a storage class can describe a known ~torage mechanism such as "RMS FILE" or "UNIX_FILE."
In the ob~ect-oriented architecture of this invention, , storage classes are also considered to be classes. Similar to other cla88es stored in the clas8 data base, the storage class can be viewed as an actual ob~ect-oriented class definition that consists of attributes, messages, and methods. The methods lassociated with each storage class are used to retrieve the class name for an instance associated with the particular storage system identified by the instance' 8 storage class.
The other mechani~m, in~tance naming, employs a stA~Ard for the naming of instances in the preferred implementation. The stAn~Ard instance handle is a string represented by the following logical structure:
~cl~ss><storage clas~><location><instance_reference_data>
The term "classH is the name of the associated ACAS class. The term "storage classH is an alternative to the cla~s name and is the name of the ~torage class. ~ The term "location" is the logical location, such as the node, of the instance. The "location" is optional and will be used if a client desires a method to run at the same location as the instance i~ located. The term I 20~9125 1 "in8tance_reference_data~' is the application private portion of the instance handle.
Instance handles allow implementations to refer to instances i abstractly, thereby avoiding the need to manage the instances I themselve~.
The instance handle preferably includes the class or storage class (if necessary), location of the instance, and the identifier for the instance~ For example, in the messages EDIT (INSTANCE HANDLE) EDIT represents the desired operation. The INSTANCE_HANDLE string could be ASCII FILE/NODE l/MYFILE.TXT. In this instance handle, ASCII FILE represents the class, NODE 1 i~ the location of the instance, and MYFILE.TXT is the identifier of the instance. This i message provides sufficient class and message information to find ~ the proper method map. It will be apparent to those of ordinary skill in the art that other formats may be employed for the INSTANCE ~AN~T-~ string to accomplish the same ob~ectives as the preferred implementation does.
~ As expl~ine~ above, all classes in a global class data base lof the preferred implementation have unique names with the particular global class data base. The class name is generally assigned by the user who first defines the cla~s.
(2) Local Class Data Bases I In addition to a global class data base, the preferred limplementation also support~ local class data bases for class and method definitions. The local class data bases function similar to the global class data base, except the contents of the local Il 2049125 1 class dsta bases are not globally available. They need only be ; available for their locsl node. Thus, the local class data bases need not be distributed or replicated in other nodes.
Figure 7 shows a preferred implementation of the local class S data bases 710, 730, and 750 in memories 150, 250 and 350, respectively. The local class data bases 710, 730 and 750 hold the class and method information crested by the corresponding nodes which has not yet been added to the global class data base.
; In the preferred embodiment, memories 150, 250 and 350 also contain node caches 720, 740 and 760, respectively, which hold method and class informstion loaded from globsl class data base 705. Cache~ sre an optimizstion and sre not strictly required.
The data ba~e system used to implement the local class data base must provide name uniqueness within a single data base.
IAccess control for the locsl class dsta base is only required at the dsta ba~e level. The preferred implementation of a local class data base relies upon the underlying security mechanisms within the dsta bsse system to control access to the contents of the local class dsta base.
, Use of the local class data base provides several advantages over use of the globsl class data base. For example, the local class d~ta base provides the ability for applications on each node to continue to communicate with each other in an ob~ect-oriented Imanner even when the network is unavsilable. In such a situation, 2~ applications on the node can continue to invoke other applications that are local to that node.
Fl~ , I

20~9125 -1 1 In addition, using a local class data base provides better performance for applications that reside in the same node as the I local class data base because many invocations can be handled `¦completely within the confines of a single platform. On platforms in which most applications will most likely use invocations that can be handled locally, use of the local class data base may eliminate or greatly reduce the need for network activity, such as accessing the global class data base, to accomplish an invocation.
~I The class data bases are preferably searched for class and I method information by searching the local data bases before searching the global data base. The local data bases of each node are preferably searched in a predetermined order as explained below. As soon as the desired information is located, the search ~stops. Only if the desired information cannot be located in a ,local data bsse is the global data base searched. Thus the search order defines the "priority' of the class data bases.
Figure 8 shows one design of a portion of a local class data base 800. This design, however, is not critical to the invention.
Preferably local clsss data base 800 contains a dsta base header 810 which is used to locate other organizational information in ¦the local clsss data base 800 such as indices and allocation maps.
Locsl cl~ss data b~e 800 also includes a block storage space 815 Icont~ln~ng a number of block~ 820, 822, and 824 which hold the ;informstion about the classes and methods.
Figure 9 shows a preferred arrangement of block 900 which could be block 820, 822, or 824. Block 900 includes a directory 910, located at the beginning of block 900, to identify the ~ - 32 -1 locAtion of the ob~ects within the blocks, and an object storage portion 920.
Entries 955 and 965 in directory 910 each correspond to a different ob~ect 950 and 960 located in ob~ect storage portion 920 , of block 900. Each directory entry includes a value for an ID
field 912, which identifies the corresponding object, a value for . an OFFSET field 915, which represents the relative location of the corresponding ob~ect in the block 900, and a value for a SIZE
. field 917 which indicates the amount of block 900 allocated to the corresponding ob~ect.
Ob~ects 950 and 960 are preferably formatted as character string, although other techniques can be used.
Referring again to Figure 8, local class data base 800 I preferably contains a NAME-TO-ID-INDEX 830 which allows objects to be retrieved by correlating their name to ob~ect identifiers.
The ob~ect identifiers are included in the ID-TO-BLOCR NO.
MAP 840. The map 840 provides block numbers for each unique ob~ect identified in the locsl class data ba~e 800.
The remaining field in the local class data base 800 is BLOCK
TABLE 850. BLOCR TABLE 850 preferably includes the locations of the block~ 820, 822, and 824 and the locations of the available space 829 within the local class data basQ 800. Available space 829 i~ the unused space of the block storage space 815 allocated by the local clas~ data base 800.
? To retrieve an ob~ect from local clas~ data base 800, the name for that ob~ect is mapped to the NAME-TO-ID-INDEX 830. The identifier information from the NAME-TO-INDEX 830 is then mapped 1, 20q9125 1 to the appropriate block number using the ID-TO-BLOCR NO. MAP 840.
The mapping yields the block number where the desired object currently resides. Once the block with the desired ob~ect is located, the ob~ect is found using the ob~ect directory 910 (Figure 9).
(3) The Loader/Unloader As shown in Figure 10, preferably a LOADER/UNLOADER software component 1010 is coupled between a local class data base 1000, a global class data base 1020, and a node cache 1030. The LOADER/
UNLOADER software component 1010, which is part of the ACAS
softw~re components 130, 230, and 330 (Figure 1), is used to control the transfer of ACAS information to and from the local data base 1020, the node cache 1030, and the global class data base 1020. In the preferred implementation, the LOADER/UNLOADER
software component 1010 permits the local class data base 1000 to load information into the global class data base 1020, and permits the node cache 1030 to retrieve class data ba.~e information from the global class data base 1020. During loading and unloading the LOADER/U~-O~nER component 1010 preferably uses memory 150 for storage.
The LOADER/U~ nER software component 1010 i~ activated by a user ~ff~h~ng to transfer class information in local class data base 1000 to the global class data base 1020. The transfer makes inform~tion previously accessible only to the platform accessible to all network u~er~ through global clas~ data base 1020.
Transfer of class information from the locsl clas~ data base 1000 to the global class data base 1020 is preferably achieved by 20~912S

l qn~n~ clsss and method ob~ect definition~ in an ASCII format to the LOADER/UNLOADER software component 1010 for loading into the global class data ba~e. The LOADER/UNLOADER ~oftware component 1010 preferably executes a process to parse language definitions stored by the local class data base, and translates those definitions into an appropriate ASCII representation. The LOADER/
UNLOADER 1010 then formats thi~ ASCII representation to be stored in an appropriate format by the global clas~ data bsse.
LOADER/UNLOADER software component 1010 must also respond to request~ from the user to unload or to retrieve information from the global class data base 1020 for loading into node cache 1030.
The retrieved information i9 preferably translated by the LOADER/
U~T~nER software component 1010 into languago definitions which are stored into the node cache 1030.
F. Creatin~ Definina/Reai~terina Classes and Methods (1) Creation Preferably cla~es are defined using non-procedural language, such as that used in the LoADER/u~oAnER~ and are then compiled and loaded into a cla~s data ba~e. The language, compiler and loader software sre preferably components of an ob~ect definition !
fscility. Other well-known techniques would also be apparent to tho~o of ordinary skill in the art.
Th- ob~ect definition facility is part of the ACAS software components 130, 230, and 330 (Figure 1) and provide~ a means to ~' l define classes, messages, class attribute~, method~ and method attributes. This facility also provides for the specification of inherltanc- among classe~ and, along wlth the LOADER/UNLOADER

1 software component 1010 described above, can be used to modify existing definitions within the global class data base and the local class data bsse. In addition, the ob~ect definition facility preferably performs the necessary syntax checks of class def inition input and method definition input used to create new class and method definitions within the global class data base.
A user of the ob~ect definition facility must specify certain information to create a class. This information preferably includes: a global class name and identifier; global names and identifiers (if any) of the superclasses of this class; messages supported by this class, along with their associated types of arguments (if any); method maps defined and the messages to which each map relates; and attributes defined for this class.
Each message is preferably specified by generating a structure including the name of the message, psrameters supported by the message, and a corresponding method map. Each message structure is converted into two sets of values in the preferred implementation. One set of values includes the message name and the list of parameters supported by the message. The other set of values identifies a set of method ob~ects that represent implementations of the message.
~ thod ob~ects are defined within the network environment in the same manner as classes. The ob~ect definition facility of the preferred implementation, however, ha~ special provisions for defining of method ob~ects. The following information is specified when defining a method ob~ect; the global name and identifier of the method ob~ect; global names and identifiers of 204912~

1 the superclasses of the method ob~ect; and metadata (i.e., descriptions of data) stored as the method attributes. The method definition also specifies the arguments and their types 1 corresponding to the parameters in the message, and whether the S method involves a parameter list. This parameter list represents the input required by the executable code (discussed below) capable of being invoked by the method.
(2) Method/Class Definition In the preferred implementation, the loading of class and ~ method definitions may either be done prior to run-time or I dynamically during run-time. Clas~es and method ob~ects may ~e ! accessible either locally on a node within the network (called ~ local definition") or globally from all platforms in the network I (called global definition~) Both local and global definition can be accomplished using the LOADER/U~O~nER software component 1010 or any other acceptable mechanism.
(3) Server Reaistration The purpose of server registration is to find method servers which are avAilable to ~ervice requests from messages. Method servers are the active (i.e., currently running) processes implementing the methods. A method server may involve execution of the code of a single application or of msny portions of the code of one or more applications.
The registration of method servers is distinct from the definiSion of classes and method ob~ect~. Whereas the definition of classes and method ob~ects is used to identify their presence !in the system, the registration of method servers is used to track ,, 204912a 1 their status (i.e., availability). If a method server is not ` registered, it i~ not known to the system.
(4) ADPlication Installation & Definition l Preferably, ~upport mechanisms are provided for registering and installing applications in the network. The preferred implementstion provides the ability to define applications and application fragments in the ob~ect-oriented model of classes, subclasses, mes~ages and methods stored in a class data base. The definition of application~ in this manner is critical to the operation of the interapplication communication performed by the preferred implementation of thi~ invention. Specifically, the storage of classes, subclas3es, messages and methods in a class data base permits an application, during run-time, to update the ~class data base and continue processing using the updated class data base without having to recompile and relink.
Applications are defined in the same manner as other classes.
In fact, as explained above, an application is itself defined to be a particular kind of class.
I Applications are installed on specific platforms in the ;manner required for the particular operating ~ystem on that ! platform. In the preferred implementation of this invention, application installation also requires some additional functions.
For ex~mple, unless it has already been defined, an application must provide its own class definition which is defined as a 2- ~subclass of the existing ACAS_APPLICATION.
~ Application installation may use class definitions already Fl I .
installed or may add new definitions. At application installation 204912~

1 I time, an installation procedure may compile and register the class definitions supported by the application into either a local class data base or the global clasis data ba~e using the LOADER/UNLOADER
software component 1010 described above, and must update the method maps of the data ob~ect clasises affected by the new application~. Application installation also involves the method ob~ect definition procedures discussed above.
G. Context Oblect Data Bases ' In the preferred implementation of thiq invention, context 1 ob~ect data base 630 (~ee Figure 6) provides a mechanism to define preferences to be used for resolving methoda, for selecting platforms to execute a method, and for locating class data bases in the network. Several levels of context ob~ect data bases can ~exist in the network 50 of Figure 1. For example, one level may - consist of a user context ob~ect data base and another level may consist of a group context ob~ect data base. System (or platform) context ob~ect data bases may also be used to identify preferences ~for users of the entire platform. All context ob~ect data bases supply preferences during method resolution, but, the group context ob~ect data bsse may be used by the ACAS software components 130, 230, and 330 to recognize the preferences of more than one user, and the system context ob~ect data base may be used to recognize the preferences of more than one group. Preferably, the data bases in context ob~ect data base 630 are used such that 2 in method resolution, preferences in the u-~er context ob~ect data bases override those in the group context ob~ect data bases, which in turn overrides the ~ystem context ob~ect data bases.

2Q~912~

.
l Context ob~ect dsta base 630 preferably reside~ on the platform associated with a user during a particular network session. In the initial log-on procedure executed when a user lenters the network, the information stored in the context object data base associated with the user is called up for later use during the operation of the ACAS software.
Figure llA ~hows a preferred memory system for a context ob~ect data base 1100. The context ob~ect data base 1100 includes a method override table 1110, a server node table 1150, and a clas~ data base override table 1170, and other u~er defined tables 1180. The method override table is used during method , resolution, described in detail below, to select a preferred method in re~ponse to a message name and a class identified in an instance handle. The server node table 1150 i~ used during the invoker operations, also described in detail below, to select and locate platforms in the network capable of being a server platform. Class data base override table 1170 defines an order for searching the local class data bases for method and class information.
Tables 1110, 1150, and 1170 are system-supplied tables.
Users may al80 8upply their own tables 1180 to effect their specific preferences.
A preferred implementation of a method override table 1110 is shown in Figure llB. ~ethod override table 1110 includes a list of method selector attribute names 1115 and as~ociated values 1120. Each entry ~pecifies for an attribute name 1115, a preferred value 1120. For example, in Figure llB, the preferred 204912~

1 platform is specified as a VAX.VMS, and the preferred interaction type is BUILT IN. If more than one method i~ identified in response to a message, the preferenceR in table 1110 will be used to choose one of those methods. If no value is specified for an ; attribute, the qystem assumes there is no preference.
A preferred implementation of a server node table 1150 of the context ob~ect data base 1100 is shown in Figure llC. Server node table 1150 is an ordered list of nodes in the network 50 of Figure 1. Each of the entrie~ in table 1150 correspond~ to a ~I platform type 1152 and the location of nodes 1154 in the network 50 with the corresponding platform type which can be used to implement the ~elected method. For example, table 1150 identifies two nodes for a plstform type of TYPE A, node a and node b.
I Figure llD contains a preferred implementation of class data base override table 1170. Table 1170 includes several entries which include a name of a local class data base 1172 and its location 1174. Thus, for entry 1175, the data base DE_SCH LST is at locations dbl and db2, and is searched before other local class ob~ect data bsse~ listed further down table 1170.
I The preferred implementation of the present invention includes an interface available to all user~ of the network which provide~ the capability to create context ob~ect data bases and to add, modify and delete entries within each of the system context ob~ect data base~. This interface preferably executes a standard compiler to perform these functions. For example, to add an entry to a context ob~ect data baqe, a user would enter a command using Fl ~ !
the provided interface. The command would then be interpreted by 20~912~

1 I the ACAS sOftware components 130, 230, and 330 (Figure 1) to cause the st~n~Ard compiler to translate the data received by the interface into the proper formats.
i H. ACAS Service ~ (l) General O~erations i With the preceding description of certain components of the preferred implementation of this invention, a fuller understanding of the ACAS components msy be gained. Preferably, the present invention is implemented using a client/server model in which a jlclient generates requests and a server respond~ to requests. In the following discussion, the service or operation associated with a client application on a client platform is called the ~client ~ service," and the service or operation associated with a server application executing on a server platform is called a ~server service." The client service and the server service of the ;preferred implementation rely upon a transport system which is capable of transmitting messages from the client platform to and from the server platform. In the preferred implementation, an RPC-like communications system is used as the transport system.
Each of the ACAS software components 130, 230, and 330 shown in Figure 1 preferably include~ client service components and the server service components which represent the client and server services, respectively. This is shown, for example, in Figure 12 which is a diagram of two platforms 1200 and 1300 and a network bus 55. Platforms 1200 and 1300 can correspond to any of platforms 100, 200, or 300 in Figure 1.

~ 20~912a - Located in platforms 1200 and 1300 are memories 1250 and 1350, respectively, and CPUs 1210 and 1310, respectively. The elements in the plstforms 1200 and 1300 function in the same i manner as similar elements described above with reference to Figure 1. CPU 1210 executes a client application 1220 and CPU
1310 executes a server application 1320. CPUs 1210 and 1310 also execute OP SYS 1 1240 and OP SYS 2 1340, respectively, and ACAS
software components 1230 and 1330, respectively.
ACAS software components 1230 and 1330 preferably include ll dispatcher software components 1232 and 1332, respectively, control server software components 1234 and 1334, respectively, invoker software components 1236 and 1336, respectively, and the :! auxiliary software components 1237 and 1337, respectively.
For the most part, invoker software components 123 6 and 1336 i represent the client service and dispatcher software components ; 1232 and 1332 represent the server service. The auxiliary software components 1237 and 1337 represent some other operations of the preferred implementation. Since platforms 1200 and 1300 in the network contain an invoker software component 1236 and 1336, respectively, a control server software component 1234 and 1334, respectively, and a dispatcher software component 1232 and 1332, respectively, either platform can act as a client or a server.
In the preferred implementation, the invoker software components 1236 and 1336 and the dispatcher software components -- l 1232 and 1332 have the responsibility for interpreting class and method information in the class data bases, as well as context data in the context ob~ect data base, to determine the appropriate 20~912S

.
1 ~ method to invoke, to determine how to invoke that method, and to ! dispatch the necessary commands to execute the code to implement the method. The invoker software components 1236 and 1336 and the l dispatcher software components 1232 and 1332 also insulate client ~ applications from the details of the method invocation and the transport level mechanisms.
The control server software component~ 1234 and 1334 have several functions. One function is to store information on currently rllnning server applications on the platforms 1200 and 'I 1300 in the network 50. The control server software components 1234 and 1334 also execute processes to start new applications that become method server~. Another function performed by control server software components 1234 and 1334 is method server registration. For example, the control server software component 1334 stores information regarding the method server, identified by the server application 1320, currently running on the server ~platform 1300. The control server software component 1334 also communicates with the server registration facility in network-wide ~memory 704 (Figure 7) to store status information regarding the I server application 1320.
The auxiliary software components 1237 and 1337 represent operations of the ACAS software components 1230 and 1330 such as class and method ob~ect definition and registration, method executable registration (de~cribed below) in a method executable ~' 'catalog of each platform, and functions of the LOADER/UNLOADER
software component 1010 (Figure 10).

1 For purpose of the following discussion, the platform 1200 is referred to as the client platform and the platform 1300 is referred to as the server platform. In this example, the client application 1220 communicates with the server application 1320 in the server platform 1300 in an ob~ected-oriented fashion. It is also possible in accordance with the present invention and in the preferred implementation for a client application on one platform to communicate with a server application on the same platform.
! When the client application 1220 communicates with the server application 1320, the dispatcher software component 1232 and ~control server software component 1234 of the client platform 1200 is not involved, and are therefore shaded in Figure 12. Likewise, invoker software component 1336 of the server platform 1300 is ~haded becsuse it is not active.
Figure 13 i~ ~ flow diagram 1360 outlining the major functions performed in an invocation of a method according to the preferred implementation. Prior to beginning the steps in flow diagram 1360 the ACAS software components 1230 and 1330 are initially in a "wait~ state.
When the client application 1220 transmits a method ~invocation request, the processes of the ACAS software components 1230 and 1330 shown in Figure 13 begin. This method invocation request includes an input message which ldentifies the desired 'operation of the client application 1220.
^~ First, the method invocation request i~ received by the invoker software component 1236 (step 1370) which processes the method invocation request (step 1375). The invoker process is 2Q4912~

.. I
1 I described in greater detail below. The usual result of the invoker process is a processed method invocation request.
The invoker software component 1236 then transmits the processed method invocation request, via network bus 55 to the S dispatcher software component 1332 (step 1380). $he dispatcher software component 1332 and control server 1334 then begin their operations.
After receiving the proce~sed method invocation request, the dispatcher software component 1332 and control server software component 1334 cause the method identified by the invocation request to be executed by the server application 1320 (step 1390).
Once the server application 1320 completes execution of the method, it outputs any arguments resulting from the execution and I the dispatcher ~oftware component 1332 generates a status message (e.g., "successful"). The output argument~ and status message are mapped into the processed method invocation request, now called a "response." This response is then transmitted by the dispatcher software component 1332 to the invoker software component 1236.
,The invoker software component 1236 completes it~ processing by returning the response received from the di~patcher software component 1332 mapped into the original method invocation request, to the client ~pplication 1220 (step 1395).
The ~r~c~ ng explanation of the ACAS software components ' 1230 and 1330 permits a greater appreciation of the flow of 'information in the preferred implementation of this invention.
Figure 14 shows additional elements of the network 50 affected by a flow of information from the invoker ~oftware component 1236 to 20~912~

1 ~ ! the dispatcher softwsre component 1332. In addition to the client application 1220, the server application 1320, the invoker software component 1236, the dispatcher software component 1332, and the control server software component 1334, Figure 14 includes context ob~ect data bases 630 (Figure 6), class data bases 640 (Figure 6), a server registration facility 1420, and a control server registry 1425, which is maintained by the control server ~software component 1334 and keeps track of the executable code in the server platform.
~ As shown in Figure 14, the context ob~ect data ba~es 630 includes a user context ob~ect data base 1402, a group context object data base 1404, and a system context ob~ect data base 1406, - each of which has been described above in the discussion of context ob~ect data bases. The class data bases 640 include a lS local data base 1000 (Figure 10), a node cache 1030, and a global class data base 1020. Each of these elements of class data bases 640 has been described above in the discussion of class data ba3es.
; As explained above, the flow of information begins when client application 1220 generates a method invocation request which is passed to invoker software component 1236. This interface is preferably provided by an InvokeMethod procedure call of the preferred implementation.
In the InvokeMethod procedure call, the client application 1220 passes to invoker software component 1236 an instance handle, a message (including a message name, and parameter list), a context ob~ect handle, and, optionally, an output instance handle.

1 A8 di8cussed in detail above, the instance handle is a structure that identifies the current instance the client application 1220 has selected to be involved in the method invocation. The message name represents the desired operation on the instance. The message parameter list consists of the parameter~ required by the mes~age. The context ob~ect handle is a reference identifying the context ob~ect data base to be used in the invocation process described in detail below. The output ~instance handle represents an instance of the running method "server associated with the invoked method. This allow~ the client application to continue to have a dialog with the same method server. The ~emantic~ of the output in~tance handle is the same ,as that for the in~tance handle.
, When the invoker software component receives the method ~linvocation request, the invoker software component 1236 queries the context ob~ect data base~ 630 and the class data bases 640 to find a method identifier. This procedure has been discussed above.
Having determined the appropriate method identifier for the message nAme, the invoker software component 1236 next queries the ~erver registration facility 1420 and the context ob~ect data base 630 to find the server platform on which to execute the method associated with the method identifier. The server registration facility 1420 is used to locate a running method server (if any) ~' capable of performing the method associated with the method identifier. A running method server i~ a method server, such as 1 the server application 1320, that has made itself known to the network 50 a~ being already started.
If there is a running method server, the invoker software ! component also queries server platform tables of the context ob~ect data base 630, to determine the location of a remote platform in the network 50 (Figure. 1) which the user of the client application 1220 would prefer to execute the method of invocation request processed by the invoker software component l1236. If however, the server application 1320 is not available, ~the control server software component 1334 notifies the invoker software component 1236 that the server application is not available on the selected remote platform. The invoker software component 1236 processing outlined above begins again with querying the server platform table of the context ob~ect data `! bases 630 and server registration facility 1420 to select another platform in the network 50 upon which to execute the identified method.
Next, the invoker software component 1236 transmits a query to the control server software component 1334 of the preferred server plAtform which causes control server software component 1334 to query a control server registry 1425 to determine whether the de~ired method server on the preferred server platform is available to proce~s the method identified in the processed method ;invocation request. Availability of a method server is determined in the preferred implementation by examining in the control server registry 1425 to find out whether the method server is currently able to process methods invoked by client applications.

.~

1 If the control server software component 1334 indicates to the invoker software component 1236 that the method server, in the form of server application 1320, is available, the invoker software component 1236 transmits the processed method invocation request to the dispatcher software component 1332 of the server platform. The invoker ~oftware component 1236 can also transmit information from the context ob~ect data base 630, which can then be used by the desired method server.
' The dispatcher software component 1332 then begins to process the desired method. Thi~ process, referred to as the 'dispatching process,-' generally involves dispatching the method identifier to begin the execution of the method by the server application 1320.
If, however, the server registration facility 1420 does not indicate that any copies of server application 1320 and currently r~nning on a platform in the network, then the invoker software component 1236 may transmit a request to the control server software component 1334, using the information retrieved from the context ob~ect data ba~es 630 and the class data bases 640, to start the server application 1340. After the server application 1320 is started, the control server ~oftware component 1334 notifies the server registration facility 1420 to update the netwvrk-wide memory 704 (Figure 7) to indicate that the server applic~tion 1320 is rllnning. Control server software component also updstes the control server registry 1405 to indicate that the server application 1320 is available. The invoker software component 1236 then transmits the processed method invocation request to the dispatcher software component 1332 to execute the 204912~

1 ~ I method corresponding to the method identifier of the processed method invocation request.
After the server application 1320 has completed its iprocessing, it returns any output information requested by the processed method invocation request to the dispatcher software component 1332. The dispatcher software component 1332 then return~ a response, as describe above, to the invoker software component 1236 along with any output information mapped into the lloutput arguments of the processed method invocation request received by the dispatcher ~oftware component 1332.
(2) Invoker OPeration The portion of the process of method invocation performed by the invoker software component 1236 can now be described in Igreater detail. Preferably, that portion consists of several Idistinct pha~es including determining the proper method to be invoked (method resolution), server connection or start-up, and transport level communications to enable the dispatching of an identifier to the proper method to be executed by the method server or other executable code.
Figures 15A - 15D and 16 contain flow diagrams of procedures performed or called by the invoker software component 1236 of Figurer 12 and 14. The main control procedure 1550 in Figures 15A
- 15D represents the steps 1370, 1375, and 1380 (Figure 13) performed by invoker software component 1236~
A~ with procedure 1360, prior to entering the main control procedure 1550, the client application 1220 (Figures 12 and 14) is running normally without a method invocation request, and the ACAS

20~9125 -1 software component 1230 is in a "wait~ state. When the client application 1220 generates a method invocation request using the InvokeMethod procedure call, the main control procedure 1550 begins (step 1552 in Figure 15A) with the invoker software component 1236 receiving the method invocation request (step ! 1555).
The invoker software component 1236 first validates the method invocation request (step 1557). If there was an error, the ~ invoker software component 1236 generates an error message tstep 1 1558) which the invoker software component 1236 returns to the client application 1220 (step 1599 in Figure l5D).
i If the method invocation reque~t i~ valid (step 1557 in Figure l5A), the invoker software component 1236 next resolves the method to be invoked from the message in the InvokeMethod call, the clasq data base~, and context ob~ect data bases (step 1560).
Method resolution is the process of determining or identifying the appropriate method.
Figure 16 show~ a preferred procedure 1600 to resolve method~. Although method resolution ha~ been referred to above, procedure 1600 show~ such resolution in much more detail than has been provided.
In the preferred implementation, the deter~i~Ation of the proper method to be invoked is indirectly handled by the invoker software component 1236. Most of the work for method resolution is then handled by the auxiliary software components 1237 and 1337 of the ACAS software components 1230 and 1330. In the preferred implementation, auxiliary software component 1237 retrieves -20~912S

1 ~ , information from the context ob~ect data bases and the clasæ data bases. Of course, invoker software component 1236 could also retrieve such information.
i After beginning the method resolution procedure 1600 (step 1 1605), the invoker software component 1236 determines whether the instance handle includes the storage class name portion (step ~1610). If a storage class exists, it is located (step 1620) a special method is invoked to retrieve the name of the class ~associated with the instance handle (cftep 1630).
After invoking the method identified by the storage class to retrieve the class name, or after deter~ining that the instance handle did not include the storage class name, a process is executed by the invoker software component 1236 to locate class .information for the class data bases 640 (Figures 6 and 14) using the searching order described above (step 1640) For example, if the messages was EDIT (INSTANCE_HANDLE), where the instance handle was ASCII_FILE/NODE l/MYFILE.TXT, the class name ASCII_FILE can be used to find class ASCII FILE 1645 in class data bases 640.
With the name of the mesQage, EDIT, the appropriate method map 1655 is then retrieved from the cla~ data base~ 6~0 (step 1650). In the spQcific example under discussion, the auxiliary ~softw~re component 1237 of the preferred implementation would then retrieve method map 1655 and check to ensure that the class .information located in step 164-0 include~ with the message name EDIT. ThiC~ ensure~ that the corresponding messagQ is supported by the class.

' - 53 -20~912S

1 - As Figure 16 shows, the method map 1655 includes method ob~ects METHOD 1 and METHOD 2 for the message name EDIT and the class ASCII_FILE 1645. Associated with the method ob~ect METHOD 1 is a set of attributes 1657 and associated with method ob~ect METHOD 2 is a set of attributes 1659. The set of attributes 1657 indicates that METHOD 1 is capable of being executed on PLATFORM TYPE A, and the set of attributes 1659 indicates that Method 2 is capable of being executed on PLATFORM_TYPE B.
I Because there might be several method ob~ects in the method map, the context ob~ect data bases 630 are referenced to resolve any ambiguities (step 1660). In referencing the context object data bases 630, the appropriate server node table maintained is also retrieved to be used later.
The entrie~ (if any) in the context ob~ect data bases 630 are then compared with the attributes in set of method ob~ects on the method map (step 1670) to select the method ob~ect and thus the appropriate method to execute the desired operation represented b~
the message (step 1680). In Figure 16, a method override table 1665 includes an entry 1668 indicsting the u~er preference is for PlatformType A. Using this entry 1668 the invoker software component 1236 selects from the clas~ data bases 640 the appropriate method 1686 to execute the desired operation EDIT. In the e~mple shown in Figure 16 the appropriate method is Method 1 to be executed on PLATFORM TYPE A. The procedure 1600 now returns to the main control procedure of 1550 of Figure 15 (step 1685).
If at any point during the operation of method resolution procedure 1600, there is an error (such as during step 1640, the 1 class identified in the instance handle was not a class locatable in the clsss data bsses), the method resolution procedure 1600 returns with a message indicating this error.
After returning from the method resolution procedure 1600, a determination is made whether an error occurred during the method resolution process (step 1562 in Figure 15A). If the answer is "yes", then the invoker software component 1236 generates the appropriate error message (step 1563), and returns the error message to the client application 1220 (step 1599 in Figure 15D).
IO Otherwise, having resolved the method without error (step 1562 in Figure 15A), the invoker software component 1236 then reviews the method attributes corresponding to the identifier of the resolved method to execute the appropriate method on an I appropriate platform in the network. If the~e method attributes indicate that the method is already linked into the client application 1220 (step 1565 in Figure 15B), for example, the value of the InteractionType method attribute is "BUILT_IN," then a check is made for an activation error (step 1566). If there was one, an error mes~age is generated (step 1576) and control is returned to client application 1220 (step 1599 in Figure 15D).
If there wa~ no error, a success flag is generated (step 1567), and the resolved method is executed by code already re~ident in the client application 1220 (step 1569).
If the method attributes -do not indicate that the method is already linked to the client application 1220 (step 1565 in Figure 15B), invoker software component 1236 asks whether the method attributes indicate that the method is dynamically loadable 1 (step 1570), Dynamically-loadable methods represent method executables which may be merged with executable code of client applications at run-time. Those skilled in the art will recognize that 8 dynamically-loadable method might be a method executable S identified by a subprocedure or function of a client application.
Preferably the test for a dynamically-loadable method server is accomplished by determining whether the value of the InteractionType method attribute is "DYNAMIC_LOAD." If so, then the invoker software component 1236 attempts to load the executable code identified by the resolved method into the client !
application 1220 (step 1572).
If an error occurred during the loading of the executable code (step 1574), then the invoker software component 1236 generates a mes~age indicating that a load error occurred (step 1576) and returns the load error mes~age to the client applicatio~
1220 (step 1599 in Figure lSD).
Otherwise, if there was no load error (step 1574), then the invoker software component 1236 then generate~ a flag indicating the successful completion of the method invocation (step 1567).
Next, the dyn~mically loaded executable code corresponding to the resolved method is executed (step lS69), and control returns to the client spplication 1220 along with any output arguments (step 1599 in Figure 15D). Any error~ in executing linked or dynamically-loadable method server~ are preferably returned as parameter values.
If the method attribute~ do not indicate a previously-linked or dynamically-loadable method (step~ 1565 and 1570 in 20~912~

1 Figure 15B), then the invoker software component 1236 must locate a r~nni~g method server on a platform in the network that can handle the resolved method as described above with regard to Figure 14.
If the information retrieved from the server registration facility 1420 (step 1578) indicates that there is at least one running method server capable of performing the method identified by the resolved method (step 1579 in Figure 15C), then the invoker software component 1236 compares the information retrieved from the server registration facility 1420 with the entries on the server node table retrieved from the context ob~ect data ba~es 630 during the method resolution procedure 1600 to select a server platform in the network (step 1580).
Having selected a server platform, the invoker software component 1236 then transmits a QueryServer call to the control server software component 1334 of the selected server platform (step 1581). The functioning of the control server software component 1334 is described in detail below in connection with Figures 17A and 17B. Briefly, control server software component 1334 determines whether the desired method server is available or not.
The msin control procedure 1550 of the invoker software co~ponent 1236 then continues in step 1582 (Figure 15C) by receiving a message generated ~y the control server software component 1334 about the desired method server' Q availability and translating the message into a formst recognizable by the client platform. The invoker software component 1236 determines from the - 57 _ I

20~9125 1 control server software component 1334 whether the method server correspon~ing to the resolved method is available to process the method identified by the resolved method tstep 1583). If the I corresponding method server is available, then processing of the invoker software component continues on Figure 15D by asking whether the method server is an asynchronous method server (step 1593) in Figure l5D. Asynchronous method servers are known in the art.
If the method ~erver is asynchronous (step 1593), then the I control server software component 1334 is called using the SignslServer call to signal the method server (step 1594). If the method ~erver i~ not asynchronous (step 1593), or after an asynchronous method server i~ signaled (step 1594), the processed i method invocation request, including the identifier for the method!
and information retrieved from the context ob~ect data bases during method resolution, is packed into a data structure used for communication in the network (step 1595) and the invoker software component 1236 then transmit~ the packed and processed method invocation request to the di~patcher software component 1332. The processes of the dispatcher ~oftware component 1332 will be described below with reference to Figures 18A and 18B.
After the dispatcher ~oftware component 1332 completes its processing and transmits a packed response, the invoker software component 1236 receives the packed response (step 1597), unpacks . the response (step 1598), and returns the response to the client application 1220 to complete its processing (step 1599).

1 If in the earlier det9rmin~tion (step 1583 in Figure 15C), the r~nnlng method server was found not to be available, the invoker software component 1236 determines whether the server registration facility 1420 indicated any other running method I servers capable of performing the method identified by the resolved method (step 1584). If so, then the retrieved information is compared to the server node table in the context ob~ect data base 630 and a QueryServer call is made to control server software component 1334 (step 1581).
Otherwise, the invoker software component selects the server node with the highest priority from the server node table tstep 1586). The control server softwsre component 1334 of that selected server platform i8 then contacted using the StartServer call which indicates to the control server software component 1334:
to attempt to start the appropriate application which corresponds to the method identified by the re~olved method (~tep 1587).
After the control server software component 1334 has completed its processing and transmitted a message, the invoker software component 1236 receives the transmitted message which it then unpacks (step 1588).
If the application was started and became a method server (step 1589), then the invoker software component 1236 completes its p~ocasses which have already been described (step 1593 of Figure 15D). If the application was not started (step 1589), then the invoker software component 1236 asks whether there are any more nodes in the server node table of the context ob~ect data bases 630 (step 1590). If not, then an error me~sage is ~enerated 1 indicating thst the method invocation was unsuccessful because a server platform could not be located (step 1592), and that error message is returned to the client application 1220 (step 1599 in Figure l5D).
, If, however, there are other nodes on the server node table (step 1590 in Figure l5C) then the platform with the next highest priority is selected (step 1591) and the processing of the invoker software component 1236 returns to step 1587 of Figure 15C. The loop consisting of steps 1587, 1588, 1589, 1590, and lS91 will be performed until the method server is started (step 1589) or until :
there are no more platforms on the server platform lists (step 1590).
(3) Control Server O~eration Figures 17A and 17B show the control server procedure 1700 which repre~ents the operations of the control server software component 1334. Persons skilled in the art will recognize many other ways of implementing the functions of control server software component 1334.
After beginning the control server procedure 1700 in step 1702 of Figure 17A, the control server software component 1334 receive~ a control server message (step 1705). In response, the control server software component 1334 determines whether the control server mes~age indicates that an application running on a common platform with the control server software component 1334 requests to be registered as a method server to handle method invocation requests (step 1710). If the answer is "yes" then the control server software component 1334 registers the server 1 application as a method server by recording the necessary inform~tion about the server application with the control server registry 1425 to indicate that the method server is available.
Control server software component 1334 also notifies the server registration facility 1420 to indicate that the method server is running (step 1715). The running and available method server may also execute appropriate methods. The control server software component 1334 al~o generates a success message (step 1729) to be returned to the now registered application (step 1799 in Figure 17B).
If the control server message does not indicate that an application wisheq to be registered (step 1710 in Figure 17A), the control server software component determines whether the control server message indicate~ that a currently regiqtered method server request~ to be unregistered with the control server software component 1334 and ~erver registration facility 1425 (step 1720).
If so, then the control server software component 1334 unregisters the method server by removing the information from the control server registry 1425. This indicate~ that the application, identified by the method server, i~ no longer available. Control ~erver software component 1334 also notifies the server reg$stration fAcility 1420 to remove the information stored in network-wide memory 704 (step 1725). The control server software component 1334 then generates-a ~uccess message (step 1729) to be returned to the now-unregistered application (step 1799 in Figure 17B).

204912~

1 If the control server message does not indicate that an application ha~ requested to register or unregister itself, the control server software component determines whether the control server me6sage indicates that the invoker software component 1236 wishes to signal an asynchronous method server to expect to be invoked to execute a processed method invocation request (step 1730). If this i~ the case, the control server software component 1334 executes a process thst signals the asynchronous method server (step 1735) and completes processing (step 1799 in Figure 17B).
As explained above, the preferred implementation of this invention can operate both with applications written to take ~ advantage of the features of this invention, or previously-written applications that have been modified for us with the preferred lS implementation. In so writing or modifying asynchronous applications to operate with the preferred implementation, a user includes program code that, in part, recognizes these asynchronous signal~ and, a~ described below, registers these signals and the following processed method invocation requests in queue. These operations are described below with reference to the processes performed by the dispatcher software component 1332.
If no other function has been requested, the control server software component 1334 determines whether the control server message indicates that the invoker software component 1236 is I requesting that a new application, which resides on the same platform as the control server software component 1334, should be started to become a method server to process a method (step 1740 1 in Figure 17B). If so, then the control server software component 1334 checks the control server registry 1425 (step 1745) to determine whether the method executable of the new application, corresponding to the resolved method, resides on the selected platform (step 1750).
Control server registry 1425 has a local scope so that only the server platform 1300 is aware of resident method executables.
The registration of method executables in registry 1425 involves registration of the actual executable code in executable files, for example shell scripts, that implement a method, and the status of those method executables. These item~ preferably have only a local registration scope because it is not necessary to manage the executable code globslly.
If the correspon~ng method executable is identified in the control server registry 1425, then the selected platform can be a server platform. The control server software component 1334 executes a process to start the corresponding method executable and registers the resulting method server with the server registration facility 1420 and with the control server registry 1425 to indicate that the newly started method server is both r~lnn~g and available (step 1752). During this starting process, the control server software component 1334 also creates a context ob~ect data base capable of being used by the started method server. Next the control server software component 1334 then generates a message indicating that the application corresponding to the resolved method has been started and is now a method server (step 1754). This message is then transmitted to the invoker 20~9125 1 ~oftware component 1236 that reque~ted that the method server be started (~tep 1790), and the control server software component 1334 has completed its processing (~tep 1799).
If the method executable corre~ponding to the re~olved method!
S is not identified in the control server registry 1425, then the control server software component 1334 generates an appropriate message indicating that the method executable was not started (step 1756). This message is then transmitted to the invoker software component 1236 that reque~ted that the method server be started (step 1790), and the control server ~oftware component 1334 has completed it~ proce~sing (step 1799).
If no other function has been reque~ted, the control server softwsre component 1334 determine~ whether the control server me~sage i8 a request from the invoker ~oftware component 1236 for , information concerning the availability of a running method serverl . to execute a method identified by the resolved method (step 1760).
If not, the control server ~oftware component 1334 generates an error mes~age (step 1780), transmits that message to the invoker software component 1236 (step 1790), and completes it~ processing (step 1799).
Otherwise the control server ~oftware component 1334 retries the ~el~a~ted information on the running method server from the control server regi~try 1425 (~tep 1765). If the information from the control server registry 1425 indicate~ that the method server identified by the resolved method i~ available (step 1770), then the control server software component 1334 generate~ a message indicating the method ~erver~s availability (step 1775). This ~1 1 message i~ then transmitted to the invoker software component 1236 (step 1790), and the processing of the control server software component is complete (step 1799).
If, however, the control server registry 1425 indicates that the method server is not available (step 1770), then the control server software component 1334 generates a message indicating the unavailability of the method server (step 1777). The control server software component 1334 then transmits the generated message to the invoker software component (step 1790), and the processing of the control server software component 1334 is complete (step 1799).
(4) Dis~atcher O~eration The process of dispstching method servers consists of dispatch~ng methods to be processed by method servers and transport level communicstions. The dispstcher software component 1332 also handles different types of method invocations.
Asynchronous method invocations do not require that the client application wait for the identified method server to complete processing. For example, the invocation request can be placed on a queue to be performed, and the RPC transport level call can return to the invoker software component 1334 and allow the client application to continue it~ own processing without bein~ ~blocked~ or prevented from continuing. The queue of processed method invocation requests received from invoker ~oftware components is then examined by dispatcher ~oftware component 1332, such as in a dispatcher procedure 1800 of Figure 18, and performed according to a predetermined order.

204912~

1 Asynchronous method invocations may be requested if the client application does not expect to receive back a response from the method server. The only response will be an indication of whether the method invocation waQ ~uccessfully received by an ACAS
software component on a ~erver platform. The response does not indicate whether the execution was successful, and will not contain any output~ of the actual method invocation, as it could for synchronous method invocation~.
Synchronous method invocation~ are the default mode for all method invocations. With synchronous method invocations the client application that invoked the method await~ a re~ponse before continuing its own processing.
Figures 18A and 18B are a flow diagram of procedures performed or called by the dispstcher software component 1332 of Figures 12 and 14. The dispatcher procedure 1800 represents the steps 1385, 1390, and 1395 (Figure 13) performed by the dispatcher software component 1332.
Prior to entering the dispatcher procedure 1800, the dispatcher software component 1332 is in a "wait" state waiting for a processed method invocation request from an invoker software component in the network. After beginning the dispatcher pro~s~nre 1800 (step 1802), the dispatcher ~oftware component 1332 recelves a transport data Qtructure, via the network transport servicQ. Thi~ transport data structure represent~ a packed and processed method invocation request transmitted by an invoker softwsre component in the network (step 1805). After receiving thi~ transport data structure, the dispatcher software component 1 1332 unpack~ and translates the transport data structure into a data structure recognizable by the server platform (step 1810).
The dispatcher software component 1332 then update~ a context ob~ect data base associated with the running method server (step 1815). A context ob~ect data base may become associated with the running method server either by being created by the control server software component 1334 when starting the method server or by a user logging onto the server platform and starting the method server.
The dispatcher software component 1332 next asks whether the proceed method invocation request it received is an asynchronous invocation request to be proces~ed by an asynchronous method server (step 1820). If not, then the dispatcher software component 1332 asks whether the invocation request includes the identification of a valid method, which is a method that can be processed by the method server (step 1825). If not, then an error message is generated (step 1840), which is then packed as a response (step 1890 in Figure 18B) and transmitted to the invoker software component (step 1895) before completing the dispatcher proce~sing (step 1899).
If the invocation request included the identification of a valid method (~tep 1825 in Figure 18A), then the dispatcher software component 1332 dispatches the valid method identified by the received invocation reques~ to be executed by the method server (step 1830). If an error occurred during the execution of the valid method by the method server (step 1835), the dispatcher software component 1332 generates an appropriate error message 1 (step 1840). The dispatcher software component 1332 then packs the error message a8 a response (step 1890 in Figure 18B) and transits the packed error message to the invoker software component (step 1895) before completing the dispstcher processing (step 1899).
If no execution error occurred (step 183S in Figure 18A), then the dispatcher software component 1332 packs a response (step 1890 in Figure 18B), which in this case is the processed method invocation request including any output from the method server that processed the method identified by the resolved method (step 1560 of Figure lSA). After the response i~ packed, it is transmitted to the invoker software component thst originally sent the originsl processed method invocation request (step 1895), and the dispatcher processing is completed (step 1899).
If the proces~ed method invocation request received by the dispatcher software component is an asynchronous invocation request (step 1820 in Figure 18A), then the asynchronous invocation request is preferably placed on a queue to be dispatchQd by the dispatcher software component 1332 to be later processed as a method server (step 1850). A message indicating the ~ucces~ of the asynchronous invocation request is generated (~tep 1855), packed as a response to the received processed method invocation requQst (step 1860), and then transmitted to the invoker software component that originally sent the processed method invocation request (step 1865).
In the preferred implementation, a~ynchronous method servers execute asynchronous method invocation requests in the order they -1 are fir8t placed on a queue. In executing the asynchronous reque~t~, the dispatcher software component 1332 asks whether there ~re any method invocation requests on the queue to be processed ~y the asynchronou~ method ~erver (~tep 1870 in Figure 18B). If there are no method invocation requests on the queue (step 1870), then the dispatcher processing is complete (step 1899).
If there were asynchronous method invocation requests on the queue (step 1870), the dispatcher software component 1332 takes the next asynchronous method invocation request off of the queue (step 1875). If the request taken off of the queue is invalid (step 1880), such as a request that cannot be proces~ed by the method ~erver, then processing returns to find out whether there are other queued method invocation requests (step 1870).
If the request taken of the queue is valid (step 1880), then the dispatcher ~oftware component 1332 dispatches the asynchronous method invocation request taken off the queue to be processed by the asynchronous method server (step 1885).
The question is then asked whether an error occurred in the processing of the method server (step 1887). The error, if any, is aco ded (~tep 1888) then, or if an error did not occur, the disp~tcher software component 11332 checks the queue (step 1870).
In thi~ manner all asynchronous invocation requests on the queue are processed, in turn, without blocking the client application that originated the method invocation request.

20~9125 1 - I. Summar~
The present invention thus provides an efficient and simple manner for an application on one platform to be invoked by an application on the same or a different platform. Such invocation can even take place between unlike platforms in a heterogeneous network.
Because, in accordance with the ob~ect-oriented techniques of' this invention, the data (or instances) and applications are not managed, tho~e data and applications can be managed in the manner chosen by the application developers. By managing only ob~ects and references to application~ instead, the requirement~ on ~ystem re~ources are reduced, and the flexibility of the system i~
increased.
Another advantage afforded by thi~ invention is the ability for applications which are not currently rllnni ng to be invoked automatically. This further enhances the power and flexibility of ~y~tem~ implemented in accordance with this invention.
Persons of ordinary skill will reco~nize that modifications and variations may be made to this invention without departing from the spirit and scope of the general inventive concept. This inventlon in it~ broader aspects is therefore not limited to the ~peciflc detail~ or representative methods ~hown and de~cribed.

Claims (6)

1. In a network containing a memory and processors connected to each other by a network bus, the memory storing a context data base and a global data base, the global data base including methods and applications, the context data base including preferences, the preferences for identifying the methods, the applications, and the processors according to a predetermined order, the processors having shared access to the context data base and the global data base, a process to execute the applications comprising the steps of:
referencing in the global data base, by a client application executing on a client processor, a method and an application to perform the method;
identifying, in response to the referencing and using the preferences, a server application to perform the method;
determining if the server application is available in the network;
if the server application is not available, identifying, using the preferences, a server processor, starting the server application on the server processor, and signalling the client processor that the server application is available; and if the server application is available in the network, executing the server application to perform the method.
2. The process of claim 1 wherein the global data base includes instances of data to be manipulated by the applications, and further comprising:
referencing an instance of data by the client application;
transmitting the reference to the instance of data to the server processor; and in response to receiving the reference to the instance of data, manipulating the instance of data by the server application while performing the method.
3. The process of claim 1 further comprising:
identifying, using the preferences, an other server application to perform the method; and determining if the other server application is available in the network.
4. The process of claim 1 wherein the method is to be performed synchronously or asynchronously, and further comprising:
if the method is to be performed synchronously, suspending the client application while the server application is performing the method; and if the method is to be performed asynchronously, continuing the client application while the server application is performing the method.
5. The process of claim 4 further comprising:
queuing the method in a queue if the method is asynchronous, the queue having a plurality of entries;
de-queuing the entries of the queue in a first-in/first-out order to perform the asynchronous method by the client user.
6. The process of claim 1 further comprising:
notifying the client application that the server application has performed the method.
CA002049125A 1990-08-14 1991-08-13 Methods and apparatus for implementing server functions in a distributed heterogeneous environment Expired - Fee Related CA2049125C (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US56713190A 1990-08-14 1990-08-14
US07/567,131 1990-08-14

Publications (2)

Publication Number Publication Date
CA2049125A1 CA2049125A1 (en) 1992-02-15
CA2049125C true CA2049125C (en) 1996-08-06

Family

ID=24265845

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002049125A Expired - Fee Related CA2049125C (en) 1990-08-14 1991-08-13 Methods and apparatus for implementing server functions in a distributed heterogeneous environment

Country Status (7)

Country Link
US (1) US5440744A (en)
EP (1) EP0471442B1 (en)
JP (1) JPH0656600B2 (en)
AU (1) AU628753B2 (en)
CA (1) CA2049125C (en)
DE (1) DE69131742T2 (en)
TW (1) TW323354B (en)

Families Citing this family (233)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5557798A (en) * 1989-07-27 1996-09-17 Tibco, Inc. Apparatus and method for providing decoupling of data exchange details for providing high performance communication between software processes
US6044205A (en) 1996-02-29 2000-03-28 Intermind Corporation Communications system for transferring information between memories according to processes transferred with the information
AU639802B2 (en) * 1990-08-14 1993-08-05 Oracle International Corporation Methods and apparatus for providing dynamic invocation of applications in a distributed heterogeneous environment
US5280610A (en) * 1990-08-14 1994-01-18 Digital Equipment Corporation Methods and apparatus for implementing data bases to provide object-oriented invocation of applications
AU628264B2 (en) * 1990-08-14 1992-09-10 Oracle International Corporation Methods and apparatus for providing a client interface to an object-oriented invocation of an application
DE4131380A1 (en) * 1991-09-20 1993-03-25 Siemens Ag METHOD FOR ADAPTING AN OBJECT-ORIENTED APPLICATION
JP3329841B2 (en) * 1991-10-18 2002-09-30 株式会社日立製作所 Network system and its software management method
CA2097564C (en) * 1992-06-16 2004-05-25 David L. Phillips Method of coupling open systems to a proprietary network
US5581760A (en) * 1992-07-06 1996-12-03 Microsoft Corporation Method and system for referring to and binding to objects using identifier objects
US6209040B1 (en) 1992-10-09 2001-03-27 Microsoft Corporation Method and system for interfacing to a type library
JP3370704B2 (en) * 1992-10-12 2003-01-27 株式会社日立製作所 Communication control method
AU683038B2 (en) * 1993-08-10 1997-10-30 Addison M. Fischer A method for operating computers and for processing information among computers
US5617570A (en) * 1993-11-03 1997-04-01 Wang Laboratories, Inc. Server for executing client operation calls, having a dispatcher, worker tasks, dispatcher shared memory area and worker control block with a task memory for each worker task and dispatcher/worker task semaphore communication
US5699518A (en) * 1993-11-29 1997-12-16 Microsoft Corporation System for selectively setting a server node, evaluating to determine server node for executing server code, and downloading server code prior to executing if necessary
US5594921A (en) * 1993-12-17 1997-01-14 Object Technology Licensing Corp. Authentication of users with dynamically configurable protocol stack
US5548726A (en) * 1993-12-17 1996-08-20 Taligeni, Inc. System for activating new service in client server network by reconfiguring the multilayer network protocol stack dynamically within the server node
US6026454A (en) * 1993-12-17 2000-02-15 Packard Bell Nec, Inc. Interface for multiplexing and reformatting information transfer between device driver programs and a network application program which only accepts information in a predetermined format
US5721904A (en) * 1993-12-20 1998-02-24 Hitachi, Ltd. Database access system and method of controlling access management to a database access system for a plurality of heterogeneous database servers using SQL
US5689700A (en) * 1993-12-29 1997-11-18 Microsoft Corporation Unification of directory service with file system services
EP0671694A1 (en) * 1994-03-08 1995-09-13 AT&T Corp. System for integrating the knowledge domains of multiple computer graphics systems
US6330582B1 (en) * 1994-03-21 2001-12-11 International Business Machines Corporation Apparatus and method enabling a client to control transaction message traffic between server and client processes
DE4414171A1 (en) * 1994-04-22 1995-10-26 Paul Bantzer Control of process loads in computer network
US5819034A (en) * 1994-04-28 1998-10-06 Thomson Consumer Electronics, Inc. Apparatus for transmitting and receiving executable applications as for a multimedia system
USRE44685E1 (en) 1994-04-28 2013-12-31 Opentv, Inc. Apparatus for transmitting and receiving executable applications as for a multimedia system, and method and system to order an item using a distributed computing system
US5694546A (en) 1994-05-31 1997-12-02 Reisman; Richard R. System for automatic unattended electronic information transport between a server and a client by a vendor provided transport software with a manifest list
US5557790A (en) * 1994-06-21 1996-09-17 International Business Machines Corp. Facility for the generic storage and management of multimedia objects
SE9404296D0 (en) * 1994-12-09 1994-12-09 Ellemtel Utvecklings Ab Methods and apparatus for telecommunications
US5701461A (en) * 1995-01-27 1997-12-23 Microsoft Corporation Method and system for accessing a remote database using pass-through queries
US5640540A (en) * 1995-02-13 1997-06-17 International Business Machines Corporation Method and apparatus for translating key codes between servers over a conference networking system
US5655081A (en) * 1995-03-08 1997-08-05 Bmc Software, Inc. System for monitoring and managing computer resources and applications across a distributed computing environment using an intelligent autonomous agent architecture
JPH08249290A (en) * 1995-03-10 1996-09-27 Hitachi Ltd Distributed system
US5694537A (en) * 1995-07-31 1997-12-02 Canon Information Systems, Inc. Network device which selects a time service provider
US5946471A (en) * 1995-08-10 1999-08-31 University Of Cincinnati Method and apparatus for emulating laboratory instruments at remote stations configured by a network controller
US5768511A (en) * 1995-09-18 1998-06-16 International Business Machines Corporation Method and system for managing objects in networked computer system with action performed in the server and object updated in the client
US5768503A (en) * 1995-09-25 1998-06-16 International Business Machines Corporation Middleware program with enhanced security
US5815708A (en) * 1995-10-06 1998-09-29 Sun Microsystems, Inc. Method and apparatus for dynamically loading method call exception code in response to a software method exception generated in a client/server computer system
US8271339B2 (en) * 1995-11-13 2012-09-18 Lakshmi Arunachalam Method and apparatus for enabling real-time bi-directional transactions on a network
US7930340B2 (en) 1995-11-13 2011-04-19 Lakshmi Arunachalam Network transaction portal to control multi-service provider transactions
US8037158B2 (en) 1995-11-13 2011-10-11 Lakshmi Arunachalam Multimedia transactional services
US6625617B2 (en) 1996-01-02 2003-09-23 Timeline, Inc. Modularized data retrieval method and apparatus with multiple source capability
US6189030B1 (en) 1996-02-21 2001-02-13 Infoseek Corporation Method and apparatus for redirection of server external hyper-link references
US5862325A (en) * 1996-02-29 1999-01-19 Intermind Corporation Computer-based communication system and method using metadata defining a control structure
US5893911A (en) * 1996-04-17 1999-04-13 Neon Software, Inc. Method for defining and applying rules for message distribution for transaction processing in a distributed application
US6487607B1 (en) 1998-02-26 2002-11-26 Sun Microsystems, Inc. Methods and apparatus for remote method invocation
US6421704B1 (en) 1998-03-20 2002-07-16 Sun Microsystems, Inc. Method, apparatus, and product for leasing of group membership in a distributed system
US6138238A (en) 1997-12-11 2000-10-24 Sun Microsystems, Inc. Stack-based access control using code and executor identifiers
US6560656B1 (en) 1998-02-26 2003-05-06 Sun Microsystems, Inc. Apparatus and method for providing downloadable code for use in communicating with a device in a distributed system
US6438614B2 (en) 1998-02-26 2002-08-20 Sun Microsystems, Inc. Polymorphic token based control
US6272559B1 (en) 1997-10-15 2001-08-07 Sun Microsystems, Inc. Deferred reconstruction of objects and remote loading for event notification in a distributed system
US6463446B1 (en) 1998-02-26 2002-10-08 Sun Microsystems, Inc. Method and apparatus for transporting behavior in an event-based distributed system
US6282652B1 (en) 1998-02-26 2001-08-28 Sun Microsystems, Inc. System for separately designating security requirements for methods invoked on a computer
US6182083B1 (en) 1997-11-17 2001-01-30 Sun Microsystems, Inc. Method and system for multi-entry and multi-template matching in a database
US6393497B1 (en) 1998-03-20 2002-05-21 Sun Microsystems, Inc. Downloadable smart proxies for performing processing associated with a remote procedure call in a distributed system
US6708171B1 (en) 1996-04-23 2004-03-16 Sun Microsystems, Inc. Network proxy
US6185611B1 (en) 1998-03-20 2001-02-06 Sun Microsystem, Inc. Dynamic lookup service in a distributed system
US6938263B2 (en) 1996-04-23 2005-08-30 Sun Microsystems, Inc. System and method for facilitating dynamic loading of “stub” information to enable a program operating in one address space to invoke processing of a remote method or procedure in another address space
US6226746B1 (en) 1998-03-20 2001-05-01 Sun Microsystems, Inc. Stack-based system and method to combine security requirements of methods
US6578044B1 (en) 1997-11-17 2003-06-10 Sun Microsystems, Inc. Method and system for typesafe attribute matching
US6466947B2 (en) 1998-03-20 2002-10-15 Sun Microsystems, Inc. Apparatus and method for dynamically verifying information in a distributed system
US6598094B1 (en) 1998-03-20 2003-07-22 Sun Microsystems, Inc. Method and apparatus for determining status of remote objects in a distributed system
US6832223B1 (en) 1996-04-23 2004-12-14 Sun Microsystems, Inc. Method and system for facilitating access to a lookup service
US6247026B1 (en) 1996-10-11 2001-06-12 Sun Microsystems, Inc. Method, apparatus, and product for leasing of delegation certificates in a distributed system
US6446070B1 (en) 1998-02-26 2002-09-03 Sun Microsystems, Inc. Method and apparatus for dynamic distributed computing over a network
US6237024B1 (en) * 1998-03-20 2001-05-22 Sun Microsystem, Inc. Method and apparatus for the suspension and continuation of remote processes
US5916307A (en) * 1996-06-05 1999-06-29 New Era Of Networks, Inc. Method and structure for balanced queue communication between nodes in a distributed computing application
US5999972A (en) 1996-07-01 1999-12-07 Sun Microsystems, Inc. System, method and article of manufacture for a distributed computer system framework
US6412017B1 (en) 1996-07-01 2002-06-25 Microsoft Corporation Urgent replication facility
US6134583A (en) * 1996-07-01 2000-10-17 Sun Microsystems, Inc. Method, system, apparatus and article of manufacture for providing identity-based caching services to a plurality of computer systems (#16)
US6154742A (en) * 1996-07-02 2000-11-28 Sun Microsystems, Inc. System, method, apparatus and article of manufacture for identity-based caching (#15)
US5745890A (en) * 1996-08-09 1998-04-28 Digital Equipment Corporation Sequential searching of a database index using constraints on word-location pairs
US5832500A (en) * 1996-08-09 1998-11-03 Digital Equipment Corporation Method for searching an index
US5809502A (en) * 1996-08-09 1998-09-15 Digital Equipment Corporation Object-oriented interface for an index
US5864863A (en) * 1996-08-09 1999-01-26 Digital Equipment Corporation Method for parsing, indexing and searching world-wide-web pages
US6745194B2 (en) 2000-08-07 2004-06-01 Alta Vista Company Technique for deleting duplicate records referenced in an index of a database
US5805829A (en) * 1996-10-01 1998-09-08 International Business Machines Corp Process for running applets over non-IP networks
US5832529A (en) 1996-10-11 1998-11-03 Sun Microsystems, Inc. Methods, apparatus, and product for distributed garbage collection
US6728737B2 (en) 1996-10-11 2004-04-27 Sun Microsystems, Inc. Method and system for leasing storage
US6237009B1 (en) 1996-10-11 2001-05-22 Sun Microsystems, Inc. Lease renewal service
US5911044A (en) * 1996-11-08 1999-06-08 Ricoh Company, Ltd. Network image scanning system which transmits image information from a scanner over a network to a client computer
US6460058B2 (en) * 1996-12-06 2002-10-01 Microsoft Corporation Object-oriented framework for hyperlink navigation
US6401099B1 (en) 1996-12-06 2002-06-04 Microsoft Corporation Asynchronous binding of named objects
US5848415A (en) * 1996-12-18 1998-12-08 Unisys Corporation Selective multiple protocol transport and dynamic format conversion in a multi-user network
GB2320594A (en) * 1996-12-20 1998-06-24 Ibm Dispatching client method calls to parallel execution threads within a server
US6791979B1 (en) 1997-04-10 2004-09-14 Cisco Technology, Inc. Mechanism for conveying data prioritization information among heterogeneous nodes of a computer network
US6115751A (en) * 1997-04-10 2000-09-05 Cisco Technology, Inc. Technique for capturing information needed to implement transmission priority routing among heterogeneous nodes of a computer network
US5991302A (en) * 1997-04-10 1999-11-23 Cisco Technology, Inc. Technique for maintaining prioritization of data transferred among heterogeneous nodes of a computer network
US5925095A (en) * 1997-05-12 1999-07-20 International Business Machines Corporation Method and a computer program product for client/server computing with support for both recoverable and non-recoverable clients
GB2328044B (en) * 1997-08-01 2002-02-27 Ibm Apparatus,method and computer program product for client/server computing with a transaction representation located on each transactionally involved server
US6009470A (en) * 1997-09-10 1999-12-28 Lsi Logic Corporation Encoded multi-media terminal
US6253256B1 (en) 1997-10-15 2001-06-26 Sun Microsystems, Inc. Deferred reconstruction of objects and remote loading in a distributed system
US6957427B1 (en) 1997-10-15 2005-10-18 Sun Microsystems, Inc. Remote object activation in a distributed system
US6148335A (en) * 1997-11-25 2000-11-14 International Business Machines Corporation Performance/capacity management framework over many servers
US6065062A (en) * 1997-12-10 2000-05-16 Cisco Systems, Inc. Backup peer pool for a routed computer network
GB2334116A (en) 1998-02-04 1999-08-11 Ibm Scheduling and dispatching queued client requests within a server computer
US6240197B1 (en) 1998-02-06 2001-05-29 Compaq Computer Corporation Technique for disambiguating proximate objects within an image
US6400830B1 (en) 1998-02-06 2002-06-04 Compaq Computer Corporation Technique for tracking objects through a series of images
US6556708B1 (en) 1998-02-06 2003-04-29 Compaq Computer Corporation Technique for classifying objects within an image
US6184858B1 (en) 1998-02-06 2001-02-06 Compaq Computer Corporation Technique for updating a background image
US6043827A (en) * 1998-02-06 2000-03-28 Digital Equipment Corporation Technique for acknowledging multiple objects using a computer generated face
US6421462B1 (en) 1998-02-06 2002-07-16 Compaq Computer Corporation Technique for differencing an image
US6052132A (en) * 1998-02-06 2000-04-18 Digital Equipment Corporation Technique for providing a computer generated face having coordinated eye and head movement
US6141434A (en) * 1998-02-06 2000-10-31 Christian; Andrew Dean Technique for processing images
US6434271B1 (en) 1998-02-06 2002-08-13 Compaq Computer Corporation Technique for locating objects within an image
US6003083A (en) * 1998-02-19 1999-12-14 International Business Machines Corporation Workload management amongst server objects in a client/server network with distributed objects
JP2002505473A (en) 1998-02-26 2002-02-19 サンマイクロシステムズ インコーポレーテッド Method and system for identifying remote methods with deterministic hash
US6604127B2 (en) 1998-03-20 2003-08-05 Brian T. Murphy Dynamic lookup service in distributed system
US6601110B2 (en) * 1998-03-17 2003-07-29 Sun Microsystems, Inc. System and method for translating file-level operations in a non-door-based operating system to door invocations on a door server
GB2335517A (en) * 1998-03-19 1999-09-22 Ibm Client/server computing system with programmable action by transaction coordinator during prepared state
GB2336006A (en) * 1998-03-31 1999-10-06 Ibm Client/server computing with client selectable location of transaction objects
US6163822A (en) * 1998-05-04 2000-12-19 Compaq Computer Corporation Technique for controlling and processing a section of an interactive presentation simultaneously with detecting stimulus event in manner that overrides process
US6249292B1 (en) 1998-05-04 2001-06-19 Compaq Computer Corporation Technique for controlling a presentation of a computer generated object having a plurality of movable components
US6108712A (en) * 1998-05-05 2000-08-22 International Business Machines Corp. Client-server system with central application management and providing export agent capability for retrofitting existing hardware and applications into the system
US6366916B1 (en) * 1998-05-22 2002-04-02 International Business Machines Corporation Configurable and extensible system for deploying asset management functions to client applications
US6826571B1 (en) * 1998-05-22 2004-11-30 International Business Machines Corporation Method and apparatus for dynamically customizing and extending functions of a server program to enable and restrict functions of the server
US6154743A (en) * 1998-06-16 2000-11-28 Cisco Technology, Inc. Technique for accessing heterogeneous directory services in an APPN environment
US6667736B1 (en) * 1998-06-17 2003-12-23 Microsoft Corporation Method for communicating local information between component objects and hosts
US6735701B1 (en) * 1998-06-25 2004-05-11 Macarthur Investments, Llc Network policy management and effectiveness system
GB2341951A (en) 1998-09-22 2000-03-29 Ibm Thin-client remote object execution
US7035895B1 (en) * 1998-12-17 2006-04-25 International Business Machines Corporation Manager object for management of multiple resources on dataless clients in a distributed computing environment
GB2346985B (en) * 1999-02-19 2003-07-09 Ibm Client/server transaction data processing system with optimum selection of last agent
US6901518B1 (en) 1999-04-08 2005-05-31 Sun Microsystems, Inc. Method and system for establishing trust in downloaded proxy code
GB2348985A (en) 1999-04-15 2000-10-18 Ibm Centralized affinity maintenance in a workload managed client/server system
US6807181B1 (en) * 1999-05-19 2004-10-19 Sun Microsystems, Inc. Context based control data
US6889260B1 (en) * 1999-06-10 2005-05-03 Ec Enabler, Ltd Method and system for transferring information
US6877163B1 (en) 1999-06-14 2005-04-05 Sun Microsystems, Inc. Method and system for dynamic proxy classes
US6845393B1 (en) 1999-06-14 2005-01-18 Sun Microsystems, Inc. Lookup discovery service in a distributed system having a plurality of lookup services each with associated characteristics and services
GB2354350B (en) * 1999-09-17 2004-03-24 Mitel Corp Policy representations and mechanisms for the control of software
US6697835B1 (en) * 1999-10-28 2004-02-24 Unisys Corporation Method and apparatus for high speed parallel execution of multiple points of logic across heterogeneous data sources
US20010047387A1 (en) * 2000-03-27 2001-11-29 Exoplex, Inc. Systems and methods for providing distributed cross-enterprise portals
US7395333B1 (en) 2000-05-09 2008-07-01 Sun Microsystems, Inc. Method and apparatus to obtain negotiated service advertisement
US6643650B1 (en) 2000-05-09 2003-11-04 Sun Microsystems, Inc. Mechanism and apparatus for using messages to look up documents stored in spaces in a distributed computing environment
US7260543B1 (en) 2000-05-09 2007-08-21 Sun Microsystems, Inc. Automatic lease renewal with message gates in a distributed computing environment
US6950875B1 (en) 2000-05-09 2005-09-27 Sun Microsystems, Inc. Message conductors in a distributed computing environment
US6898618B1 (en) 2000-05-09 2005-05-24 Sun Microsystems, Inc. Client-specified display services in a distributed computing environment
US7243356B1 (en) 2000-05-09 2007-07-10 Sun Microsystems, Inc. Remote method invocation with secure messaging in a distributed computing environment
US8082491B1 (en) 2000-05-09 2011-12-20 Oracle America, Inc. Dynamic displays in a distributed computing environment
US6862594B1 (en) 2000-05-09 2005-03-01 Sun Microsystems, Inc. Method and apparatus to discover services using flexible search criteria
US7200848B1 (en) 2000-05-09 2007-04-03 Sun Microsystems, Inc. Migrating processes using data representation language representations of the processes in a distributed computing environment
US6973493B1 (en) 2000-05-09 2005-12-06 Sun Microsystems, Inc. Mechanism and apparatus for security of newly spawned repository spaces in a distributed computing environment
US7370091B1 (en) 2000-05-09 2008-05-06 Sun Microsystems, Inc. Method and apparatus for obtaining space advertisements
US8135796B1 (en) 2000-05-09 2012-03-13 Oracle America, Inc. Mechanism and apparatus for accessing and addressing services in a distributed computing environment
US8001232B1 (en) 2000-05-09 2011-08-16 Oracle America, Inc. Event message endpoints in a distributed computing environment
US6970869B1 (en) 2000-05-09 2005-11-29 Sun Microsystems, Inc. Method and apparatus to discover services and negotiate capabilities
US6850979B1 (en) 2000-05-09 2005-02-01 Sun Microsystems, Inc. Message gates in a distributed computing environment
US6918084B1 (en) 2000-05-09 2005-07-12 Sun Microsystems, Inc. Spawning new repository spaces using information provided in advertisement schema messages
US7577834B1 (en) 2000-05-09 2009-08-18 Sun Microsystems, Inc. Message authentication using message gates in a distributed computing environment
US7080078B1 (en) 2000-05-09 2006-07-18 Sun Microsystems, Inc. Mechanism and apparatus for URI-addressable repositories of service advertisements and other content in a distributed computing environment
US7010573B1 (en) 2000-05-09 2006-03-07 Sun Microsystems, Inc. Message gates using a shared transport in a distributed computing environment
US6789077B1 (en) 2000-05-09 2004-09-07 Sun Microsystems, Inc. Mechanism and apparatus for web-based searching of URI-addressable repositories in a distributed computing environment
US6792466B1 (en) 2000-05-09 2004-09-14 Sun Microsystems, Inc. Trusted construction of message endpoints in a distributed computing environment
US6917976B1 (en) 2000-05-09 2005-07-12 Sun Microsystems, Inc. Message-based leasing of resources in a distributed computing environment
US6868447B1 (en) 2000-05-09 2005-03-15 Sun Microsystems, Inc. Mechanism and apparatus for returning results of services in a distributed computing environment
US7065574B1 (en) 2000-05-09 2006-06-20 Sun Microsystems, Inc. Messaging system using pairs of message gates in a distributed computing environment
US6789126B1 (en) 2000-05-09 2004-09-07 Sun Microsystems, Inc. Addressing message gates in a distributed computing environment
US7016966B1 (en) 2000-05-09 2006-03-21 Sun Microsystems, Inc. Generating results gates in a distributed computing environment
US7716492B1 (en) 2000-05-09 2010-05-11 Oracle America, Inc. Method and apparatus to obtain service capability credentials
US7188251B1 (en) 2000-05-09 2007-03-06 Sun Microsystems, Inc. System and method for secure message-based leasing of resources in a distributed computing environment
US7072967B1 (en) 2000-05-09 2006-07-04 Sun Microsystems, Inc. Efficient construction of message endpoints
US6925490B1 (en) * 2000-05-31 2005-08-02 International Business Machines Corporation Method, system and program products for controlling system traffic of a clustered computing environment
US6854115B1 (en) 2000-06-02 2005-02-08 Sun Microsystems, Inc. Process persistence in a virtual machine
US6865657B1 (en) 2000-06-02 2005-03-08 Sun Microsystems, Inc. Garbage collector for a virtual heap
US6957237B1 (en) 2000-06-02 2005-10-18 Sun Microsystems, Inc. Database store for a virtual heap
US6760815B1 (en) 2000-06-02 2004-07-06 Sun Microsystems, Inc. Caching mechanism for a virtual heap
US6941410B1 (en) 2000-06-02 2005-09-06 Sun Microsystems, Inc. Virtual heap for a virtual machine
US6763440B1 (en) 2000-06-02 2004-07-13 Sun Microsystems, Inc. Garbage collection using nursery regions for new objects in a virtual heap
US6948135B1 (en) 2000-06-21 2005-09-20 Microsoft Corporation Method and systems of providing information to computer users
US7155667B1 (en) 2000-06-21 2006-12-26 Microsoft Corporation User interface for integrated spreadsheets and word processing tables
US7624356B1 (en) 2000-06-21 2009-11-24 Microsoft Corporation Task-sensitive methods and systems for displaying command sets
US7117435B1 (en) 2000-06-21 2006-10-03 Microsoft Corporation Spreadsheet fields in text
US7000230B1 (en) 2000-06-21 2006-02-14 Microsoft Corporation Network-based software extensions
US6874143B1 (en) 2000-06-21 2005-03-29 Microsoft Corporation Architectures for and methods of providing network-based software extensions
US6883168B1 (en) 2000-06-21 2005-04-19 Microsoft Corporation Methods, systems, architectures and data structures for delivering software via a network
US7191394B1 (en) 2000-06-21 2007-03-13 Microsoft Corporation Authoring arbitrary XML documents using DHTML and XSLT
US7346848B1 (en) 2000-06-21 2008-03-18 Microsoft Corporation Single window navigation methods and systems
AU2001264895A1 (en) 2000-06-21 2002-01-02 Microsoft Corporation System and method for integrating spreadsheets and word processing tables
US6754621B1 (en) * 2000-10-06 2004-06-22 Andrew Cunningham Asynchronous hypertext messaging system and method
EP1198101A1 (en) * 2000-10-13 2002-04-17 Sun Microsystems, Inc. Provisioning mechanism for a service gateway
EP1198102B1 (en) * 2000-10-13 2007-06-27 Sun Microsystems, Inc. Extendable provisioning mechanism for a service gateway
US7296275B2 (en) 2001-01-04 2007-11-13 Sun Microsystems, Inc. Method and system for passing objects in a distributed system using serialization contexts
US6961773B2 (en) * 2001-01-19 2005-11-01 Esoft, Inc. System and method for managing application service providers
US7024662B2 (en) * 2001-03-14 2006-04-04 Microsoft Corporation Executing dynamically assigned functions while providing services
US7539747B2 (en) 2001-03-14 2009-05-26 Microsoft Corporation Schema-based context service
US7302634B2 (en) 2001-03-14 2007-11-27 Microsoft Corporation Schema-based services for identity-based data access
US8019807B2 (en) * 2001-05-23 2011-09-13 Wireless Enterprise Solutions Technology Limited Method and system for communication between computer systems
US7660887B2 (en) 2001-09-07 2010-02-09 Sun Microsystems, Inc. Systems and methods for providing dynamic quality of service for a distributed system
US7756969B1 (en) 2001-09-07 2010-07-13 Oracle America, Inc. Dynamic provisioning of identification services in a distributed system
US7568219B2 (en) * 2002-01-08 2009-07-28 Bottomline Technologies (De), Inc. Transfer server of a secure system for unattended remote file and message transfer
US20030204592A1 (en) * 2002-03-07 2003-10-30 Crown Media Holdings, Inc. System for uniquely identifying assets and subsribers in a multi-media communicaion network
US8527408B2 (en) 2002-05-06 2013-09-03 Bottom Line Technologies (De), Inc. Integrated payment system
US9886309B2 (en) 2002-06-28 2018-02-06 Microsoft Technology Licensing, Llc Identity-based distributed computing for device resources
US7627585B2 (en) * 2002-12-02 2009-12-01 Sap Ag Data structure mapping and packaging
US7370066B1 (en) 2003-03-24 2008-05-06 Microsoft Corporation System and method for offline editing of data files
US7415672B1 (en) 2003-03-24 2008-08-19 Microsoft Corporation System and method for designing electronic forms
US7275216B2 (en) 2003-03-24 2007-09-25 Microsoft Corporation System and method for designing electronic forms and hierarchical schemas
US7296017B2 (en) 2003-03-28 2007-11-13 Microsoft Corporation Validation of XML data files
US7913159B2 (en) 2003-03-28 2011-03-22 Microsoft Corporation System and method for real-time validation of structured data files
US7516145B2 (en) 2003-03-31 2009-04-07 Microsoft Corporation System and method for incrementally transforming and rendering hierarchical data files
US7168035B1 (en) 2003-06-11 2007-01-23 Microsoft Corporation Building a view on markup language data through a set of components
US7451392B1 (en) 2003-06-30 2008-11-11 Microsoft Corporation Rendering an HTML electronic form by applying XSLT to XML using a solution
US7197515B2 (en) 2003-06-30 2007-03-27 Microsoft Corporation Declarative solution definition
US7581177B1 (en) 2003-08-01 2009-08-25 Microsoft Corporation Conversion of structured documents
US7406660B1 (en) 2003-08-01 2008-07-29 Microsoft Corporation Mapping between structured data and a visual surface
US7334187B1 (en) 2003-08-06 2008-02-19 Microsoft Corporation Electronic form aggregation
US7792874B1 (en) 2004-01-30 2010-09-07 Oracle America, Inc. Dynamic provisioning for filtering and consolidating events
US8819072B1 (en) 2004-02-02 2014-08-26 Microsoft Corporation Promoting data from structured data files
US7430711B2 (en) 2004-02-17 2008-09-30 Microsoft Corporation Systems and methods for editing XML documents
US7318063B2 (en) 2004-02-19 2008-01-08 Microsoft Corporation Managing XML documents containing hierarchical database information
US7496837B1 (en) 2004-04-29 2009-02-24 Microsoft Corporation Structural editing with schema awareness
US7568101B1 (en) 2004-05-13 2009-07-28 Microsoft Corporation Digital signatures with an embedded view
US7281018B1 (en) 2004-05-26 2007-10-09 Microsoft Corporation Form template data source change
US7774620B1 (en) 2004-05-27 2010-08-10 Microsoft Corporation Executing applications at appropriate trust levels
US7516399B2 (en) 2004-09-30 2009-04-07 Microsoft Corporation Structured-document path-language expression methods and systems
US7692636B2 (en) 2004-09-30 2010-04-06 Microsoft Corporation Systems and methods for handwriting to a screen
US8487879B2 (en) 2004-10-29 2013-07-16 Microsoft Corporation Systems and methods for interacting with a computer through handwriting to a screen
US7584417B2 (en) 2004-11-15 2009-09-01 Microsoft Corporation Role-dependent action for an electronic form
US7712022B2 (en) 2004-11-15 2010-05-04 Microsoft Corporation Mutually exclusive options in electronic forms
US7721190B2 (en) 2004-11-16 2010-05-18 Microsoft Corporation Methods and systems for server side form processing
US7509353B2 (en) 2004-11-16 2009-03-24 Microsoft Corporation Methods and systems for exchanging and rendering forms
US7904801B2 (en) 2004-12-15 2011-03-08 Microsoft Corporation Recursive sections in electronic forms
US7437376B2 (en) 2004-12-20 2008-10-14 Microsoft Corporation Scalable object model
US7937651B2 (en) 2005-01-14 2011-05-03 Microsoft Corporation Structural editing operations for network forms
US7725834B2 (en) 2005-03-04 2010-05-25 Microsoft Corporation Designer-created aspect for an electronic form template
US8010515B2 (en) 2005-04-15 2011-08-30 Microsoft Corporation Query to an electronic form
US7543228B2 (en) 2005-06-27 2009-06-02 Microsoft Corporation Template for rendering an electronic form
US8200975B2 (en) 2005-06-29 2012-06-12 Microsoft Corporation Digital signatures for network forms
US7613996B2 (en) 2005-08-15 2009-11-03 Microsoft Corporation Enabling selection of an inferred schema part
US8001459B2 (en) 2005-12-05 2011-08-16 Microsoft Corporation Enabling electronic documents for limited-capability computing devices
US7779343B2 (en) 2006-01-30 2010-08-17 Microsoft Corporation Opening network-enabled electronic documents
JP6465376B2 (en) * 2014-06-16 2019-02-06 株式会社インタラクティブソリューションズ Display information management system
JP6078515B2 (en) 2014-11-13 2017-02-08 京セラドキュメントソリューションズ株式会社 Electronic equipment and programs
US11532040B2 (en) 2019-11-12 2022-12-20 Bottomline Technologies Sarl International cash management software using machine learning
US11526859B1 (en) 2019-11-12 2022-12-13 Bottomline Technologies, Sarl Cash flow forecasting using a bottoms-up machine learning approach
US11704671B2 (en) 2020-04-02 2023-07-18 Bottomline Technologies Limited Financial messaging transformation-as-a-service

Family Cites Families (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4325120A (en) * 1978-12-21 1982-04-13 Intel Corporation Data processing system
JPS60229160A (en) * 1984-04-26 1985-11-14 Toshiba Corp Multiprocessor system
AU589400B2 (en) * 1985-03-05 1989-10-12 Wang Laboratories, Inc. Apparatus and method for control of one computer system by another computer system
US4882674A (en) * 1985-03-05 1989-11-21 Wang Laboratories, Inc. Apparatus and method for control of one computer system by another computer system
US5014192A (en) * 1985-05-06 1991-05-07 Motorola Computer X, Inc. System for locating a file in a logical ring by sequentially forwarding access request with file system name and file name
US4825354A (en) * 1985-11-12 1989-04-25 American Telephone And Telegraph Company, At&T Bell Laboratories Method of file access in a distributed processing computer network
US4868745A (en) * 1986-05-30 1989-09-19 Hewlett-Packard Company Data processing system and method for the direct and indirect execution of uniformly structured object types
US4887204A (en) * 1987-02-13 1989-12-12 International Business Machines Corporation System and method for accessing remote files in a distributed networking environment
US4885684A (en) * 1987-12-07 1989-12-05 International Business Machines Corporation Method for compiling a master task definition data set for defining the logical data flow of a distributed processing network
US4853843A (en) * 1987-12-18 1989-08-01 Tektronix, Inc. System for merging virtual partitions of a distributed database
US5109486A (en) * 1989-01-06 1992-04-28 Motorola, Inc. Distributed computer system with network and resource status monitoring
US5142622A (en) * 1989-01-31 1992-08-25 International Business Machines Corporation System for interconnecting applications across different networks of data processing systems by mapping protocols across different network domains
US5265250A (en) * 1990-03-29 1993-11-23 At&T Bell Laboratories Apparatus and methods for performing an application-defined operation on data as part of a system-defined operation on the data
AU628264B2 (en) * 1990-08-14 1992-09-10 Oracle International Corporation Methods and apparatus for providing a client interface to an object-oriented invocation of an application
AU639802B2 (en) * 1990-08-14 1993-08-05 Oracle International Corporation Methods and apparatus for providing dynamic invocation of applications in a distributed heterogeneous environment
US5280610A (en) * 1990-08-14 1994-01-18 Digital Equipment Corporation Methods and apparatus for implementing data bases to provide object-oriented invocation of applications

Also Published As

Publication number Publication date
DE69131742D1 (en) 1999-12-02
AU7945591A (en) 1992-03-26
JPH0675889A (en) 1994-03-18
TW323354B (en) 1997-12-21
EP0471442A3 (en) 1993-01-13
EP0471442A2 (en) 1992-02-19
DE69131742T2 (en) 2000-04-27
US5440744A (en) 1995-08-08
JPH0656600B2 (en) 1994-07-27
EP0471442B1 (en) 1999-10-27
AU628753B2 (en) 1992-09-17
CA2049125A1 (en) 1992-02-15

Similar Documents

Publication Publication Date Title
CA2049125C (en) Methods and apparatus for implementing server functions in a distributed heterogeneous environment
US5341478A (en) Methods and apparatus for providing dynamic invocation of applications in a distributed heterogeneous environment
EP0474339B1 (en) Methods and apparatus for providing a client interface to an object-oriented invocation of an application
US5280610A (en) Methods and apparatus for implementing data bases to provide object-oriented invocation of applications
EP0501610B1 (en) Object oriented distributed computing system
EP0669020B1 (en) Methods for marshalling interface pointers for remote procedure calls
US6470375B1 (en) System and method for managing the execution of system management tasks
US5930503A (en) System and method for on demand registration of tasks
US8191077B2 (en) Method for providing stand-in objects
KR19990064026A (en) Object-oriented method maintenance mechanism that does not require the computer system or its program to be stopped
US6208994B1 (en) Supporters providing extensible classes without recoding for object-oriented applications
EP0767434B1 (en) System and method for adding object services to a binary class in an object oriented system
Ott Simple shared object

Legal Events

Date Code Title Description
EEER Examination request
MKLA Lapsed