mustache 0.12.0 → 0.12.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/lib/mustache/context.rb +4 -4
- data/lib/mustache/parser.rb +7 -4
- data/lib/mustache/sinatra.rb +2 -3
- data/lib/mustache/version.rb +1 -1
- data/test/mustache_test.rb +8 -0
- metadata +4 -4
data/lib/mustache/context.rb
CHANGED
@@ -29,11 +29,11 @@ class Mustache
|
|
29
29
|
# Look for the first Mustache in the stack.
|
30
30
|
mustache = mustache_in_stack
|
31
31
|
|
32
|
-
#
|
33
|
-
|
32
|
+
# Indent the partial template by the given indentation.
|
33
|
+
part = mustache.partial(name).to_s.gsub(/^/, indentation)
|
34
34
|
|
35
|
-
#
|
36
|
-
result.
|
35
|
+
# Call the Mustache's `partial` method and render the result.
|
36
|
+
result = mustache.render(part, self)
|
37
37
|
end
|
38
38
|
|
39
39
|
# Find the first Mustache in the stack. If we're being rendered
|
data/lib/mustache/parser.rb
CHANGED
@@ -108,6 +108,7 @@ EOF
|
|
108
108
|
# Scan until we hit an opening delimiter.
|
109
109
|
start_of_line = @scanner.beginning_of_line?
|
110
110
|
pre_match_position = @scanner.pos
|
111
|
+
last_index = @result.length
|
111
112
|
|
112
113
|
return unless x = @scanner.scan(/([ \t]*)?#{Regexp.escape(otag)}/)
|
113
114
|
padding = @scanner[1] || ''
|
@@ -144,11 +145,13 @@ EOF
|
|
144
145
|
@result << [:mustache, :section, content, block]
|
145
146
|
@sections << [content, position, @result]
|
146
147
|
@result = block
|
148
|
+
last_index = 1
|
147
149
|
when '^'
|
148
150
|
block = [:multi]
|
149
151
|
@result << [:mustache, :inverted_section, content, block]
|
150
152
|
@sections << [content, position, @result]
|
151
153
|
@result = block
|
154
|
+
last_index = 1
|
152
155
|
when '/'
|
153
156
|
section, pos, result = @sections.pop
|
154
157
|
raw = @scanner.pre_match[pos[3]...pre_match_position] + padding
|
@@ -188,18 +191,18 @@ EOF
|
|
188
191
|
# the remaining whitespace. If not, but we've been hanging on to padding
|
189
192
|
# from the beginning of the line, re-insert the padding as static text.
|
190
193
|
if start_of_line
|
191
|
-
if SKIP_WHITESPACE.include?(type)
|
194
|
+
if @scanner.peek(1) == "\n" && SKIP_WHITESPACE.include?(type)
|
192
195
|
@scanner.skip(/[ \t]*\n/)
|
193
196
|
else
|
194
|
-
@result.insert(
|
197
|
+
@result.insert(last_index, [:static, padding]) unless padding.empty?
|
195
198
|
end
|
196
199
|
end
|
197
200
|
|
198
|
-
return unless @result == [:multi]
|
199
|
-
|
200
201
|
# Store off the current scanner position now that we've closed the tag
|
201
202
|
# and consumed any irrelevant whitespace.
|
202
203
|
@sections.last[1] << @scanner.pos unless @sections.empty?
|
204
|
+
|
205
|
+
return unless @result == [:multi]
|
203
206
|
end
|
204
207
|
|
205
208
|
# Try to find static text, e.g. raw HTML with no {{mustaches}}.
|
data/lib/mustache/sinatra.rb
CHANGED
@@ -70,19 +70,18 @@ class Mustache
|
|
70
70
|
else
|
71
71
|
layout = layout.new
|
72
72
|
end
|
73
|
-
|
74
73
|
end
|
75
74
|
|
76
75
|
# Find and cache the view class we want. This ensures the
|
77
76
|
# compiled template is cached, too - no looking up and
|
78
77
|
# compiling templates on each page load.
|
79
78
|
klass = mustache_class(template, options)
|
80
|
-
|
79
|
+
|
81
80
|
# Does the view subclass the layout? If so we'll use the
|
82
81
|
# view to render the layout so you can override layout
|
83
82
|
# methods in your view - tricky.
|
84
83
|
view_subclasses_layout = klass < layout.class if layout
|
85
|
-
|
84
|
+
|
86
85
|
# Create a new instance for playing with.
|
87
86
|
instance = klass.new
|
88
87
|
|
data/lib/mustache/version.rb
CHANGED
data/test/mustache_test.rb
CHANGED
@@ -57,6 +57,14 @@ end_complex
|
|
57
57
|
assert_equal %Q'<p class="flash-notice" style="display: none;">', instance.render
|
58
58
|
end
|
59
59
|
|
60
|
+
def test_sassy_single_line_sections
|
61
|
+
instance = Mustache.new
|
62
|
+
instance[:full_time] = true
|
63
|
+
instance.template = "\n {{#full_time}}full time{{/full_time}}\n"
|
64
|
+
|
65
|
+
assert_equal "\n full time\n", instance.render
|
66
|
+
end
|
67
|
+
|
60
68
|
def test_two_line_sections
|
61
69
|
html = %(<p class="flash-notice" {{# no_flash }}style="display: none;"\n{{/ no_flash }}>)
|
62
70
|
|
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: mustache
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
hash:
|
4
|
+
hash: 45
|
5
5
|
prerelease: false
|
6
6
|
segments:
|
7
7
|
- 0
|
8
8
|
- 12
|
9
|
-
-
|
10
|
-
version: 0.12.
|
9
|
+
- 1
|
10
|
+
version: 0.12.1
|
11
11
|
platform: ruby
|
12
12
|
authors:
|
13
13
|
- Chris Wanstrath
|
@@ -15,7 +15,7 @@ autorequire:
|
|
15
15
|
bindir: bin
|
16
16
|
cert_chain: []
|
17
17
|
|
18
|
-
date:
|
18
|
+
date: 2011-02-22 00:00:00 -08:00
|
19
19
|
default_executable:
|
20
20
|
dependencies: []
|
21
21
|
|