File: modularity.rb

package info (click to toggle)
ruby-parslet 1.6.1-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 908 kB
  • ctags: 473
  • sloc: ruby: 5,220; makefile: 2
file content (47 lines) | stat: -rw-r--r-- 1,137 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
$:.unshift File.dirname(__FILE__) + "/../lib"

require 'pp'
require "parslet"

# Demonstrates modular parsers, split out over many classes. Please look at
# ip_address.rb as well.

module ALanguage
  include Parslet
    
  # Parslet rules are really a special kind of method. Mix them into your
  # classes!
  rule(:a_language) { str('aaa') }
end

# Parslet parsers are parslet atoms as well. Create an instance and chain them
# to your other rules. 
#
class BLanguage < Parslet::Parser
  root :blang
  
  rule(:blang) { str('bbb') }
end

# Parslet atoms are really Ruby values, pass them around. 
c_language = Parslet.str('ccc')
  
class Language < Parslet::Parser
  def initialize(c_language)
    @c_language = c_language
    super()
  end
  
  root :root

  include ALanguage
  
  rule(:root) { str('a(') >> a_language >> str(')') >> space |
                str('b(') >> BLanguage.new >> str(')') >> space | 
                str('c(') >> @c_language >> str(')') >> space }
  rule(:space) { str(' ').maybe }
end

Language.new(c_language).parse('a(aaa)')
Language.new(c_language).parse('b(bbb)')
Language.new(c_language).parse('c(ccc)')