One form of the present invention is a data processing system, computer program product and/or method of operating an operating system for providing inter-application communications between a publisher application and a server application. The method includes receiving a publication request from the publisher application at the operating system, receiving a subscription request from the subscriber application at the operating system, performing an operating system based event brokering procedure based on the publication request and the subscription request, and publishing an event based on the procedure.
A second form of the present invention is an operating system for providing inter-application communications between a publisher application and a subscriber application. The operating system comprises computer readable code for receiving a publication request from the publisher application at the operating system, computer readable code for receiving a subscription request from the subscriber application at the operating system, computer readable code for performing an operating system based event brokering procedure based on the publication request and the subscription request, and computer readable code for publishing an event based on the procedure.
A third form of the present invention is an operating system for providing inter-application communications between a publisher application and a subscriber application. The operating system comprises means for receiving a publication request from the publisher application at the operating system, means for receiving a subscription request from the subscriber application at the operating system, and means for performing an operating system based event brokering procedure based on the publication request and the subscription request, and means for publishing an event based on the procedure.
The foregoing and other features and advantages of the invention will become further apparent from the following detailed description of the presently preferred embodiments, read in conjunction with the accompanying drawings. The detailed description and drawings are merely illustrative of the invention, rather than limiting the scope of the invention being defined by the appended claims and equivalents thereof.
An operating system runs on processor 152 to coordinate and provide control of various components within computer system 150. Further, the operating system coordinates inter-application communications as described in further detail below. The operating system can be any appropriate available operating system such as Windows, Macintosh, UNIX, AIX, HP-UX, LINUX, or OS/2, or the like. “Windows” is a trademark of Microsoft Corporation. “Macintosh” is a trademark of Apple Computer, Inc. “UNIX” is a trademark of The Open Group. HP-UX is a trademark of Hewlett-Packard Company. “Linux” is a trademark of the Linux Mark Institute. “A/X” and “OS/2” are trademarks of International Business Machines Corporation. Instructions for the operating system, an object-oriented operating system, and applications or programs are located on storage devices, such as hard disk drive 176 and can be loaded into main memory 154 for execution by processor 152.
Those of ordinary skill in the art will appreciate that the hardware in
The invention can take the form of an entirely hardware embodiment or an embodiment containing both hardware and software elements. Furthermore, the invention can take the form of a computer program product accessible from a computer-usable or computer-readable storage device providing program code for use by or in connection with one or more computers or any instruction execution system. For the purposes of this description, a computer-usable or computer readable storage device can be any apparatus that can store the program for use by or in connection with the instruction execution system, apparatus, or device. The storage device can be an electronic, magnetic, optical, electromagnetic, or semiconductor system (or apparatus or device). Examples of a computer-readable storage device include a semiconductor or solid-state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk. The term “computer-readable storage device” does not encompass a signal propagation media such as a copper transmission cable, an optical transmission fiber or wireless transmission media.
Method 200 continues at step 220 by receiving a publication request from a publisher application at an operating system (OS). An OS organizes and controls operations of hardware and provides an environment to execute applications on top of and under control of the OS. In one embodiment, the operating system 300 is in communication with a registry repository 310, shown in
As shown in
At step 230, the publisher application is registered with the operating system. In one embodiment, the registration takes place during an installation process. Alternatively, the publisher application registers during an independent registration process. For example, if the publisher application is already installed, the publisher application can register at any point by running the independent registration process. At either of these points, a process is run to register the application, and the events it may publish, with the registry of the operating system. In one embodiment, this registration process may be run independently of installation. For example, another application or a system user can request that the publisher application register if it is not already done so. Post-installation registration or update of registration can be applied in instances of a software update, user request, or other process.
At step 240, a subscription request is received from a subscriber application at the operating system. In one embodiment, the subscription request is recorded at the registry. A subscription request may include an application identifier, such as an application name. The application identifier may indicate which application from which the subscriber application wishes to receive events. When a subscription request is received at the operating system, the application identifier may be compared to a collection of application identifiers that are currently registered as publisher applications.
At step 250, an event filter is created. The subscription request may also include a list of event types or other subscription criteria. Subscription criteria may be used to filter what events are passed to the subscriber application. In one embodiment, the subscriber application creates an event filter with the operating system during the filing of a subscription request. An event filter may specify the number and type of published events that are communicated from the registry to the subscriber application. For example, the event filter may only allow published events of an event type specified in subscription criteria to pass through to the subscriber application. The subscription request may include an object that implements an event listener interface with the operating system. The event listener interface of the operating system waits for detection of published events that pass through the filter. If the event matches the subscription request, and passes one or more event filters if they exist, the listener interface communicates the event to the subscriber application. If the event does not match the subscription request, or does not pass at least one of the event filters, the listener interface does not communicate the event to the subscriber application.
The event filter and an event listener interface facilitate an operating system based event brokering by the operations system that encompasses steps 260, 270 and 280.
At step 260, an event is published upon receiving the publication request at the operating system. A published event is an event that has occurred in an application and has been received by the operating system for brokering. In one embodiment, a published event awaits communication to the subscriber application.
In one embodiment, the publisher application publishes and stores events in the registry repository at step 270. Information may be alternatively stored in a standard file or database. The registry repository is a system-defined database used by the operating system to store configuration information. Applications may register, write data and publish events, all of which may be stored and retrieved through the registry repository. The data and format of the registration and published events in the registry and registry repository can vary according to the version and brand of the operating system, or according to the implementation of the operating system event brokering. The operating system may provide publication of the events stored in the registry repository for times the subscriber application is unavailable (e.g., not running). For example, if the subscriber application is closed when an event is published, the published events may be communicated to the subscriber application when it becomes active, as the events have been stored in the registry repository. Alternatively, published events may be discarded if the subscriber application is not available to provide real-time publication and subsequent communication of the event.
Those skilled in the art will recognize that the publisher and subscriber applications can vary in number. For example, a single publisher application can communicate with a plurality of subscriber applications. Likewise, a single subscriber application can communicate with a plurality of publisher applications. The invention is not limited to a single publisher application and a single subscriber application. For example, a plurality of computers running the subscriber application can subscribe for another computer running the publisher application through a connection. As such, published publisher application events are broadcast to numerous computers running the subscriber application through the Internet. As another example, a single subscriber application subscribes to events published by numerous publisher applications running on the same computer. As such, the subscriber application utilizes the information of the events of the numerous publisher applications for various purposes.
At step 280, the published event is communicated from the operating system to the subscriber application based on the subscription request. In one embodiment, the published event is communicated from the operating system registry repository to a subscriber application running on the same client computer as the publisher application. In another embodiment, the published event is communicated from the registry repository to one or more instances of the subscriber application running on separate client computer(s) and linked through a LAN or WAN, such as the Internet. Communication involves sending the published event from the registry repository of the OS of the publisher application to the subscriber application via a network connection. The published event may cause the subscriber application to perform some action. In one embodiment, the event may include a compiled program or application code, either of which may cause the subscriber application to perform some action. For example, a published event can control certain characteristics of the subscriber applications (e.g., mouse movements and/or clicks, open and closing the subscriber application, publication/display of data in real-time, and the like).
As the events are published through the operating system, programming code for providing direct inter-application communication capabilities is not required for each individual application. In addition, the use of an operating system as an event broker can reduce incompatibility issues as the strategy for communicating between applications is standardized. Besides providing an event filter and event listener, the operating system can provide event logging, guaranteed event delivery, event correlation, protocol translation, and other functions.
Those skilled in the art will appreciate that the publisher and subscriber applications can exchange published events through the operating system in a bilateral manner. For example, the subscriber program optionally includes capabilities of the publisher program whereby the program publishes events to the registry repository. The publisher program, which optionally includes capabilities of the subscriber program, subscribes to the events. The publisher and subscriber programs can exchange information in a synchronous or asynchronous manner on the same computer or over different client computers over a LAN or WAN. In this manner, applications may be run over multiple computers in a distributed manner via a publish/subscribe mechanism over the Internet.
In one embodiment, information can be shared during a network meeting, which illustrates various steps implemented by the present invention. A publisher application, running on a host computer, publishes screen shot images as well as various actions being performed on the application. These events may be published over a network (e.g., Internet) to numerous participants (e.g., client computers) in the meeting. The participants each run the subscriber application, which receives published events (i.e., as screen shot images and the actions) from the OS of the publisher computer based on subscription requests from the subscriber application at step 240. The participants can see not only the screen shot images being communicated across the network, but also the actions being performed on the publisher application as step 280. Processing may terminate thereafter at step 290.
In the present example, the published events (e.g., which are subscribed to during step 250) are communicated from the publisher application to the subscriber application via the OS of the host computer, which were stored in the registry repository during step 240. The published events (which are published during step 270) include the screen shot images as well as the actual actions being performed on the publisher application. As such, the network meeting allows communication between the publisher application and OS run on the host computer and the subscriber application run on the client computer(s).
In one embodiment, the publisher/subscriber model may be applied to hand writing recognition. For example, some hand writing recognition software applications have two modes, one for recognizing alphabetical characters and the other for recognizing numeric characters. The handwriting and numeric applications can subscribe to another application for providing, for instance, contacts, calendars, appointments, and the like. When a user tabs to a numeric field in an appointment application (e.g., the publisher application) the tab information can be communicated as published events to the handwriting recognition application (e.g., the subscriber application). The handwriting recognition application can then automatically switch its mode to the numeric recognition application. As such, communication is provided between a publisher application, OS, and subscriber application running on the same computer.
While the embodiments of the present invention disclosed herein are presently considered to be preferred embodiments, various changes and modifications can be made without departing from the spirit and scope of the present invention. The scope of the invention is indicated in the appended claims, and all changes that come within the meaning and range of equivalents are intended to be embraced therein.
The present invention is a continuation to parent U.S. patent application Ser. No. 15/005,241, filed Jan. 25, 2016 entitled “SYSTEM AND METHOD OF PROVIDING INTER-APPLICATION COMMUNICATIONS”. patent application Ser. No. 15/005,241, itself, is a continuation to, U.S. patent application Ser. No. 14/063,321, filed Oct. 25, 2013 entitled “SYSTEM AND METHOD OF PROVIDING INTER-APPLICATION COMMUNICATIONS”. patent application Ser. No. 14/063,321, itself, is a continuation to Ser. No. 11/278,732, filed Apr. 5, 2006, entitled “SYSTEM AND METHOD OF PROVIDING INTER-APPLICATION COMMUNICATIONS” priority to which is claimed. The present invention claims priority to at least Ser. No.11/278,732, the earliest-filed among the above-stated applications. The present invention relates generally to computer systems and in particular to the communications between applications. There are situations when it is desirable to allow communication between two or more applications. Such communication allows the programs to provide a flow of information for achieving numerous tasks and can be implemented in numerous circumstances. However, to provide such operability currently requires the applications to be known to, for example, a programmer in order to provide coding for each application. The programmer can thus facilitate communications functionality to each individual program through the coding. Such a process can be tedious and time consuming as the number of programs to which it is desirable to provide inter-application communications can be large. Another problem with having to provide code to numerous programs can arise from incompatibility issues. In some situations, it is possible that the provided code to the large number of different applications can result in miscommunication or worse, total incompatibility (possibly resulting in a crash in one or more of the applications). As such, it would be desirable to provide a strategy for ensuring that different applications can reliably communicate with one another. Therefore, it would be desirable to provide a strategy for providing inter-application communications that would overcome the aforementioned and other disadvantages.
Number | Name | Date | Kind |
---|---|---|---|
5404534 | Foss et al. | Apr 1995 | A |
6202099 | Gillies et al. | Mar 2001 | B1 |
6782403 | Kino et al. | Aug 2004 | B1 |
6834296 | Brown et al. | Dec 2004 | B2 |
6938247 | Czajkowski | Aug 2005 | B2 |
20020144010 | Younis et al. | Oct 2002 | A1 |
20040205458 | Hwang | Oct 2004 | A1 |
20050044197 | Lai | Feb 2005 | A1 |
20050044554 | Hinson et al. | Feb 2005 | A1 |
20060010392 | Noel | Jan 2006 | A1 |
20060209868 | Callaghan | Sep 2006 | A1 |
20070282793 | Majors | Dec 2007 | A1 |
20120191784 | Lee et al. | Jul 2012 | A1 |
Entry |
---|
Beamex Place—Ramblings on Microsoft Technology, How to see the same screen on server 2003/2008 (share a session), Mar. 11, 2008, http://beamex.wordpress.com/2008/03/11/how-to-see-the-same-screen-on-server-20032008-share-a-session/. |
B Zhen, Office Action U.S. Appl. No. 11/278,732, Mar. 8, 2010. |
Robert C. Rolnik, AmendmenttoOfficeAction U.S. Appl. No. 11/278,732, May 10, 2010. |
Li B Zhen, Office Action U.S. Appl. No. 11/278,732, Aug. 3, 2010. |
Robert C. Rolnik, Request for Continued Examination U.S. Appl. No. 11/278,732, Sep. 29, 2010. |
Kimberly L. Jordan, Office Action U.S. Appl. No. 11/278,732, Dec. 20, 2012. |
Robert C. Rolnik, Response to Office Action Examination U.S. Appl. No. 11/278,732, Apr. 22, 2013. |
Kimberly L. Jordan, Office Action U.S Appl. No. 11/278,732, Aug. 16, 2013. |
Li B. Zhen, Office Action U.S. Appl. No. 11/278,732, Mar. 8, 2010. |
Li B. Zhen, Response to Office Action U.S. Appl. No. 11/278,732, May 11, 2015. |
Kimberly Jordan, Office Action U.S. Appl. No. 14/063,321, Aug. 14, 2015. |
Kimberly Jordan, Response to Office Action U.S. Appl. No. 14/063,321, Sep. 24, 2015. |
Kimberly Jordan, Notice of Allowance, U.S. Appl. No. 14/063,321, Jan. 4, 2016. |
Kimberly Jordan, Office Action U.S. Appl. No. 15/005,241, Mar. 4, 2016. |
Robert C. Rolnik, Response to Office Action U.S. Appl. No. 15/005,241, Mar. 4, 2016. |
Kimberly Jordan, Notice of Allowance U.S. Appl. No. 15/005,241, Mar. 12, 2016. |
Lawrence G. Palmer; Shared Desktop:A Collaborative Tool for Sharing 3-D Applications among Different Window Systems; Digital Technical Journal, vol. 9, No. 3 1997. |
Number | Date | Country | |
---|---|---|---|
20160239355 A1 | Aug 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15005241 | Jan 2016 | US |
Child | 15137169 | US | |
Parent | 14063321 | Oct 2013 | US |
Child | 15005241 | US | |
Parent | 11278732 | Apr 2006 | US |
Child | 14063321 | US |