TweetFollow Us on Twitter

IAC in Sys 7
Volume Number:5
Issue Number:8
Column Tag:Developer's Notes

Related Info: Apple Event Mgr PPC ToolBox Event Manager Edition Manager

Apple's IAC in System 7

By Frank Alviani, Contributing Editor, Waukegan, IL

Inter-Application Communications - The Future is Rapidly Approaching

It was just one year ago that my first article on Inter-Application Communications was printed here in MacTutor. In it and the succeeding two articles Paul Snively and I described and implemented a facility for allowing programs to be written that could automatically communicate without bothering the user. Apple has “validated” that concept by making it a centerpiece of the upcoming System 7.0. This article will be a short look at the approach taken by Apple, and how it is going to change the face of the Macintosh forever. (If you work in Word 4.0 with Superpaint 1.1MS, the linked combination gives some hint of the feel of the linked-document future we are heading towards!) It is NOT an introduction to the actual programming interfaces.

In addition to the new world Apple is entering, DEC has an analogous concept called Compound Data Architecture (CDA). The similarities between a suite of IAC-linked documents on a Mac and a DEC compound document are enough to strongly suggest that once both are established in the marketplace, it will be reasonably straightforward to convert between the two systems. This is a non-trivial operational concern in mixed shops, and important from a marketing viewpoint. I would be mildly surprised if the two companies didn’t work together to ensure the interconvertability of their systems.

Apple has taken a layered approach to implementing their IAC facilities; this is consistent with the approach taken with the other toolboxes and a natural division based on the intended usage for each layer. The material that appeared here in MacTutor corresponds to the PPC-toolbox level in the Apple scheme.

Figure 1 shows the layering designed by Apple, intended to show how interfaces on one layer depend on the next layer down, and how the interfaces at the same level serve different aspects of a common requirement.

SuperPaint!Me:Write Ups:Apple-IAC Illustrations!Draw(107,129:203,179)

SuperPaint!Me:Write Ups:Apple-IAC Illustrations!Draw(103,56:350,178)

The PPC Toolbox

The lowest level provides the raw messaging tools: direct communication and “store and forward”. This level is not intended for user-interface usage. It corresponds most closely to the SAWS IAC system, although the details of the Apple implementation haven’t been spelled out enough to tell how similar the internals are (I suspect they are significantly different, since certain of our IAC facilities are placed in different layers in the Apple software).

This level services two classes of clients: the upper layer of the IAC system software, and non-event based “chunks o’ code” such as RDEVs, DAs, etc. In a sense, all code executing on a Macintosh will be on an equal footing, able to talk with any other code executing at the same time or in the future. It is very important to note that programs and processes do NOT have to be on the same machine to take advantage of the PPC facilities.

These tools open up various interesting possibilities:

• Programs would be able to preserve “state information” across sessions by using the store-and-forward facilities to send messages to their future incarnations.

• Cooperation between programs on networked machines - well beyond the capabilities of today’s programs such as Timbuktu - becomes practical. For example, an artist can be building an illustration for an article, on machine A, while the article is being written on machine B, and the illustration would be in place in the article even while being drawn. This could allow unprecedented cooperation.

• Control panel devices could be used to actually control executing programs, etc. For example, an intercom is one possible such device.

The “Higher Level Events”

For the programmer, there is a significant extension of the event manager: “higher level events”. This is intended mostly for “below the surface” program-to-program requests, many in the form of remote menu-command executions.

In order for higher level events to be extensible for the future, several fields in the existing message record have had additional usages layered on top of their existing definition (in much the same way that the Text Edit toolbox was extended).

As shown in Figure 2, the “message” and “where” fields are redefined when interpreting a higher level event. The “what2” field - message class - identifies the protocol that defines how the specific message in the “what3” field is to be interpreted. How are those message classes going to be assigned so there won’t be anarchy and inadvertent duplication?

Apple long ago put a workable system in place when it decided to use 4 character fields to identify resources, application signatures, etc., and that same system will be used here. Applications will use their signature (‘MACA’, etc.) as the message class they send; Apple is, as usual, reserving all-lower-case combinations for themselves. For each class of messages, there are 232 possible messages.

I expect that at first each publisher will independently define sets of messages that will allow his applications to cooperate. However, there was discussion at the developers’ conference of perhaps arranging a conference on AppleLink to support the growth of a set of industry standard, publisher-independent messages. This would be of enormous benefit to the user, since it would make the development of a universal scripting language (see the note about AppleScript later) much more likely.

Apple will define the message class roughly corresponding to the File and Edit menus (calling their protocol AppleEvents™ and using the signature ‘stdr’); the remaining classes are defined at the discretion of the developers.

The general method of using higher level events is the same that’s used for existing events - WaitNextEvent to accept events and PostEvent to send them. There are few options that don’t exist in System 6, but they don’t change current fundamental techniques.

Certain aspects of this API are still not completely worked out, and will require considerable care to do properly. For example, we now have the possibility of an entirely new class of VandalWare: programs maliciously misusing higher level events. Methods for assuring you are certain of who’s sending a message before you act upon it will be required.

The Publish-and-Subscribe Interface

The segment of most interest to the user is the “publish-and-subscribe” support intended to standardize the user-interface approach. This resembles the technique used in the SAWS IAC driver, and in fact some of the terminology is the same.

The phrase “publish-and-subscribe” was carefully chosen to suggest to users that there can be a slight delay between when data is published and when it is received; it also suggests that there can be geographic separation between the data source and destination.

Apple’s goals for the interface are as follows:

• It must be generalizable - usable for all applications

• It must be scalable - capable of dealing with large amounts of data (for database or multimedia work, for example)

• It must work cleanly with the existing Mac interface

• It must work over the network to support networked cooperative tasks.

Like the SAWS IAC suggested interface, the fundamental units that are linked are sections, not documents. A document can have any number of publishing sections and subscribing sections, and can in fact even subscribe to itself (a wonderful fractal demo took advantage of this fact!) The IAC toolbox called the Publication Manager includes support for resources that are required to track the status of these sections, thus simplifying the programming task. The sections drawn during the demos at the developers’ conference were all rectangular, but I don’t believe that is required (if it is it should be generalized).

Like the SAWS IAC driver, the Apple IAC support can be viewed as an extension of the scrap manager (which is in fact shown in Figure 2). This suggests that applications need the same types of facilities to support IAC - such as the ability to handle at least the standard data formats, such as PICT and TEXT. This minimal level of support alone can go a long way towards making sure that relatively arbitrary combinations of applications can be “integrated” smoothly; your application doesn’t need to know how to interpret every data format in the new universe to fit in.

Unlike the SAWS IAC driver, the published data is kept by Apple in external files. These “pub files” are standard, named files that have their own Finder icon. This approach provides considerably greater generality: by putting “pub files” on a file server such as AppleShare, any number of documents can subscribe to the same data. As with the SAWS IAC driver, the exchange of data from publisher to subscriber can be asynchronous. The System 7.0 enhancements to the file manager provide file-ID facilities that are location-independent, so that publication files can be moved around on a single volume without confusing the client (publisher and subscriber) applications.

Unlike the suggested user interface for the SAWS IAC driver, Apple’s interface explicitly requires intervention for data to be published; the suggested action is when the Save command is invoked. Subscribers in open documents are notified immediately; subscribers in closed documents are notified when that document is next opened. Explicit intervention was chosen to simplify the application’s programming model and to avoid problematic recursive situations. My experience in writing the original MacTutor sample program suggests that this is a good solution; deciding automatically when the fresh data is cooked enough to publish is trickier than it looks, and depends a good deal on the type of data being manipulated. My only suggested extension would be to also have an explicit “update publication” command as an alternative for programs where saving is a time-consuming operation, such as databases.

The subscriber, in the Apple model, is a somewhat passive participant; it normally will just display the data retrieved from the pub file. The user interface guidelines, however, do support the idea of adornment - style changes made to text, etc. by the subscribing application before displaying the new data. Scaling and clipping would be among the appropriate adornments to apply to graphic data.

A very useful facility available to a subscriber is “go to publisher”, possible because of the backlinks between files. Implemented according to the guidelines, this transfers control to the publishing application, after the document has been opened if necessary, and the section has been scrolled into view.

Establishing a linkage between two documents is straightforward:

• The user selects some data; the application calls the publication manager to create the section-tracking resource.

• The “publish” command is invoked. The application brings up a standard-file like dialog to name the “pub file”, and then creates it.

• The user goes to the destination document.

• A section is selected to be a subscriber; the application calls the publication manager to create the section-tracking resource.

• The “subscribe” command is invoked. The application brings up a standard-file like dialog to select the “pub file”, and then reads it.

• The link is established.

Again, the API is not finalized and there are rough edges that will need to be smoothed out before System 7.0 is unleashed on the world. For example, there is no record of the last time a pub file was used, so that there is no easy way to detect “stale” pub files. If you think junk files accumulate on your hard disk, with only you living there, think of what some poor AppleShare administrator is looking at...

Conclusions

The design of the IAC support in System 7.0 was very well done. It will be a reasonable task to incorporate IAC support into existing applications; interface decisions may be more work for some applications than the actual coding. The facilities possible are exciting even to jaded developers - the IAC session kept being interrupted by applause!

In the long run, for anything more complex than a letter to Aunt Sybil, suites of linked documents are going to become the norm due to the convenience of working with your personal favorites in each required specialty. This reduces somewhat the attraction of all-in-one programs such as Lotus’ Jazz and Microsoft Works, although it may prove that requiring no configuration at all is enough of a feature to support a worthwhile market.

Applescript is a nebulous future concept that kept surfacing during the developers’ conference without ever being clearly defined. It sounds like Apple’s syntactic Holy Grail - a single language syntax that is usable for MPW scripts, SADE scripts, and the user’s control of the machine as a whole. One planned feature appears to be that it will have facilities for users to send “higher level event” messages to programs. This would give them text-based application-independent macro capabilities, rather like Tempo.

As an example of what all of these facilities together promise, imagine you have investments in several high-tech stocks that tend to move wildly all over the chart. Keeping peace in the house requires that you prepare a chart every so often to prove that poverty isn’t just around the corner, and so you decide to automate the process to make it less of a nuisance. All it requires is a quick script that does the following:

• At midnight on the 1st of each month, launch your favorite telecomm program with a program to dial up your data service and download all the prices required.

• Launch your wordprocessor with the basic stock report ready to go, including the subscribers for the data values and chart of price gyrations.

• Launch your spreadsheet with a worksheet and macro that loads the new data and charts it. Both the data cells and the chart are publishers, so you save the worksheet and publish the selected data and chart.

• The stock report updated automatically, so just order it to be saved and printed.

• Close all the applications.

MacTutor programmers, of course, will almost instantly be creating scripts of far greater complexity, and there will no doubt be a column devoted to AppleScript programming, but this gives you some idea of the potential that will be available to us in the near future.

In a couple of years we will probably be working in an environment that has some characteristics of the traditional mini-computer: (1) Multiple “parallel” processes, with communications between them, and (2) At least 1 powerful scripting language that allows flexible automation of repetitive actions - but with the addition of almost universal data-interchange formats, a huge variety of off-the-shelf software, and a consistent user interface.

The change from single-program to multi-program workstyle is not going to be without experimental evolution unprecedented in computer history; we’ve never had enough power available on a widespread basis to make this new mode of working feasible. There will undoubtedly be several styles of integration at first, until the market determines which is most workable, for example. There may be conflicts for a while between message sets that make it a little rocky to integrate arbitrary combinations of applications. In spite of these caveats, I am looking forward eagerly to an IACed universe - and so should you.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Postbox 5.0.9 - Powerful and flexible em...
Postbox is a new email application that helps you organize your work life and get stuff done. It has all the elegance and simplicity of Apple Mail, but with more power and flexibility to manage even... Read more
VueScan 9.5.61 - Scanner software with a...
VueScan is a scanning program that works with most high-quality flatbed and film scanners to produce scans that have excellent color fidelity and color balance. VueScan is easy to use, and has... Read more
DiskCatalogMaker 6.5.16 - Catalog your d...
DiskCatalogMaker is a simple disk management tool which catalogs disks. Simple, light-weight, and fast. Finder-like intuitive look and feel. Super-fast search algorithm. Can compress catalog data... Read more
TrailRunner 3.8.827 - Route planning for...
TrailRunner is the perfect companion for runners, bikers, hikers, and all people wandering under the sky. Plan routes on a geographical map. Import GPS or workout recordings and journalize your... Read more
Civilization VI 1.0.1 - Next iteration o...
Sid Meier’s Civilization VI is the next entry in the popular Civilization franchise. Originally created by legendary game designer Sid Meier, Civilization is a strategy game in which you attempt to... Read more
Chromium 55.0.2883.75 - Fast and stable...
Chromium is an open-source browser project that aims to build a safer, faster, and more stable way for all Internet users to experience the web. Version 55.0.2883.75: Security fixes: High CVE-2016... Read more
Google Chrome 55.0.2883.75 - Modern and...
Google Chrome is a Web browser by Google, created to be a modern platform for Web pages and applications. It utilizes very fast loading of Web pages and has a V8 engine, which is a custom built... Read more
VirtualBox 5.1.10 - x86 virtualization s...
VirtualBox is a family of powerful x86 virtualization products for enterprise as well as home use. Not only is VirtualBox an extremely feature rich, high performance product for enterprise customers... Read more
Pixa 1.1.9 - Quickly and easily organize...
Pixa is an image-organizing application. The new app functions well, is easy to use, and helps people organize their images quickly and easily on their computers. For those who prefer not to use the... Read more
VirtualBox 5.1.10 - x86 virtualization s...
VirtualBox is a family of powerful x86 virtualization products for enterprise as well as home use. Not only is VirtualBox an extremely feature rich, high performance product for enterprise customers... Read more

Latest Forum Discussions

See All

Amateur Surgeon 4 Guide: Become the worl...
It's time to wield your trusty pizza cutter again, as Amateur Surgeon has returned with a whole fresh set of challenges (and some old, familiar ones, too). Starting anew isn't easy, especially when all you have at your disposal is a lighter, the... | Read more »
Le Parker: Sous Chef Extraordinaire (Ga...
Le Parker: Sous Chef Extraordinaire 1.0 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0 (iTunes) Description: | Read more »
Telltale Games really is working on a Gu...
Telltale Games' next episodic adventure is indeed Guardians of the Galaxy. A document tied to the voice actors strike suggested that the project was in the work, but now we have direct confirmation following an announcement at the Game Awards that... | Read more »
Amateur Surgeon returns to iOS and Andro...
Amateur Surgeon and its two sequels disappeared from the App Store some time and it was sad days for all. But now, just in time for the holidays, the Adult Swim favorite makes its joyous return in the shape of Amateur Surgeon 4, a remake with... | Read more »
The best board games on mobile
Sometimes you need to ditch all of the high speed, high action games in favor of something a little more traditional. If you don't feel like parting ways from your mobile device, though, there are still plenty of ways to get that old-school fix.... | Read more »
The best Facebook Messenger Instant Game...
Facebook's new Instant Games is now here, meaning you can play games with your friends directly via Facebook. It's a fun new way to connect with friends, of course, but it's also proving to be a solid gaming experience in its own right, with a... | Read more »
You can now play game's on Facebook...
Facebook launched its new Instant Games platform in an exciting new attempt to engage its user base. As a result, you can now play a number of different games directly through Facebook Messenger. All of these games run with HTML5, meaning you play... | Read more »
Apollo Justice Ace Attorney (Games)
Apollo Justice Ace Attorney 1.00.00 Device: iOS Universal Category: Games Price: $.99, Version: 1.00.00 (iTunes) Description: Court Is Back In Session Star as rookie defense attorney, Apollo Justice, as he visits crime scenes,... | Read more »
KORG iWAVESTATION (Music)
KORG iWAVESTATION 1.0 Device: iOS Universal Category: Music Price: $19.99, Version: 1.0 (iTunes) Description: A revolutionary new world of sound.The Wave Sequence Synthesizer for iPad - KORG iWAVESTATION | Read more »
Don't Grind Guide: Tips for becomin...
Don’t Grind is a surprising, derpy little one touch game with fun hand-drawn graphics. The goal is simple -- get the high score without being chopped to bits. That can be tough when you’re not used to the game, and that’s compounded by the fact... | Read more »

Price Scanner via MacPrices.net

Holiday sale: Apple MacBook Airs available fo...
B&H Photo has 13″ MacBook Airs on sale for $100 off MSRP. Shipping is free, and B&H charges NY sales tax only: - 13″ 1.6GHz/128GB MacBook Air (MMGF2LL/A): $899 $100 off MSRP - 13″ 1.6GHz/... Read more
13-inch Silver Touch Bar MacBook Pro in stock...
Amazon has the new 2016 13″ 2.9GHz/256GB Silver Touch Bar MacBook Pro (MLVP2LL/A) in stock today and on sale for $1749 including free shipping. That’s $50 off MSRP, and it’s the lowest price... Read more
Parallels Toolbox 1.3 for Mac Offers 25 Singl...
Parallels has launched Parallels Toolbox 1.3 for Mac, an upgrade that adds five new utilities to the stand-alone application which was released in August and is available exclusively online at http... Read more
OWC Mercury Elite Pro Dual mini Ultra-Portabl...
OWC has introduced the new OWC Mercury Elite Pro Dual mini, a powerful yet ultra-portable dual-drive RAID solution. The new Mercury Elite Pro Dual mini packs phenomenal performance into a small... Read more
Clearance 13-inch Retina MacBook Pros availab...
B&H Photo has clearance 2015 13″ Retina Apple MacBook Pros available for up to $200 off original MSRP. Shipping is free, and B&H charges NY tax only: - 13″ 2.7GHz/128GB Retina MacBook Pro: $... Read more
Roundup of 2016 13-inch 2.0GHz MacBook Pro sa...
B&H has the non-Touch Bar 13″ MacBook Pros in stock today for $50-$100 off MSRP. Shipping is free, and B&H charges NY sales tax only: - 13″ 2.0GHz MacBook Pro Space Gray (MLL42LL/A): $1449 $... Read more
New 13-inch 2.0GHz Space Gray MacBook Pro in...
Adorama has the new 13″ 2.0GHz Space Gray MacBook Pro (non-Touch Bar, MLL42LL/A) in stock for $1499 including a free 3-year AppleCare Protection Plan. Shipping is free, and Adorama charges sales tax... Read more
Finnair Adopts iOS Enterprise iPad Apps from...
Finnair and IBM have announced a first-of-its-kind agreement to utilize iOS enterprise apps from IBM to support the airline’s overall digital transformation. Finnair is focused on Asia-Europe traffic... Read more
Tech21 Launches Evo Go iPhone 7 Case Availabl...
Tech21 has announced the launch of the Evo Go case for Apple iPhone 7 and iPhone 7 Plus, exclusively at T-Mobile. Available online and at participating T-Mobile stores nationwide, Evo Go cases start... Read more
Apple Turns (RED) with More Ways to Join the...
In recognition of World AIDS Day, Apple is offering more ways than ever for customers to join (RED) in its mission to create an AIDS-free generation. Apple is the worlds largest corporate contributor... Read more

Jobs Board

*Apple* Retail - Multiple Positions- Kansas...
Job Description:SalesSpecialist - Retail Customer Service and SalesTransform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Retail - Multiple Positions- Chicago...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
Hardware Design Validation Engineer - *Apple...
The Apple Watch team is looking for a Hardware Design Validation Engineer. This person will be part of the Apple Watch hardware team with responsibilities for Read more
SW Engineer *Apple* TV Frameworks - Apple I...
The Apple TV team is looking for a software...create features that reflect the look and feel of Apple TV. Description: Were looking for someone who is Read more
*Apple* Retail - Multiple Positions- Greenwi...
Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, you're also the Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.