TweetFollow Us on Twitter

Jul 97 Viewpoint

Volume Number: 13 (1997)
Issue Number: 7
Column Tag: Viewpoint

July 1997 Viewpoint

by Eric Gundrum

Reality Distortion Field... Engage

WWDC is over, and I've just spent a full week listening to the official Apple message. Many weeks may have passed by the time you read this article, but my mind is still hashing out the things I heard just a few days ago. I must admit, I attended WWDC 1997 with pretty low expectations. Last year attendees had Copland forced on them as the only possible future for Macintosh development. This year was very different; Apple listened to developers and offered us several options for our future development. In fact, they even encouraged us to send our comments to rhapsody-dev-feedback@apple.com. I am pleased with how well Apple handled the conference.

Rhapsody Does Not Make Obsolete Programmer's Abilities

Since Apple and NeXT's merger, I have heard many Macintosh developers express concern that their skills programming the Macintosh will be obsolete. After all, Rhapsody replaces the Mac Toolbox with something new, code named Yellow Box. (Yellow Box is the combination of OPENSTEP and key Apple technologies.) The APIs to Yellow Box is dramatically different from the Macintosh Toolbox. However, what makes a good programmer is not merely knowledge of one system's API. Good programming is about bringing organization to a complex situation, providing a simple solution to solve a complex problem, and identifying what a user wants. Our skills as programmers rely more heavily on our ability to organize the problem and solution than they do on knowledge of any particular API. Anyone can look up API calls in a manual, but it takes an experienced programmer to know what routines to look for and how to connect them together to make a meaningful application.

Some of our greatest skills as Macintosh programmers are our abilities to design meaningful interfaces to help users solve complex problems. These skills can translate to any platform. (One need try only a few Windows applications to see how rare are these skills.) Even though we will need to learn a new programming environment, it also presents a fresh start for new and non-Macintosh programmers to join us. Those who have the high quality skills we have come to expect of Macintosh Progrmmers will do well; the others...well, who knows. Rhapsody offers many new opportunities to build more powerful and interesting tools; I very much look forward to using those tools, and creating some myself.

MacOS 8 is Alive and Well

Apple had many strong presentations about the future of MacOS 8. They presented a clear schedule for delivering significant upgrades well into 1999. They presented several new technologies being developed for MacOS 8. Most important, they told us Yellow Box would be made to run on MacOS 8 in addition to running on Rhapsody.

Apple is realistic about the addoption rate of Rhapsody; they expect 4-5 million Rhapsody users by mid 1999. That is a far cry from the current 27 million MacOS 7 users. Many developers have complained that they don't want to have to write their applications twice: once to support Rhapsody and a rewrite to support MacOS 8. Apple has responded by porting the Yellow Box APIs to MacOS 8. This will allow developers to use one API to write their code once and have it run on all Macintosh platforms.

This single API approach is especially important given how much we all (developers and Apple) rely on MacOS 8 for our bread and butter now and for the future. Enabling developers to take avantage of Yellow Box to build applications faster than ever before and deploy them on MacOS 8 as well as Rhapsody makes it that much more compelling for us to begin our Rhapsody development as soon as possible.

Rhapsody Provides Compelling New Opportunities

Many Macintosh developers have been dreaming for some time of entering the Windows software market. We see analists' numbers that generally have an extra zero or two at the end as compared to our own Macintosh market. (People tend to forget that those extra zeros apply to costs as well as revenues, and to the number of competitors.) I've talked with many developers struggling to deal with porting their software to other platforms. Rhapsody -- or more specifically Yellow Box -- offers a very different approach. Unlike Java, Yellow Box today offers a much more mature solution to the multiplatform software problem. With so many competing implementations, Java only dreams of solving the problem of write your software once, and deploy it anywhere. With Apple controlling all implementations, Yellow Box is actually delivering it.

Apple has promissed Yellow Box compatability in at least four flavors: Rhapsody for PowerPC, Rhapsody for Intel, Yellow Box for MacOS, Yellow Box for Win32 (that is, NT and 9x). Additionally, there are strong rumors that Yellow Box will also be available for Solaris and HP unix. That is a pretty broad market. The goal is that we developers can write our software to one API and merely recompile for each target platform. Apple is even working on multiplatform delivery mechanisms. In reality there are subtle differences between platforms that require some additioanl tweaks, but Apple is helping even there. For example, there is a specific nib file (resource fork) for each target platform, allowing platform-specific interface changes to override the platform's default behavior.

Another reason to develop for Yellow Box is the completeness of the application framework. We have had frameworks for Macintosh for many years now, but none fully hide the need to know the underlying Mac Toolbox. Yellow Box is the toolbox. When building an Yellow Box application, so much of the user interface code is already written, we developers are free to ship sooner or spend time adding more features.

Still Some Holes in Rhapsody

Rhapsody is not all peaches and cream. There are some holes; the poor networking support is the biggest. Between Apple's presentations and my conversations in the halls of WWDC, it is clear that Apple still doesn't understand how the Internet is changing; their "strategy" is limited to web content development and deployment. They seem to be ignoring many other areas including communications, collaboration and commerce. For example, Yellow Box does not provide any foundation classes for using common Internet protocols such as HTTP or FTP. It doesn't even provide a foundation class for basic IP networking. This means that every network-savvy Yellow Box application must use platform-specific network code. A Rhapsody application will use Rhapsody's version of BSD sockets, a MacOS application will use OpenTransport streams and a Wintel application will use WinSock. Given that networking is the fastest growing segment of the software industry, it seems absurd that Apple does not provide a network abstraction layer in Yellow Box as they have for the user interface.

This networking issue also raises the question of why Apple is using sockets instead of streams. Everyone I spoke with has made a strong argument for streams being a more flexible and generally superior architecture. When Apple asked us all to move our network code to OpenTransport (streams), they said it was a technology for the furture. Streams provides standard APIs at all levels, allowing developers to write code to adjust the contents of the network at the level that makes sense for their software. Some developers argued that Apple should develop a sockets interface to make porting code to other platforms easier. Apple answered that sockets could easily be implemented on top of streams, and some third parties offered libraries doing exactly that. It is very hard to go the other way because sockets implementations really define only the highest level API. The underpinings are specific to each platform.

Not only is it odd that Apple seems to have ignored their original reasons for moving all developers to a streams implementation, but Apple already has most of the streams code for Rhapsody, including complete network stacks for AppleTalk, IP, IPX, and TokenTalk. Instead, they are porting the NeXTSTEP sockets code and adding the AIX AppleTalk sockets code; then they have to find a way to make Blue Box's OpenTransport (streams) work on top of this. Many WWDC attendees asked Apple how they intended to solve specific, difficult problems with this scenario. Apple's most common answer was "Hm, we hadn't thought of that. That's is a hard problem, but we're sure we can solve it when we get to it." To Apple's credit, they repeatedly took some harsh critism from attendees, and they appeared to really listen. Hopefully they got the mesage that they should reevaluate the technical merits of choosing sockets over streams so we can have a networking architecture that can grow with the rest of the platform.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Dropbox 193.4.5594 - Cloud backup and sy...
Dropbox is a file hosting service that provides cloud storage, file synchronization, personal cloud, and client software. It is a modern workspace that allows you to get to all of your files, manage... Read more
Google Chrome 122.0.6261.57 - 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
Skype 8.113.0.210 - Voice-over-internet...
Skype is a telecommunications app that provides HD video calls, instant messaging, calling to any phone number or landline, and Skype for Business for productive cooperation on the projects. This... Read more
Tor Browser 13.0.10 - Anonymize Web brow...
Using Tor Browser you can protect yourself against tracking, surveillance, and censorship. Tor was originally designed, implemented, and deployed as a third-generation onion-routing project of the U.... Read more
Deeper 3.0.4 - Enable hidden features in...
Deeper is a personalization utility for macOS which allows you to enable and disable the hidden functions of the Finder, Dock, QuickTime, Safari, iTunes, login window, Spotlight, and many of Apple's... Read more
OnyX 4.5.5 - Maintenance and optimizatio...
OnyX is a multifunction utility that you can use to verify the startup disk and the structure of its system files, to run miscellaneous maintenance and cleaning tasks, to configure parameters in the... Read more
Hopper Disassembler 5.14.1 - Binary disa...
Hopper Disassembler is a binary disassembler, decompiler, and debugger for 32- and 64-bit executables. It will let you disassemble any binary you want, and provide you all the information about its... Read more
WhatsApp 24.3.78 - Desktop client for Wh...
WhatsApp is the desktop client for WhatsApp Messenger, a cross-platform mobile messaging app which allows you to exchange messages without having to pay for SMS. WhatsApp Messenger is available for... Read more
War Thunder 2.33.0.135 - Multiplayer war...
In War Thunder, aircraft, attack helicopters, ground forces and naval ships collaborate in realistic competitive battles. You can choose from over 1,500 vehicles and an extensive variety of combat... Read more
Iridient Developer 4.2 - Powerful image-...
Iridient Developer (was RAW Developer) is a powerful image-conversion application designed specifically for OS X. Iridient Developer gives advanced photographers total control over every aspect of... Read more

Latest Forum Discussions

See All

Gorgeous Tactical Puzzle Game ‘Howl’ is...
Following its release on PC and Nintendo Switch this past November, and it’s arrival on Xbox and PlayStation back in January, publisher Astragon Entertainment and developer Mi’pu’mi Games are now bringing their super stylish tactical puzzler Howl to... | Read more »
Best iPhone Game Updates: ‘Shoot the Moo...
Hello everyone, and welcome to the week! It’s time once again for our look back at the noteworthy updates of the last seven days. It feels like a bit of a dry spell this week, at least in terms of really interesting updates. I mean, I found some... | Read more »
Celebrate Phobies spooky second annivers...
Get ready to have that classic song stuck in your head, as Phobies celebrates its second anniversary with the release of its latest update; Birthday Bash, Monster Mash. Starting March 5th and lasting for four weeks, it will be a month of... | Read more »
‘Dissidia Final Fantasy Opera Omnia’ Sto...
Square Enix finally shut down Dissidia Final Fantasy Opera Omnia (Free) on iOS and Android last week following the end of service announcement back in November last year. Following the game shutting down, Square Enix | Read more »
‘Monster Hunter Now’ Is Celebrating the...
Niantic and Capcom have begun celebrating the 20th anniversary of Capcom’s best franchise from today inside Monster Hunter Now (Free) on iOS and Android for a limited time. | Read more »
New ‘Warframe Mobile’ Update Adds 60fps...
Warframe Mobile (Free) launched worldwide on iOS just under two weeks ago. I’ve been playing it for review across multiple iOS devices, but have also been picking it up on Steam Deck and Switch to compare. Right from launch, I was impressed with... | Read more »
Passionate About Fidget Toys – The Touch...
In this week’s episode of The TouchArcade Show we kick things off with some passionate discussion about… fidget toys? For some reason? We quickly change gears to talk about the card-based rogulike Balatro, which we’ve both been playing and enjoying... | Read more »
TouchArcade Game of the Week: ‘Flying Ta...
For me Hexage is one of those developers that harkens back to the early days of the App Store and really the beginnings of iPhone gaming. I have spent many collective hours playing the likes of Totemo, Radiant, Radiant Defense, EVAC, Reaper… the... | Read more »
SwitchArcade Round-Up: ‘Ufouria 2: The S...
Hello gentle readers, and welcome to the SwitchArcade Round-Up for March 1st, 2024. In today’s article, we’re looking at the remaining releases of the week. There are a few really good ones today, but the bin bunch certainly isn’t going home hungry... | Read more »
Steam Deck Weekly: Reviews of PowerWash...
Welcome to the first Steam Deck Weekly of March and this week’s edition is bigger than usual. I was a bit unwell last week and had to push some reviews to this week. Alongside that, there have been many notable announcements, releases, and new Steam... | Read more »

Price Scanner via MacPrices.net

Deal Alert! B&H is now selling 13-inch M2...
B&H Photo has 13″ MacBook Airs with M2 CPUs and 256GB of storage in stock and on sale for $100 off Apple’s new MSRP, now only $899. Free 1-2 day delivery is available to most US addresses. Their... Read more
At $999, Apple’s 13-inch M2 MacBook Air is th...
With today’s introduction of the new 13-inch M3 MacBook Air for $1099, Apple dropped prices on the previous-generation 13-inch M2 MacBook Air to $999. At the same time, Apple discontinued the 13-inch... Read more
Apple discontinues 15-inch M2 MacBook Airs, d...
With today’s introduction of new M3-powered 15″ MacBook Airs, Apple has dropped prices on clearance, Certified Refurbished, 15″ M2 MacBook Airs to a new low of $1019. These are the cheapest 15″... Read more
Price Drop! 13-inch M2 MacBook Airs at Apple...
Apple has dropped prices on Certified Refurbished 13″ M2 MacBook Airs to a new low of $849. These are the cheapest M2-powered MacBooks for sale at Apple. Apple’s one-year warranty is included,... Read more
Apple finally discontinues the 13-inch M1 Mac...
With the introduction of M3-powered 13″ MacBook Airs today, Apple has dropped prices on clearance 13″ M1 MacBook Airs, Certified Refurbished, to $759 for 8-Core CPU/7-Core GPU/256GB models and $929... Read more
Updated Apple iPad Price Trackers
Our Apple award-winning iPad Price Trackers are the best place to find the latest information on iPad sales and deals. We track prices from 20+ Apple retailers, including Apple, Amazon, Best Buy,... Read more
Updated Apple MacBook Price Trackers
Our Apple award-winning MacBook Price Trackers are continually updated with the latest information on prices, bundles, and availability for 16″, 14″, and (recently-discontinued) 13″ MacBook Pros... Read more
Mac Studios with Apple M2 Max and M2 Ultra CP...
B&H Photo has the standard-configuration Mac Studio model with Apple’s M2 Ultra CPU in stock today and on sale for $300 off MSRP, now $3699 (24-Core CPU and 64GB RAM/1TB SSD). B&H Photo has... Read more
Extended: Switch to Verizon and get the Apple...
Verizon has the iPhone 15 on sale for $0 per month when you add a new line if service. Discount is applied to your account monthly over a 36 month term and is valid for the 128GB model. For the first... Read more
Select 16-inch M3 Pro and M3 Max MacBook Pros...
B&H Photo has select 16-inch M3 Pro and M3 Max MacBook Pros on sale for $250 off MSRP. Their prices are the lowest currently available for these configurations. Free 1-2 day shipping is available... Read more

Jobs Board

Teller Part Time *Apple* Valley MN *Apple*...
…is not eligible for Visa sponsorship **Posting Location:** + 15574 Pilot Knod Road Apple Valley, MN 55124 @RWF22 **Posting End Date:** Job posting may come down Read more
*Apple* End User Support Specialist - North...
…that they are performed. + Responsible for support of all College owned Apple computers, mobile ios devices, and peripherals, and for diagnosing and resolving Read more
Omnichannel Associate - *Apple* Blossom Mal...
Omnichannel Associate - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Read more
Teller Part Time *Apple* Valley MN *Apple*...
…is not eligible for Visa sponsorship **Posting Location:** + 15574 Pilot Knod Road Apple Valley, MN 55124 @RWF22 **Posting End Date:** Job posting may come down Read more
Nurse Anesthetist - *Apple* Hill Surgery Ce...
Nurse Anesthetist - Apple Hill Surgery Center WellSpan Medical Group, York, PA | Advanced Practice Providers | Certified Registered Nurse Anesthetists | FTE: 1 | Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.