Software Gems: The Computer History Museum Historical Source Code Series
Electronic mail is one of “killer apps” of networked computing. The ability to quickly send and receive messages without having to be online at the same time created a new form of human communication. By now billions of people have used email.
Email has a long and storied history, dating back to MIT’s Compatible Time Sharing System (CTSS) and the US government’s AUTODIN in the early 1960s. These early systems, which often used propriety communications networks and protocols, were generally incompatible with each other; you could only exchange mail with people using the same system.
The first email on the ARPANET (the predecessor of today’s internet) was sent by Ray Tomlinson in 1971, and mail formats became standardized (RFC 524, RFC 561) soon thereafter. In the 1980s, the Post Office Protocol for TCP/IP codified the communication between email clients (which run on the user’s computer) and the email server (where messages are received from other systems and stored), so that there could be independent implementations of both on different computers and operating systems.
Eventually many email clients were written for personal computers, but few became as successful as Eudora. Available both for the IBM PC and the Apple Macintosh, in its heyday Eudora had tens of millions of happy users. Eudora was elegant, fast, feature-rich, and could cope with mail repositories containing hundreds of thousands of messages. In my opinion it was the finest email client ever written, and it has yet to be surpassed.
I still use it today, but, alas, the last version of Eudora was released in 2006. It may not be long for this world. With thanks to Qualcomm, we are pleased to release the Eudora source code for its historical interest, and with the faint hope that it might be resuscitated. I will muse more about that later.
How Eudora Came to Be
In the 1980s, Steve Dorner was working at the computer center at the University of Illinois at Urbana-Champaign.
“I started Eudora in 1988, at the University of Illinois, about four years before I came to Qualcomm. We began it because the internet was a growing and burgeoning place, but email was not really established on the desktop computers that people were using at the time. It was something that you logged in to some mainframe computer to do, and with the use of use that the desktop operating systems brought, that just wasn’t the right way for people to do email anymore.”
It took Dorner just over a year to create the first version of Eudora, which had 50,000 lines of C code and ran only on the Apple Macintosh. Like many university-produced programs, it was available to anyone for free.
Why did he call it Eudora? Dorner explained for a 1997 article in the New York Times CyberTimes that it was because of a short story he had read in college: “Why I Live at the P.O,” by Mississippi writer Eudora Welty. Working intently on an email program, Dorner said “I felt like I lived at the post office.”
In 1991, Qualcomm, a communications company in San Diego famous for CDMA cellular communications technology, licensed Eudora from the University of Illinois. Dorner was eventually hired by them to continue to develop it, working remotely from his home in Illinois.
Qualcomm’s motivations were several. They knew that the internet would fuel the need for wireless data, and they thought that email would be one of the drivers. They also thought it prudent to diversify beyond ICs for wireless technology into software applications.
But Eudora as a Mac-only product wouldn’t cut it. Qualcomm project manager John Noerenberg assigned Jeff Beckley and Jeff Gehlhaar in San Diego the task of making an MS-DOS and then a Windows version of the program. “The style of the company was to put an MS-DOS or Macintosh computer on each employee’s desk—whichever most suited their needs and their personal preference,” he said. “We required email software that was internet-savvy, and platform agnostic. There wasn’t anything commercially available that satisfied either of those goals, much less both.”
Initially Eudora was only used internally at Qualcomm. It was well-received. Noerenberg heard one financial executive at Qualcomm saying, “I used to hate email. But I love Eudora!!” and observed, “It was at that moment I realized we were on to something.”
The company later said, “As a leader in developing and delivering digital communications, Qualcomm recognized email as an important communications tool for the future,” and they released it as a consumer product in 1993. The Eudora team at Qualcomm expanded quickly from the initial four to a moderately large product group, and at its peak was over 50 people.
The Rise of Eudora
The Qualcomm version of Eudora was originally available for free, and it quickly gained in popularity. To get a feel for the user community, Beckley called it “postcard-ware” and asked people to send him a postcard if they liked it. “I got thousands of postcards from all over the world. . . . There was this great feeling about the software, and everybody really loved it.”
“But,” Noerenberg recalls, “postcards don’t pay the bills.” He faced management pressure to stop spending money on a free product. “In 1993 I hatched the idea that if we could somehow convince Qualcomm there was money in an internet software business, we could turn this into a product and we’d get to keep doing what we loved.”
Eudora was soon commercialized as a paid version for $19.95. There was still a free version, now supported by advertisements. By 2001, over 100 person-years of development had been invested in the Windows and Macintosh versions. The paid version eventually sold for as much as $65, and it was aggressively marketed by Qualcomm.
The Demise of Eudora
After 15 years, Qualcomm decided in 2006 that Eudora was no longer consistent with their other major project lines, and they stopped development. A likely factor was the increasing adoption of Microsoft Outlook as an email client for corporations. Outlook was preloaded for free on many PCs, and companies often standardized on it along with the rest of the Microsoft suite of office productivity products. Other free email clients were also available. So regardless of how successful Eudora was, it was never going to be a business big enough to “move the needle” for a company of Qualcomm’s size.
The last Qualcomm versions of Eudora, 220.127.116.11 for Windows and 6.2.4 for Macintosh, were released on October 11, 2006.
To provide a “soft landing” for the millions of Eudora users, Qualcomm generously sponsored the creation of a new compatible open-source version based on Mozilla Thunderbird. For some time they paid the salaries of the programmers working on it, which included Steve Dorner, Jeff Beckley, Dale Wiggins, Geoff Wenger, Matt Dudziak, and Mark Charlebois.
A beta of the new version 8.0 was released in August 2007. But it was panned by the Eudora faithful, in part because it had both a different look and feel and an incompatible mailbox data format. The production version 1.0 of what was renamed “Eudora OSE” (Open Source Edition) was released in September 2010, but fared no better.
Jeff Beckley mused that “Classic Eudora had many years of very detailed design and implementation in it. There are a lot of little things that go on behind the scenes, or at least very subtly visible to the user. Users come to depend on those subtle interactions, and, when they aren’t there, it just feels different.”
After a few more years of intermittent work, the project for an open-source Eudora collapsed.
The last Qualcomm Windows version of Eudora continues, with some glitches, to work well under Windows 10. The Apple Macintosh version, unfortunately, did not survive the transition to the modern Mac processors and operating systems, and can now only run using emulators.
It’s hard to overstate Eudora’s popularity in the mid-1990s. The April 22, 1996 InfoWorld article announcing the release of Eudora Pro 2.0 called it Qualcomm’s “best-selling product,” and said that “according to International Data Corp. (IDC), Qualcomm claimed 64.7 percent of all e-mail software revenues in 1995.” A later exhibit about Eudora in Qualcomm’s company museum observed that “By 1996 Eudora had 18 million users, making it the world’s most widely used internet email software at the time.”
Even though it has mostly faded away, Eudora had a lasting impact. As Dorner says, “It had a great effect on how people do email even today. There are concepts that we introduced, which we were the first to do, that are now a standard part of any email client out there.”
The Eudora Source Code
The discussion with Qualcomm for the release of the Eudora source code by the company’s museum took five years. In the end, they decided not to simply grant a license, but to transfer ownership of the code, the Eudora trademarks, the copyrights, and the Eudora domain names to the Computer History Museum (CHM). The transfer agreement allows us to publish the code under the very liberal BSD open source license, which means that anyone can use it for either personal or commercial purposes.
The source code we are distributing is what we received from Qualcomm, with only the following changes:
- addition of the CHM copyright notice and the BSD license
- sanitization of “bad words”, mostly in comments, as requested by Qualcomm
- removal of third-party software that neither the museum nor Qualcomm has the right to distribute
The Windows version of Eudora is written in C++. The source tree consists of 8,651 files in 565 folders, taking up 458 MB. There are both production (“Eudora71”) and test (“Sandbox”) versions of the code.
The Macintosh version of Eudora is an entirely different code base and is written in C. The source tree consists of 1,433 files in 47 folders, taking up 69.9 MB.
The license for the code allows you to use the code for free, with or without modifications, for personal or commercial use, as long as the copyright notices, the list of conditions, and the disclaimers are retained in the code. The license does NOT allow you to use any of the trademarks or domain names related to Eudora, including Eudora™, www.eudora.com, and www.eudora.org.
Reviving the Windows Version of Eudora
Although Eudora became unsupported as of 2006, some of us are in denial and still use it as our primary email client. I have over 350,000 archived messages in the Windows Eudora format going back to 1997, along with 28,000 embedded images and 33,000 saved attachments. I run it with only minor problems under Windows 10.
I know of no other email client that can manage repositories that large and search them so quickly. I spend hours each day using Eudora to read and send email. I can do a complex search for anything in the 20 years of archived email in under a minute. It will be a sad day when I have to give it up.
Are there others like me? We have no way of knowing how large the community of current Eudora users is. If you would like to contribute to a short informal poll about your current and past Eudora usage, please fill out the survey here.
I do hope that someone, or some group, or some company, will adopt the Windows Eudora source code and revive it as a supported program. The Computer History Museum cannot do that. Only the Eudora fan base can.
It won’t be easy. The tasks in reviving the Windows version include replacing several third-party libraries for isolated tasks, like spell-checking. The HTML rendering engine should be replaced with something more modern. The handling of Unicode and other special character encoding needs to be improved.
Also, the Windows version uses a Qualcomm-modified version of RogueWave Software’s Stingray package of extensions to MFC, the Microsoft Foundation Class library for C++. After more than three years of discussion, we finally secured an agreement with RogueWave, giving us permission to distribute a binary linkable library compiled from the 20-year-old source code, but only for noncommercial use. That library is not currently part of this release, but we will build and distribute it if there is credible interest in rebuilding a noncommercial Windows version of Eudora. But it will take some effort to make the changes to the RogueWave source code necessary to compile it in a modern development environment, and we could use help in doing that.
Reviving the Macintosh Version of Eudora
The Macintosh version, because it is based on an older processor and operating system, would be harder to resuscitate. It would have to be substantially rewritten for the current Mac environment. But not much is beyond the capability of motivated and clever programmers. Have at it.
Long live Eudora!
- Thanks to Qualcomm, Wintertree, and RogueWave their various permissions.
- Thanks to Grady Booch, Steve Jasik, and Jennifer Stanley of Fenwick & West for their help.
- Thanks to Steve Dorner, Jeff Beckley, and John Noerenberg for their encouragement and participation in this multiyear odyssey to release the code, and for creating Eudora in the first place. You should be very proud of what you did.
Historical Source Code Releases @CHM
- MacPaint and QuickDraw Source Code, July 18, 2010
- APL Programming Language Source Code, October 10, 2012
- Adobe Photoshop Source Code, February 13, 2013
- Apple II DOS Source Code, November 12, 2013
- Microsoft MS-DOS Early Source Code, March 25, 2014
- Microsoft Word for Windows Version 1.1a Source Code, March 25, 2014
- Early Digital Research CP/M Source Code, October 1, 2014
- Xerox Alto Source Code, October 21, 2014
- Electronic Arts DeluxePaint Early Source Code, July 22, 2015