Module: Liquidscript::Compiler::ICR::Literals

Included in:
Liquidscript::Compiler::ICR
Defined in:
lib/liquidscript/compiler/icr/literals.rb

Instance Method Summary collapse

Instance Method Details

#_compile_for_in(ident) ⇒ Object



49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/liquidscript/compiler/icr/literals.rb', line 49

def _compile_for_in(ident)
  content = shift :identifier
  unless content.value == "in"
    raise CompileError, "Expected `in', got #{content.value}"
  end

  obj = shift :identifier
  shift :rparen

  set ident
  body = _compile_block
  code :for_in, ident, ref(obj), body
end

#_compile_for_seg(first) ⇒ Object



63
64
65
66
67
68
69
70
71
72
73
# File 'lib/liquidscript/compiler/icr/literals.rb', line 63

def _compile_for_seg(first)
  first = value_expect(first)
  shift :comma
  second = compile_vexpression
  shift :comma
  third = compile_vexpression
  shift :rparen

  body = _compile_block
  code :for_seg, first, second, third, body
end

#compile_actionObject



21
22
23
# File 'lib/liquidscript/compiler/icr/literals.rb', line 21

def compile_action
  code :action, shift(:action)
end

#compile_arrayObject



148
149
150
151
152
153
154
155
# File 'lib/liquidscript/compiler/icr/literals.rb', line 148

def compile_array
  shift :lbrack

  parts = collect_compiles(:vexpression, :rbrack,
    :comma => action.shift)

  code :array, parts
end

#compile_forObject



34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/liquidscript/compiler/icr/literals.rb', line 34

def compile_for
  shift :for
  shift :lparen
  if peek?(:identifier)
    ident = shift :identifier
    if peek?(:identifier)
      _compile_for_in(ident)
    else
      _compile_for_seg(compile_identifier(ident))
    end
  else
    compile_for_seg compile_vexpression
  end
end

#compile_functionObject



164
165
166
# File 'lib/liquidscript/compiler/icr/literals.rb', line 164

def compile_function
  compile_function_with_parameters([])
end

#compile_heredocObject



94
95
96
97
98
99
100
# File 'lib/liquidscript/compiler/icr/literals.rb', line 94

def compile_heredoc
  h = shift(:heredoc, :iheredoc)

  top[:heredocs][top[:herenum]].body = [h]
  top[:herenum] += 1
  nil
end

#compile_hrefObject



85
86
87
88
89
90
91
92
# File 'lib/liquidscript/compiler/icr/literals.rb', line 85

def compile_href
  ref = shift :heredoc_ref, :iheredoc_ref
  heredoc = Heredoc.new(ref.value, ref.type == :iheredoc_ref)
  top[:heredocs] ||= []
  top[:herenum]  ||= 0
  top[:heredocs] << heredoc
  code :href, heredoc
end

#compile_identifier(identifier) ⇒ Object



75
76
77
78
79
# File 'lib/liquidscript/compiler/icr/literals.rb', line 75

def compile_identifier(identifier)
  ref(identifier) unless peek?(:equal)

  identifier
end

#compile_iheredoc_beginObject



102
103
104
105
106
107
108
109
110
# File 'lib/liquidscript/compiler/icr/literals.rb', line 102

def compile_iheredoc_begin
  start = shift :iheredoc_begin
  contents = [start]
  _compile_interop(:iheredoc, contents)

  top[:heredocs][top[:herenum]].body = contents
  top[:herenum] += 1
  nil
end

#compile_istringObject



120
121
122
# File 'lib/liquidscript/compiler/icr/literals.rb', line 120

def compile_istring
  code :istring, shift(:istring).value
end

#compile_istring_beginObject



112
113
114
115
116
117
118
# File 'lib/liquidscript/compiler/icr/literals.rb', line 112

def compile_istring_begin
  start = shift :istring_begin
  contents = [start]
  _compile_interop(:istring, contents)

  code :interop, *contents
end

#compile_keywordObject



132
133
134
# File 'lib/liquidscript/compiler/icr/literals.rb', line 132

def compile_keyword
  code :keyword, shift(:keyword)
end

#compile_newlineObject



168
169
170
171
172
173
# File 'lib/liquidscript/compiler/icr/literals.rb', line 168

def compile_newline
  if peek?(:newline)
    pop
    code :newline
  end
end

#compile_numberObject



6
7
8
9
10
11
12
13
14
15
16
17
18
19
# File 'lib/liquidscript/compiler/icr/literals.rb', line 6

def compile_number
  #code :number, pop.value
  n = shift(:number)

  if peek?(:prop)
    shift(:prop)
    shift(:prop)
    n2 = shift(:number)

    code :range, n.value, n2.value
  else
    code :number, n.value
  end
end

#compile_objectObject



136
137
138
139
140
141
142
143
144
145
146
# File 'lib/liquidscript/compiler/icr/literals.rb', line 136

def compile_object
  shift :lbrace

  objects = collect_compiles :rbrace,
    :comma => action.shift,
    :newline => action.shift do
    [compile_object_key, compile_vexpression]
  end

  code :object, objects
end

#compile_object_keyObject



157
158
159
160
161
162
# File 'lib/liquidscript/compiler/icr/literals.rb', line 157

def compile_object_key
  key = shift :identifier, :istring
  shift :colon

  key
end

#compile_operatorObject



128
129
130
# File 'lib/liquidscript/compiler/icr/literals.rb', line 128

def compile_operator
  code :operator, shift(:operator), compile_vexpression
end

#compile_regexObject



81
82
83
# File 'lib/liquidscript/compiler/icr/literals.rb', line 81

def compile_regex
  code :regex, shift(:regex)
end

#compile_sstringObject



124
125
126
# File 'lib/liquidscript/compiler/icr/literals.rb', line 124

def compile_sstring
  code :sstring, shift(:sstring).value[1..-1]
end

#compile_whileObject



25
26
27
28
29
30
31
32
# File 'lib/liquidscript/compiler/icr/literals.rb', line 25

def compile_while
  shift :while
  shift :lparen
  conditional = compile_vexpression
  shift :rparen
  body = _compile_block
  code :while, conditional, body
end