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

Cyberduck 4.7.1 - FTP and SFTP browser....
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
PDFpen 7.2 - Edit and annotate PDFs with...
We're also offering PDFpenPro for 30% off! PDFpen allows users to easily edit PDF's. Add text, images and signatures. Fill out PDF forms. Merge or split PDF documents. Reorder and delete pages. Even... Read more
Skype 7.9.746 - Voice-over-internet phon...
Skype allows you to talk to friends, family and co-workers across the Internet without the inconvenience of long distance telephone charges. Using peer-to-peer data transmission technology, Skype... Read more
Apple GarageBand 10.1 - Complete recordi...
The new GarageBand is a whole music creation studio right inside your Mac -- complete with keyboard, synths, orchestral and percussion instruments, presets for guitar and voice, an entirely... Read more
Duplicate Annihilator 5.7.7 - Find and d...
Duplicate Annihilator takes on the time-consuming task of comparing the images in your iPhoto library using effective algorithms to make sure that no duplicate escapes. Duplicate Annihilator... Read more
OS X Server 4.1.3 - For OS X 10.10 Yosem...
Designed for OS X and iOS devices, OS X Server makes it easy to share files, schedule meetings, synchronize contacts, develop software, host your own website, publish wikis, configure Mac, iPhone,... Read more
Firefox 39.0 - Fast, safe Web browser. (...
Firefox offers a fast, safe Web browsing experience. Browse quickly, securely, and effortlessly. With its industry-leading features, Firefox is the choice of Web development professionals and casual... Read more
pwSafe 4.1 - Secure password management...
pwSafe provides simple and secure password management across devices and computers. pwSafe uses iCloud to keep your password databases backed-up and synced between Macs and iOS devices. It is... Read more
Kodi 15.0.rc1 - Powerful media center to...
Kodi (was XBMC) is an award-winning free and open-source (GPL) software media player and entertainment hub that can be installed on Linux, OS X, Windows, iOS, and Android, featuring a 10-foot user... Read more
Coda 2.5.11 - One-window Web development...
Coda is a powerful Web editor that puts everything in one place. An editor. Terminal. CSS. Files. With Coda 2, we went beyond expectations. With loads of new, much-requested features, a few surprises... Read more

This Week at 148Apps: June 29-July 3, 20...
Into July With 148Apps How do you know what apps are worth your time and money? Just look to the review team at 148Apps. We sort through the chaos and find the apps you're looking for. The ones we love become Editor’s Choice, standing out above the... | Read more »
Sonic Runners Guide
Despite its flaws, Sonic Runners' platforming action is actually quite fun. Though it can be a little more complicated than old-school Sonic games. Here's how to make sure you're up to speed when jumping in. [Read more] | Read more »
Rage of Bahamut is Giving Almost All of...
The App Store isn't what it used to be back in 2012, so it's not unexpected to see some games changing their structures with the times. Now we can add Rage of Bahamut to that list with the recent announcement that the game is severely cutting back... | Read more »
Adventures of Pip (Games)
Adventures of Pip 1.0 Device: iOS iPhone Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: ** ONE WEEK ONLY — 66% OFF! *** “Adventures of Pip is a delightful little platformer full of charm, challenge and impeccable... | Read more »
Divide By Sheep - Tips, Tricks, and Stre...
Who would have thought splitting up sheep could be so involved? Anyone who’s played Divide by Sheep, that’s who! While we’re not about to give you complete solutions to everything (because that’s just cheating), we will happily give you some... | Read more »
NaturalMotion and Zynga Have Started Tea...
An official sequel to 2012's CSR Racing is officially on the way, with Zynga and NaturalMotion releasing a short teaser trailer to get everyone excited. Well, as excited as one can get from a trailer with no gameplay footage, anyway. [Read more] | Read more »
Grab a Friend and Pick up Overkill 3, Be...
Overkill 3 is a pretty enjoyable third-person shooter that was sort of begging for some online multiplayer. Fortunately the begging can stop, because its newest update has added an online co-op mode. [Read more] | Read more »
Scanner Pro's Newest Update Adds Au...
Scanner Pro is one of the most popular document scanning apps on iOS, thanks in no small part to its near-constant updates, I'm sure. Now we're up to update number six, and it adds some pretty handy new features. [Read more] | Read more »
Heroki (Games)
Heroki 1.0 Device: iOS Universal Category: Games Price: $7.99, Version: 1.0 (iTunes) Description: CLEAR THE SKIES FOR A NEW HERO!The peaceful sky village of Levantia is in danger! The dastardly Dr. N. Forchin and his accomplice,... | Read more »
Wars of the Roses (Games)
Wars of the Roses 1.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: | Read more »

Price Scanner via MacPrices.net

Apple refurbished Mac minis available startin...
The Apple Store has Apple Certified Refurbished 2014 Mac minis available starting at $419. Apple’s one-year warranty is included with each mini, and shipping is free: - 1.4GHz Mac mini: $419 $80 off... Read more
College Student Deals: Additional $100 off Ma...
Take an additional $100 off all MacBooks and iMacs at Best Buy Online with their College Students Deals Savings, valid through August 8, 2015. Anyone with a valid .EDU email address can take... Read more
Sky Atlas Star Walk 2 App For iPhone And iPa...
Vito Technology, developer of educational apps for Android and iOS, is for a limited time offering free of charge their Star Walk 2, the next generation of the company’s best-selling stargazing guide... Read more
13-inch 1.6GHz MacBook Air on sale for $849,...
Amazon has the 2015 13″ 1.6GHz/128GB MacBook Air on sale for $849.99 including free shipping. Their price is $150 off MSRP, and it’s the lowest price available for this model. Read more
13-inch 2.5GHz MacBook Pro on sale 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
Updated Mac Price Trackers
We’ve updated our Mac Price Trackers with the latest information on prices, bundles, and availability on systems from Apple’s authorized internet/catalog resellers: - 15″ MacBook Pros - 13″ MacBook... Read more
15-inch Retina MacBook Pros on sale for up to...
B&H Photo has new 2015 15″ Retina MacBook Pros on sale for up to $225 off MSRP including free shipping plus NY sales tax only: - 15″ 2.2GHz Retina MacBook Pro: $1819 $180 off - 15″ 2.5GHz Retina... Read more
RamDisk4Mac App Helps Run Your Mac Faster And...
Ever use a RAM disk? If you’ve come to the Mac in the OS X era, likely not. The Classic Mac OS had a RAM disk function built-in, but that was dropped in the conversion to OS X. What is a RAM disk?... Read more
13-inch 1.6GHz MacBook Air on sale for $849,...
Best Buy has the 2015 13″ 1.6GHz/128GB MacBook Air on sale for $849.99 on their online store this weekend. Choose free shipping or free local store pickup (if available). Sale price for online orders... Read more
Apple Refurbished iMacs available for up to $...
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 – $1949 $... Read more

Jobs Board

*Apple* Solutions Consultant - Retail Sales...
**Job Summary** As an Apple Solutions Consultant (ASC) you are the link between our customers and our products. Your role is to drive the Apple business in a retail Read more
Senior Payments Security Manager - *Apple*...
**Job Summary** Apple , Inc. is looking for a highly motivated, innovative and hands-on senior payments security manager to join the Apple Pay security team. You will Read more
Sr. Technical Services Consultant, *Apple*...
**Job Summary** Apple Professional Services (APS) has an opening for a senior technical position that contributes to Apple 's efforts for strategic and transactional Read more
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
Project Manager - *Apple* Pay Security - Ap...
**Job Summary** The Apple Pay Security team is seeking a highly organized, results-driven Project Manager to drive the development of Apple Pay Security. If you are Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.