• MacTech Network:
  • Tech Support
  • |
  • MacForge.net
  • |
  • Apple News
  • |
  • Register Domains
  • |
  • SSL Certificates
  • |
  • iPod Deals
  • |
  • Mac Deals
  • |
  • Mac Book Shelf

MAC TECH

  • Home
  • Magazine
    • About MacTech in Print
    • Issue Table of Contents
    • Subscribe
    • Risk Free Sample
    • Back Issues
    • MacTech DVD
  • Archives
    • MacTech Print Archives
    • MacMod
    • MacTutor
    • FrameWorks
    • develop
  • Forums
  • News
    • MacTech News
    • MacTech Blog
    • MacTech Reviews and KoolTools
    • Whitepapers, Screencasts, Videos and Books
    • News Scanner
    • Rumors Scanner
    • Documentation Scanner
    • Submit News or PR
    • MacTech News List
  • Store
  • Apple Expo
    • by Category
    • by Company
    • by Product
  • Job Board
  • Editorial
    • Submit News or PR
    • Writer's Kit
    • Editorial Staff
    • Editorial Calendar
  • Advertising
    • Benefits of MacTech
    • Mechanicals and Submission
    • Dates and Deadlines
    • Submit Apple Expo Entry
  • User
    • Register for Ongoing Raffles
    • Register new user
    • Edit User Settings
    • Logout
  • Contact
    • Customer Service
    • Webmaster Feedback
    • Submit News or PR
    • Suggest an article
  • Connect Tools
    • MacTech Live Podcast
    • RSS Feeds
    • Twitter

Moving from Microsoft Office VBA to AppleScript:
MacTech's Guide to Making the Transition

Introduction  |  Table of Contents

Page Prev and Page Next buttons at bottom of the page.

Would you like a hard copy
or PDF of this Guide?

You can get a hard copy sent to you
AND download a PDF now ($19.95)
, or

... just download a PDF ($9.95).

Either way, you get a complimentary
MacTech Magazine Subscription

courtesy of the
Microsoft Mac Business Unit


 

  Magazine Reg. Price:  $50.00 value  
  Guide Reg. Price:  $40.00 value  
  You Save:  over $80.00!  

April, 2007
Page 8



end tell

That, of course, is very similar to VBA's With-End With blocks, discussed in more detail below.

Here‘s the place to mention a "gotcha": just sometimes those chains of "ofs" (or apostrophe-s‘s, or tells) don‘t work, for no apparent reason: occasionally the developers have forgotten to implement the "implicit get" and you need to use an "explicit get" for one of the deeper 'of' properties:

tell application "Microsoft Word"

    tell active document

        tell text object

            tell find object

               set content to "blue"

               set forward to true

               execute find

            end tell

        end tell

    end tell

end tell
--> false

whereas:

tell application "Microsoft Word"

    tell active document

        tell text object

            tell (get find object) -- crucial!

               set content to "blue"

               set forward to true

               execute find

            end tell

        end tell

    end tell

end tell
--> true

In most applications, when this happens, the absence of an explicit get, when needed, results in an error: this can be perplexing, but at least you know something is wrong. Here you get an incorrect result, which is worse. But it‘s very rare in Word (more common recently in Entourage, especially among the new Exchange properties, where you‘ll get either an error or missing value as a result, without get.) When in doubt, throw in a get.

One more "gotcha" that scripters familiar with VBA, or just about any language but AppleScript, tend to keep stumbling on, even when they know better: in AppleScript, the = sign is not used as an assignment operator (the implicit Let Method in VBA):

     someVariable = "text"

In AppleScript, the = sign is used only as an equality comparison operator:

   if someVariable = "text" then …

To assign a value to a variable, you must use set…to:

   set someVariable to "text"

Also note that, unlike in VBA, there is no difference in the syntax whether you are assigning a basic type like string or integer to the variable, or an application object: you always use set.

Subs and Handlers

In a VBA macro, every line of code is in a Sub or Function. Even if there‘s only one simple procedure in the macro, it has to be in a named Sub Whatever(). In AppleScript, the equivalent "one simple procedure" is the top-level of the script, not in a handler (subroutine).

Actually, as the AppleScript books will tell you, the top level is an implicit 'run' handler, and you can make it explicit if you want by encasing it all in an on run/end run block. But there‘s almost never a reason for doing so, and almost no one ever does. There is only one rare situation where it is necessary: If you are loading and calling the script from another, external, script and need to pass it arguments. Normally, this would be done by calling a subroutine, but there are some rare circumstances – usually from an application, shell or Internet contexts outside AppleScript itself – that can only run a script, not call individual subroutines.



< Previous Page Next Page>
 
MacTech Only Search:
Community Search:

 
 
 

 
 
 
 
 
  • SPREAD THE WORD:
  • Slashdot
  • Digg
  • Del.icio.us
  • Reddit
  • Newsvine
  • Generate a short URL for this page:



MacTech Magazine. www.mactech.com
Toll Free 877-MACTECH, Outside US/Canada: 805-494-9797
MacTech is a registered trademark of Xplain Corporation. Xplain, "The journal of Apple technology", Apple Expo, Explain It, MacDev, MacDev-1, THINK Reference, NetProfessional, Apple Expo, MacTech Central, MacTech Domains, MacNews, MacForge, and the MacTutorMan are trademarks or service marks of Xplain Corporation. Sprocket is a registered trademark of eSprocket Corporation. Other trademarks and copyrights appearing in this printing or software remain the property of their respective holders.
All contents are Copyright 1984-2010 by Xplain Corporation. All rights reserved. Theme designed by Icreon.
 
Nov. 20: Take Control of Syncing Data in Sow Leopard' released
Nov. 19: Cocktail 4.5 (Leopard Edition) released
Nov. 19: macProVideo offers new Cubase tutorials
Nov. 18: S Stardom anounces Safe Capsule, a companion piece for Apple's
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live
Nov. 17: Ableton releases Max for Live