momo 0.3.5 → 0.4.0

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: d080260c90d6597f9d8477b523a10e736173df21
4
- data.tar.gz: cc7a5a49da20b45d1a5f65272ca2323a14741721
3
+ metadata.gz: ce74a879ad8df4b3d48702def1cb718e45dda190
4
+ data.tar.gz: 62828aafe7ab0bfc8fd39afe531cbea90de01b7f
5
5
  SHA512:
6
- metadata.gz: cfb564730f88ce401eacba3248d6cc4f66a933c853a3ca3596ddf8b4f74f8cf241218c44032a6fd3daa8c40ed2e11f4d504d5b5221bb2870139fe9ff5309652c
7
- data.tar.gz: d5c2ce22e0d601dda03bb518cf6b8280c1103a3c56fc6d1184755d827cbf67ce6482e8369eec846ce226ca22cece37d2603b3120990f4655391c3418f96846a2
6
+ metadata.gz: 38e7b5d7fa785d067b48d89296ceca77c7cfda6193c69673cd7559a472f532d0b47c02c79293aa418c6d8379cfc8ba51be1e84b97216de844ab4f54ac39e2f07
7
+ data.tar.gz: e04f44afe9fa6db008a34fdd5c74b5c2a73428a5a5e8c7e122e69b3c7019d980678cf88aa9aa17729b8acbc3a8d7558caeee4d53f0895f7e745151ad290ee14c
@@ -2,7 +2,23 @@ require "momo/funccall"
2
2
 
3
3
  module Momo
4
4
 
5
- def Momo.resolve(something, options={})
5
+ class BlockHash
6
+ attr_accessor :props
7
+ def initialize(options, &block)
8
+ @options = options
9
+ @props = {}
10
+ instance_eval(&block)
11
+ end
12
+
13
+ def method_missing(name, *args, &block)
14
+ if /^[[:upper:]]/.match(name) == nil
15
+ raise "Invalid property name: #{name}"
16
+ end
17
+ @props[name] = Momo.resolve(args[0], @options, &block)
18
+ end
19
+ end
20
+
21
+ def Momo.resolve(something, options={}, &block)
6
22
 
7
23
  if something.is_a? String or
8
24
  something.is_a? TrueClass or
@@ -31,6 +47,8 @@ module Momo
31
47
  return something.representation
32
48
  elsif something.is_a? Parameter
33
49
  return { "Ref" => something.name }
50
+ elsif something == nil && block
51
+ return result = BlockHash.new(options, &block).props
34
52
  else
35
53
  raise "Invalid var: #{something.inspect} in #{options[:resource]}"
36
54
  end
data/lib/momo/resource.rb CHANGED
@@ -20,13 +20,18 @@ module Momo
20
20
 
21
21
  def method_missing(name, *args, &block)
22
22
 
23
- if /^[[:upper:]]/.match(name) == nil
24
- raise "Invalid resource name: #{name}"
25
- end
26
-
27
23
  if !@complete
28
- @props[name] = Momo.resolve(args[0], resource: name, stack: @stack)
24
+ if /^[[:upper:]]/.match(name) == nil
25
+ raise "Invalid property name: #{name}"
26
+ end
27
+ @props[name] = Momo.resolve(args[0], resource: name, stack: @stack, &block)
28
+
29
29
  else
30
+ if /^[[:upper:]]/.match(name) == nil
31
+ raise "Invalid attribute name: #{name}"
32
+ end
33
+ # For get attributes when the resource is completed
34
+ # TODO: should instead instance eval with a different class
30
35
  MemberReference.new @name, name, @stack
31
36
  end
32
37
  end
data/lib/momo/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module Momo
2
- VERSION = "0.3.5"
2
+ VERSION = "0.4.0"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: momo
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.5
4
+ version: 0.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - David Siaw
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2017-05-22 00:00:00.000000000 Z
11
+ date: 2017-06-23 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -156,7 +156,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
156
156
  version: '0'
157
157
  requirements: []
158
158
  rubyforge_project:
159
- rubygems_version: 2.6.11
159
+ rubygems_version: 2.4.8
160
160
  signing_key:
161
161
  specification_version: 4
162
162
  summary: Momo template maker for AWS