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

WhiteCap 6.6 - Visual plug-in for iTunes...
WhiteCap is a sleek and sophisticated music visualizer and screensaver that features futuristic, wireframe mesh visuals with dynamic backgrounds and colors. WhiteCap contains thousands of visual... Read more
VueScan 9.5.65 - Scanner software with a...
VueScan is a scanning program that works with most high-quality flatbed and film scanners to produce scans that have excellent color fidelity and color balance. VueScan is easy to use, and has... Read more
Carbon Copy Cloner 4.1.13 - Easy-to-use...
Carbon Copy Cloner backups are better than ordinary backups. Suppose the unthinkable happens while you're under deadline to finish a project: your Mac is unresponsive and all you hear is an ominous,... Read more
TrailRunner 3.8.831 - Route planning for...
TrailRunner is the perfect companion for runners, bikers, hikers, and all people wandering under the sky. Plan routes on a geographical map. Import GPS or workout recordings and journalize your... Read more
Quicken 4.4.2 - Complete personal financ...
Quicken makes managing your money easier than ever. Whether paying bills, upgrading from Windows, enjoying more reliable downloads, or getting expert product help, Quicken's new and improved features... Read more
Adobe Illustrator CC 2017 21.0.2 - Profe...
Illustrator CC 2017 is available as part of Adobe Creative Cloud for as little as $19.99/month (or $9.99/month if you're a previous Illustrator customer). Adobe Illustrator CC 2017 is the industry... Read more
Paparazzi! 1.0b2 - Make user-defined siz...
Paparazzi! is a small utility for OS X that makes screenshots of webpages. This very simple tool takes screenshots of websites which do not fit on one screen. You specify the desired width, minimal... Read more
Monodraw 1.2.1 - Powerful ASCII art edit...
Monodraw allows you to easily create text-based art (like diagrams, layouts, flow charts) and visually represent algorithms, data structures, binary formats and more. Because it's all just text, it... Read more
Monodraw 1.2.1 - Powerful ASCII art edit...
Monodraw allows you to easily create text-based art (like diagrams, layouts, flow charts) and visually represent algorithms, data structures, binary formats and more. Because it's all just text, it... Read more
Iridient Developer 3.1.3 - Powerful imag...
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

ROME: Total War - Barbarian Invasion set...
To the delight of mobile strategy fans, Feral Interactive released ROME: Total War just a few months ago. Now the game's expansion, Barbarian Invasion is marching onto iPads as a standalone release. [Read more] | Read more »
Yuri (Games)
Yuri 1.0 Device: iOS iPhone Category: Games Price: $3.99, Version: 1.0 (iTunes) Description: It's night. Yuri opens his eyes. He wakes up in a strange forest.The small, courageous explorer rides on his bed on casters in this... | Read more »
Space schmup Xenoraid launches on the Ap...
10Tons Xenoraid is out today on the App Store, bringing some high-speed space action to your mobile gadgets just in time for the weekend. The company's last premium title, another sci-fi game titled Neon Chrome, did quite well for itself, so... | Read more »
Star Wars: Force Arena Beginner's G...
Star Wars: Force Arena joined the populous ranks of Star Wars games on mobile today. It's a two-lane MOBA starring many familiar faces from George Lucas's famed sci-fi franchise. As with most games of this nature, Force Arena can be a little obtuse... | Read more »
Mysterium: The Board Game (Games)
Mysterium: The Board Game 1.0 Device: iOS Universal Category: Games Price: $6.99, Version: 1.0 (iTunes) Description: The official adaptation of the famous board game Mysterium! | Read more »
Sonny (Games)
Sonny 1.0.4 Device: iOS Universal Category: Games Price: $2.99, Version: 1.0.4 (iTunes) Description: Reimagined for iOS, cult-hit RPG Sonny brings challenging turn-based combat that requires strategy and mastery of each new skill to... | Read more »
Towaga (Games)
Towaga 1.0 Device: iOS iPhone Category: Games Price: $2.99, Version: 1.0 (iTunes) Description: "It has been foretold that a masked being would stand atop the legendary Towaga Temple, dwelling among shadows to fulfil The Black Moon... | Read more »
Bubble Witch 3 Saga Guide: How to get th...
King's bringing its fairytale bubble-popping puzzler back for its 3rd outing in Bubble Witch 3 Saga. If you're familiar with the series, not much has changed here on the surface level, though you'll likely be pleased with the improvements. If you'... | Read more »
Sunless Sea sails onto iPad this spring
Failbetter Games, the folks who brought you Fallen London, are celebrating their 7th birthday today. To commemorate the event, the team revealed that Sunless Sea is coming to iPad this spring. | Read more »
The Binding of Isaac: Rebirth (Games)
The Binding of Isaac: Rebirth 1.1 Device: iOS Universal Category: Games Price: $14.99, Version: 1.1 (iTunes) Description: Gameplay | Read more »

Price Scanner via MacPrices.net

13-inch 1.6GHz/128GB MacBook Air on sale for...
Overstock.com has the 1.6GHz/128GB 13″ MacBook Air on sale for $130 off MSRP including free shipping: - 13″ 1.6GHz/128GB MacBook Air (MMGF2LL/A): $869.99 $130 off MSRP Their price is the lowest... Read more
12-inch 32GB Space Gray iPad Pro on sale for...
B&H Photo has 12″ Space Gray 32GB WiFi Apple iPad Pros on sale for $55 off MSRP including free shipping. B&H charges sales tax in NY only: - 12″ Space Gray 32GB WiFi iPad Pro: $744.44 $55 off... Read more
9-inch 32GB Space Gray iPad Pro on sale for $...
B&H Photo has the 9.7″ 32GB Space Gray Apple iPad Pro on sale for $549 for a limited time. Shipping is free, and B&H charges NY sales tax only. Read more
Apple iMacs on sale for up to $120 off MSRP,...
B&H Photo has 21″ and 27″ Apple iMacs on sale for up to $120 off MSRP, each including free shipping plus NY sales tax only: - 27″ 3.3GHz iMac 5K: $2199 $100 off MSRP - 27″ 3.2GHz/1TB Fusion iMac... Read more
Apple refurbished Apple TVs available for up...
Apple has Certified Refurbished 32GB and 64GB Apple TVs available for up to $30 off the cost of new models. Apple’s standard one-year warranty is included with each model, and shipping is free: -... Read more
1.4GHz Mac mini, refurbished, available for $...
The Apple Store has Apple Certified Refurbished 1.4GHz Mac minis available for $419. Apple’s one-year warranty is included, and shipping is free. Their price is $80 off MSRP, and it’s the lowest... Read more
16GB iPad Air 2, Apple refurbished, available...
Apple has Certified Refurbished 16GB iPad Air 2s available for $319 including free shipping. A standard Apple one-year is included. Their price is $60 off original MSRP for this model. Read more
Mac Pros on sale for $200 off MSRP, refurbish...
B&H Photo has Mac Pros on sale for $200 off MSRP. Shipping is free, and B&H charges sales tax in NY only: - 3.7GHz 4-core Mac Pro: $2799, $200 off MSRP - 3.5GHz 6-core Mac Pro: $3799, $200... Read more
Save with Apple refurbished iPad Pros, models...
Apple has Certified Refurbished 9″ and 12″ Apple iPad Pros available for up to $160 off the cost of new iPads. An Apple one-year warranty is included with each model, and shipping is free: - 32GB 9″... Read more
Amazon drops 12-inch Retina MacBook prices to...
Amazon has 2016 12″ Apple Retina MacBooks on sale for $300 off MSRP for a limited time. Shipping is free. The following configurations are available: - 12″ 1.1GHz Silver Retina MacBook: $999.99 $300... Read more

Jobs Board

*Apple* & PC Desktop Support Technician...
Apple & PC Desktop Support Technician job in Los Angeles, CA Introduction: We have immediate job openings for several Desktop Support Technicians with one of our Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Premier Retailer - PT Service Specia...
DescriptionSimply Mac is the largest premier retailer for Apple products and solutions. At Simply Mac we are all Apple , all the time. Same products. Same prices. Read more
*Apple* Premier Retailer - Service Manager -...
DescriptionSimply Mac is the largest premier retailer for Apple products and solutions. At Simply Mac we are all Apple , all the time. Same products. Same prices. Read more
*Apple* Solutions Consultant - Apple (United...
# Apple Solutions Consultant Job Number: 54267729 Altamonte Springs, Florida, United States Posted: Jan. 6, 2017 Weekly Hours: 40.00 **Job Summary** As an Apple Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.