TweetFollow Us on Twitter

May 96 Viewpoint
Volume Number:12
Issue Number:5
Column Tag:Viewpoint

Viewpoint

By Scott T Boyd, Editor Emeritus, http://www.montara.com/

Way back in 1984 Apple did something fundamentally different with the Macintosh that few people talk about when singing Apple’s praises for changing computing’s paradigm.

We came to know it as the A-trap mechanism. For those who haven’t delved into this before, it’s a little oddity made possible by Motorola’s chip designers. Many people might not have even noticed a feature which captured the imagination of a few special people at Apple. 68xxx processors have a number of instructions or conditions which generate exceptions. Each of these causes an exception handler to get called. One entire class of exceptions is triggered by any instruction whose hex value begins with an $A (e.g. $ABCD, $AAFA, etc ). Those wise guys at Apple figured out that they could have the A-line exception code use the instruction’s value as something of an index to figure out which function to further dispatch to. This we now know as the A-trap dispatcher.

The greatest disadvantage of this approach was execution time. It takes time to “throw” an exception. The processor has to put a fair amount of its state onto the stack before it can jump to the exception vector (and restore it later). Then the dispatcher has to do some fancy footwork to figure out who to call, and sometimes it saves and restores even more registers.

Now for the upside. First, a two byte trap word is smaller than any jump you could hope to make into a library of functions. On a 128K machine, that kind of savings really added up. Second, it made it easy to conceive of a vast library of functions that any code could call. While A-traps weren’t necessary for things like the Macintosh Toolbox, they sure didn’t hurt. They provided a consistent mechanism to dispatch to code anywhere on the machine, be it in the ROM, in RAM, or even on the disk, using a standard lookup key (the trap word). Third, it created a mechanism whereby Apple engineers and third parties could correct, modify, and extend the vast library of code (we know this as patching and/or implementing traps).

For years Macintosh programmers felt special. A-traps offered a rich breeding ground for unusual software. We customized our machines in ways not even imaginable on other (lesser?) machines. We had more fun and productivity to show for it, as well as a thriving utility software market.

Alas, the A-trap mechanism might very well have been too useful. You see, there came a time with other operating systems started to face some of the problems that Macintosh had already confronted. Only by this time these machines were already an order of magnitude larger. Perhaps their OS engineers weren’t as clever as Apple’s, but they didn’t seem particularly interested in paying the price of exception handling to do a late-binding method dispatch (which is, after all, essentially what we’ve been talking about). While Apple was busily guarding and carefully managing the growth of the trap tables, other OS vendors were coming up with these things called DLLs - Dynamically Linked Libraries.

DLLs are like object code libraries, but aren’t linked directly into an application, and can generally be shared. In that sense, they can become like system software, with just one copy of a library per machine. If you put some system functionality into a DLL, you can often ship it by itself rather than wait for an entire system release. Apple has long achieved this effect by shipping extensions which, when installed, add new functionality at boot time. DLLs have the benefit, though, of not needing to load at boot time, and not having to live in a special place on disk. DLLs also have the benefit of freedom from the space constraints that trap code typically tries to live by. With the addition of file mapping and a good virtual memory system, they can even execute directly off of disk. Have a good night programming and speed up a DLL by 50%? Ship the new DLL and watch all of the apps which use it simply go faster! Other operating systems mastered this before Apple even realized that having a DLL mechanism would be a good thing to have.

Apple dabbled with ASLM, the Component Manager, and others. Fortunately, the PowerPC effort brought forth the Code Fragment Manager, the one we’ve been waiting for, and now 68K CFM is ready, too. I’ve recently been involved in an effort to build some fat code fragments for use by a dynamic language environment, and I’ve got to tell you that I am pumped!

But now I find that I want lots more fragments to play with. Wouldn’t you like to have a DLL that converted PICTs to GIF, told your Web browser to resolve a URL, or went a ftp’d a file, all with the ease of a couple of function calls? Here’s where you come in. You know that really clever or useful library you wrote and linked in to your latest application? How about that slick little shareware utility? How about releasing it as a DLL? That and a header file, and you can have thousands of grateful developers treat you like their own system software engineer. CFM is cool. If you learn just one new thing today, learn what CFM can do for you. One starting point is :

http://dev.info.apple.com/evangelism/DLLDirectional.html

I also recommend looking at Apple’s latest Developer CDs.

Food for Thought

Presenting his keynote to the Microsoft Professional Developers Conference, Bill Gates noted that he believes that the #1 reason to develop for Windows is “Volume!” That’s 60 million copies of Windows each year. As an aside, he mentioned, “30 million copies wouldn’t pay Microsoft’s bills.”

 
AAPL
$565.32
Apple Inc.
-5.24
MSFT
$29.07
Microsoft Corpora
-0.04
GOOG
$603.66
Google Inc.
-5.80
MacTech Search:
Community Search:

Empire of the Eclipse Review
Empire of the Eclipse Review By Carter Dotson on May 24th, 2012 Our Rating: :: OVERSHADOWINGiPhone App - Designed for the iPhone, compatible with the iPad Empire of the Eclipse is an ambitious strategy MMO that is very deep, and... | Read more »
Bejeweled HD Review
Bejeweled HD Review By Jennifer Allen on May 24th, 2012 Our Rating: :: ADDICTIVEiPad Only App - Designed for the iPad The iPad version of the ever addictive Match Three title.   Developer: PopCap Price: $3.99 Version Reviewed: 1... | Read more »
Facebook Releases New Camera App To Stre...
While not a replacement for Instagram, Facebook Camera is a good first step in this month+ old union of the two companies. Released today, Facebook camera looks to streamline the viewing of photos and the uploading of them. The app allows you to... | Read more »
Missile Monkey Review
Missile Monkey Review By Lisa Caplan on May 24th, 2012 Our Rating: :: FLYING LOWUniversal App - Designed for iPhone and iPad Missile Monkey is a must miss   Developer: Munsey Clan Games Price: $0.99 Version Reviewed: 1.0 Device... | Read more »
Boomlings Review
Boomlings Review By Lisa Caplan on May 24th, 2012 Our Rating: :: FUN FREEBIEUniversal App - Designed for iPhone and iPad Boomlings is a traditional matching puzzle game, with some explosive twists   | Read more »
Dave vs Cave Review
Dave vs Cave Review By Jason Wadsworth on May 24th, 2012 Our Rating: :: WATCH FOR FALLING ROCKSUniversal App - Designed for iPhone and iPad Kid falls down hole, kid gets trapped in cave, kid fights evil rock monsters to escape... | Read more »
Python Pocket Power: Python Bytes 3 – Mo...
Python fans are certain to welcome the best bits from the penultimate season of the BBC sketch comedy in a new iPhone app: Python Bytes 3 – Monty Python Series 3. If you have a flair for the obvious, you’ll correctly assume this is third in a series... | Read more »

Price Scanner via MacPrices.net

13″ 2.8GHz MacBook Pro on sale for $100 off MSRP
Adorama has lowered their price on the 13″ 2.8GHz MacBook Pro to $1399 including free shipping plus NY/NJ sales tax only. Their price is $100 off MSRP, and it’s the lowest price for this model from... Read more
Apple refurbished iPads available starting at $279
 The Apple Store Online has dropped prices on Apple Certified Refurbished iPad 2s and original iPads by as much as $50, with models now starting at $279. Apple’s one-year warranty is included with... Read more
Security Based Portable Operating System, Pocket D...
In conjunction with their consumer technology product, Pocket Desktop, a USB device that offers consumers enhanced security and portability in computing, has announced a new strategic alliance with... Read more
Apple’s Jonathan Ive Knighted By Britain’s Princes...
The BBC reports that Apple Senior Vice President Of Industrial Design Jonathan Ive is now Sir Jonathan Ive, having been knighted by Queen Elizabeth II’s daughter Anne, the Princess Royal (and an iPad... Read more
Microsoft Fixing to release Office for iOS and And...
BGR’s Jonathan S. Geller says BGR has learned from a “reliable source” that Microsoft is planning to release the company’s full Office suite for not only Apple’s iPad, but for Android tablets as well... Read more
Mac mini Server available for $949, $50 off MSRP
Adorama has Mac mini Servers on sale for $949 including free shipping. Their price is $50 off MSRP, and it’s the lowest price available for this model from any Apple Authorized Reseller. NY and NJ... Read more
21″ 2.7GHz iMac on sale for $1399, $100 off full r...
Adorama has the 21″ 2.7GHz iMac on sale for $1399 including free shipping. Their price is $100 off MSRP, and it’s the lowest price for this model from any Apple Authorized Reseller. NY and NJ sales... Read more
iMacs on sale bundled with free upgrade to 8GB RAM
MacConnection has 2011 iMacs in stock today with a free upgrade to 8GB of RAM. Shipping is also free. Their prices represent a $200+ savings over custom 8GB iMacs at The Apple Store: - 21″ 2.5GHz... Read more

Jobs Board

iOS Developer (iPhone and iPad) at Mahal...
Mahalo is looking for talented iOS developers to join its team of highly skilled engineers. Weve already released multiple successful apps in the Apple App Store with well over a million installs... Read more
MAC Imaging/Packaging, Administration.Pr...
Skills: Very good experience in building MAC ( Apple Macintosh ) operating system images. OS imaging Knowledge on ... Knowledge on configuring the LAN and Wireless network on MAC note books Knowledge... Read more
*Apple* Solutions Consultant-Retail Sal...
Requisition Number 15545402 Job title Apple Solutions Consultant-Retail Sales Location Mobile Country United States City Mobile State Alabama Job type Job description Read more
iPhone Developer at Mastech (Los Angeles...
We are currently seeking an Android/ iPhone Developer for our client in the Insurance domain. We value our professionals, providing comprehensive benefits, exciting challenges, and the opportunity... Read more
24 funny 2d Charaters for iPhone game. a...
We are developing an iPhone game and desire to have 24 characters drawn to our specification. Attached is the detailed spec. Desired Skills: Cartoon, Illustration Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.