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

Vivaldi 1.10.867.48 - An advanced browse...
Vivaldi is a browser for our friends. 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... Read more
EarthDesk 7.2 - Striking real-time anima...
EarthDesk replaces your static desktop picture with a rendered image of Earth showing correct sun, moon, and city illumination. With an Internet connection, EarthDesk displays near-real-time global... Read more
Fission 2.3.2 - Streamlined audio editor...
Fission can crop and trim audio, paste in or join files, or just rapidly split one long file into many. It's streamlined for fast editing. Plus, it works without the quality loss caused by other... Read more
Drive Genius 5.0.3 - Powerful system uti...
Drive Genius gives you faster performance from your Mac while also protecting it. The award-winning and improved DrivePulse feature alerts you to hard drive issues before they become major problems.... Read more
iDefrag 5.2.0 - Disk defragmentation and...
iDefrag helps defragment and optimize your disk for improved performance. iDefrag Features Supports HFS and HFS+ (Mac OS Extended). Supports case sensitive and journaled filesystems. Supports... Read more
Things 3.1.1 - 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
GraphicConverter 10.4.3 - $39.95
GraphicConverter is an all-purpose image-editing program that can import 200 different graphic-based formats, edit the image, and export it to any of 80 available file formats. The high-end editing... Read more
Google Chrome 60.0.3112.78 - Modern and...
Google Chrome is a Web browser by Google, created to be a modern platform for Web pages and applications. It utilizes very fast loading of Web pages and has a V8 engine, which is a custom built... Read more
PDFpenPro 9.1 - Advanced PDF toolkit for...
PDFpenPro allows users to edit PDF's easily. Add text, images and signatures. Fill out PDF forms. Merge or split PDF documents. Reorder and delete pages. Create fillable forms and tables of content... Read more
PDFpen 9.1 - $74.95
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 correct text and edit graphics! Features... Read more

Latest Forum Discussions

See All

The 5 best life-saving apps for dog owne...
While it's true that dogs are man's best friend, they're also a pretty big responsibility. We want to give our dogs the best lives, but with busy schedules that's not always easy. Luckily, though, there are a bunch of quality apps out there that... | Read more »
Mix and match magical brews in Miracle M...
Miracle Merchant, the charming fantasy card game by Tiny Touch Tales, is arriving next week. The development team, which also brought you Card Crawl and Card Thief, announced the game's launch with a pleasant little trailer that showcases the game'... | Read more »
Last Day on Earth: Zombie Survival guide...
Last Day on Earth: Zombie Survival is the latest big hit in the survival game craze. The gist of the game is pretty cut and dry -- try your best to survive in a world overrun by flesh-eating zombies. But Last Day on Earth justifies the hype... | Read more »
Eden: Renaissance (Games)
Eden: Renaissance 1.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: Eden: Renaissance is a thrilling turn-based puzzle adventure set in a luxurious world, offering a deep and moving... | Read more »
Glyph Quest Chronicles guide - how to ma...
Glyph Quest returns with a new free-to-play game, Glyph Quest Chronicles. Chronicles offers up more of the light-hearted, good humored fantasy fun that previous games featured, but with a few more refined tricks up its sleeve. It's a clever mix of... | Read more »
Catch yourself a Lugia and Articuno in P...
Pokémon Go Fest may have been a bit of a disaster, with Niantic offering fans full refunds and $100 worth of in-game curency to apologize for the failed event, but that hasn't ruined trainers' chances of catching new legendary Pokémon. Lugia nad... | Read more »
The best deals on the App Store this wee...
There are quite a few truly superb games on sale on the App Store this week. If you haven't played some of these, many of which are true classics, now's the time to jump on the bandwagon. Here are the deals you need to know about. [Read more] | Read more »
Realpolitiks Mobile (Games)
Realpolitiks Mobile 1.0 Device: iOS Universal Category: Games Price: $5.99, Version: 1.0 (iTunes) Description: PLEASE NOTE: The game might not work properly on discontinued 1GB of RAM devices (iPhone 5s, iPhone 6, iPhone 6 Plus, iPad... | Read more »
Layton’s Mystery Journey (Games)
Layton’s Mystery Journey 1.0.0 Device: iOS Universal Category: Games Price: $15.99, Version: 1.0.0 (iTunes) Description: THE MUCH-LOVED LAYTON SERIES IS BACK WITH A 10TH ANNIVERSARY INSTALLMENT! Developed by LEVEL-5, LAYTON’S... | Read more »
Full Throttle Remastered (Games)
Full Throttle Remastered 1.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: Originally released by LucasArts in 1995, Full Throttle is a classic graphic adventure game from industry legend Tim... | Read more »

Price Scanner via MacPrices.net

Photographer Explains Choosing Dell Laptop Ov...
Last week photographer and video blogger Manny Ortiz posted a video explaining the five most important reasons he settled on a Dell XPS 15 laptop instead of a MacBook Pro for his latest portable... Read more
Sale! 10-inch iPad Pros for $50 off MSRP, no...
B&H Photo has 64GB and 256GB 10.5″ iPad Pros in stock today and on sale for $50 off MSRP. Each iPad includes free shipping, and B&H charges sales tax in NY & NJ only: – 10.5″ 64GB iPad... Read more
WaterField Designs Upgrades TSA-friendly Zip...
San Francisco based designer and manufacturer Waterfield Designs has unveiled an upgraded and refined Zip Brief. Ideal for the minimalist professional, the ultra-slim Zip laptop bag actually holds a... Read more
USB 3.0 Promoter Group Announces USB 3.2 Upda...
The USB 3.0 Promoter Group has announced the pending release of the USB 3.2 specification, an incremental update that defines multi-lane operation for new USB 3.2 hosts and devices. USB Developer... Read more
Save on MacBook Pros with Apple Refurbished 2...
Apple recently dropped prices on Certified Refurbished 2016 15″ and 13″ MacBook Pros with models now as much as $590 off original MSRP. An Apple one-year warranty is included with each model, and... Read more
13-inch 2.3GHz/256GB MacBook Pros on sale for...
B&H Photo has 13″ 2.3GHz/256GB MacBook Pros in stock today and on sale for $100 off MSRP including free shipping plus NY & NJ sales tax only: – 13-inch 2.3GHz/256GB Space Gray MacBook Pro (... Read more
Clearance 2016 13-inch MacBook Airs, Apple re...
Apple has Certified Refurbished 2016 13″ MacBook Airs available starting at $809. An Apple one-year warranty is included with each MacBook, and shipping is free: – 13″ 1.6GHz/8GB/128GB MacBook Air: $... Read more
PHOOZY World’s First Thermal Capsules to Summ...
Summer days spent soaking up the sun can be tough on smartphones, causing higher battery consumption and overheating. To solve this problem, eXclaim IP, LLC has introduced the PHOOZY Thermal Capsule... Read more
2018 Honda Ridgeline with Android Auto and Ap...
The 2018 Honda Ridgeline is arriving in dealerships nationwide with a Manufacturer’s Suggested Retail Price (MSRP1) starting at $29,630. The 2017 Honda Ridgeline was named North American Truck of the... Read more
comScore Ranks Top 15 U.S. Smartphone Apps fo...
comScore, Inc. recently released data from comScore Mobile Metrix, reporting the top smartphone apps in the U.S. by audience reach for June 2017. * “Apple Music,” as it appears in comScore’s monthly... Read more

Jobs Board

Frameworks Engineering Manager, *Apple* Wat...
Frameworks Engineering Manager, Apple Watch Job Number: 41632321 Santa Clara Valley, California, United States Posted: Jun. 15, 2017 Weekly Hours: 40.00 Job Summary Read more
*Apple* Solutions Consultant (ASC) - Poole -...
Job Summary The people here at Apple don't just create products - they create the kind of wonder that's revolutionised entire industries. It's the diversity of those Read more
SW Engineer *Apple* TV - Apple Inc. (United...
Changing the world is all in a day's work at Apple . If you love innovation, here's your chance to make a career of it. You'll work hard. But the job comes with more Read more
Frameworks Engineering Manager, *Apple* Wat...
Frameworks Engineering Manager, Apple Watch Job Number: 41632321 Santa Clara Valley, California, United States Posted: Jun. 15, 2017 Weekly Hours: 40.00 Job Summary Read more
Product Manager - *Apple* Pay on the *Appl...
Job Summary Apple is looking for a talented product manager to drive the expansion of Apple Pay on the Apple Online Store. This position includes a unique Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.