「
WSOFTScriptからの移行
」を編集中
ナビゲーションに移動
検索に移動
警告:
ログインしていません。編集を行うと、あなたの IP アドレスが公開されます。
ログイン
または
アカウントを作成
すれば、あなたの編集はその利用者名とともに表示されるほか、その他の利点もあります。
スパム攻撃防止用のチェックです。 決して、ここには、値の入力は
しない
でください!
{{Alert|この記事のより新しい版が[https://docs.wsoft.ws/products/alice/tutorial/migration-from-wsoftscript/ WSOFTDocs]にあります。AliceScriptWikiでは、この記事はもう更新されません。||04}} [[Category:チュートリアル]] AliceScriptによる開発と従来のWSOFTScriptによる開発の類似点と相違点について説明します。 {{Alert|WSOFTScriptバージョン2020LTS及び0.07R4以降、新たなバージョンのWSOFTScriptの開発は行われません。WSOFTは、2022年6月18日に、全てのWSOFTScriptおよびWSOFTScript.XならびにWSOFTScript.Pocketの各バージョンのサポートを終了します。||4|1em}} 今後のWSOFTScriptのサポートについては[https://wsoft.gq/script/?id=WSOFTScriptのライフサイクル WSOFTScriptのライフサイクル]を参照してください。 この記事では、AliceScriptによる開発に関心があるWSOFTScript開発者を対象に、WSOFTScriptとAliceScriptの開発の違いを解説しています。 WSOFTScriptについて詳しく知るには[https://wsoft.gq/script/ WSOFTScriptのサイト]を参照してください。 =はじめに= AliceScriptが登場するまで、簡易的なコンソールアプリケーションとShangri-laによるデスクトップアプリケーションの開発は、WSOFTScriptを用いて行われて来ました。まず第一に、WSOFTScriptのメインライブラリは複雑で、サイズも大きなものでした。また、組み込みの例外処理やデバッグ支援機能はまだ未成熟で、信頼性の高いアプリケーションを開発するには脆弱でもありました。 AliceScriptが登場し、従来のWSOFTScriptはAliceScriptへと進化しました。AliceScriptのさまざまな改良により、ライブラリは小さくまとまり、組み込みの例外処理やデバッグ支援機能も実装され、信頼性の高いアプリケーションを開発することができるようになりました。しかしその一方で、WSOFTScriptに実装されていた一部の機能は実装されていなかったり、多くの組み込み機能を使用するためにAlice.Runtime.dllが必要になるなど、設計思想に起因するいくつかの根本的な違いも残っています。 この記事では、まず最初にAliceScriptで開発を始めるために必要な作業を確認します。(すでにAliceScriptを使用している場合はこのセクションを飛ばしても構いません)。次に、AliceScriptを使って簡単なコンソールアプリケーションを例として作成し、WSOFTScriptとAliceScriptの機能の類似点や相違点を実際に見てみます。 =AliceScriptを使用するための準備= AliceScriptを使用したアプリケーションの開発についての説明の前に、まず、AliceScriptを実行できるコンピュータを用意する必要があります。.NETCore3.1がインストールされているコンピュータが必要です。そのようなコンピュータを用意できない場合は、WSOFTScriptと同じ要件で操作する[[AliceSister]]を使用する必要があります。AliceSisterはAliceScriptとほぼ同じ動作をするAliceScriptの別の実装です。 自分のコンピュータでAliceScriptを実行する場合は、次のソフトウェアをインストールする必要があります。 *.NETCore v3.1以上 *AliceScript .NETCoreのインストールについては、Microsoftの公式ガイドを参照してください。 *Windowsに.NETをインストールする[[https://docs.microsoft.com/ja-jp/dotnet/core/install/windows?tabs=net50|Windowsに.NETをインストールする]] .NETCoreに加えて、AliceScriptもコンピュータにインストールする必要があります。するには、[[AliceScriptのダウンロード]]を参照してください。 =初めてのAliceScriptアプリケーションの作成= AliceScriptアプリケーションは、WSOFTScriptアプリケーションと同じように、任意のテキストエディタで作成できます。 それでは早速、簡単なコンソールアプリケーションをAliceScriptで作成して、AliceScriptアプリケーションの作成方法のWSOFTScriptとの違いについて実際に見てみましょう。任意のテキストエディタで次のコードを入力してください。 print(“Hello,World!”); ファイルを保存したら、次のコマンドを入力して実行します。 alice -r {ファイル名} Hello,World!と表示されれば成功です。 ここまでの作業を通じて、AliceScriptとWSOFTScriptとの大きな違いは見当たりません。これは、[[Print]]関数がWSOFTScriptと同じようにAliceScriptに組み込まれているからです。しかし、ファイル操作や正規表現など、WSOFTScriptには組みこまれていたがAliceScriptには組み込まれていない関数を使用する場合に注意が必要です。 AliceScriptのライブラリには、AliceScript.dllに加えて、Alice.Runitime.dllがあります。これは、AliceScript.dllと同じディレクトリに配置されているときにデフォルトで読み込まれる、AliceScriptのライブラリ群です。ここに、ファイル操作などのよく使う関数やクラスが実装されています。Alice.Runtimeに実装されている関数のうち、名前空間が[[Alice(名前空間)]]でないものは関数の使用前に次のようなコードが必要です。 import “{読み込みたい名前空間の名前}”; 次の例では、まずWSOFTScriptを使用してHello,Worldをテキストファイルに書き込みます。 file_write_text(“test.txt”,”Hello,World”); このコードと同じ動作をするAliceScriptのコードは以下の通りです。 import “Alice.IO”; file_write_text(“test.txt”,”Hello,World”); 注目すべき唯一の違いは、関数の呼出前に[[Import]]関数が呼び出されていることです。<code>import</code>は、<code>Alice.IO</code>名前空間からファイルやディレクトリの入出力についての関数群を読み込むことを事前に宣言します。これが、WSOFTScriptでも関数表現<code>import(“WSOFTScript.Shangrila”);</code>や、フラグ表現<code>[Import:”WSOFTScript.Shangrila”]</code>と決定的に異なる点は、<code>import</code>がファイルを読み込むのではなく、すでに読み込まれたライブラリから名前空間を使用可能なように読み込む点です。 =関数とフラグ= ところで、AliceScriptにはWSOFTScriptに実装されているようなフラグ機能はありません。インタプリタに事前に報告すべき情報がある場合は、<code>Alice.Interpreter</code>名前空間にある関数を呼び出して代用します。例えば、次のフラグの機能を、AliceScriptで表現することを考えます。 [DllImport:”Library.dll”] このフラグは、AliceScriptで特定の.NETライブラリを読み込むフラグです。これをAliceScriptで表現するには次のコードに置き換えます。 Dllimport(“Library.dll”); また、標準出力から発生する出力を抑制したいとき、WSOFTScriptではCanPrintフラグを使用していました。これと同じように動作するコードをAliceScriptで表現すると、次のようになります。 import “Alice.Interpreter”; Interpreter_AllowOutput(false); さらに、AliceScriptの関数には、オーバーライドという概念が導入されています。この概念によって原則同じ関数を複数回定義することはできません。同じ関数を複数回定義されることが予想される場合は事前に<code>virtual</code>属性を付与することを検討してください。また、属性の付与された関数を上書きする場合には、<code>override</code>属性を付与します。次に例を示します。 function virtual Func() { print(“Hello”); } Func();//出力:Hello function override Func() { print(“World”); } Func();//出力:World また、AliceScriptの関数は可変長個の引数を受け取ることができる、<code>parms</code>パラメータをサポートしています。これは、その関数に幾つでも引数を渡すことが可能であることを表しています。次に例を示します。 function Func(parms args) { print(args); } Func(“A”,”B”,”C”);//出力:[“A”,”B”,”C”] この時、<code>args</code>は自動的に配列型になります。引数は省略することもできます。 関数について詳しくは、[[関数]]も参照してください。 =変数= 変数に関する重要な変更についても注意が必要です。まず、WSOFTScriptとは違い、AliceScriptでは、未定義の変数を宣言するときに<code>var</code>キーワードが必須になりました。また、一度宣言された変数に<code>var</code>キーワードを使うことはできません。 スコープは、その変数が有効な範囲です。WSOFTScriptでは、すべての変数はグローバル変数として定義されていました。AliceScriptでは、通常の変数(これをローカル変数と呼ぶことにします)は、そのスコープとそれ以下のスコープの範囲に限られます。AliceScriptでグローバル変数を宣言するには、<code>var</code>キーワードの後に<code>global</code>修飾子をつけます。次に例を示します。 var global abc = “ABC”; 定数は、AliceScriptで導入された新しい機能です。定数は、一度のみ宣言でき、一度定義するとそれに再度代入することはできません。宣言するには<code>var</code>キーワードの代わりに<code>const</code>キーワードを使用します。定数にもやはりローカル定数とグローバル定数が存在します。次の例では、ローカル定数<code>lconst</code>と<code>gconst</code>をそれぞれ定義します。 const lconst a = 1; const global gconst b = 2; 変数について詳しく知るには、[[変数]]を参照してください。 =繰り返し構造の違い= AliceScriptでは、WSOFTScriptとは異なり完全な<code>for</code>文と<code>foreach</code>文の分離が図られました。AliceScriptでは配列から一つ一つ取り出して実行するために<code>for</code>文を使用することはできません。また、<code>foreach(item as array)</code>や、<code>foreach(item : array)</code>の形は使用できなくなりました。<code>foreach(item in array)</code>を使用することを検討してください。また、<code>array.Foreach(delegate(item));</code>の形も使用できます。次の例を参照してください。 var ary = [“a”,”b”,”c”]; ary.Foreach((item)=> { print(item); }); //出力:a // b // c また、AliceScriptでは終了条件までループする<code>until</code>文は廃止されました。しかし、<code>while(!bool)</code>で代用することができます。 =型の違い= AliceScriptではWSOFTScriptからいくつかの型が追加または変更されました。次にそれらの型を示します。 ==Bool型== WSOFTScriptでは<code>if</code>文や<code>while</code>文のように条件をとるステートメントには、<code>number</code>型の0を偽とし、非0を真としていました。<code>true</code>や<code>false</code>キーワードはそれぞれ1や0を返していました。 AliceScriptでは、真または偽のいずれかを表現することのできる<code>bool</code>型が導入され、<code>bool</code>型を厳格に求めるような場面が頻繁にあります。これは、比較式が必要な場面で代入式も使用できてしまい、混乱を招く恐れがあったためです。 AliceScriptでは、<code>true</code>や<code>false</code>キーワードはそれぞれ<code>bool</code>型の<code>true</code>や<code>false</code>を返します。次に例を示します。 var condition = (1 == 1); print(condition.type);//出力例:BOOLEAN ==Type型== AliceScriptには変数の型を表現する<code>type</code>型が存在します。全ての変数は<code>Type</code>プロパティを実装していて、その変数の型を表す値を取得することができます。これはWSOFTScriptの<code>Type</code>プロパティに似ています。しかし、WSOFTScriptの<code>Type</code>プロパティは<code>type</code>型ではなく<code>string</code>型でその値を表す文字列表現を返します。<code>string</code>、<code>number</code>、<code>bool</code>キーワードなどはそれぞれの型の値を表す定数です。また、[[式#型変換演算子|型変換演算子<code>as</code>]]を使用することでその型に変数を明示的に変換することができます。次に例を示します。 var num = 123; print(num.type);//出力例:NUMBER var str = (num as string); print(str.type);//出力例:STRING
編集内容の要約:
AliceScript Wikiへの投稿はすべて、他の投稿者によって編集、変更、除去される場合があります。 自分が書いたものが他の人に容赦なく編集されるのを望まない場合は、ここに投稿しないでください。
また、投稿するのは、自分で書いたものか、パブリック ドメインまたはそれに類するフリーな資料からの複製であることを約束してください(詳細は
AliceScript Wiki:著作権
を参照)。
著作権保護されている作品は、許諾なしに投稿しないでください!
キャンセル
編集ヘルプ
(新しいウィンドウで開きます)
このページで使用されているテンプレート:
テンプレート:Alert
(
編集
)
テンプレート:Func-getcolor
(
編集
)
テンプレート:Func-getsafe
(
編集
)
ナビゲーション メニュー
個人用ツール
ログインしていません
トーク
投稿記録
アカウント作成
ログイン
名前空間
ページ
議論
日本語
表示
閲覧
編集
履歴表示
その他
検索
案内
メインページ
ツアー
ダウンロード
規約
おまかせ表示
ツール
リンク元
関連ページの更新状況
特別ページ
ページ情報