123456789_123456789_123456789_123456789_123456789_

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.

Constant Summary

Instance Method Summary

Instance Method Details

#_dispatch_0 (private)

This method is for internal use only.
[ GitHub ]

  
# File 'ext/ripper/lib/ripper/core.rb', line 34

def _dispatch_0() nil end

#_dispatch_1(a) (private)

This method is for internal use only.
[ GitHub ]

  
# File 'ext/ripper/lib/ripper/core.rb', line 35

def _dispatch_1(a) a end

#_dispatch_2(a, b) (private)

This method is for internal use only.
[ GitHub ]

  
# File 'ext/ripper/lib/ripper/core.rb', line 36

def _dispatch_2(a, b) a end

#_dispatch_3(a, b, c) (private)

This method is for internal use only.
[ GitHub ]

  
# File 'ext/ripper/lib/ripper/core.rb', line 37

def _dispatch_3(a, b, c) a end

#_dispatch_4(a, b, c, d) (private)

This method is for internal use only.
[ GitHub ]

  
# 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)

This method is for internal use only.
[ GitHub ]

  
# 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)

This method is for internal use only.
[ GitHub ]

  
# 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)

This method is for internal use only.
[ GitHub ]

  
# 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.

[ GitHub ]

  
# 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.

[ GitHub ]

  
# 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.

[ GitHub ]

  
# File 'ext/ripper/lib/ripper/core.rb', line 59

def warning(fmt, *args)
end