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



55
56
57
58
59
60
61
62
63
64
65
66
67
# File 'lib/liquidscript/compiler/icr/literals.rb', line 55

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

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

#_compile_for_seg(first) ⇒ Object



69
70
71
72
73
74
75
76
77
78
79
# File 'lib/liquidscript/compiler/icr/literals.rb', line 69

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



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

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

#compile_arrayObject



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

def compile_array
  shift :lbrack

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

  code :array, parts
end

#compile_forObject



39
40
41
42
43
44
45
46
47
48
49
50
51
52
# File 'lib/liquidscript/compiler/icr/literals.rb', line 39

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



172
173
174
# File 'lib/liquidscript/compiler/icr/literals.rb', line 172

def compile_function
  compile_function_with_parameters([])
end

#compile_heredocObject



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

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

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

#compile_hrefObject



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

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



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

def compile_identifier(identifier)
  if peek?(:equal)
    identifier
  else
    ref(identifier)
  end
end

#compile_iheredoc_beginObject



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

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



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

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

#compile_istring_beginObject



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

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

  code :interop, *contents
end

#compile_keywordObject



140
141
142
# File 'lib/liquidscript/compiler/icr/literals.rb', line 140

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

#compile_newlineObject



176
177
178
179
180
181
# File 'lib/liquidscript/compiler/icr/literals.rb', line 176

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
20
# File 'lib/liquidscript/compiler/icr/literals.rb', line 6

def compile_number
  n = shift(:number)

  if peek?(:range)
    shift(:range)

    if peek?(:number)
      code :nrange, n.value, shift(:number).value
    else
      compile_range(code(:number, n.value))
    end
  else
    code :number, n.value
  end
end

#compile_objectObject



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

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



165
166
167
168
169
170
# File 'lib/liquidscript/compiler/icr/literals.rb', line 165

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

  key
end

#compile_operatorObject



136
137
138
# File 'lib/liquidscript/compiler/icr/literals.rb', line 136

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

#compile_range(subject) ⇒ Object



26
27
28
# File 'lib/liquidscript/compiler/icr/literals.rb', line 26

def compile_range(subject)
  code :range, subject, compile_vexpression
end

#compile_regexObject



89
90
91
# File 'lib/liquidscript/compiler/icr/literals.rb', line 89

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

#compile_sstringObject



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

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

#compile_whileObject



30
31
32
33
34
35
36
37
# File 'lib/liquidscript/compiler/icr/literals.rb', line 30

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