TweetFollow Us on Twitter

Learning to Love SOM
Volume Number:11
Issue Number:1
Column Tag:Foundation Technology

Learning To Love SOM

Choosing it for OpenDoc was a no-brainer

By Jens Peter Alfke, Apple Computer, Inc.

The System Object Model (SOM) provides the object-oriented substrate used by OpenDoc and by future versions of the Macintosh Toolbox. SOM is fairly complex, relatively new on the Mac, and competes against other proprietary object models. It’s not surprising, then, that there is some degree of apprehension and misinformation surrounding it. In this article, I will give you the straight scoop on SOM.

Frankly, my own initial feelings toward SOM were not warm and fuzzy. After we on the OpenDoc team decided to make the move to SOM, and I began reading about it and thinking about the task of converting our existing code base, I was heard to ask Kurt Piersol: “We’re all going to die, aren’t we?” Fortunately, I was wrong; and since then I’ve come to like and respect SOM.

Why Is SOM Necessary?

Object-based shared libraries are a holy grail of software engineering, since they turn code into black-box components that can be plugged together by programmers. Unfortunately, existing object models have been either too slow and too hard to use from existing code (e.g. Smalltalk), or insufficiently robust (e.g. C++.)

Fragile Base Classes

What do I mean by “insufficiently robust”? The technical term is fragile base-classes, and what it means is that changes to a base class - such as adding methods or instance variables - often break code that uses the base class, or makes subclasses of it, until that client code is recompiled.

In other words, if I update my JensTools C++ class library from version 1.0 to 1.1, and users install the new version, all their apps that use it may crash until they get new releases from the developers. Needless to say, this has impeded the use of object-based shared libraries.

There are two ways around this. The first is to abandon key features of object-oriented programming like inheritance and polymorphism. This is what Microsoft’s Component Object Model (COM) does. What you’re left with is a system of procedural dispatch tables that I find quite reminiscent of the Component Manager. I’ve used the Component Manager extensively as part of developing AppleScript, and let me say that it is not my favorite shared library solution. (For a much more detailed look at how SOM and COM differ, read “SOM vs. COM” in the documentation folder on the CD.)

The better solution is to attack the problem head on and fix it, which is what researchers at IBM did in producing SOM. I won’t go into the gory details here, but by abstracting the way object instantiation and method dispatch work, they were able to produce an object model that is extremely robust and still efficient and fully object-oriented.

In other words, by basing my JensTools library on SOM (though it’s still implemented in C++) I am able to add new methods and/or change its internal implementation while retaining full binary compatibility: when users install the new version, their existing apps continue to work perfectly, while new clients can take advantage of the new features.

Language and Compiler Neutrality

A frequently-mentioned advantage of SOM is that it can be used with any programming language, once the appropriate interfaces and glue code are written. This is because the SOM kernel isn’t based on any single object model, and has robust enough support for almost any language (for instance, it supports metaclasses and name-based dispatching, features found in Smalltalk but not in C++.) C and C++ support currently exist, with Smalltalk in the works.

Language neutrality is also sometimes disparaged; some see it as nothing more than unnecessary support for exotic languages that no one uses. Setting aside the fact that many large businesses are using Smalltalk, and that it would be damn cool to be able to write OpenDoc parts in Dylan, what these critics don’t realize or admit is that different C++ compilers might as well be different languages when it comes to their runtime object model. Due to differences in vtable layout and parameter passing, objects created by one C++ compiler generally cannot be used by client code compiled by a different C++ compiler. On the Mac, cfront, Apple’s new Mr.C compiler, Symantec C++ and Metrowerks’ C++ are all mutually incompatible.

This incompatibility causes headaches even with COM. A frequent trick used by COM programs is to use a C++ vtable as a COM method table. By strange coincidence, this works just fine with the vtables laid out by the Microsoft C++ compiler. But it doesn’t work with most other C++ compilers, and users of those compilers are forced to lay out the method tables by hand, which turns out to be a lot more difficult than creating a SOM class (in fact, it’s a lot like the tables SOM builds internally and thankfully hides from you.)

Cross-Platform Support

Implementations of SOM currently exist for OS/2, Unix, Windows, and now the Macintosh (both 68k and native PowerPC, included on the OpenDoc CD.) Future targets include Netware, IBM’s Workplace, MVS and OS/400. IBM plans to license SOM to Component Integration Labs, so it will be available for other vendors to license.

Using SOM With C++

This adds up to a pretty compelling case for using SOM. There’s nothing else available that supports real object-oriented programming, with strong binary compatibility, language and compiler independence, that runs on all major operating systems. Choosing it for OpenDoc was a no-brainer once we’d analyzed the alternatives.

Unfortunately you do give up some things when you use SOM from C++. SOM is not tied to the C++ object model, and it doesn’t support some fancier C++ features like templates and operator overloading (although it does do things C++ doesn’t, like metaclasses and name-based dispatching.) SOM classes aren’t the same as C++ classes; this isn’t apparent on the client side since you call methods of a SOM object exactly as you would a C++ object, but a SOM class’ methods are implemented as procedural functions, which adds a certain amount of “syntactic vinegar” to your implementation (as my colleague Richard Rodseth puts it.)

Many of these drawbacks will be alleviated by direct-to-SOM C++ compilers. These are compilers with a native understanding of the SOM object model, which make creating a SOM class as simple as inheriting from SOMObject. Direct-to-SOM compilers are already available for OS/2 and Windows, and may be on the Mac soon.

Until then, there are tricks you can use if you want to do your work closer to normal C++. One that works well, and is used in the sample OpenDoc leaf part class that comes with PartMaker, is to create a normal C++ class with basically the same API as the SOM class you want to implement. Then the SOM class’ implementation simply instantiates a matching object of the C++ class, and each SOM method calls the corresponding C++ method. This incurs a little bit of extra overhead, but eases the transition to SOM for someone familiar with C++.

Cool Features

SOM supports features you don’t ordinarily get with C++. For instance, you can determine the class of an arbitrary SOM object at runtime, or check whether an object descends from a particular class or implements a particular method. You can examine all the methods defined by a particular class and send an arbitrary message to an object given a string representing the method name. You can even add new methods to a class at runtime. All this is possible because SOM supports metaclasses, a concept originating in Smalltalk which means that SOM classes are real objects.

Building A SOM Class

The full process of implementing a SOM class consists of:

• Write an IDL file: a SOM header that declares your class’ interface. The class will inherit from an existing SOM class (such as SOMObject, or ODPart for an OpenDoc part handler). In the interface you add any extra methods and instance variables that your part objects will need.

IDL stands for Interface Definition Language, a simple syntax for defining classes. It’s part of the industry-standard CORBA architecture. Fortunately, IDL looks very much like a C++ class definition, with a few extensions.

• Crank your IDL file through the SOM compiler. This translates your part’s definition from the abstract IDL syntax into a C or C++ API, plus the appropriate magic glue for the SOM runtime. The output is several binding files that you use to build your part with C or C++.

• Fill out the implementation. One of the binding files generated is a .c or .cpp file that contains a blank C or C++ implementation of your part: the method functions are all there but their bodies are empty. You fill in the bodies with the actual code for each method.

• Compile and link the implementation files. The implementation binding file and any other source files you create are linked against the SOM library, and the libraries of any other SOM classes you use or inherit from, to produce a shared library that implements your class. You can use any compiler that knows how to build CFM shared libraries, such as scpp or CodeWarrior PPC.

• Iterate. If you fix bugs or make other changes that just modify existing class methods, or non-class code, all you need to do is recompile and relink. If you need to change the class structure by adding methods or instance variables, you’ll need to run the SOM compiler again. The (blank) new methods will be appended to your implementation file without disturbing the existing C/C++ code.

Networked Objects

SOM has an extension called DSOM that supports distributed objects. It allows SOM objects on different machines on a network (or in separate address spaces on one machine) to talk to each other as though they were all running in the same process. DSOM is pretty transparent to your code; you just have to avoid pitfalls like trying to send a remote object a raw pointer to data.

DSOM already runs on OS/2 and will be ported to the Mac OS; we plan to support it in the second release of OpenDoc to allow distributed parts, documents and other services.

On a broader scale yet, DSOM is an implementation of CORBA, an industry standard for distributed objects. This means that DSOM clients can interact with non-SOM distributed applications from vendors like DEC and H/P, running on workstations or mainframes. This gives SOM-based systems like OpenDoc a well defined way to connect to large corporate databases, which may or may not excite you but makes IS managers sit up and drool.

Conclusion

SOM is one of those things where you have to look at the big picture. Yes, it’s a bit of a pain at the micro-level of individual lines of code. But alternatives like COM, which may seem simpler at first, turn out to be more complicated when used with some compilers, and too limited to support true object-oriented programming. And SOM becomes extremely cool at the larger scale of reusable and robust shared class libraries, and positively mind-bending with its prospects of distributed objects and Net-spanning applications.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Chromium 75.0.3770.142 - 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 75.0.3770.142: Release notes were... Read more
Viber 11.1.0 - Send messages and make fr...
Viber lets you send free messages and make free calls to other Viber users, on any device and network, in any country! Viber syncs your contacts, messages and call history with your mobile device, so... Read more
Wireshark 3.0.3 - Network protocol analy...
Wireshark is one of the world's foremost network protocol analyzers, and is the standard in many parts of the industry. It is the continuation of a project that started in 1998. Hundreds of... Read more
DEVONthink Pro 3.0beta4 - Knowledge base...
DEVONthink Pro is your essential assistant for today's world, where almost everything is digital. From shopping receipts to important research papers, your life often fills your hard drive in the... Read more
Adobe Creative Cloud 4.9.0.512 - Access...
Adobe Creative Cloud costs $20.99/month for a single app, or $52.99/month for the entire suite. Introducing Adobe Creative Cloud desktop applications, including Adobe Photoshop CC and Illustrator CC... Read more
SketchUp 19.1.174 - Create 3D design con...
SketchUp is an easy-to-learn 3D modeling program that enables you to explore the world in 3D. With just a few simple tools, you can create 3D models of houses, sheds, decks, home additions,... Read more
ClamXav 3.0.12 - Virus checker based on...
ClamXav is a popular virus checker for OS X. Time to take control ClamXAV keeps threats at bay and puts you firmly in charge of your Mac’s security. Scan a specific file or your entire hard drive.... Read more
BetterTouchTool 3.151 - Customize multi-...
BetterTouchTool adds many new, fully customizable gestures to the Magic Mouse, Multi-Touch MacBook trackpad, and Magic Trackpad. These gestures are customizable: Magic Mouse: Pinch in / out (zoom)... Read more
FontExplorer X Pro 6.0.9 - Font manageme...
FontExplorer X Pro is optimized for professional use; it's the solution that gives you the power you need to manage all your fonts. Now you can more easily manage, activate and organize your... Read more
Dropbox 77.4.131 - Cloud backup and sync...
Dropbox is an application that creates a special Finder folder that automatically syncs online and between your computers. It allows you to both backup files and keeps them up-to-date between systems... Read more

Latest Forum Discussions

See All

Upcoming visual novel Arranged shines a...
If you’re in the market for a new type of visual novel designed to inform and make you think deeply about its subject matter, then Arranged by Kabuk Games could be exactly what you’re looking for. It’s a wholly unique take on marital traditions in... | Read more »
TEPPEN guide - The three best decks in T...
TEPPEN’s unique take on the collectible card game genre is exciting. It’s just over a week old, but that isn’t stopping lots of folks from speculating about the long-term viability of the game, as well as changes and additions that will happen over... | Read more »
Intergalactic puzzler Silly Memory serve...
Recently released matching puzzler Silly Memory is helping its fans with their intergalactic journeys this month with some very special offers on in-app purchases. In case you missed it, Silly Memory is the debut title of French based indie... | Read more »
TEPPEN guide - Tips and tricks for new p...
TEPPEN is a wild game that nobody asked for, but I’m sure glad it exists. Who would’ve thought that a CCG featuring Capcom characters could be so cool and weird? In case you’re not completely sure what TEPPEN is, make sure to check out our review... | Read more »
Dr. Mario World guide - Other games that...
We now live in a post-Dr. Mario World world, and I gotta say, things don’t feel too different. Nintendo continues to squirt out bad games on phones, causing all but the most stalwart fans of mobile games to question why they even bother... | Read more »
Strategy RPG Brown Dust introduces its b...
Epic turn-based RPG Brown Dust is set to turn 500 days old next week, and to celebrate, Neowiz has just unveiled its biggest and most exciting update yet, offering a host of new rewards, increased gacha rates, and a brand new feature that will... | Read more »
Dr. Mario World is yet another disappoin...
As soon as I booted up Dr. Mario World, I knew I wasn’t going to have fun with it. Nintendo’s record on phones thus far has been pretty spotty, with things trending downward as of late. [Read more] | Read more »
Retro Space Shooter P.3 is now available...
Shoot-em-ups tend to be a dime a dozen on the App Store, but every so often you come across one gem that aims to shake up the genre in a unique way. Developer Devjgame’s P.3 is the latest game seeking to do so this, working as a love letter to the... | Read more »
Void Tyrant guide - Guildins guide
I’ve still been putting a lot of time into Void Tyrant since it officially released last week, and it’s surprising how much stuff there is to uncover in such a simple-looking game. Just toray, I finished spending my Guildins on all available... | Read more »
Tactical RPG Brown Dust celebrates the s...
Neowiz is set to celebrate the summer by launching a 2-month long festival in its smash-hit RPG Brown Dust. The event kicks off today, and it’s divided into 4 parts, each of which will last two weeks. Brown Dust is all about collecting, upgrading,... | Read more »

Price Scanner via MacPrices.net

Verizon is offering a 50% discount on iPhone...
Verizon is offering 50% discounts on Apple iPhone 8 and iPhone 8 Plus models though July 24th, plus save 50% on activation fees. New line required. The fine print: “New device payment & new... Read more
Get a new 21″ iMac for under $1000 today at t...
B&H Photo has new 21″ Apple iMacs on sale for up to $100 off MSRP with models available starting at $999. These are the same iMacs offered by Apple in their retail and online stores. Shipping is... Read more
Clearance 2017 15″ 2.8GHz Touch Bar MacBook P...
Apple has Certified Refurbished 2017 15″ 2.8GHz Space Gray Touch Bar MacBook Pros available for $1809. Apple’s refurbished price is currently the lowest available for a 15″ MacBook Pro. An standard... Read more
Clearance 12″ 1.2GHz MacBook on sale for $899...
Focus Camera has clearance 12″ 1.2GHz Space Gray MacBooks available for $899.99 shipped. That’s $400 off Apple’s original MSRP. Focus charges sales tax for NY & NJ residents only. Read more
Get a new 2019 13″ 2.4GHz 4-Core MacBook Pro...
B&H Photo has new 2019 13″ 2.4GHz MacBook Pros on sale for up to $150 off Apple’s MSRP. Overnight shipping is free to many addresses in the US: – 2019 13″ 2.4GHz/256GB 6-Core MacBook Pro Silver... Read more
AirPods with Wireless Charging Case now on sa...
Amazon has extended their Prime Day savings on Apple AirPods by offering AirPods with the Wireless Charging case for $169.99. That’s $30 off Apple’s MSRP, and it’s the cheapest price available for... Read more
New 2019 15″ MacBook Pros on sale for $200 of...
B&H Photo has the new 2019 15″ 6-Core and 8-Core MacBook Pros on sale for $200 off Apple’s MSRP. Overnight shipping is free to many addresses in the US: – 2019 15″ 2.6GHz 6-Core MacBook Pro Space... Read more
Amazon drops prices, now offers clearance 13″...
Amazon has new dropped prices on clearance 13″ 2.3GHz Dual-Core non-Touch Bar MacBook Pros by $200 off Apple’s original MSRP, with prices now available starting at $1099. Shipping is free. Be sure to... Read more
2018 15″ MacBook Pros now on sale for $500 of...
Amazon has dropped prices on select clearance 2018 15″ 6-Core MacBook Pros to $500 off Apple’s original MSRP. Prices now start at $1899 shipped: – 2018 15″ 2.2GHz Touch Bar MacBook Pro Silver: $1899.... Read more
Price drop! Clearance 12″ 1.2GHz Silver MacBo...
Amazon has dropped their price on the recently-discontinued 12″ 1.2GHz Silver MacBook to $849.99 shipped. That’s $450 off Apple’s original MSRP for this model, and it’s the cheapest price available... Read more

Jobs Board

Best Buy *Apple* Computing Master - Best Bu...
**696259BR** **Job Title:** Best Buy Apple Computing Master **Job Category:** Store Associates **Location Number:** 001076-Temecula-Store **Job Description:** The Read more
Business Development Manager, *Apple* Globa...
Business Development Manager, Apple Global Tampa, FL, US Requisition Number:73805 As a Global Apple Business Development Manager at Insight, you proactively Read more
*Apple* Systems Architect/Engineer, Vice Pre...
…its vision to be the world's most trusted financial group. **Summary:** Apple Systems Architect/Engineer with strong knowledge of products and services related to Read more
*Apple* IOS Systems Engineer - Randstad (Uni...
Apple IOS Systems Engineer **job details:** + location:Irvine, CA + salary:$45 - $55 per hour + date posted:Tuesday, July 16, 2019 + job type:Temp to Perm + Read more
Business Development Manager, *Apple* Globa...
Business Development Manager, Apple Global Tampa, FL, US Requisition Number:73805 As a Global Apple Business Development Manager at Insight, you proactively Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.