TweetFollow Us on Twitter

Open Source Macintosh

Volume Number: 15 (1999)
Issue Number: 8
Column Tag: Open Source

Open Source on the Macintosh

by Steve Huntsberry

How Apple developers can benefit from the Apple Public Source project

Introduction to Open Source

In March, Apple announced that they were the first mainstream operating system provider to release their source code to the public with the launch of Darwin. Some may question this statement, given the popularity of Linux and other open source operating systems, but the fact remains that there are now some components of the Mac OS that are available as open source. This article will analyze Apple's commitment to open source and how Apple developers can benefit. At the end of this article are several Internet URLs where you can find the details of many of the topics discussed.

What is Open Source? The term "open source" has become popular recently in the media due to Linux, which some consider to be a threat to Microsoft Windows. The concept of open source has been around for quite some time. The definition used by Apple comes from the Open Source Initiative, which has determined that the Apple Public Source License conforms to their definition of open source.

The Apple Public Source License (APSL) binds the users of Apple's open source code and determines what you can and cannot do with it. The complete text of the APSL is available at the Apple Public Source web site. The key points of the APSL allow you to use the code provided for whatever purposes you wish without paying Apple, but if you modify any of the Apple-supplied portions, you must submit the changes back to Apple. Therefore you can write your own code that builds on Apple open source code without needing to hand all of your code over to Apple.

There are several goals for the Apple Public Source project. Apple benefits by having a group of developers to provide it with free improvements and bug fixes for its source code. Apple will also contribute their bug fixes and incremental improvements back to the open source community. One of the Darwin engineers made a presentation at the USENIX Technical Conference in June, describing Apple's plans for using open software in their commercial operating system.

Developers benefit by obtaining a better understanding of the system to allow them to fine-tune their application performance and to reduce development time. Developers can also add specific features to Apple software that Apple might not add by itself, in order to improve their own specialized applications.

Open Source is not the same as Free Software. The Free Software Foundation (FSF) was established many years ago by Richard Stallman, president of the FSF, founder of the GNU project, and principal author of the GNU C compiler (gcc), GNU symbolic debugger (gdb), and GNU emacs. The principal project of the FSF is the GNU operating system, a free version of Unix. The FSF is dedicated to eliminating restrictions on any copying, modification, or redistribution of computer programs. They advocate that all software should be completely free, and that developers should make their living through providing support for such free software.

The GNU General Public License (GPL) uses "copyleft" (rather than copyright) protection. It requires developers using GPL-protected source code to make all of their source code available. Therefore, if you write a new compiler using code from gcc, you must publish all of the source code to your new compiler under GPL, in addition to any modifications you made to the original gcc code. Richard Stallman has written a document detailing his problems with the Apple Public Source License, since it does not conform to the GPL definition of free software.

Apple does have support for its open source project from many of the other members of the open source community. Besides the approval of the Open Source Initiative, Apple has support from FreeBSD and NetBSD, two open source Unix operating systems based on Berkeley Standard Distribution (BSD) Unix.

Microsoft is not ignoring the developments in open source. Their external party line is that they do not consider open source to be a concern, however last year in October the "Halloween Documents" appeared on the Internet. These were leaked internal Microsoft memos describing the threat posed to the traditional Windows proprietary closed source model from open source software and from Linux in particular. It will be interesting to see what transpires in this arena.

Apple Open Source Projects

Currently there are three open source projects at Apple. OpenPlay is a network abstraction layer that runs on Mac OS 8 and Windows. The Darwin Streaming Server is a QuickTime streaming server that runs on Mac OS X Server. Darwin is the Mach plus FreeBSD foundation of Mac OS X and runs as a stand-alone Unix implementation. Apple indicates there are more open source projects in the works, but they do not plan to reveal them until they actually become available.

OpenPlay was originally developed for "Myth: The Fallen Lords" from Bungie Software, to support cross-platform network games between Mac OS 8 and Windows computers. OpenPlay provides a network abstraction layer for the Open Transport and WinSock APIs. It supports TCP/IP and AppleTalk (on Macintosh). It provides a plug-in architecture to allow developers to add new protocols. It is useful for any cross-platform networking application, not just for games.

Darwin Streaming Server sends streaming QuickTime data to clients across the Internet. It uses industry standard RTP, RTCP, and RTSP protocols. RTP is the Real-time Transport Protocol, providing transport layer functionality for real-time data over multicast or unicast connections. RTCP is the Real-Time Control Protocol, using RTP to synchronize transmissions between sender and receiver. RTSP is the Real-Time Streaming Protocol, providing VCR-like controls for content delivery, such as play, stop, pause, etc. Darwin Streaming Server has some limitations in that it requires hinted QuickTime files generated by QuickTime Pro, so providing streaming content is not entirely free. It also uses reflection and not true multicast, such that it is not scalable and is limited to about 1000 receivers per transmission.

Darwin is a stand-alone Unix implementation consisting of the Mach kernel plus the FreeBSD set of Unix tools. Darwin is perhaps the most exciting piece of Apple open source in that it is the core of Mac OS X (both Client and Server), such that any improvements made to Darwin will become improvements in Mac OS X. Darwin also provides several pieces of Apple technology, including AppleTalk networking, the HFS+ file system, and NetInfo (directory services from Mac OS X Server).

Darwin is useful for developers in two ways. Because it is the core of Mac OS X, improvements can be made by developers to Darwin that will later improve their applications running on Mac OS X. Darwin is also useful by itself, as it provides a full set of Unix tools and command-line interface that work with the Macintosh file system.

In May, Sassafras Software reported they were able to add AppleTalk networking support to the Mac OS X Server version of their KeyServer license metering product within a week. Their development work was greatly assisted by access to Darwin low-level source code. The key benefit was the ability to reconcile discrepancies between documentation and implementation quickly, which reduced their debugging time dramatically.

Currently Darwin runs on PowerPC hardware, although Apple is considering making it work on Intel hardware. The original NextStep ran on Intel, so there is no technical reason preventing Darwin from running on Intel hardware. However, Apple wants to concentrate on PowerPC development, and supporting Intel hardware would require additional development work and additional testing. Such a commitment remains under consideration. If Intel support is important for you, then you may want to voice your opinion to Apple.

Other Open Source Projects

As noted above, the Apple open source project is relatively new to the world of open source. To find out more about open source, one should look into the existing open source projects. The GNU Project and the Free Software Foundation were discussed above. Perhaps the most popular open source project today is Linux, an open source Unix operating system. Red Hat, Inc. is one of the most well-known Linux distributors. Although Linux is free, Red Hat packages it with a number of useful tools and support and sells it on CD-ROM. Debian is another Linux distributor. The GNOME project is designing an open source user interface for Linux. One of the major drawbacks of any Unix-like operating system is the command-line interface, which is difficult to use for people used to a windowing environment. Some people think that once Linux has a modern user interface it will pose a real threat to Microsoft Windows. Other open source Unix operating systems include FreeBSD, NetBSD, and OpenBSD.

There also a few open source applications. The Apache project maintains an open source HTTP server that is used on over sixty percent of the Web sites on the Internet. The Mozilla project is the open source version of Netscape Communicator, the Web browser and e-mail/news client. Both of these projects invite outside developers to help to improve their respective applications.

Open Source on the Web

Apple Open Source Infrastructure

Apple has put together a number of resources to assist developers with open source on the Macintosh. The Apple Public Source web page contains a wealth of information, including open source news, developer registration, Internet mailing lists, Usenet newsgroups, etc. Soon they plan to have centralized bug tracking, most likely following the Bugzilla model used by the Mozilla project. At the Apple Worldwide Developers Conference (May 10), Apple quoted figures of 33,000 registered developers and 185,000 downloads of open source software, following its initial release on March 16.

Recently Apple announced support for source code management through Concurrent Versions System (CVS). This is a source code management system similar to SourceSafe or Perforce. CVS enables access to the very latest source code releases, change logs, and incremental updates. CVS access is not yet available, but should be soon. Mac OS 8 users can use MacCVS Pro, a CVS client sponsored by Mozilla. The Mozilla Web site is also a good source for CVS documentation.

Installing Open Source Software

Once you have registered as an open source developer and downloaded the appropriate software, you will need to get it installed. As this is a new project for Apple, installation can be tricky and frustrating. Eventually Apple plans to have a more robust installation solution, but for now you will just have to bear with them.

Installing OpenPlay is reasonably straightforward. The OpenPlay distribution consists of a StuffIt archive containing CodeWarrior projects, C source and header files, and documentation. The code files are split into folders labeled Macintosh, Windows, and Common (with cross-platform code). There is also a test application so you can see how it works. The documentation is fairly spartan, but everything seems to be there.

Installing Darwin Streaming Server is somewhat trickier. The Darwin Streaming Server distribution consists of a zipped tar archive containing C++ source and header files, along with the requisite Makefiles and a few PowerPC binary files. There is one documentation file but it merely provides an overview; for the most part you are on your own.

Installing Darwin itself is the most convoluted process. Darwin has the same hardware requirements as Mac OS X Server, namely a Power Macintosh G3 with 64 MB of RAM. The installation requires 60 MB of free disk space. After you download the 45 MB Darwin image, you need to find a blank 1 GB or larger ATA or SCSI hard drive (fast-wide SCSI is not supported). Then use the Apple Software Restore utility to install the image on the hard disk. The hard disk will end up with a 1 GB UFS partition called "Darwin Root" containing the Darwin software, with any remaining space formatted as a Macintosh HFS+ format volume. You then use the System Disk utility to select the "Darwin Root" volume and restart. Eventually you will end up with a system which can be dual-booted in either Darwin or Mac OS mode.

This article covers Darwin version 0.2, released on May 10. There are two major changes that will occur between now and the release of Mac OS X client. First is that Mach 3.0 will be replacing Mach 2.5 as the kernel. Second is that IOKit will be replacing DriverKit for drivers. Therefore if you plan to modify or use code from either one of these areas, you may want to wait until Apple releases these modifications, or write your code in such a way that the switch will not be too painful.

Darwin Project Ideas

Apple would like to see more software that runs on Darwin. Currently Darwin is limited to basic Unix tools and a few Apple technologies such as AppleTalk. Apple would like to see real installer utilities, both to install Darwin itself, as well as to install other Darwin applications. They would also like developers to implement additional device drivers and file systems so Darwin can be made more universal. Another project might be some kind of user interface beyond the command-line interface, such as X-Windows. I am under the impression the Darwin team would like to see Darwin become a living, breathing operating system that can stand on its own merits, and not merely the core of Mac OS X.

Your Next Step

Open source on the Macintosh provides a number of new opportunities for developers. You can use the supplied libraries such as OpenPlay and Darwin Streaming Server to add features to your applications without reinventing the wheel. You can work with the Darwin source code to understand and/or improve the Mac OS X core so your Mac OS X applications run better. You can design entire applications to run on Darwin to provide services to users who may want to use the Mac kernel with BSD on PowerPC hardware, but who may not want the additional overhead of the Mac OS X environment.

Open source can also help Apple to make the Mac OS a better operating system. Darwin developers can work on core OS features to improve performance and to add special features. Apple system engineers can concentrate on Apple-specific pieces of technology, such as improving the user interface, ColorSync, QuickTime, Sherlock, and speech recognition.

You must decide for yourself how to make best use of open source on the Macintosh. You may even decide that your application is outside the scope of the open source libraries provided by Apple, and that you do not want to work on the Darwin core of Mac OS X. Even so, you may find that because others are working on the Apple open source projects, the Mac OS will be improved, and it will become a better place for you, your applications, and your users to exist.


Steve Huntsberry is a Computer Scientist in the Type Engineering department at Adobe Systems Inc. He is the Technical Lead for the Macintosh Type On Call 4.2 and Adobe Type Library 2.0J products. Steve can be reached at shuntsbe@adobe.com.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Spotify 1.0.4.90. - Stream music, create...
Spotify is a streaming music service that gives you on-demand access to millions of songs. Whether you like driving rock, silky R&B, or grandiose classical music, Spotify's massive catalogue puts... Read more
djay Pro 1.1 - Transform your Mac into a...
djay Pro provides a complete toolkit for performing DJs. Its unique modern interface is built around a sophisticated integration with iTunes and Spotify, giving you instant access to millions of... Read more
Vivaldi 1.0.118.19 - Lightweight browser...
Vivaldi browser. In 1994, two programmers started working on a web browser. Our idea was to make a really fast browser, capable of running on limited hardware, keeping in mind that users are... Read more
Stacks 2.6.11 - New way to create pages...
Stacks is a new way to create pages in RapidWeaver. It's a plugin designed to combine drag-and-drop simplicity with the power of fluid layout. Features: Fluid Layout: Stacks lets you build pages... Read more
xScope 4.1.3 - Onscreen graphic measurem...
xScope is powerful set of tools that are ideal for measuring, inspecting, and testing on-screen graphics and layouts. Its tools float above your desktop windows and can be accessed via a toolbar,... Read more
Cyberduck 4.7 - FTP and SFTP browser. (F...
Cyberduck is a robust FTP/FTP-TLS/SFTP browser for the Mac whose lack of visual clutter and cleverly intuitive features make it easy to use. Support for external editors and system technologies such... Read more
Labels & Addresses 1.7 - Powerful la...
Labels & Addresses is a home and office tool for printing all sorts of labels, envelopes, inventory labels, and price tags. Merge-printing capability makes the program a great tool for holiday... Read more
teleport 1.2.1 - Use one mouse/keyboard...
teleport is a simple utility to let you use one single mouse and keyboard to control several of your Macs. Simply reach the edge of your screen, and your mouse teleports to your other Mac! The... Read more
Apple iMovie 10.0.8 - Edit personal vide...
With an all-new design, Apple iMovie lets you enjoy your videos like never before. Browse your clips more easily, instantly share your favorite moments, and create beautiful HD movies and Hollywood-... Read more
Box Sync 4.0.6233 - Online synchronizati...
Box Sync gives you a hard-drive in the Cloud for online storage. Note: You must first sign up to use Box. What if the files you need are on your laptop -- but you're on the road with your iPhone? No... Read more

Become the World's Most Important D...
Must Deliver, by cherrypick games, is a top-down endless-runner witha healthy dose of the living dead. [Read more] | Read more »
SoundHound + LiveLyrics is Making its De...
SoundHound Inc. has announced that SoundHound + LiveLyrics, will be one of the first third-party apps to hit the Apple Watch. With  SoundHound you'll be able to tap on your watch and have the app recognize the music you are listening to, then have... | Read more »
Adobe Joins the Apple Watch Lineup With...
A whole tidal wave of apps are headed for the Apple Watch, and Adobe has joined in with 3 new ways to enhance your creativity and collaborate with others. The watch apps pair with iPad/iPhone apps to give you total control over your Adobe projects... | Read more »
Z Steel Soldiers, Sequel to Kavcom'...
Kavcom has released Z Steel Soldiers, which continues the story of the comedic RTS originally created by the Bitmap Brothers. [Read more] | Read more »
Seene Lets You Create 3D Images With You...
Seene, by Obvious Engineering, is a 3D capture app that's meant to allow you to create visually stunning 3D images with a tap of your finger, and then share them as a 3D photo, video or gif. [Read more] | Read more »
Lost Within - Tips, Tricks, and Strategi...
Have you just downloaded Lost Within and are you in need of a guiding hand? While it’s not the toughest of games out there you might still want some helpful tips to get you started. [Read more] | Read more »
Entertain Your Pet With Your Watch With...
The Petcube Camera is a device that lets you use live video to check in on your pet, talk to them, and play with them using a laser pointer - all while you're away. And the Petcube app is coming to the Apple Watch, so you'll be able to hang out with... | Read more »
Now You Can Manage Your Line2 Calls With...
You'll be able to get your Line2 cloud phone service on the Apple Watch very soon. The watch app can send and receive messages using hands-free voice dictation, or by selecting from a list of provided responses. [Read more] | Read more »
R.B.I. Baseball 15 (Games)
R.B.I. Baseball 15 1.01 Device: iOS Universal Category: Games Price: $4.99, Version: 1.01 (iTunes) Description: The legendary Major League Baseball franchise returns to the diamond. Make History. ** ALL iPOD Touch, the iPad 2 and the... | Read more »
Here's How You Can Tell if an App W...
The Apple Watch is pretty much here, and that means a whole lot of compatible apps and games are going to be updated or released onto the App Store. That's okay though, beacause Apple has quietly updated their app description pages to make things... | Read more »

Price Scanner via MacPrices.net

Intel Compute Stick: A New Mini-Computing For...
The Intel Compute Stick, a new pocket-sized computer based on a quad-core Intel Atom processor running Windows 8.1 with Bing, is available now through Intel Authorized Dealers across much of the... Read more
Heal to Launch First One-Touch House Call Doc...
Santa Monica, California based Heal, a pioneer in on-demand personal health care services — will offer the first one-touch, on-demand house call doctor app for the Apple Watch. Heal’s Watch app,... Read more
Mac Notebooks: Avoiding MagSafe Power Adapter...
Apple Support says proper usage, care, and maintenance of Your Mac notebook’s MagSafe power adapter can substantially increase the the adapter’s service life. Of course, MagSafe itself is an Apple... Read more
12″ Retina MacBook In Shootout With Air And P...
BareFeats’ rob-ART morgan has posted another comparison of the 12″ MacBook with other Mac laptops, noting that the general goodness of all Mac laptops can make which one to purchase a tough decision... Read more
FileMaker Go for iPad and iPhone: Over 1.5 Mi...
FileMaker has announced that its FileMaker Go for iPad and iPhone app has surpassed 1.5 million downloads from the iTunes App Store. The milestone confirms the continued popularity of the FileMaker... Read more
Sale! 13-inch 2.7GHz Retina MacBook Pro for $...
 Best Buy has the new 2015 13″ 2.7GHz/128GB Retina MacBook Pro on sale for $1099 – $200 off MSRP. Choose free shipping or free local store pickup (if available). Price for online orders only, in-... Read more
Minimalist MacBook Confirms Death of Steve Jo...
ReadWrite’s Adriana Lee has posted a eulogy for the “Digital Hub” concept Steve Jobs first proposed back in 2001, declaring the new 12-inch MacBook with its single, over-subscribed USB-C port to be... Read more
13-inch 2.7GHz Retina MacBook Pro for $1234 w...
Adorama has the 13″ 2.7GHz/128GB Retina MacBook Pro in stock for $1234.99 ($65 off MSRP) including free shipping plus a free LG external DVD/CD optical drive. Adorama charges sales tax in NY & NJ... Read more
13-inch 2.5GHz MacBook Pro available for $999...
 Adorama has the 13-inch 2.5GHz MacBook Pro on sale for $999 including free shipping plus NY & NJ sales tax only. Their price is $100 off MSRP. Read more
Save up to $600 with Apple refurbished Mac Pr...
The Apple Store is offering Apple Certified Refurbished Mac Pros for up to $600 off the cost of new models. An Apple one-year warranty is included with each Mac Pro, and shipping is free. The... Read more

Jobs Board

*Apple* Client Systems Solution Specialist -...
…drive revenue and profit in assigned sales segment and/or region specific to the Apple brand and product sets. This person will work directly with CDW Account Managers Read more
*Apple* Software Support - Casper (Can work...
…experience . Full knowledge of Mac OS X and prior . Mac OSX / Server . Apple Remote Desktop . Process Documentation . Ability to prioritize multiple tasks in a fast pace Read more
*Apple* Software Support - Xerox Corporation...
…Imaging experience Full knowledge of Mac OS X and prior Mac OSX / Server Apple Remote Desktop Process Documentation Ability to prioritize multiple tasks in a fast pace Read more
*Apple* Support Technician IV - Jack Henry a...
Job Description Jack Henry & Associates is seeking an Apple Support Technician. This position while acting independently, ensures the proper day-to-day control of Read more
*Apple* Retail - Multiple Positions (US) - A...
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.