昨日作ったAppleScriptライブラリ「checkboxLib」をアップデートしてみました。
–> Download checkboxLib_v2.scptd(To ~/Library/Script Libraries)
JXAからの呼び出しに対応(1)〜data typeの記述を正しく
昨日のバージョンは問題が見つかっていました。AppleScriptから呼び出す分には問題がなかったのですが、JXAから呼び出すとエラーになっていました。
sdef(AppleScript用語辞書)をつけたライブラリは、AppleScriptで記述しつつも従来のOSAXのような運用が可能で、とりわけ他のOSA言語からも使える共有モジュールとして運用できる点が重要です。
今日明日ですぐに必要になるわけではありませんが、AppleScriptで記述したライブラリにsdefさえ添付しておけば、JXA側からも呼び出せる共有モジュールとして運用できる「ことになっています」。それがOSA(Open Scripting Architecture)上でのAppleScript Librariesの設計思想です。
そのため、JXA側からの呼び出しもテストしていたのですが、なかなかお題目どおりには行かず、ちょっとMacScripter.netのBBSで相談して、対処を行ってみました。
sdefを書くにあたっては、既存のアプリケーションの膨大なsdefのストックがあるので、それを参考にしていました(たまに記述が間違っているものがあって困ります)。
その中で、データタイプにAppleScriptでしか利用できない「list」というタイプを指定していたのが問題でした。つまり、AppleScript側からの呼び出しだけで検証していては、AppleScriptからの呼び出し時だけ正常に動く「バグ」を抱えたままの状態である可能性を否定できません。他のOSA言語からの呼び出しも検証しておかないと、潜在バグのあぶり出しが行えません。
<parameter name="with titles" type="list" code="COLL" description="Titles of every path"/>
これをShaneのアドバイスどおりに書き換えて、
<parameter name="with titles" code="COLL" description="Titles of every checkbox"> <type type="text" list="yes"/> </parameter>
と、修正。これで、JXA側からも呼び出せるようになりました。
AppleScript名:check box sample 4_e |
— Created 2019-08-12 by Takaaki Naganoya — 2019 Piyomaru Software use AppleScript version "2.5" use scripting additions use checkLib : script "checkboxLib" set tList to {"Carrot", "Burdock", "Radish", "Apple", "Cabbage", "Lettuce", "Potato", "Garlic", "Komatsuna", "Bok choy", "Shiitake mushroom", "Hen of the Woods"} set cRes to choose checkbox main message "Select Vegetables" sub message "Select vegetables you like" with columns 2 with titles tList checkbox type standard return type data |
JavaScript名:sample_jxa_4 |
// Created 2019-08-12 by Takaaki Naganoya // 2019 Piyomaru Software var app = Application.currentApplication() app.includeStandardAdditions = true var alib = Library("checkboxLib") var array = ["Carrot", "Burdock", "Radish", "Apple", "Cabbage", "Lettuce", "Potato", "Garlic", "komatsuna", "Bok choy", " Shiitake mushroom", "Hen of the Woods"] alib.chooseCheckbox( subMessage:"Select vegetables you like", withColumns:2, withTitles:array, checkboxType:"standard", returnType:"item number" } ) |
JXAからの呼び出しに対応(2)〜enumをそのまま処理しない
とりあえず予定していた機能は実現できたわけですが、sdefにenum(定数)を定義して使ってみたくなりました。パラメータをダイレクトパラメータ(文字列、数字など)のみで指定するだけは不満が出てきそうです。
かくして、「こんな感じかな?」と手探りでenumを定義してみたのですが、例によってAppleScript側ではエラーにならないのに、JXA側ではエラーになりました。
結局、ライブラリ側のパラメータ受信部分でenumをそのまま処理せず、いったん文字列に変換して処理するようにしてみました。
いずれも、AppleScript側だけだとエラーになりませんでしたが、JXA側からの呼び出しもできるようにしておけば、他のOSA言語やObjective-C/Swiftなどの言語からの呼び出し時にも問題が出ないことでしょう。現状でJXAの存在意義はその程度です。
JXAからのライブラリ呼び出しについては、現行バージョンでもパラメータの省略時にエラーが出るのですが、「パラメータの省略はできないもの」と割り切っても問題はなさそうです。
最終的にsdefは上記(↑)のようになりました。enumの宣言部分の書き方がこなれていなかったので、その部分を修正。このsdefをスクリプトエディタでレンダリングすると、このようになります。
■参考文献リンク
Technical Note TN2106 Scripting Interface Guidelines