Difference between revisions of "YOLOL:jp"
(Translated into Japanese.) |
Danthbyrth (talk | contribs) m |
||
(8 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
{{Otherlang2 | {{Otherlang2 | ||
|en=YOLOL | |||
|de=YOLOL:de | |de=YOLOL:de | ||
| | |fr=YOLOL:fr | ||
|ru=YOLOL:ru | |ru=YOLOL:ru | ||
|ua=YOLOL:ua | |ua=YOLOL:ua | ||
|jp=YOLOL:jp | |jp=YOLOL:jp | ||
|zh-cn=YOLOL语言 | |||
}} | }} | ||
== 概要 == | == 概要 == | ||
YOLOLは、[[ | YOLOLは、[[デバイスとマシン|デバイス]]を制御・管理するためのプログラミング言語です。<br> | ||
コードは[[YOLOL | コードは[[YOLOL Chip|YOLOLチップ]]に書かれており、[[Chip socket|チップソケット]]に挿入され、チップがメッセージを読み取って中継する。<br> | ||
このプログラミング言語は、既知の宇宙にあるほとんどすべてのデバイスのプログラミングと制御を可能にします。 | このプログラミング言語は、既知の宇宙にあるほとんどすべてのデバイスのプログラミングと制御を可能にします。 | ||
Line 15: | Line 18: | ||
=== 使い方 === | === 使い方 === | ||
コードはプログラマブル・チップに書き込まれて実行され、[[ | コードはプログラマブル・チップに書き込まれて実行され、[[データネットワーク]]に接続された[[デバイスとマシン|デバイス]]の監視と制御の両方に使用される。<br> | ||
コードの行は、上から下へと順番に実行され、最後の行が実行された後、チップのサイクルを繰り返します。ただし、スクリプトに特定の行を変更したり、実行を完全に停止したりするプログラムされた命令が含まれている場合はこの限りではありません。 | コードの行は、上から下へと順番に実行され、最後の行が実行された後、チップのサイクルを繰り返します。ただし、スクリプトに特定の行を変更したり、実行を完全に停止したりするプログラムされた命令が含まれている場合はこの限りではありません。 | ||
Line 37: | Line 40: | ||
=== 関連ページ === | === 関連ページ === | ||
* [[ | * [[データネットワーク]] | ||
* [[ | * [[デバイスとマシン]] | ||
* [[Device fields]] | * [[Device fields]] | ||
* [[ | * [[ユニバーサルツール]] | ||
* [[YOLOL Chip]] | * [[YOLOL Chip]] | ||
* [[Memory chip]] | * [[Memory chip]] | ||
Line 81: | Line 84: | ||
==== 小数点以下 ==== | ==== 小数点以下 ==== | ||
プログラミング言語における数値は、64ビット固定小数点の10進数です。 | |||
変数は小数点第3位までの数値が格納されます。 | |||
そのため、最大値の範囲(演算中も含む)は | そのため、最大値の範囲(演算中も含む)は -9223372036854775.808~9223372036854775.807 となります。 | ||
pieVariable= 3.142 | pieVariable= 3.142 | ||
* | * 上記のスクリプトでは、変数 '''pieVariable''' に 3.142 という数値が割り当てられています。 | ||
** | ** 変数が格納できる値よりも正確な値を与えても動作しますが、最終的な結果には影響しません。 | ||
notPieVariable= 0.5772156649 | notPieVariable= 0.5772156649 | ||
* | * 上記のスクリプトは、変数 '''notPieVariable''' に 0.5772156649 という数値を割り当てようとしています。 | ||
* | * 最終的な結果は notPieVariable == 0.577 です。 | ||
** | ** ここでは、より正確な値にカットされ、少数第3位までが残されます。 | ||
==== | ==== 文字列 ==== | ||
プログラミング言語で文字列変数を指定するには、希望する文字列の値をダブルクォーテーションで囲む必要があります。 | |||
badRobots= "saltberia" | badRobots= "saltberia" | ||
* | * このスクリプトは、"'''saltberia'''" という文字列値を変数 '''badRobots''' に割り当てます。 | ||
==== | ==== デバイスフィールド / 外部変数 ==== | ||
外部変数とデバイス・フィールドは、プログラミング言語で次のような構文で使用できます:<br> | |||
* ''':variableName''' | * ''':variableName''' | ||
**'''variableName''' | ** '''variableName'''には設定されたデバイスフィールドIDを指定します。 | ||
コロンのプレフィックス ''':'''は、スクリプト内で宣言または使用されていない外部変数を使用する代わりに、外部変数にアクセスしていることをスクリプトに伝えるために使用されます。<br> | |||
プログラム可能な[[YOLOL Chip|チップ]]を[[デバイスとマシン|デバイス]]に接続すると、同じ[[データネットワーク|ネットワーク]]内のすべてのデバイスにアクセスできます。<br> | |||
そして、アクセスできるすべてのデバイスフィールドを変更したり、聞いたりすることができます。<br> | |||
if ''' | if ''':ButtonState''' == 1 then ''':DoorState''' = 1 end | ||
* | * 上記のスクリプトは、データネットワーク上で'''ButtonState'''の値が1の場合、デバイスフィールド'''DoorState'''をリッスンしているすべてのデバイスに1の値を送信します。 | ||
==== | ==== 命名の制限 ==== | ||
現在、変数に '''if''' や '''end''' などのキーワードが含まれていると、正しく解析されないことがありますので、避けてください。 | |||
== | == 演算子とコマンド == | ||
プログラム可能な[[YOLOL Chip|チップ]]の種類によって、使用できる演算子が制限されることがあります。<br> | |||
基本的なチップは限られた機能しかありませんが、高度なチップではより複雑な演算をネイティブに行うことができます。 | |||
=== | === 基本的な算術演算子と代入演算子について === | ||
{| class="wikitable" | {| class="wikitable" | ||
|- | |- | ||
! | ! 演算|| 数値演算 || 文字列演算 || チップの種類 | ||
|- | |- | ||
| A + B || | | A + B || 加算|| 文字列Aに文字列Bを足す。 || すべて | ||
|- | |- | ||
| A - B || | | A - B || 減算 || 文字列 A の中で文字列 B の最後の出現部分が文字列 A から削除されます。 || すべて | ||
|- | |- | ||
| A * B || | | A * B || 乗算 || ランタイムエラー。この行の残りの部分はスキップされます。 || すべて | ||
|- | |- | ||
| A / B || | | A / B || 除算 || ランタイムエラー。この行の残りの部分はスキップされます。 || すべて | ||
|- | |- | ||
| A ++ || | | A ++ || ポストインクリメント (A=A+1) || 文字列 A にスペースを追加します。 || すべて | ||
|- | |- | ||
| A -- || | | A -- || ポストインクリメント (A=A-1) || 文字列の最後の文字を削除します。""(空白)を削除しようとするとランタイムエラーになります。元の値に評価されます。 || すべて | ||
|- | |- | ||
| ++ A || | | ++ A || プレインクリメント (A=A+1) || 文字列 A にスペースを追加します。 || すべて | ||
|- | |- | ||
| -- A || | | -- A || プレインクリメント (A=A-1) || 文字列の最後の文字を削除します。""(空白)を削除しようとするとランタイムエラーになります。元の値に評価されます。 || すべて | ||
|- | |- | ||
| A = B || | | A = B || 代入 (変数 A に変数 B の値を設定) || 代入 || すべて | ||
|- | |- | ||
| A += B || | | A += B || 加算の代入 (A=A+B) || 文字列操作 A+B の値を代入する。 || すべて | ||
|- | |- | ||
| A -= B || | | A -= B || 減算の代入(A=A-B) || 文字列操作 A-B の値を代入する。 || すべて | ||
|- | |- | ||
| A *= B || | | A *= B || 乗算の代入 (A=A*B) || ランタイムエラー。この行の残りの部分はスキップされます。 || すべて | ||
|- | |- | ||
| A /= B || | | A /= B || 除算の代入 (A=A/B) || ランタイムエラー。この行の残りの部分はスキップされます。 || すべて | ||
|- | |- | ||
| A ^= B || | | A ^= B || 累乗の代入 (A=A^B) || ランタイムエラー。この行の残りの部分はスキップされます。 || アドバンス, プロフェッショナル | ||
|- | |- | ||
| A %= B || | | A %= B || 余りの代入 (A=A%B) || ランタイムエラー。この行の残りの部分はスキップされます。 || アドバンス, プロフェッショナル | ||
|- | |- | ||
| A ^ B || | | A ^ B || 累乗 || ランタイムエラー。この行の残りの部分はスキップされます。 || アドバンス, プロフェッショナル | ||
|- | |- | ||
| A % B || | | A % B || 余り || ランタイムエラー。この行の残りの部分はスキップされます。 || アドバンス, プロフェッショナル | ||
|- | |- | ||
| ABS A || | | ABS A || 対数係数(絶対値) (A=A if A>=0, else A=-A)と同じ処理となる。 || ランタイムエラー。この行の残りの部分はスキップされます。|| アドバンス, プロフェッショナル | ||
|- | |- | ||
| A! || | | A! || 階乗 || ランタイムエラー。この行の残りの部分はスキップされます。 || アドバンス, プロフェッショナル | ||
|- | |- | ||
| SQRT A || | | SQRT A || Aの平方根 || ランタイムエラー。この行の残りの部分はスキップされます。 || アドバンス, プロフェッショナル | ||
|- | |- | ||
| SIN A || | | SIN A || AのSIN(度) || ランタイムエラー。この行の残りの部分はスキップされます。. || プロフェッショナル | ||
|- | |- | ||
| COS A || | | COS A || AのCOS(度) || ランタイムエラー。この行の残りの部分はスキップされます。 || プロフェッショナル | ||
|- | |- | ||
| TAN A || | | TAN A || AのTAN(度) || ランタイムエラー。この行の残りの部分はスキップされます。 || プロフェッショナル | ||
|- | |- | ||
| ASIN A || | | ASIN A || AのASIN(度) || ランタイムエラー。この行の残りの部分はスキップされます。 || プロフェッショナル | ||
|- | |- | ||
| ACOS A || | | ACOS A || AのACOS(度) || ランタイムエラー。この行の残りの部分はスキップされます。 || プロフェッショナル | ||
|- | |- | ||
| ATAN A || | | ATAN A || AのATAN(度) || ランタイムエラー。この行の残りの部分はスキップされます。 || プロフェッショナル | ||
|} | |} | ||
=== | === 論理演算子 === | ||
論理演算子は、命令が真か偽かを識別するチェックです。<br> | |||
すべての論理演算は、'''0の偽'''または'''1の真'''のいずれかを返します。<br> | |||
また、'''NOT'''、'''AND'''、'''OR'''キーワードは、0を偽とし、0以外を真とします。 | |||
{| class="wikitable" | {| class="wikitable" | ||
|- | |- | ||
! | ! 演算||数値演算||文字列演算||チップの種類 | ||
|- | |- | ||
| A < B || | | A < B || AはBより小さい || 文字列Aがアルファベット順で1番目の場合は1を、そうでない場合は0を返します。 || すべて | ||
|- | |- | ||
| A > B || | | A > B || AはBより大きい || 文字列Aがアルファベット順で1番目の場合は0を、そうでない場合は1を返します。 || すべて | ||
|- | |- | ||
| A <= B || | | A <= B || AはB以下 || 文字列Aがアルファベット順で1番目の場合か、文字列Bと同じであれば1を、そうでない場合は0を返します。 || すべて | ||
|- | |- | ||
| A >= B || | | A >= B || AはB以上 || 文字列Aがアルファベット順で1番目の場合か、文字列Bと同じであれば0を、そうでない場合は1を返します。 || すべて | ||
|- | |- | ||
| A != B || | | A != B || AはBと異なる || 文字列Aが文字列Bと等しくない場合は1を、等しい場合は0を返します。 || すべて | ||
|- | |- | ||
| A == B || | | A == B || AはBと同じ || 文字列Aが文字列Bと等しい場合は1を、等しくない場合は0を返します。 || すべて | ||
|- | |- | ||
| NOT A || | | NOT A || 真偽反転 || A が 0 であれば 1 を、そうでなければ 0 を返します。 || すべて | ||
|- | |- | ||
| A AND B || | | A AND B || AとBの両方 || A も B も 0 でなければ 1 を、そうでなければ 0 を返します。 || すべて | ||
|- | |- | ||
| A OR B || | | A OR B || AまたはBのどちらか || A または B のどちらかが 0 でない場合は 1 を、そうでない場合は 0 を返します。 || すべて | ||
|} | |} | ||
=== | === 演算における変数型の混在 === | ||
演算の中で変数の型を混ぜると、すべてのパラメータを''文字列''として演算を行います。 | |||
Mixing variable types in an operation handles the operation using all parameters as ''strings''. | Mixing variable types in an operation handles the operation using all parameters as ''strings''. | ||
previouslyNumber= "10" + 15 | previouslyNumber= "10" + 15 | ||
* | * 上記スクリプトの結果、'''precedlyNumber''' には文字列値 "1015" が格納されます。 | ||
** | ** 関係するパラメータ自体の型は変更されず、その値は操作の目的のために文字列として変換されるだけであることに注意してください。 | ||
purelyNumber = 15 | purelyNumber = 15 | ||
purelyString = "10" + purelyNumber | purelyString = "10" + purelyNumber | ||
* | * このスクリプトが実行されたとき、'''purelyString''' には文字列値の "1015" が、'''purelyNumber''' には数値値の "15" が入っています。 | ||
=== | === goto文 === | ||
goto文は、通常のスクリプトの1->20の読み順が望ましくない場合や、変更する必要がある場合に使用します。 | |||
gotoは次のような構文で使用します: | |||
*'''goto lineNumber''' | * '''goto lineNumber'''です。 | ||
** lineNumber | ** lineNumber は、このコマンドがスクリプトの実行を開始する行です。 | ||
** | ** goto コマンドの後に同じ行にある残りのスクリプトは実行されません。 | ||
*** | *** goto の前に if 文を使用すると、if 文が false であると仮定して、goto の構文を無視します。 | ||
** | ** 条件式を使って同じ行に複数のgotoコマンドを追加することができますが、'''False'''のgotoコマンドはスキップされます。 | ||
** | ** [1,20] の範囲外の数値は、この範囲にクランプされます。 | ||
** | ** 非整数の値は整数として扱われます。 | ||
** | ** 文字列値はランタイムエラーになります。 | ||
if variable == 5 then '''goto 4''' end '''goto 6''' | if variable == 5 then '''goto 4''' end '''goto 6''' | ||
上のスクリプトは、もし'''variable'''の値が5であれば、4行目に進みます。<br> | |||
それ以外の場合は、6行目に進みます。数値演算はgoto文の中でも行うことができます。(例) | |||
goto 4+1 | goto 4+1 | ||
=== | === if-else文 === | ||
if-else文は、スクリプトを異なる経路に分岐させるために使用します。<br> | |||
以下のような構文になります: | |||
* '''if ''条件式'' then ''命令'' else ''命令'' end''' | |||
** 条件式は結果が数値になる必要があり(0はFalse、それ以外はTrueとして解析されます)で、命令は実行されるスクリプトの一部です。 | |||
** すべての if-else文は、文が完了した後に '''end''' 命令を記述しなければなりません。 | |||
<br> | |||
If は、スクリプトの実行を変数の値に基づいて2つの結果に分岐させるために使用できます。<br> | |||
'''例:'''<br> | |||
<font color="orangered">'''if'''</font> variable != 2 <font color="orangered">'''then'''</font> endResult = 3 <font color="orangered">'''else'''</font> endResult = 4 <font color="orangered">'''end'''</font> | |||
* このスクリプトは、'''variable'''が2の値の場合、'''endResult''' の値を3に設定します。 | |||
* ''' | |||
* '''variable'''の値が2の場合、'''endResult'''の値は4に設定されます。 | |||
なお、else 文の部分は、必要なければ省略することができます。<br>。 | |||
'''例:'''<br> | |||
''' | |||
<font color="orangered">'''if'''</font> variable != 2 <font color="orangered">'''then'''</font> endResult = 3 <font color="orangered">'''end'''</font> | <font color="orangered">'''if'''</font> variable != 2 <font color="orangered">'''then'''</font> endResult = 3 <font color="orangered">'''end'''</font> | ||
* | *このスクリプトは、'''variable'''の値が2でない場合に、'''endResult''' に3の値を設定するだけで、他には何もしていません。 | ||
==== | ==== if文の入れ子 ==== | ||
true/false文のブロックの中にif文を入れることで、さらに実行を分岐させることができます。<br> | |||
例:<br> | |||
<font color="orangered">'''if'''</font> variable == 0 <font color="orangered">'''then'''</font> endResult = 1 <font color="orangered">'''else'''</font> <font color="cyan">'''if'''</font> variable == 1 <font color="cyan">'''then'''</font> endResult = 2 <font color="cyan">'''end'''</font> <font color="orangered">'''end'''</font> | <font color="orangered">'''if'''</font> variable == 0 <font color="orangered">'''then'''</font> endResult = 1 <font color="orangered">'''else'''</font> <font color="cyan">'''if'''</font> variable == 1 <font color="cyan">'''then'''</font> endResult = 2 <font color="cyan">'''end'''</font> <font color="orangered">'''end'''</font> | ||
* | * このスクリプトは、'''variable'''が0の場合、'''endResult''' を1に設定します。 | ||
* | * '''variable''' が 0 にならず、1 になる場合、'''endResult''' は 2 に設定されます。 | ||
例:<br> | |||
<font color="orangered">'''if'''</font> variable == 0 <font color="orangered">'''then'''</font> <font color="cyan">'''if'''</font> endResult == 1 <font color="cyan">'''then'''</font> endResult = 2 <font color="cyan">'''end'''</font> <font color="orangered">'''else'''</font> endResult = 1 <font color="orangered">'''end'''</font> | <font color="orangered">'''if'''</font> variable == 0 <font color="orangered">'''then'''</font> <font color="cyan">'''if'''</font> endResult == 1 <font color="cyan">'''then'''</font> endResult = 2 <font color="cyan">'''end'''</font> <font color="orangered">'''else'''</font> endResult = 1 <font color="orangered">'''end'''</font> | ||
* | * このスクリプトは、'''vaiable'''の値が0で、'''endResult'''が1の場合、'''endResult''' を2に設定します。 | ||
* | * そうでなければ '''endResult''' を 1 に設定します。 | ||
なお、入れ子になったif文を含むスクリプトは、インデントされたきれいな形にフォーマットしたほうが、スクリプトの流れを計画したり、デバッグしたりしやすいかもしれません。<br> | |||
''' | '''注意:このようにスクリプトを書いても[[YOLOL Chip|チップ]]では動作しませんが、スクリプトをデバッグする際にはこのようにすると便利です。 | ||
これは、2つ目の入れ子になった例を整形したものです: | |||
<font color="orangered">'''if'''</font> variable == 0 <font color="orangered">'''then'''</font> | <font color="orangered">'''if'''</font> variable == 0 <font color="orangered">'''then'''</font> | ||
Line 293: | Line 293: | ||
<font color="orangered">'''end'''</font> | <font color="orangered">'''end'''</font> | ||
=== | === コメント === | ||
コメントは、多くのプログラマが使用するコードを書くときに便利です。<br> | |||
また、コメントは1行70文字の文字数制限にカウントされることに注意してください。<br> | |||
コメントは次のような構文で使用します。 | |||
*// '''テキスト''' | |||
** テキストは一行分の任意の文字集合です。 | |||
'''//''' これはコメントです。他の行のスクリプトがどのように動作するかを説明します。 | |||
* コメント構文の例 | |||
* | |||
== エラー == | |||
プログラミング言語では、2種類のエラーが発生することがあります。 | |||
# 構文エラー(Syntax errors) | |||
# ランタイムエラー(Runtime errors) | |||
* 構文エラーは、無効で解析不能なスクリプトから発生し、その行全体が実行されません。 | |||
* ランタイムエラーは、スクリプトが実行されている間のみ発生します。ランタイムエラーは、スクリプトが実行されている間にのみ発生し、その行の実行は中断されますが、エラーが発生するまでの効果は残ります。 | |||
== 既知のバグ/意図しない動作 == | |||
以下は、YOLOLに関する既知の問題のリストです:<br> | |||
* | * "if" のようなキーワードを含む 変数名は、そのキーワードを考慮して解析され、シンタックスエラーになります。例: :life は :l if e と解析されます。 | ||
== | == 関連ページ == | ||
* [[YOLOL Tricks]] | * [[YOLOL Tricks]] | ||
[[Category:Networks|YOLOL]] | [[Category:Networks|YOLOL]] |
Latest revision as of 09:16, 11 October 2021
概要
YOLOLは、デバイスを制御・管理するためのプログラミング言語です。
コードはYOLOLチップに書かれており、チップソケットに挿入され、チップがメッセージを読み取って中継する。
このプログラミング言語は、既知の宇宙にあるほとんどすべてのデバイスのプログラミングと制御を可能にします。
基本情報
使い方
コードはプログラマブル・チップに書き込まれて実行され、データネットワークに接続されたデバイスの監視と制御の両方に使用される。
コードの行は、上から下へと順番に実行され、最後の行が実行された後、チップのサイクルを繰り返します。ただし、スクリプトに特定の行を変更したり、実行を完全に停止したりするプログラムされた命令が含まれている場合はこの限りではありません。
要点:
- コードの実行は1行目から
- 1行目を読んだ後、チップの時間間隔に基づいて次の行に進む
- このプロセスは、2行目、3行目、4行目...と繰り返されます。
- チップは、最後の行が実行された後、再び1行目の実行を開始します。(最後の行にgoto文が含まれている場合や、実行が一時停止されている場合を除く)
このように、空行でも0.2秒を使用するので、短い実行遅延として使用することができます。(コメントのみの行は実質的に空行と同じです)
制限事項
- 行の実行には0.2秒かかります。
- 1行に入力できる文字数は最大70文字(コメント、スペースを含む)です。
- 一部の機能は、特定のYOLOLチップでのみ動作します。
*そのため、以下の例のようにゲーム内で動作しないことがありますのでご注意ください。
関連ページ
コマンドリファレンス
大文字小文字を区別しない
プログラミング言語は、大文字と小文字を区別しません。
つまり、次の2つのスクリプト例は、互いに同じ機能を持っています:
if ButtonState == 1 then DoorState = 1 end
IF buttonstate == 1 THEN doorstate = 1 END
- どちらのスクリプトも、buttonstateの値が1であれば、doorstateを1に設定します。
- プログラミング言語の文字は、小文字でも大文字でも書くことができます。
- 大文字小文字を区別せずに解析されます。
- このようにして、コードを少し整理することができます。
変数
- プログラミング言語の変数は弱い型付け(型の有効性を強制しない)で、2つのデータ型をサポートしています。固定小数点の10進数(0.001までの精度)と文字列です。
- 簡単に言うと、変数は文字列か数字のどちらかで導入することができ、前の変数の型が同一でない場合は、エラーを起こさずに前の変数の型を無視します。
- 各変数は常に単一の型ですが、必要に応じて暗黙のうちに変換されます。
- 初期化されていない変数のデフォルト値は0で、NULL値はサポートされていません。
- True/Falseは、0以外の数値と0の数値です。
- True =! 0
- False == 0
変数に値を代入すると、その変数は常に新しく代入された値の型に変換されます。
例:
ultimateAutopilot= 128.643
- この結果、変数 ultimateAutopilot には 128.643 という数値が格納されます。
ultimateAutopilot= "Error prone"
- この結果、変数 ultimateAutopilot は文字列変数 "Error prone" となり、数値 128.643 が削除されます。
小数点以下
プログラミング言語における数値は、64ビット固定小数点の10進数です。 変数は小数点第3位までの数値が格納されます。 そのため、最大値の範囲(演算中も含む)は -9223372036854775.808~9223372036854775.807 となります。
pieVariable= 3.142
- 上記のスクリプトでは、変数 pieVariable に 3.142 という数値が割り当てられています。
- 変数が格納できる値よりも正確な値を与えても動作しますが、最終的な結果には影響しません。
notPieVariable= 0.5772156649
- 上記のスクリプトは、変数 notPieVariable に 0.5772156649 という数値を割り当てようとしています。
- 最終的な結果は notPieVariable == 0.577 です。
- ここでは、より正確な値にカットされ、少数第3位までが残されます。
文字列
プログラミング言語で文字列変数を指定するには、希望する文字列の値をダブルクォーテーションで囲む必要があります。
badRobots= "saltberia"
- このスクリプトは、"saltberia" という文字列値を変数 badRobots に割り当てます。
デバイスフィールド / 外部変数
外部変数とデバイス・フィールドは、プログラミング言語で次のような構文で使用できます:
- :variableName
- variableNameには設定されたデバイスフィールドIDを指定します。
コロンのプレフィックス :は、スクリプト内で宣言または使用されていない外部変数を使用する代わりに、外部変数にアクセスしていることをスクリプトに伝えるために使用されます。
プログラム可能なチップをデバイスに接続すると、同じネットワーク内のすべてのデバイスにアクセスできます。
そして、アクセスできるすべてのデバイスフィールドを変更したり、聞いたりすることができます。
if :ButtonState == 1 then :DoorState = 1 end
- 上記のスクリプトは、データネットワーク上でButtonStateの値が1の場合、デバイスフィールドDoorStateをリッスンしているすべてのデバイスに1の値を送信します。
命名の制限
現在、変数に if や end などのキーワードが含まれていると、正しく解析されないことがありますので、避けてください。
演算子とコマンド
プログラム可能なチップの種類によって、使用できる演算子が制限されることがあります。
基本的なチップは限られた機能しかありませんが、高度なチップではより複雑な演算をネイティブに行うことができます。
基本的な算術演算子と代入演算子について
演算 | 数値演算 | 文字列演算 | チップの種類 |
---|---|---|---|
A + B | 加算 | 文字列Aに文字列Bを足す。 | すべて |
A - B | 減算 | 文字列 A の中で文字列 B の最後の出現部分が文字列 A から削除されます。 | すべて |
A * B | 乗算 | ランタイムエラー。この行の残りの部分はスキップされます。 | すべて |
A / B | 除算 | ランタイムエラー。この行の残りの部分はスキップされます。 | すべて |
A ++ | ポストインクリメント (A=A+1) | 文字列 A にスペースを追加します。 | すべて |
A -- | ポストインクリメント (A=A-1) | 文字列の最後の文字を削除します。""(空白)を削除しようとするとランタイムエラーになります。元の値に評価されます。 | すべて |
++ A | プレインクリメント (A=A+1) | 文字列 A にスペースを追加します。 | すべて |
-- A | プレインクリメント (A=A-1) | 文字列の最後の文字を削除します。""(空白)を削除しようとするとランタイムエラーになります。元の値に評価されます。 | すべて |
A = B | 代入 (変数 A に変数 B の値を設定) | 代入 | すべて |
A += B | 加算の代入 (A=A+B) | 文字列操作 A+B の値を代入する。 | すべて |
A -= B | 減算の代入(A=A-B) | 文字列操作 A-B の値を代入する。 | すべて |
A *= B | 乗算の代入 (A=A*B) | ランタイムエラー。この行の残りの部分はスキップされます。 | すべて |
A /= B | 除算の代入 (A=A/B) | ランタイムエラー。この行の残りの部分はスキップされます。 | すべて |
A ^= B | 累乗の代入 (A=A^B) | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
A %= B | 余りの代入 (A=A%B) | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
A ^ B | 累乗 | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
A % B | 余り | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
ABS A | 対数係数(絶対値) (A=A if A>=0, else A=-A)と同じ処理となる。 | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
A! | 階乗 | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
SQRT A | Aの平方根 | ランタイムエラー。この行の残りの部分はスキップされます。 | アドバンス, プロフェッショナル |
SIN A | AのSIN(度) | ランタイムエラー。この行の残りの部分はスキップされます。. | プロフェッショナル |
COS A | AのCOS(度) | ランタイムエラー。この行の残りの部分はスキップされます。 | プロフェッショナル |
TAN A | AのTAN(度) | ランタイムエラー。この行の残りの部分はスキップされます。 | プロフェッショナル |
ASIN A | AのASIN(度) | ランタイムエラー。この行の残りの部分はスキップされます。 | プロフェッショナル |
ACOS A | AのACOS(度) | ランタイムエラー。この行の残りの部分はスキップされます。 | プロフェッショナル |
ATAN A | AのATAN(度) | ランタイムエラー。この行の残りの部分はスキップされます。 | プロフェッショナル |
論理演算子
論理演算子は、命令が真か偽かを識別するチェックです。
すべての論理演算は、0の偽または1の真のいずれかを返します。
また、NOT、AND、ORキーワードは、0を偽とし、0以外を真とします。
演算 | 数値演算 | 文字列演算 | チップの種類 |
---|---|---|---|
A < B | AはBより小さい | 文字列Aがアルファベット順で1番目の場合は1を、そうでない場合は0を返します。 | すべて |
A > B | AはBより大きい | 文字列Aがアルファベット順で1番目の場合は0を、そうでない場合は1を返します。 | すべて |
A <= B | AはB以下 | 文字列Aがアルファベット順で1番目の場合か、文字列Bと同じであれば1を、そうでない場合は0を返します。 | すべて |
A >= B | AはB以上 | 文字列Aがアルファベット順で1番目の場合か、文字列Bと同じであれば0を、そうでない場合は1を返します。 | すべて |
A != B | AはBと異なる | 文字列Aが文字列Bと等しくない場合は1を、等しい場合は0を返します。 | すべて |
A == B | AはBと同じ | 文字列Aが文字列Bと等しい場合は1を、等しくない場合は0を返します。 | すべて |
NOT A | 真偽反転 | A が 0 であれば 1 を、そうでなければ 0 を返します。 | すべて |
A AND B | AとBの両方 | A も B も 0 でなければ 1 を、そうでなければ 0 を返します。 | すべて |
A OR B | AまたはBのどちらか | A または B のどちらかが 0 でない場合は 1 を、そうでない場合は 0 を返します。 | すべて |
演算における変数型の混在
演算の中で変数の型を混ぜると、すべてのパラメータを文字列として演算を行います。 Mixing variable types in an operation handles the operation using all parameters as strings.
previouslyNumber= "10" + 15
- 上記スクリプトの結果、precedlyNumber には文字列値 "1015" が格納されます。
- 関係するパラメータ自体の型は変更されず、その値は操作の目的のために文字列として変換されるだけであることに注意してください。
purelyNumber = 15 purelyString = "10" + purelyNumber
- このスクリプトが実行されたとき、purelyString には文字列値の "1015" が、purelyNumber には数値値の "15" が入っています。
goto文
goto文は、通常のスクリプトの1->20の読み順が望ましくない場合や、変更する必要がある場合に使用します。
gotoは次のような構文で使用します:
- goto lineNumberです。
- lineNumber は、このコマンドがスクリプトの実行を開始する行です。
- goto コマンドの後に同じ行にある残りのスクリプトは実行されません。
- goto の前に if 文を使用すると、if 文が false であると仮定して、goto の構文を無視します。
- 条件式を使って同じ行に複数のgotoコマンドを追加することができますが、Falseのgotoコマンドはスキップされます。
- [1,20] の範囲外の数値は、この範囲にクランプされます。
- 非整数の値は整数として扱われます。
- 文字列値はランタイムエラーになります。
if variable == 5 then goto 4 end goto 6
上のスクリプトは、もしvariableの値が5であれば、4行目に進みます。
それ以外の場合は、6行目に進みます。数値演算はgoto文の中でも行うことができます。(例)
goto 4+1
if-else文
if-else文は、スクリプトを異なる経路に分岐させるために使用します。
以下のような構文になります:
- if 条件式 then 命令 else 命令 end
- 条件式は結果が数値になる必要があり(0はFalse、それ以外はTrueとして解析されます)で、命令は実行されるスクリプトの一部です。
- すべての if-else文は、文が完了した後に end 命令を記述しなければなりません。
If は、スクリプトの実行を変数の値に基づいて2つの結果に分岐させるために使用できます。
例:
if variable != 2 then endResult = 3 else endResult = 4 end
- このスクリプトは、variableが2の値の場合、endResult の値を3に設定します。
- variableの値が2の場合、endResultの値は4に設定されます。
なお、else 文の部分は、必要なければ省略することができます。
。
例:
if variable != 2 then endResult = 3 end
- このスクリプトは、variableの値が2でない場合に、endResult に3の値を設定するだけで、他には何もしていません。
if文の入れ子
true/false文のブロックの中にif文を入れることで、さらに実行を分岐させることができます。
例:
if variable == 0 then endResult = 1 else if variable == 1 then endResult = 2 end end
- このスクリプトは、variableが0の場合、endResult を1に設定します。
- variable が 0 にならず、1 になる場合、endResult は 2 に設定されます。
例:
if variable == 0 then if endResult == 1 then endResult = 2 end else endResult = 1 end
- このスクリプトは、vaiableの値が0で、endResultが1の場合、endResult を2に設定します。
- そうでなければ endResult を 1 に設定します。
なお、入れ子になったif文を含むスクリプトは、インデントされたきれいな形にフォーマットしたほうが、スクリプトの流れを計画したり、デバッグしたりしやすいかもしれません。
注意:このようにスクリプトを書いてもチップでは動作しませんが、スクリプトをデバッグする際にはこのようにすると便利です。
これは、2つ目の入れ子になった例を整形したものです:
if variable == 0 then if otherVariable == 1 then otherVariable = 2 end else otherVariable = 1 end
コメント
コメントは、多くのプログラマが使用するコードを書くときに便利です。
また、コメントは1行70文字の文字数制限にカウントされることに注意してください。
コメントは次のような構文で使用します。
- // テキスト
- テキストは一行分の任意の文字集合です。
// これはコメントです。他の行のスクリプトがどのように動作するかを説明します。
- コメント構文の例
エラー
プログラミング言語では、2種類のエラーが発生することがあります。
- 構文エラー(Syntax errors)
- ランタイムエラー(Runtime errors)
- 構文エラーは、無効で解析不能なスクリプトから発生し、その行全体が実行されません。
- ランタイムエラーは、スクリプトが実行されている間のみ発生します。ランタイムエラーは、スクリプトが実行されている間にのみ発生し、その行の実行は中断されますが、エラーが発生するまでの効果は残ります。
既知のバグ/意図しない動作
以下は、YOLOLに関する既知の問題のリストです:
- "if" のようなキーワードを含む 変数名は、そのキーワードを考慮して解析され、シンタックスエラーになります。例: :life は :l if e と解析されます。