mote 1.1.3 → 1.1.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/LICENSE +1 -1
- data/README.md +11 -2
- data/lib/mote.rb +5 -5
- data/test/mote_test.rb +11 -15
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 0bf64ea0a8637abd44b6e4ffe5c8307849171e7d
|
4
|
+
data.tar.gz: df273253e96dca30b70aa34b0f5b02fe6be78a2b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 28f751114df86a5345052b7fec958e3c08fcdeedd9bfb71a7278e2bc0eba77ca3c8aa3a2ca97ce946b80ce09442bed017c9f642cd9e42d22c9ba4d6e7d6a7ec5
|
7
|
+
data.tar.gz: d2d889b1f9d050089adb4c126e63ccaa1497ad9cf62b5e33dbdce893c091b7fc9ed4159f0a93ebfa0b3f42585039fc93caa93656bc6899a552fbe4f011b36135
|
data/LICENSE
CHANGED
data/README.md
CHANGED
@@ -22,16 +22,26 @@ Silly example, you may say, and I would agree. What follows is a short list of
|
|
22
22
|
the different use cases you may face:
|
23
23
|
|
24
24
|
```
|
25
|
+
% # This is a comment
|
25
26
|
% if user == "Bruno"
|
26
27
|
{{user}} rhymes with Piano
|
27
28
|
% elsif user == "Brutus"
|
28
29
|
{{user}} rhymes with Opus
|
29
30
|
% end
|
31
|
+
|
32
|
+
<?
|
33
|
+
# Multiline code evaluation
|
34
|
+
lucky = [1, 3, 7, 9, 13, 15]
|
35
|
+
prime = [2, 3, 5, 7, 11, 13]
|
36
|
+
?>
|
37
|
+
|
38
|
+
{{ lucky & prime }}
|
30
39
|
```
|
31
40
|
|
32
41
|
## Control flow
|
33
42
|
|
34
|
-
Lines that start with `%` are evaluated as Ruby code.
|
43
|
+
Lines that start with `%` are evaluated as Ruby code. Anything between
|
44
|
+
`<?` and `?>`, including new lines, is also evaluated as Ruby code.
|
35
45
|
|
36
46
|
## Assignment
|
37
47
|
|
@@ -45,7 +55,6 @@ There's nothing special about comments, it's just a `#` inside your Ruby code:
|
|
45
55
|
% # This is a comment.
|
46
56
|
```
|
47
57
|
|
48
|
-
|
49
58
|
## Block evaluation
|
50
59
|
|
51
60
|
As with control instructions, it happens naturally:
|
data/lib/mote.rb
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
# Copyright (c) 2011
|
1
|
+
# Copyright (c) 2011-2015 Michel Martens
|
2
2
|
#
|
3
3
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
4
4
|
# of this software and associated documentation files (the "Software"), to deal
|
@@ -18,9 +18,9 @@
|
|
18
18
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
19
19
|
# THE SOFTWARE.
|
20
20
|
class Mote
|
21
|
-
VERSION = "1.1.
|
21
|
+
VERSION = "1.1.4"
|
22
22
|
|
23
|
-
PATTERN = /^
|
23
|
+
PATTERN = /^[^\S\n]*(%)[^\S\n]*(.*?)(?:\n|\Z)|(<\?)\s+(.*?)\s+\?>|(\{\{)(.*?)\}\}/m
|
24
24
|
|
25
25
|
def self.parse(template, context = self, vars = [])
|
26
26
|
terms = template.split(PATTERN)
|
@@ -28,10 +28,10 @@ class Mote
|
|
28
28
|
parts = "Proc.new do |params, __o|\n params ||= {}; __o ||= ''\n"
|
29
29
|
|
30
30
|
vars.each do |var|
|
31
|
-
parts << "%s = params[%
|
31
|
+
parts << "%s = params[%p]\n" % [var, var]
|
32
32
|
end
|
33
33
|
|
34
|
-
while term = terms.shift
|
34
|
+
while (term = terms.shift)
|
35
35
|
case term
|
36
36
|
when "<?" then parts << "#{terms.shift}\n"
|
37
37
|
when "%" then parts << "#{terms.shift}\n"
|
data/test/mote_test.rb
CHANGED
@@ -22,7 +22,7 @@ scope do
|
|
22
22
|
end
|
23
23
|
|
24
24
|
test "assignment" do
|
25
|
-
example = Mote.parse("{{
|
25
|
+
example = Mote.parse("{{ '***' }}")
|
26
26
|
assert_equal "***", example.call
|
27
27
|
end
|
28
28
|
|
@@ -75,7 +75,7 @@ scope do
|
|
75
75
|
|
76
76
|
test "multiline" do
|
77
77
|
example = Mote.parse("The\nMan\nAnd\n{{\"The\"}}\nSea")
|
78
|
-
assert_equal "The\nMan\nAnd\nThe\nSea", example
|
78
|
+
assert_equal "The\nMan\nAnd\nThe\nSea", example.call
|
79
79
|
end
|
80
80
|
|
81
81
|
test "quotes" do
|
@@ -87,8 +87,8 @@ scope do
|
|
87
87
|
context = Object.new
|
88
88
|
def context.user; "Bruno"; end
|
89
89
|
|
90
|
-
example = Mote.parse("{{
|
91
|
-
assert_equal "Bruno", example.call
|
90
|
+
example = Mote.parse("{{ user }}", context)
|
91
|
+
assert_equal "Bruno", example.call
|
92
92
|
end
|
93
93
|
|
94
94
|
test "locals" do
|
@@ -101,23 +101,19 @@ scope do
|
|
101
101
|
assert_equal "", example.call(user: nil)
|
102
102
|
end
|
103
103
|
|
104
|
-
test "curly bug" do
|
105
|
-
example = Mote.parse("{{ [1, 2, 3].map { |i| i * i }.join(',') }}")
|
106
|
-
assert_equal "1,4,9", example.call
|
107
|
-
end
|
108
|
-
|
109
104
|
test "multi-line XML-style directives" do
|
110
105
|
template = (<<-EOT).gsub(/^ /, "")
|
111
|
-
<?
|
112
|
-
|
113
|
-
|
114
|
-
|
106
|
+
<?
|
107
|
+
# Multiline code evaluation
|
108
|
+
lucky = [1, 3, 7, 9, 13, 15]
|
109
|
+
prime = [2, 3, 5, 7, 11, 13]
|
115
110
|
?>
|
116
|
-
|
111
|
+
|
112
|
+
{{ lucky & prime }}
|
117
113
|
EOT
|
118
114
|
|
119
115
|
example = Mote.parse(template)
|
120
|
-
assert_equal "\
|
116
|
+
assert_equal "\n\n[3, 7, 13]\n", example.call
|
121
117
|
end
|
122
118
|
|
123
119
|
test "preserve XML directives" do
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: mote
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.1.
|
4
|
+
version: 1.1.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Michel Martens
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2015-05-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: cutest
|