TweetFollow Us on Twitter

May 93 - Editor's Column - AppleScript and Dylan

Editor's Column - AppleScript and Dylan

Mary Elaine Califf

Since not everyone in MADA read the Dylan newsgroup or mailing list, I thought that I would devote this space to selections from a recent thread that I think will be of interest to many.

The question

Tom Gordon wrote:

The AppleScript programming language, for those of you who might not have heard of it yet, is a new "shell" or "extension" language for Macs from Apple. Users will be able to write programs which send applications messages, also across networks.

Yes, AppleScript is a dynamic object-oriented language.

My question: why isn't AppleScript Dylan? Apple had the opportunity to recreate a Lisp machine like environment, with a single, elegant object-oriented language for both developers and users. Instead it looks like Mac users will have to live with the usual Tower of Babel: HyperTalk, AppleScript, and Dylan (not to mention C++, etc.)

Are there engineering reasons for this decision, or is this just the result of different organizational pressures and interests?

The Response

Larry Tesler replied:

Since it was I who started both projects (around four years ago), I can assure you that the outcome was not politically motivated.

Note that:

  1. AppleScript is an end-user language, in the vein of spreadsheet macros.
  2. Dylan is a language for professional software development, in the vein of C.
  3. Their audiences will be almost as different as MacDraw's is from QuickDraw's.

    Nevertheless:

  4. Chunk expressions and other powerful features of AppleScript, though not implemented in the standard Dylan library, can be supplied by a non-standard library.
  5. The designers of each language kept the other language in mind.
  6. Therefore:
  7. AppleScript can be implemented by translating it to Dylan.

So why did Apple not implement Macintosh AppleScript 1.0 using Dylan?

Because it is risky to plan a future product that can't be completed until after a more complex future product has been completed and its performance and memory footprint understood. I hope that helps.

Larry

P.S.: HyperTalk is approximately a subset of AppleScript. In this case, we worked to maintain similarity, because the users and uses of both are expected to be similar. There are some differences, but they are not gratuitous.

excerpts from discussion

Tom Gordon:

This is all very encouraging. Thank you for the inside information.

As we all know from the Dylan FAQ, an "Algol" syntax is being designed for Dylan, as an alternative to the Lisp/Scheme syntax. Wouldn't it be nice if this syntax would be "compatible" with the syntax used in both AppleScript and HyperTalk? I put "compatible" in quotes, because I'm not at all sure to what extent this can be achieved. AppleScript's model of object-oriented programming appears not to be based on generic functions, but on "sending" messages to objects.

Brian Harvey:

[Accusing Apple of elitism in distinguishing between Dylan as a tool for programmers and AppleScript as a tool for users]

One reason things have changed is the commercial reason that companies fear they can't make money on software if they provide source code. (It's not clear to me that this fear is well-grounded; the Unix source code is widely distributed and that doesn't stop AT&T making money.) But another reason is plain elitism as Apple corporate policy. Remember how on the original Macs if you wanted to be able to reboot your Mac without power cycling it you had to go down on your knees and convince Apple that you were *worthy* of being allowed to buy a "programmer's switch"?

Remember how in Hypercard there are five levels of intelligence built into the program's model of the user, and you have to type magic passwords to prove you're intelligent enough to be allowed to use HyperTalk? There is no commercial reason for this, just elitism. I'm sorry if this comes off as an irrelevant flame, but I think this question of whether you think your users can think or not is crucially important to the kind of world we technologists are going to build for the next generation. Apple puts a lot of effort into education, and I hate seeing that effort poisoned by this elitism that's at the heart of every technical decision they make.

I was really really pleased when HyperCard came out, because it was Apple's first grudging step toward tearing down the wall *they* had erected between programmers and users. But, in designing HyperTalk, why couldn't they have reinvented Logo, instead of reinventing Cobol?

Chris Espinosa:

I have to correct some of Brian Harvey's misunderstandings and misstatements about Apple's products and history. Unfortunately he uses these misunderstandings to make a point that Apple is elitist, when in fact our whole corporate history has been fighting elitism--the elitism of the belief that people SHOULD learn to program in order to use computers.

I have read recently that AT&T has sold USL to Novell, who does not distribute the source code to its products. I think the proprietary vs. "open" debate, while a good discussion in its own right, is not pertinent here. Proof of that is the extremely substantial amount of Apple II software that was written because that machine had AppleSoft BASIC in ROM, even though Microsoft's source code for it was not published. Good platforms attract programmers, open or not.

As a member of the team that developed the original Mac, what I remember is how we shipped a programmer's switch in every box. The reason that we didn't bring the reset and IRQ buttons out to the front is our experience with the Apple II, where people were accidentially resetting the machine, losing data and corrupting disks. By making it an option (available to everyone) to install the switch, we put the risk-versus-benefit choice in the hands of each individual user. At its worst you could call that paternalistic, but I think "elitist" is just plain wrong.

As the product manager who shipped HyperCard, I remember our decision to ship HyperCard to literally millions of people pre-set to allow them to browse and edit the stacks we supplied. By going to the Preferences card in the Home stack, they could turn on scripting ability. (No "magic password" was required for three years, when Claris divided the product into two versions, a "development" edition and a "browsing" edition. The "browsing" edition that was still given away free still had the full programming power. Now there's a separate HyperCard player that does not have the programming features--still given away free.) Brian's half-empty glass is that we "dumbed down" a programming environment. My half-full glass is that we gave millions of people who never considered programming the chance to get into it. Tens of thousands did. And those who didn't still had a useful tool.

I'm afraid that the issue is that Apple fundamentally believes in using technology to create products to sell to non-technologists. Brian equates the ability to program and read source code with being "able to think". That's the most elitist thing I've ever heard. I respect my customers because they have the ability to think about their jobs, their desires, and their inspirations without having to learn arcane computer languages to do so.

Making technology accessable to millions of not-technologists is the hardest thing we know how to do. I think Larry's analogy is excellent: Dylan is QuickDraw to AppleScript's MacDraw. They are not a class division; they are two points on a continuum, two different ways of satisfying different kind of people. I agree with you that the best thing would be to make a product that could grow smoothly from technologists to non-technologists, and that's also a hard thing to do (but very valuable). Meanwhile, I don't see anything elitist about delivering technology-oriented tools (like Dylan) to technologists, and productivity-oriented tools (like AppleScript) to non-technologists.

Bob Kerns:

[responding to Brian Harvey]

I will add that that in HyperTalk, we have a language which is "easy to learn", but can only be used effectivly by expert programmers! Only us elite programmers know the various tricks by which you can do such things as arrays, lookup tables, or objects representing domain abstractions. Not to mention the knowledge you need to make your code run acceptably fast!

Hypercard's strength lay in its interactivity and the fact that it's relatively easy to learn to do trivial things in HyperTalk when you want just a little more than what you can get with the interactive interface.

One of the Mac's strengths has been that you don't HAVEto program it to use it. However, one of its biggest failings has always been that if you want it to do a bit more than it does now, you have a huge barrier to cross, higher than almost any other system I can think of.

I have the impression that many in Apple think these two facts are somehow logical consequences of each other, but I strongly disagree.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

OmniOutliner Pro 4.2 - Pro version of th...
OmniOutliner Pro is a flexible program for creating, collecting, and organizing information. Give your creativity a kick start by using an application that's actually designed to help you think. It's... Read more
VLC Media Player 2.2.1 - Popular multime...
VLC Media Player is a highly portable multimedia player for various audio and video formats (MPEG-1, MPEG-2, MPEG-4, DivX, MP3, OGG, ...) as well as DVDs, VCDs, and various streaming protocols. It... Read more
Nisus Writer Pro 2.1.1 - Multilingual wo...
Nisus Writer Pro is a powerful multilingual word processor, similar to its entry level products, but brings new features such as table of contents, indexing, bookmarks, widow and orphan control,... Read more
Tinderbox 6.2.0 - Store and organize you...
Tinderbox is a personal content management assistant. It stores your notes, ideas, and plans. It can help you organize and understand them. And Tinderbox helps you share ideas through Web journals... Read more
OmniOutliner 4.2 - Organize your ideas,...
OmniOutliner is a flexible program for creating, collecting, and organizing information. Give your creativity a kick start by using an application that's actually designed to help you think. It's... Read more
Things 2.5.4 - Elegant personal task man...
Things is a task management solution that helps to organize your tasks in an elegant and intuitive way. Things combines powerful features with simplicity through the use of tags and its intelligent... Read more
NeoOffice 2014.10 - Mac-tailored, OpenOf...
NeoOffice is a complete office suite for OS X. With NeoOffice, users can view, edit, and save OpenOffice documents, PDF files, and most Microsoft Word, Excel, and PowerPoint documents. NeoOffice 3.x... Read more
iPhoto Library Manager 4.2 - Manage mult...
iPhoto Library Manager allows you to organize your photos among multiple iPhoto libraries, rather than having to store all of your photos in one giant library. You can browse the photos in all your... Read more
Web Snapper 3.3.8 - Capture entire Web p...
Web Snapper lets you capture Web pages exactly as they appear in your browser. You can send them to a file as images or vector-based, multi-page PDFs. It captures the whole Web page - eliminating the... Read more
TeamViewer 10.0.41404 - Establish remote...
TeamViewer gives you remote control of any computer or Mac over the Internet within seconds, or can be used for online meetings. Find out why more than 200 million users trust TeamViewer! Free for... Read more

Chainsaw Warrior: Lords of the Night has...
It's time to put the Darkness back in its place now that Chainsaw Warrior: Lords of the Night has officially made it to iOS. | Read more »
A World of Ice and Fire Lets You Stalk 2...
George R. R. Martin’s A World of Ice and Fire, by Random House, is a mobile guide to the epic series. The new update gives you the Journeys map feture that will let you track the movements of 25 different characters. But don't worry, you can protect... | Read more »
Gameloft Announces Battle Odyssey, a New...
Battle Odyssey, Gameloft's newest puzzle RPG, is coming to the App Store next week. Set in the world of Pondera, you will need to control the power of the elements to defend the world from evil. You'll be able to entlist over 500 allies to aid you... | Read more »
Fusion - HDR Camera (Photography)
Fusion - HDR Camera 1.0.0 Device: iOS Universal Category: Photography Price: $1.99, Version: 1.0.0 (iTunes) Description: Fusion creates HDR (high dynamic range) photos by capturing different exposures and then combining them into one... | Read more »
Sago Mini Toolbox (Education)
Sago Mini Toolbox 1.1 Device: iOS Universal Category: Education Price: $2.99, Version: 1.1 (iTunes) Description: Come build with the Sago Mini friends! Use a wrench, try a saw, or hammer some nails. From sewing hand puppets to... | Read more »
You Should Probably Grab Hitman GO While...
Hitman GO is a surprisingly cool (yet also incredibly drastic) departure from the Hitman series. It's well worth playing for any puzzle game fans out there, and at the moment you can get your hands - or garrotte if you will - on it for a mere $0.99... | Read more »
IFTTT is Bringing Do Button and Do Note...
IFTTT has announced Do Button and Do Note for the Apple Watch. Do Button lets you make your own personalized button that can connect to things like your Google Drive, control the temperature in your home with Nest Thermostat, or turn the lights on... | Read more »
How Many Days, Hours, and Minutes Are Le...
Countdown, by Yves Tscherry, is now available on the App Store. The app keeps track of countdowns to your favorite things such as someones birthday or days till the New Year. You can display the time in seconds, minutes, hours, days, weeks, months,... | Read more »
The All-New Misfit 2.0 App is Available...
Misfit has just given their app a complete overhaul. Misfit 2.0 now has a brand new interface with a sleek design and is easier to navigate. You'll be able to sync your Misfit device and look up health and fitness information faster than ever before... | Read more »
Halo: Spartan Strike (Games)
Halo: Spartan Strike 1.0 Device: iOS Universal Category: Games Price: $5.99, Version: 1.0 (iTunes) Description: Delve into 30 challenging missions through cities and jungles using a devastating arsenal of weapons, abilities and... | Read more »

Price Scanner via MacPrices.net

TigerText Introduces First Secure Enterprise...
TigerText, a provider of secure, real-time messaging for the enterprise, has announced the launch of TigerText for the Apple Watch. TigerText for the Apple Watch enables users to securely send and... Read more
The Conservation Fund Partners with Apple To...
The Conservation Fund has announced that it will partner with Apple to help protect working forests in the United States. The Apple initiative will conserve more than 36,000 acres of working... Read more
Clearance 13-inch 2.6GHz Retina MacBook Pro a...
B&H Photo has clearance 2014 13″ 2.6GHz/128GB Retina MacBook Pros now available for $1099, or $200 off original MSRP. Shipping is free, and B&H charges NY sales tax only. Read more
Apple refurbished 2014 13-inch Retina MacBook...
The Apple Store has Apple Certified Refurbished 2014 13″ Retina MacBook Pros available for up to $400 off original MSRP, starting at $979. An Apple one-year warranty is included with each model, and... Read more
iMacs on sale for up to $205 off MSRP, NY tax...
B&H Photo has 21″ and 27″ iMacs on sale for up to $205 off MSRP including free shipping plus NY sales tax only: - 21″ 1.4GHz iMac: $1019 $80 off - 21″ 2.7GHz iMac: $1189 $110 off - 21″ 2.9GHz... Read more
Sale! 16GB iPhone 5S for $1 with service
Best Buy is offering 16GB iPhone 5Ss for $1.00 with 2-year activation at a participating cellular provider. Choose free home shipping and activation, or buy online and activate during in-store pickup... Read more
Apple refurbished 2014 MacBook Airs available...
The Apple Store has Apple Certified Refurbished 2014 MacBook Airs available starting at $679. An Apple one-year warranty is included with each MacBook, and shipping is free. These are currently the... Read more
27-inch 3.5GHz 5K iMac on sale for $2349, sav...
 Adorama has the 27″ 3.5GHz 5K iMac in stock today and on sale for $2349 including free shipping plus NY & NJ sales tax only. Their price is $150 off MSRP. For a limited time, Adorama will... Read more
Save up to $380 on an iMac with Apple refurbi...
The Apple Store has Apple Certified Refurbished iMacs available for up to $380 off the cost of new models. Apple’s one-year warranty is standard, and shipping is free: - 27″ 3.5GHz 5K iMac – $2119 $... Read more
iFixIt Teardown Awards 12-IInch Retina MacBoo...
iFixIt has posted its illustrated teardown of the new 12-inch MacBook Retina. They note that this new MacBook is less than half the thickness of the last Apple notebook called just “MacBook” back in... Read more

Jobs Board

Sr. Payment Program Manager, *Apple* Pay -...
**Job Summary** Apple Pay is an exciting environment and a…devices in a simple, private and secure way. The Apple Pay Team is looking for an experienced Senior Read more
Marketing Program Manager, *Apple* Retail O...
**Job Summary** Imagine what you could do here. At Apple , great ideas have a way of becoming great products, services, and customer experiences very quickly. Bring Read more
Senior Manager, Business Development - *Appl...
**Job Summary** Apple Pay is seeking an experienced business development manager to support the identification, recruitment, negotiation and ongoing management of Read more
*Apple* Pay - Senior Software Engineer - App...
…delight? Do you have a natural curiosity for lea ing new technologies? The Apple Pay server engineering team wants to hear from you. **Key Qualifications** Architect and Read more
Engineering Manager, Search Relevance, *Appl...
Job Description: Job Summary. Apple 's new Spotlight Suggestions service provides fast, relevant search results from the Internet in Spotlight and Safari on iOS and OS X. Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.