cybrid_api_organization_ruby 0.73.1 → 0.73.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +4 -2
- data/README.md +5 -5
- data/cybrid_api_organization_ruby.gemspec +1 -1
- data/lib/cybrid_api_organization_ruby/api/organizations_organization_api.rb +1 -1
- data/lib/cybrid_api_organization_ruby/api_client.rb +1 -1
- data/lib/cybrid_api_organization_ruby/api_error.rb +1 -1
- data/lib/cybrid_api_organization_ruby/configuration.rb +1 -1
- data/lib/cybrid_api_organization_ruby/models/error_response_organization_model.rb +1 -1
- data/lib/cybrid_api_organization_ruby/models/organization_organization_model.rb +1 -1
- data/lib/cybrid_api_organization_ruby/models/patch_organization_organization_model.rb +1 -1
- data/lib/cybrid_api_organization_ruby/version.rb +2 -2
- data/lib/cybrid_api_organization_ruby.rb +1 -1
- data/spec/api/organizations_organization_api_spec.rb +1 -1
- data/spec/api_client_spec.rb +1 -1
- data/spec/configuration_spec.rb +1 -1
- data/spec/models/error_response_organization_model_spec.rb +1 -1
- data/spec/models/organization_organization_model_spec.rb +1 -1
- data/spec/models/patch_organization_organization_model_spec.rb +1 -1
- data/spec/spec_helper.rb +1 -1
- data/vendor/bundle/ruby/3.2.0/bin/racc +29 -0
- data/vendor/bundle/ruby/3.2.0/cache/parser-3.2.2.3.gem +0 -0
- data/vendor/bundle/ruby/3.2.0/cache/racc-1.7.0.gem +0 -0
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/byebug-11.1.3/gem_make.out +5 -5
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/ffi-1.15.5/gem_make.out +5 -5
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/jaro_winkler-1.5.6/gem_make.out +5 -5
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/psych-5.1.0/gem_make.out +5 -5
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/racc-1.7.0/gem.build_complete +0 -0
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/racc-1.7.0/gem_make.out +28 -0
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/racc-1.7.0/mkmf.log +57 -0
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/racc-1.7.0/racc/cparse.so +0 -0
- data/vendor/bundle/ruby/3.2.0/extensions/x86_64-linux/3.2.0/stringio-3.0.7/gem_make.out +5 -5
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/macruby.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby18.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby19.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby20.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby21.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby22.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby23.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby24.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby25.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby26.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby27.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby30.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby31.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby32.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby33.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/rubymotion.rb +3 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/version.rb +1 -1
- data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/parser.gemspec +1 -1
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/COPYING +22 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/ChangeLog +846 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/README.ja.rdoc +94 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/README.rdoc +79 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/TODO +5 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/bin/racc +320 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/en/NEWS.en.rdoc +282 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/en/grammar.en.rdoc +226 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/en/grammar2.en.rdoc +219 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/NEWS.ja.rdoc +307 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/command.ja.html +94 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/debug.ja.rdoc +36 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/grammar.ja.rdoc +348 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/index.ja.html +10 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/parser.ja.rdoc +125 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/doc/ja/usage.ja.html +414 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/ext/racc/MANIFEST +4 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/ext/racc/cparse/Makefile +269 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/ext/racc/cparse/cparse.c +861 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/ext/racc/cparse/extconf.rb +9 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/compat.rb +33 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/cparse.so +0 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/debugflags.rb +60 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/exception.rb +16 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/grammar.rb +1114 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/grammarfileparser.rb +561 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/info.rb +17 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/iset.rb +92 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/logfilegenerator.rb +212 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/parser-text.rb +658 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/parser.rb +632 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/parserfilegenerator.rb +470 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/sourcetext.rb +35 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/state.rb +972 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/statetransitiontable.rb +311 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc/static.rb +5 -0
- data/vendor/bundle/ruby/3.2.0/gems/racc-1.7.0/lib/racc.rb +6 -0
- data/vendor/bundle/ruby/3.2.0/specifications/{parser-3.2.2.1.gemspec → parser-3.2.2.3.gemspec} +5 -5
- data/vendor/bundle/ruby/3.2.0/specifications/racc-1.7.0.gemspec +27 -0
- metadata +126 -82
- data/vendor/bundle/ruby/3.2.0/cache/parser-3.2.2.1.gem +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/LICENSE.txt +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/bin/ruby-parse +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/bin/ruby-rewrite +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/gauntlet_parser.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/all.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ast/node.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ast/processor.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/base.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/builders/default.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/clobbering_error.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/color.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/context.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/current.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/current_arg_stack.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/deprecation.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/diagnostic/engine.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/diagnostic.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer/dedenter.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer/explanation.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer/literal.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer/stack_state.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer-F0.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer-F1.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/lexer-strings.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/max_numparam_stack.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/messages.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/meta.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/rewriter.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/ruby28.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/runner/ruby_parse.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/runner/ruby_rewrite.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/runner.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/buffer.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/comment/associator.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/comment.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/collection.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/condition.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/constant.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/definition.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/for.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/heredoc.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/index.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/keyword.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/method_definition.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/objc_kwarg.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/operator.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/rescue_body.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/send.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/ternary.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map/variable.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/map.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/range.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/rewriter/action.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/rewriter.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/tree_rewriter/action.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/source/tree_rewriter.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/static_environment.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/syntax_error.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/tree_rewriter.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser/variables_stack.rb +0 -0
- /data/vendor/bundle/ruby/3.2.0/gems/{parser-3.2.2.1 → parser-3.2.2.3}/lib/parser.rb +0 -0
@@ -0,0 +1,348 @@
|
|
1
|
+
= 規則ファイル文法リファレンス
|
2
|
+
|
3
|
+
== 文法に関する前バージョンとの非互換
|
4
|
+
|
5
|
+
* (1.2.5) ユーザーコードを連結する時、外部ファイルよりも
|
6
|
+
埋めこんであるコードを先に連結します。
|
7
|
+
* (1.1.6) 新しいディレクティブ options が追加されました。
|
8
|
+
* (1.1.5) 予約語 token の意味が変更になりました。
|
9
|
+
* (0.14) ルールの最後のセミコロンが省略可能になりました。
|
10
|
+
また、token prechigh などが予約語でなくなりました。
|
11
|
+
* (10.2) prepare が header に driver が footer になりました。
|
12
|
+
今はそのままでも使えますが、2.0 からは対応しません。
|
13
|
+
* (0.10) class に対応する end がなくなりました。
|
14
|
+
* (0.9) ダサダサのピリオド方式をやめて { と } で囲むようにしました。
|
15
|
+
|
16
|
+
== 全体の構造
|
17
|
+
|
18
|
+
トップレベルは、規則部とユーザーコード部に分けられます。
|
19
|
+
ユーザーコード部はクラス定義の後に来なければいけません。
|
20
|
+
|
21
|
+
=== コメント
|
22
|
+
|
23
|
+
文法ファイルには、一部例外を除いて、ほとんどどこにでもコメントを
|
24
|
+
書くことができます。コメントは、Rubyの #.....(行末) スタイルと、
|
25
|
+
Cの /*......*/ スタイルを使うことができます。
|
26
|
+
|
27
|
+
=== 規則部
|
28
|
+
|
29
|
+
規則部は以下のような形をしています。
|
30
|
+
--
|
31
|
+
class クラス名 [< スーパークラス]
|
32
|
+
[演算子順位]
|
33
|
+
[トークン宣言]
|
34
|
+
[オプション]
|
35
|
+
[expect]
|
36
|
+
[トークンシンボル値おきかえ]
|
37
|
+
[スタート規則]
|
38
|
+
rule
|
39
|
+
文法記述
|
40
|
+
--
|
41
|
+
"クラス名"はここで定義するパーサクラスの名前です。
|
42
|
+
これはそのままRubyのクラス名になります。
|
43
|
+
|
44
|
+
また M::C のように「::」を使った名前を使うと、クラス定義を
|
45
|
+
モジュール M の中にネストさせます。つまり class M::C ならば
|
46
|
+
--
|
47
|
+
module M
|
48
|
+
class C < Racc::Parser
|
49
|
+
いろいろ
|
50
|
+
end
|
51
|
+
end
|
52
|
+
--
|
53
|
+
のように出力します。
|
54
|
+
|
55
|
+
さらに、Ruby と同じ構文でスーパークラスを指定できます。
|
56
|
+
ただしこの指定をするとパーサの動作に重大な影響を与えるので、
|
57
|
+
特に必要がない限り指定してはいけません。これは将来の拡張の
|
58
|
+
ために用意したもので、現在指定する必然性はあまりありません。
|
59
|
+
|
60
|
+
=== 文法の記述
|
61
|
+
|
62
|
+
racc で生成するパーサが理解できる文法を記述します。
|
63
|
+
文法は、予約語 rule と end の間に、以下のような書式で書きます。
|
64
|
+
--
|
65
|
+
トークン: トークンの並び アクション
|
66
|
+
|
67
|
+
トークン: トークンの並び アクション
|
68
|
+
| トークンの並び アクション
|
69
|
+
| トークンの並び アクション
|
70
|
+
(必要なだけ同じようにつづける)
|
71
|
+
--
|
72
|
+
アクションは { } で囲みます。アクションでは Ruby の文はほとんど
|
73
|
+
使えますが、一部だけは非対応です。対応していないものは以下のとおり。
|
74
|
+
|
75
|
+
* ヒアドキュメント
|
76
|
+
* =begin ... =end 型コメント
|
77
|
+
* スペースで始まる正規表現
|
78
|
+
* ごくまれに % の演算。普通に演算子のまわりにスペースを入れていれば問題なし
|
79
|
+
|
80
|
+
このあたりに関しては完全な対応はまず無理です。あきらめてください。
|
81
|
+
|
82
|
+
左辺の値($$)は、オプションによって返し方がかわります。まずデフォルトでは
|
83
|
+
ローカル変数 result (そのデフォルト値は val[0])が 左辺値を表し、アクション
|
84
|
+
ブロックを抜けた時の result の値が左辺値になります。または明示的に return
|
85
|
+
で返した場合もこの値になります。一方、options で no_result_var を指定した
|
86
|
+
場合、左辺値はアクションブロックの最後の文の値になります (Ruby のメソッドと
|
87
|
+
同じ)。
|
88
|
+
|
89
|
+
どちらの場合でもアクションは省略でき、省略した場合の左辺値は常に val[0] です。
|
90
|
+
|
91
|
+
以下に文法記述の全体の例をしめします。
|
92
|
+
--
|
93
|
+
rule
|
94
|
+
goal: def ruls source
|
95
|
+
{
|
96
|
+
result = val
|
97
|
+
}
|
98
|
+
|
99
|
+
def : /* none */
|
100
|
+
{
|
101
|
+
result = []
|
102
|
+
}
|
103
|
+
| def startdesig
|
104
|
+
{
|
105
|
+
result[0] = val[1]
|
106
|
+
}
|
107
|
+
| def
|
108
|
+
precrule # これは上の行の続き
|
109
|
+
{
|
110
|
+
result[1] = val[1]
|
111
|
+
}
|
112
|
+
(略)
|
113
|
+
--
|
114
|
+
アクション内では特別な意味をもった変数がいくつか使えます。
|
115
|
+
そのような変数を以下に示します。括弧の中は yacc での表記です。
|
116
|
+
|
117
|
+
* result ($$)
|
118
|
+
|
119
|
+
左辺の値。初期値は val[0] です。
|
120
|
+
|
121
|
+
* val ($1,$2,$3…)
|
122
|
+
|
123
|
+
右辺の記号の値の配列。Ruby の配列なので当然インデックスはゼロから始まります。
|
124
|
+
この配列は毎回作られるので自由に変更したり捨てたりして構いません。
|
125
|
+
|
126
|
+
* _values (...,$-2,$-1,$0)
|
127
|
+
|
128
|
+
値スタック。Racc コアが使っているオブジェクトがそのまま渡されます。
|
129
|
+
この変数の意味がわかる人以外は<em>絶対に</em>変更してはいけません。
|
130
|
+
|
131
|
+
またアクションの特別な形式に、埋めこみアクションというものがあります。
|
132
|
+
これはトークン列の途中の好きなところに記述することができます。
|
133
|
+
以下に埋めこみアクションの例を示します。
|
134
|
+
--
|
135
|
+
target: A B { puts 'test test' } C D { normal action }
|
136
|
+
--
|
137
|
+
このように記述すると A B を検出した時点で puts が実行されます。
|
138
|
+
また、埋めこみアクションはそれ自体が値を持ちます。つまり、以下の例において
|
139
|
+
--
|
140
|
+
target: A { result = 1 } B { p val[1] }
|
141
|
+
--
|
142
|
+
最後にある p val[1] は埋めこみアクションの値 1 を表示します。
|
143
|
+
B の値ではありません。
|
144
|
+
|
145
|
+
意味的には、埋めこみアクションは空の規則を持つ非終端記号を追加することと
|
146
|
+
全く同じ働きをします。つまり、上の例は次のコードと完全に同じ意味です。
|
147
|
+
--
|
148
|
+
target : A nonterm B { p val[1] }
|
149
|
+
nonterm : /* 空の規則 */ { result = 1 }
|
150
|
+
--
|
151
|
+
|
152
|
+
=== 演算子優先順位
|
153
|
+
|
154
|
+
あるトークン上でシフト・還元衝突がおこったとき、そのトークンに
|
155
|
+
演算子優先順位が設定してあると衝突を解消できる場合があります。
|
156
|
+
そのようなものとして特に有名なのは数式の演算子と if...else 構文です。
|
157
|
+
|
158
|
+
優先順位で解決できる文法は、うまく文法をくみかえてやれば
|
159
|
+
優先順位なしでも同じ効果を得ることができます。しかしたいていの
|
160
|
+
場合は優先順位を設定して解決するほうが文法を簡単にできます。
|
161
|
+
|
162
|
+
シフト・還元衝突がおこったとき、Racc はまずその規則に順位が設定
|
163
|
+
されているか調べます。規則の順位は、その規則で一番うしろにある
|
164
|
+
終端トークンの優先順位です。たとえば
|
165
|
+
--
|
166
|
+
target: TERM_A nonterm_a TERM_B nonterm_b
|
167
|
+
--
|
168
|
+
のような規則の順位はTERM_Bの優先順位になります。もしTERM_Bに
|
169
|
+
優先順位が設定されていなかったら、優先順位で衝突を解決することは
|
170
|
+
できないと判断し、「Shift/Reduce conflict」を報告します。
|
171
|
+
|
172
|
+
演算子の優先順位はつぎのように書いて定義します。
|
173
|
+
--
|
174
|
+
prechigh
|
175
|
+
nonassoc PLUSPLUS
|
176
|
+
left MULTI DEVIDE
|
177
|
+
left PLUS MINUS
|
178
|
+
right '='
|
179
|
+
preclow
|
180
|
+
--
|
181
|
+
prechigh に近い行にあるほど優先順位の高いトークンです。上下をまるごと
|
182
|
+
さかさまにして preclow...prechigh の順番に書くこともできます。left
|
183
|
+
などは必ず行の最初になければいけません。
|
184
|
+
|
185
|
+
left right nonassoc はそれぞれ「結合性」を表します。結合性によって、
|
186
|
+
同じ順位の演算子の規則が衝突した場合にシフト還元のどちらをとるかが
|
187
|
+
決まります。たとえば
|
188
|
+
--
|
189
|
+
a - b - c
|
190
|
+
--
|
191
|
+
が
|
192
|
+
--
|
193
|
+
(a - b) - c
|
194
|
+
--
|
195
|
+
になるのが左結合 (left) です。四則演算は普通これです。
|
196
|
+
一方
|
197
|
+
--
|
198
|
+
a - (b - c)
|
199
|
+
--
|
200
|
+
になるのが右結合 (right) です。代入のクオートは普通 right です。
|
201
|
+
またこのように演算子が重なるのはエラーである場合、非結合 (nonassoc) です。
|
202
|
+
C 言語の ++ や単項のマイナスなどがこれにあたります。
|
203
|
+
|
204
|
+
ところで、説明したとおり通常は還元する規則の最後のトークンが順位を
|
205
|
+
決めるのですが、ある規則に限ってそのトークンとは違う順位にしたいことも
|
206
|
+
あります。例えば符号反転のマイナスは引き算のマイナスより順位を高く
|
207
|
+
しないといけません。このような場合 yacc では %prec を使います。
|
208
|
+
racc ではイコール記号を使って同じことをできます。
|
209
|
+
--
|
210
|
+
prechigh
|
211
|
+
nonassoc UMINUS
|
212
|
+
left '*' '/'
|
213
|
+
left '+' '-'
|
214
|
+
preclow
|
215
|
+
(略)
|
216
|
+
exp: exp '*' exp
|
217
|
+
| exp '-' exp
|
218
|
+
| '-' exp = UMINUS # ここだけ順位を上げる
|
219
|
+
--
|
220
|
+
このように記述すると、'-' exp の規則の順位が UMINUS の順位になります。
|
221
|
+
こうすることで符号反転の '-' は '*' よりも順位が高くなるので、
|
222
|
+
意図どおりになります。
|
223
|
+
|
224
|
+
=== トークン宣言
|
225
|
+
|
226
|
+
トークン(終端記号)のつづりを間違えるというのはよくあることですが、
|
227
|
+
発見するのはなかなか難しいものです。1.1.5 からはトークンを明示的に
|
228
|
+
宣言することで、宣言にないトークン / 宣言にだけあるトークンに対して
|
229
|
+
警告が出るようになりました。yacc の %token と似ていますが最大の違いは
|
230
|
+
racc では必須ではなく、しかもエラーにならず警告だけ、という点です。
|
231
|
+
|
232
|
+
トークン宣言は以下のように書きます。
|
233
|
+
--
|
234
|
+
token A B C D
|
235
|
+
E F G H
|
236
|
+
--
|
237
|
+
トークンのリストを複数行にわたって書けることに注目してください。
|
238
|
+
racc では一般に「予約語」は行の先頭に来た時だけ予約語とみなされるので
|
239
|
+
prechigh などもシンボルとして使えます。ただし深淵な理由から end だけは
|
240
|
+
どうやっても予約語になってしまいます。
|
241
|
+
|
242
|
+
=== オプション
|
243
|
+
|
244
|
+
racc のコマンドラインオプションの一部をファイル中にデフォルト値
|
245
|
+
として記述することができます。
|
246
|
+
--
|
247
|
+
options オプション オプション …
|
248
|
+
--
|
249
|
+
現在ここで使えるのは
|
250
|
+
|
251
|
+
* omit_action_call
|
252
|
+
|
253
|
+
空のアクション呼び出しを省略する
|
254
|
+
|
255
|
+
* result_var
|
256
|
+
|
257
|
+
変数 result を使う
|
258
|
+
|
259
|
+
です。
|
260
|
+
それぞれ no_ を頭につけることで意味を反転できます。
|
261
|
+
|
262
|
+
=== expect
|
263
|
+
|
264
|
+
実用になるパーサはたいてい無害な shift/reduce conflict を含みます。
|
265
|
+
しかし文法ファイルを書いた本人はそれを知っているからいいですが、
|
266
|
+
ユーザが文法ファイルを処理した時に「conflict」と表示されたら
|
267
|
+
不安に思うでしょう。そのような場合、以下のように書いておくと
|
268
|
+
shift/reduce conflict のメッセージを抑制できます。
|
269
|
+
--
|
270
|
+
expect 3
|
271
|
+
--
|
272
|
+
この場合 shift/reduce conflict はぴったり三つでなければいけません。
|
273
|
+
三つでない場合はやはり表示が出ます (ゼロでも出ます)。
|
274
|
+
また reduce/reduce conflict の表示は抑制できません。
|
275
|
+
|
276
|
+
=== トークンシンボル値の変更
|
277
|
+
|
278
|
+
トークンシンボルを表す値は、デフォルトでは
|
279
|
+
|
280
|
+
* 文法中、引用符でかこまれていないもの (RULEとかXENDとか)
|
281
|
+
→その名前の文字列を intern して得られるシンボル (1.4 では Fixnum)
|
282
|
+
* 引用符でかこまれているもの(':'とか'.'とか)
|
283
|
+
→その文字列そのまま
|
284
|
+
|
285
|
+
となっていますが、たとえば他の形式のスキャナがすでに存在する場合などは、
|
286
|
+
これにあわせなければならず、このままでは不便です。このような場合には、
|
287
|
+
convert 節を加えることで、トークンシンボルを表す値を変えることができます。
|
288
|
+
以下がその例です。
|
289
|
+
--
|
290
|
+
convert
|
291
|
+
PLUS 'PlusClass' #→ PlusClass
|
292
|
+
MIN 'MinusClass' #→ MinusClass
|
293
|
+
end
|
294
|
+
--
|
295
|
+
デフォルトではトークンシンボル PLUS に対してはトークンシンボル値は
|
296
|
+
:PLUS ですが、上のような記述がある場合は PlusClass になります。
|
297
|
+
変換後の値は false・nil 以外ならなんでも使えます。
|
298
|
+
|
299
|
+
変換後の値として文字列を使うときは、次のように引用符を重ねる必要があります。
|
300
|
+
--
|
301
|
+
convert
|
302
|
+
PLUS '"plus"' #→ "plus"
|
303
|
+
end
|
304
|
+
--
|
305
|
+
また、「'」を使っても生成された Ruby のコード上では「"」になるので
|
306
|
+
注意してください。バックスラッシュによるクオートは有効ですが、バック
|
307
|
+
スラッシュは消えずにそのまま残ります。
|
308
|
+
--
|
309
|
+
PLUS '"plus\n"' #→ "plus\n"
|
310
|
+
MIN "\"minus#{val}\"" #→ \"minus#{val}\"
|
311
|
+
--
|
312
|
+
|
313
|
+
=== スタート規則
|
314
|
+
|
315
|
+
パーサをつくるためには、どの規則が「最初の」規則か、ということを Racc におしえて
|
316
|
+
やらなければいけません。それを明示的に書くのがスタート規則です。スタート規則は
|
317
|
+
次のように書きます。
|
318
|
+
--
|
319
|
+
start real_target
|
320
|
+
--
|
321
|
+
start は行の最初にこなければいけません。このように書くと、ファイルで
|
322
|
+
一番最初に出てくる real_target の規則をスタート規則として使います。
|
323
|
+
省略した場合は、ファイルの最初の規則がスタート規則になります。普通は
|
324
|
+
最初の規則を一番上にかくほうが書きやすく、わかりやすくなりますから、
|
325
|
+
この記法はあまりつかう必要はないでしょう。
|
326
|
+
|
327
|
+
=== ユーザーコード部
|
328
|
+
|
329
|
+
ユーザーコードは、パーサクラスが書きこまれるファイルに、
|
330
|
+
アクションの他にもコードを含めたい時に使います。このようなものは
|
331
|
+
書きこまれる場所に応じて三つ存在し、パーサクラスの定義の前が
|
332
|
+
header、クラスの定義中(の冒頭)が inner、定義の後が footer です。
|
333
|
+
ユーザコードとして書いたものは全く手を加えずにそのまま連結されます。
|
334
|
+
|
335
|
+
ユーザーコード部の書式は以下の通りです。
|
336
|
+
--
|
337
|
+
---- 識別子
|
338
|
+
ruby の文
|
339
|
+
ruby の文
|
340
|
+
ruby の文
|
341
|
+
|
342
|
+
---- 識別子
|
343
|
+
ruby の文
|
344
|
+
:
|
345
|
+
--
|
346
|
+
行の先頭から四つ以上連続した「-」(マイナス)があるとユーザーコードと
|
347
|
+
みなされます。識別子は一つの単語で、そのあとには「=」以外なら何を
|
348
|
+
書いてもかまいません。
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<h1>Racc ユーザマニュアル</h1>
|
2
|
+
<p>バージョン 1.4 対応</p>
|
3
|
+
<ul>
|
4
|
+
<li><a href="usage.html">Racc の使い方</a>
|
5
|
+
<li><a href="command.html">racc コマンドリファレンス</a>
|
6
|
+
<li><a href="grammar.html">規則ファイル文法リファレンス</a>
|
7
|
+
<li><a href="parser.html">Parser クラスリファレンス</a>
|
8
|
+
<li><a href="debug.html">パーサのデバッグ</a>
|
9
|
+
<li><a href="NEWS.html">リリースノート</a>
|
10
|
+
</ul>
|
@@ -0,0 +1,125 @@
|
|
1
|
+
= class Racc::Parser
|
2
|
+
Racc の生成するパーサはすべて Racc::Parser クラスを継承します。
|
3
|
+
Racc::Parser クラスにはパース中に使用するメソッドがいくつかあり、
|
4
|
+
そのようなメソッドをオーバーロードすると、パーサを初期化したり
|
5
|
+
することができます。
|
6
|
+
|
7
|
+
== Super Class
|
8
|
+
|
9
|
+
Object
|
10
|
+
|
11
|
+
== Constants
|
12
|
+
|
13
|
+
プリフィクス "Racc_" がついた定数はパーサの予約定数です。
|
14
|
+
そのような定数は使わないでください。動作不可能になります。
|
15
|
+
== Instance Methods
|
16
|
+
ここに載っているもののほか、プリフィクス "racc_" および "_racc_" が
|
17
|
+
ついたメソッドはパーサの予約名です。そのようなメソッドは使わないで
|
18
|
+
ください。
|
19
|
+
|
20
|
+
: do_parse -> Object
|
21
|
+
パースを開始します。
|
22
|
+
また、トークンが必要になった時は #next_token を呼び出します。
|
23
|
+
|
24
|
+
--
|
25
|
+
# Example
|
26
|
+
---- inner
|
27
|
+
def parse
|
28
|
+
@q = [[1,1],
|
29
|
+
[2,2],
|
30
|
+
[3,3],
|
31
|
+
[false, '$']]
|
32
|
+
do_parse
|
33
|
+
end
|
34
|
+
|
35
|
+
def next_token
|
36
|
+
@q.shift
|
37
|
+
end
|
38
|
+
--
|
39
|
+
|
40
|
+
: next_token -> [Symbol, Object]
|
41
|
+
[abstract method]
|
42
|
+
|
43
|
+
パーサが次のトークンを読みこむ時に使います。
|
44
|
+
[記号, その値] の形式の配列を返してください。
|
45
|
+
記号はデフォルトでは
|
46
|
+
|
47
|
+
* 文法中、引用符でかこまれていないもの
|
48
|
+
→ その名前の文字列のシンボル (例えば :ATOM )
|
49
|
+
* 引用符でかこまれているもの<br>
|
50
|
+
→ その文字列そのまま (例えば '=' )
|
51
|
+
|
52
|
+
で表します。これを変更する方法については、
|
53
|
+
文法リファレンスを参照してください。
|
54
|
+
|
55
|
+
また、もう送るシンボルがなくなったときには
|
56
|
+
[false, なにか] または nil を返してください。
|
57
|
+
|
58
|
+
このメソッドは抽象メソッドなので、#do_parse を使う場合は
|
59
|
+
必ずパーサクラス中で再定義する必要があります。
|
60
|
+
定義しないままパースを始めると例外 NotImplementedError が
|
61
|
+
発生します。
|
62
|
+
|
63
|
+
: yyparse( receiver, method_id )
|
64
|
+
パースを開始します。このメソッドでは始めてトークンが
|
65
|
+
必要になった時点で receiver に対して method_id メソッドを
|
66
|
+
呼び出してトークンを得ます。
|
67
|
+
|
68
|
+
receiver の method_id メソッドはトークンを yield しなければ
|
69
|
+
なりません。形式は #next_token と同じで [記号, 値] です。
|
70
|
+
つまり、receiver の method_id メソッドの概形は以下のように
|
71
|
+
なるはずです。
|
72
|
+
--
|
73
|
+
def method_id
|
74
|
+
until end_of_file
|
75
|
+
:
|
76
|
+
yield 記号, 値
|
77
|
+
:
|
78
|
+
end
|
79
|
+
end
|
80
|
+
--
|
81
|
+
少し注意が必要なのは、method_id が呼び出されるのは始めて
|
82
|
+
トークンが必要になった時点であるということです。method_id
|
83
|
+
メソッドが呼び出されたときは既にパースが進行中なので、
|
84
|
+
アクション中で使う変数を method_id の冒頭で初期化すると
|
85
|
+
まず失敗します。
|
86
|
+
|
87
|
+
トークンの終端を示す [false, なにか] を渡したらそれ以上は
|
88
|
+
yield しないでください。その場合には例外が発生します。
|
89
|
+
|
90
|
+
最後に、method_id メソッドからは必ず yield してください。
|
91
|
+
しない場合は何が起きるかわかりません。
|
92
|
+
|
93
|
+
: on_error( error_token_id, error_value, value_stack )
|
94
|
+
パーサコアが文法エラーを検出すると呼び出します (yacc の yyerror)。
|
95
|
+
エラーメッセージを出すなり、例外を発生するなりしてください。
|
96
|
+
このメソッドから正常に戻った場合、パーサはエラー回復モード
|
97
|
+
に移行します。
|
98
|
+
|
99
|
+
error_token はパースエラーを起こした記号の内部表現 (整数) です。
|
100
|
+
#token_to_str で文法ファイル上の文字列表現に直せます。
|
101
|
+
|
102
|
+
error_value はその値です。
|
103
|
+
|
104
|
+
value_stack はエラーの時点での値スタックです。
|
105
|
+
value_stack を変更してはいけません。
|
106
|
+
|
107
|
+
on_error のデフォルトの実装は例外 ParseError を発生します。
|
108
|
+
|
109
|
+
: token_to_str( t ) -> String
|
110
|
+
Racc トークンの内部表現 (整数)
|
111
|
+
を文法ファイル上の記号表現の文字列に変換します。
|
112
|
+
|
113
|
+
t が整数でない場合は TypeError を発生します。
|
114
|
+
t が範囲外の整数だった場合は nil を返します。
|
115
|
+
|
116
|
+
: yyerror
|
117
|
+
エラー回復モードに入ります。このとき #on_error は呼ばれません。
|
118
|
+
アクション以外からは呼び出さないでください。
|
119
|
+
|
120
|
+
: yyerrok
|
121
|
+
エラー回復モードから復帰します。
|
122
|
+
アクション以外からは呼び出さないでください。
|
123
|
+
|
124
|
+
: yyaccept
|
125
|
+
すぐに値スタックの先頭の値を返して #do_parse、#yyparse を抜けます。
|