(lisppad applescript)
Library (lisppad applescript)
exports procedures for invoking Automator workflows and AppleScript scripts and subroutines from Scheme code. Since LispPad runs in a sandbox and scripts and subroutines are executed outside of the sandbox, this will enable direct integrations with other macOS applications supporting AppleScript or Automator such as Mail, Safari, Music, etc.
Script authorization
The script authorization mechanism of macOS is unfortunately a bit cumbersome, requiring the installation of the Automator and AppleScript files in a particular directory specifically for LispPad. (system-directory 'application-scripts)
returns a list of directories in which scripts are accessible by LispPad. This includes typically the directory:
This directory can be opened on macOS's Finder via:
Scripts need to be copied to this directory.
Script integration
As an example, the following script defines two AppleScript subroutines safariFrontURL
and setSafariFrontURL
. The AppleScript code also displays an error if the script is run overall as its only role is to make subroutines accessible to LispPad. Such scripts are written using Apple's Script Editor application and need to be stored in a directory accesible by LispPad as explained above.
Assuming that the script was saved in a file at path:
it is now possible to load the script via procedure applescript
into an AppleScript object from which the various subroutines can be accessed:
It is possible to run the whole script via procedure execute-applescript
:
The execution of scripts is always synchronous, so the procedure call to execute-applescript
terminates only when the execution of the script terminates. When executed, the script above will always display an alert since it was not made to be executed.
It is not possible to pass parameters via execute-applescript
or receive results. This can be achieved by calling subroutines with procedure apply-applescript-proc
. The following code will invoke subroutine safariFrontURL
from the script above and return the URL of the current frontmost Safari window:
The third argument of procedure apply-applescript-proc
is a list of parameters for the subroutine. The following code will set the URL of the frontmost Safari window to "http://lisppad.objecthub.net".
Library (lisppad applescript)
provides a means to quickly create Scheme functions matching AppleScript subroutines. This is shown in the following code:
Marshaling data
This is how library (lisppad applescript)
is marshaling/unmarshaling data when data is exchanged between Scheme and AppleScript:
void
null
boolean
boolean
fixnum
int32
flonum
double
proper list
list
string
unicode text
date-time
date
If other data is attempted to be exchanged, it might lead to failure.
API
Returns #t
if obj is an AppleScript object, #f
otherwise.
Loads and compiles the AppleScript file at path returning an AppleScript object that can be used to execute the script or subroutines defined by the script.
Returns the file path from which the AppleScript object script was created.
Executes the given AppleScript script. The execution is synchronous and execute-applescript
will only return once script has been executed.
Invokes the subroutine name defined by AppleScript script with the arguments args. name is a string, script is an AppleScript object, and args is a list of arguments passed on to the subroutine. apply-applescript-proc
returns the result returned by the subroutine, i.e. the execution of the subroutine is synchronous.
Returns a Scheme procedure for subroutine name defined in AppleScript script. name is a string and script is an AppleScript object. applescript-proc
is defined in the following way:
Last updated