Class: Ripper
| Relationships & Source Files | |
| Namespace Children | |
|
Classes:
| |
| Extension / Inclusion / Inheritance Descendants | |
|
Subclasses:
|
|
| Inherits: | Object |
| Defined in: | ext/ripper/lib/ripper.rb, ext/ripper/lib/ripper/core.rb, ext/ripper/lib/ripper/filter.rb, ext/ripper/lib/ripper/lexer.rb, ext/ripper/lib/ripper/sexp.rb |
Overview
Ripper is a Ruby script parser.
You can get information from the parser with event-based style. Information such as abstract syntax trees or simple lexical analysis of the Ruby program.
Usage
Ripper provides an easy interface for parsing your program into a symbolic
expression tree (or S-expression).
Understanding the output of the parser may come as a challenge, it's recommended you use PP to format the output for legibility.
require 'ripper'
require 'pp'
pp Ripper.sexp('def hello(world) "Hello, #{world}!"; end')
#=> [:program,
[[:def,
[:@ident, "hello", [1, 4]],
[:paren,
[:params, [[:@ident, "world", [1, 10]]], nil, nil, nil, nil, nil, nil]],
[:bodystmt,
[[:string_literal,
[:string_content,
[:@tstring_content, "Hello, ", [1, 18]],
[:string_embexpr, [[:var_ref, [:@ident, "world", [1, 27]]]]],
[:@tstring_content, "!", [1, 33]]]]],
nil,
nil,
nil]]]]
You can see in the example above, the expression starts with :program.
From here, a method definition at :def, followed by the method's identifier
:@ident. After the method's identifier comes the parentheses
:paren and the method parameters under :params.
Next is the method body, starting at :bodystmt (stmt meaning statement),
which contains the full definition of the method.
In our case, we're simply returning a String, so next we have the
:string_literal expression.
Within our :string_literal you'll notice two @tstring_content,
this is the literal part for Hello, and !. Between
the two @tstring_content statements is a :string_embexpr,
where embexpr is an embedded expression. Our expression consists of a local
variable, or var_ref, with the identifier (@ident) of world.
Resources
Requirements
- ruby 1.9 (support CVS HEAD only)
- bison 1.28 or later (Other yaccs do not work)
License
Ruby License.
- Minero Aoki
- aamine@loveruby.net
- http://i.loveruby.net
Constant Summary
-
EVENTS =
# File 'ext/ripper/lib/ripper/core.rb', line 29
This array contains name of all ripper events.
PARSER_EVENTS + SCANNER_EVENTS
-
PARSER_EVENTS =
# File 'ext/ripper/lib/ripper/core.rb', line 23
This array contains name of parser events.
PARSER_EVENT_TABLE.keys
-
SCANNER_EVENTS =
# File 'ext/ripper/lib/ripper/core.rb', line 26
This array contains name of scanner events.
SCANNER_EVENT_TABLE.keys
Instance Method Summary
-
#compile_error(msg)
private
This method is called when the parser found syntax error.
-
#warn(fmt, *args)
private
This method is called when weak warning is produced by the parser.
-
#warning(fmt, *args)
private
This method is called when strong warning is produced by the parser.
- #_dispatch_0 private Internal use only
- #_dispatch_1(a) private Internal use only
- #_dispatch_2(a, b) private Internal use only
- #_dispatch_3(a, b, c) private Internal use only
- #_dispatch_4(a, b, c, d) private Internal use only
- #_dispatch_5(a, b, c, d, e) private Internal use only
- #_dispatch_6(a, b, c, d, e, f) private Internal use only
- #_dispatch_7(a, b, c, d, e, f, g) private Internal use only
Instance Method Details
#_dispatch_0 (private)
# File 'ext/ripper/lib/ripper/core.rb', line 34
def _dispatch_0() nil end
#_dispatch_1(a) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 35
def _dispatch_1(a) a end
#_dispatch_2(a, b) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 36
def _dispatch_2(a, b) a end
#_dispatch_3(a, b, c) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 37
def _dispatch_3(a, b, c) a end
#_dispatch_4(a, b, c, d) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 38
def _dispatch_4(a, b, c, d) a end
#_dispatch_5(a, b, c, d, e) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 39
def _dispatch_5(a, b, c, d, e) a end
#_dispatch_6(a, b, c, d, e, f) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 40
def _dispatch_6(a, b, c, d, e, f) a end
#_dispatch_7(a, b, c, d, e, f, g) (private)
# File 'ext/ripper/lib/ripper/core.rb', line 41
def _dispatch_7(a, b, c, d, e, f, g) a end
#compile_error(msg) (private)
This method is called when the parser found syntax error.
# File 'ext/ripper/lib/ripper/core.rb', line 63
def compile_error(msg) end
#warn(fmt, *args) (private)
This method is called when weak warning is produced by the parser.
fmt and args is printf style.
# File 'ext/ripper/lib/ripper/core.rb', line 54
def warn(fmt, *args) end
#warning(fmt, *args) (private)
This method is called when strong warning is produced by the parser.
fmt and args is printf style.
# File 'ext/ripper/lib/ripper/core.rb', line 59
def warning(fmt, *args) end