ngi 0.2.3 → 0.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (80) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +7 -1
  3. data/bin/ngi +1 -31
  4. data/lib/config/{angular_init.config.json → backup/angular_init.config.json} +0 -0
  5. data/lib/config/backup/config.components.aliases.yml +3 -0
  6. data/lib/config/backup/config.components.yml +55 -0
  7. data/lib/config/backup/config.configurable.yml +1 -0
  8. data/lib/config/backup/config.languages.yml +5 -0
  9. data/lib/config/backup/config.yml +3 -0
  10. data/lib/config/backup/template-skeleton.js +93 -0
  11. data/lib/config/config.components.aliases.yml +3 -0
  12. data/lib/config/config.components.yml +55 -0
  13. data/lib/config/config.configurable.yml +2 -0
  14. data/lib/config/config.languages.yml +5 -0
  15. data/lib/config/config.yml +4 -0
  16. data/lib/ngi.rb +4 -7
  17. data/lib/ngi/configure.rb +236 -75
  18. data/lib/ngi/delegate.rb +3 -8
  19. data/lib/ngi/generator.rb +74 -46
  20. data/lib/ngi/parser.rb +97 -0
  21. data/lib/{templates → ngi/templates}/markup/html/default/index.html +0 -0
  22. data/lib/{templates → ngi/templates}/script/coffee/default/basic.js +0 -0
  23. data/lib/{templates → ngi/templates}/script/coffee/default/config.js +0 -0
  24. data/lib/{templates → ngi/templates}/script/coffee/default/constant.js +0 -0
  25. data/lib/{templates → ngi/templates}/script/coffee/default/module.js +0 -0
  26. data/lib/{templates → ngi/templates}/script/es5/default/basic.js +0 -0
  27. data/lib/{templates → ngi/templates}/script/es5/default/config.js +0 -0
  28. data/lib/{templates → ngi/templates}/script/es5/default/constant.js +0 -0
  29. data/lib/{templates → ngi/templates}/script/es5/default/module.js +0 -0
  30. data/lib/ngi/utils/command_parser.rb +90 -75
  31. data/lib/ngi/utils/current_dir.rb +20 -0
  32. data/lib/ngi/utils/jser.rb +45 -32
  33. data/lib/ngi/utils/user_input.rb +22 -0
  34. data/lib/ngi/utils/utils.rb +4 -21
  35. data/lib/ngi/version.rb +1 -1
  36. data/ngi.gemspec +2 -1
  37. data/test/config/config.components.aliases.yml +3 -0
  38. data/test/config/config.components.yml +55 -0
  39. data/test/config/config.configurable.yml +2 -0
  40. data/test/config/config.languages.yml +5 -0
  41. data/test/config/config.yml +4 -0
  42. data/test/finished_files/script/coffee/directive.finished.coffee +20 -0
  43. data/test/finished_files/script/es5/controller.finished.js +13 -0
  44. data/test/finished_files/script/es5/directive.finished.js +25 -0
  45. data/test/finished_files/script/es5/filter.finished.js +18 -0
  46. data/test/templates/markup/html/default/index.html +11 -0
  47. data/test/templates/script/coffee/default/basic.js +23 -0
  48. data/test/templates/script/coffee/default/config.js +12 -0
  49. data/test/templates/script/coffee/default/constant.js +7 -0
  50. data/test/templates/script/coffee/default/module.js +7 -0
  51. data/test/templates/script/es5/default/basic.js +29 -0
  52. data/test/templates/script/es5/default/config.js +13 -0
  53. data/test/templates/script/es5/default/constant.js +7 -0
  54. data/test/templates/script/es5/default/module.js +7 -0
  55. data/test/test_ngi.rb +274 -56
  56. data/test/testing_utils.rb +26 -0
  57. metadata +78 -36
  58. data/lib/dep/json.rb +0 -62
  59. data/lib/dep/json/add/bigdecimal.rb +0 -28
  60. data/lib/dep/json/add/complex.rb +0 -28
  61. data/lib/dep/json/add/core.rb +0 -11
  62. data/lib/dep/json/add/date.rb +0 -34
  63. data/lib/dep/json/add/date_time.rb +0 -50
  64. data/lib/dep/json/add/exception.rb +0 -31
  65. data/lib/dep/json/add/ostruct.rb +0 -31
  66. data/lib/dep/json/add/range.rb +0 -29
  67. data/lib/dep/json/add/rational.rb +0 -27
  68. data/lib/dep/json/add/regexp.rb +0 -30
  69. data/lib/dep/json/add/struct.rb +0 -30
  70. data/lib/dep/json/add/symbol.rb +0 -25
  71. data/lib/dep/json/add/time.rb +0 -38
  72. data/lib/dep/json/common.rb +0 -484
  73. data/lib/dep/json/ext.rb +0 -21
  74. data/lib/dep/json/ext/.keep +0 -0
  75. data/lib/dep/json/generic_object.rb +0 -70
  76. data/lib/dep/json/pure.rb +0 -21
  77. data/lib/dep/json/pure/generator.rb +0 -522
  78. data/lib/dep/json/pure/parser.rb +0 -359
  79. data/lib/dep/json/version.rb +0 -8
  80. data/test/sup/test.config.json +0 -100
@@ -1,62 +0,0 @@
1
- require 'json/common'
2
-
3
- ##
4
- # = JavaScript Object Notation (JSON)
5
- #
6
- # JSON is a lightweight data-interchange format. It is easy for us
7
- # humans to read and write. Plus, equally simple for machines to generate or parse.
8
- # JSON is completely language agnostic, making it the ideal interchange format.
9
- #
10
- # Built on two universally available structures:
11
- # 1. A collection of name/value pairs. Often referred to as an _object_, hash table, record, struct, keyed list, or associative array.
12
- # 2. An ordered list of values. More commonly called an _array_, vector, sequence or list.
13
- #
14
- # To read more about JSON visit: http://json.org
15
- #
16
- # == Parsing JSON
17
- #
18
- # To parse a JSON string received by another application or generated within
19
- # your existing application:
20
- #
21
- # require 'json'
22
- #
23
- # my_hash = JSON.parse('{"hello": "goodbye"}')
24
- # puts my_hash["hello"] => "goodbye"
25
- #
26
- # Notice the extra quotes <tt>''</tt> around the hash notation. Ruby expects
27
- # the argument to be a string and can't convert objects like a hash or array.
28
- #
29
- # Ruby converts your string into a hash
30
- #
31
- # == Generating JSON
32
- #
33
- # Creating a JSON string for communication or serialization is
34
- # just as simple.
35
- #
36
- # require 'json'
37
- #
38
- # my_hash = {:hello => "goodbye"}
39
- # puts JSON.generate(my_hash) => "{\"hello\":\"goodbye\"}"
40
- #
41
- # Or an alternative way:
42
- #
43
- # require 'json'
44
- # puts {:hello => "goodbye"}.to_json => "{\"hello\":\"goodbye\"}"
45
- #
46
- # <tt>JSON.generate</tt> only allows objects or arrays to be converted
47
- # to JSON syntax. <tt>to_json</tt>, however, accepts many Ruby classes
48
- # even though it acts only as a method for serialization:
49
- #
50
- # require 'json'
51
- #
52
- # 1.to_json => "1"
53
- #
54
- module JSON
55
- require 'json/version'
56
-
57
- begin
58
- require 'json/ext'
59
- rescue LoadError
60
- require 'json/pure'
61
- end
62
- end
@@ -1,28 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
- defined?(::BigDecimal) or require 'bigdecimal'
5
-
6
- class BigDecimal
7
- # Import a JSON Marshalled object.
8
- #
9
- # method used for JSON marshalling support.
10
- def self.json_create(object)
11
- BigDecimal._load object['b']
12
- end
13
-
14
- # Marshal the object to JSON.
15
- #
16
- # method used for JSON marshalling support.
17
- def as_json(*)
18
- {
19
- JSON.create_id => self.class.name,
20
- 'b' => _dump,
21
- }
22
- end
23
-
24
- # return the JSON value
25
- def to_json(*)
26
- as_json.to_json
27
- end
28
- end
@@ -1,28 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
- defined?(::Complex) or require 'complex'
5
-
6
- class Complex
7
-
8
- # Deserializes JSON string by converting Real value <tt>r</tt>, imaginary
9
- # value <tt>i</tt>, to a Complex object.
10
- def self.json_create(object)
11
- Complex(object['r'], object['i'])
12
- end
13
-
14
- # Returns a hash, that will be turned into a JSON object and represent this
15
- # object.
16
- def as_json(*)
17
- {
18
- JSON.create_id => self.class.name,
19
- 'r' => real,
20
- 'i' => imag,
21
- }
22
- end
23
-
24
- # Stores class name (Complex) along with real value <tt>r</tt> and imaginary value <tt>i</tt> as JSON string
25
- def to_json(*)
26
- as_json.to_json
27
- end
28
- end
@@ -1,11 +0,0 @@
1
- # This file requires the implementations of ruby core's custom objects for
2
- # serialisation/deserialisation.
3
-
4
- require 'json/add/date'
5
- require 'json/add/date_time'
6
- require 'json/add/exception'
7
- require 'json/add/range'
8
- require 'json/add/regexp'
9
- require 'json/add/struct'
10
- require 'json/add/symbol'
11
- require 'json/add/time'
@@ -1,34 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
- require 'date'
5
-
6
- # Date serialization/deserialization
7
- class Date
8
-
9
- # Deserializes JSON string by converting Julian year <tt>y</tt>, month
10
- # <tt>m</tt>, day <tt>d</tt> and Day of Calendar Reform <tt>sg</tt> to Date.
11
- def self.json_create(object)
12
- civil(*object.values_at('y', 'm', 'd', 'sg'))
13
- end
14
-
15
- alias start sg unless method_defined?(:start)
16
-
17
- # Returns a hash, that will be turned into a JSON object and represent this
18
- # object.
19
- def as_json(*)
20
- {
21
- JSON.create_id => self.class.name,
22
- 'y' => year,
23
- 'm' => month,
24
- 'd' => day,
25
- 'sg' => start,
26
- }
27
- end
28
-
29
- # Stores class name (Date) with Julian year <tt>y</tt>, month <tt>m</tt>, day
30
- # <tt>d</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
31
- def to_json(*args)
32
- as_json.to_json(*args)
33
- end
34
- end
@@ -1,50 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
- require 'date'
5
-
6
- # DateTime serialization/deserialization
7
- class DateTime
8
-
9
- # Deserializes JSON string by converting year <tt>y</tt>, month <tt>m</tt>,
10
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
11
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> to DateTime.
12
- def self.json_create(object)
13
- args = object.values_at('y', 'm', 'd', 'H', 'M', 'S')
14
- of_a, of_b = object['of'].split('/')
15
- if of_b and of_b != '0'
16
- args << Rational(of_a.to_i, of_b.to_i)
17
- else
18
- args << of_a
19
- end
20
- args << object['sg']
21
- civil(*args)
22
- end
23
-
24
- alias start sg unless method_defined?(:start)
25
-
26
- # Returns a hash, that will be turned into a JSON object and represent this
27
- # object.
28
- def as_json(*)
29
- {
30
- JSON.create_id => self.class.name,
31
- 'y' => year,
32
- 'm' => month,
33
- 'd' => day,
34
- 'H' => hour,
35
- 'M' => min,
36
- 'S' => sec,
37
- 'of' => offset.to_s,
38
- 'sg' => start,
39
- }
40
- end
41
-
42
- # Stores class name (DateTime) with Julian year <tt>y</tt>, month <tt>m</tt>,
43
- # day <tt>d</tt>, hour <tt>H</tt>, minute <tt>M</tt>, second <tt>S</tt>,
44
- # offset <tt>of</tt> and Day of Calendar Reform <tt>sg</tt> as JSON string
45
- def to_json(*args)
46
- as_json.to_json(*args)
47
- end
48
- end
49
-
50
-
@@ -1,31 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
-
5
- # Exception serialization/deserialization
6
- class Exception
7
-
8
- # Deserializes JSON string by constructing new Exception object with message
9
- # <tt>m</tt> and backtrace <tt>b</tt> serialized with <tt>to_json</tt>
10
- def self.json_create(object)
11
- result = new(object['m'])
12
- result.set_backtrace object['b']
13
- result
14
- end
15
-
16
- # Returns a hash, that will be turned into a JSON object and represent this
17
- # object.
18
- def as_json(*)
19
- {
20
- JSON.create_id => self.class.name,
21
- 'm' => message,
22
- 'b' => backtrace,
23
- }
24
- end
25
-
26
- # Stores class name (Exception) with message <tt>m</tt> and backtrace array
27
- # <tt>b</tt> as JSON string
28
- def to_json(*args)
29
- as_json.to_json(*args)
30
- end
31
- end
@@ -1,31 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
- require 'ostruct'
5
-
6
- # OpenStruct serialization/deserialization
7
- class OpenStruct
8
-
9
- # Deserializes JSON string by constructing new Struct object with values
10
- # <tt>v</tt> serialized by <tt>to_json</tt>.
11
- def self.json_create(object)
12
- new(object['t'] || object[:t])
13
- end
14
-
15
- # Returns a hash, that will be turned into a JSON object and represent this
16
- # object.
17
- def as_json(*)
18
- klass = self.class.name
19
- klass.to_s.empty? and raise JSON::JSONError, "Only named structs are supported!"
20
- {
21
- JSON.create_id => klass,
22
- 't' => table,
23
- }
24
- end
25
-
26
- # Stores class name (OpenStruct) with this struct's values <tt>v</tt> as a
27
- # JSON string.
28
- def to_json(*args)
29
- as_json.to_json(*args)
30
- end
31
- end
@@ -1,29 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
-
5
- # Range serialization/deserialization
6
- class Range
7
-
8
- # Deserializes JSON string by constructing new Range object with arguments
9
- # <tt>a</tt> serialized by <tt>to_json</tt>.
10
- def self.json_create(object)
11
- new(*object['a'])
12
- end
13
-
14
- # Returns a hash, that will be turned into a JSON object and represent this
15
- # object.
16
- def as_json(*)
17
- {
18
- JSON.create_id => self.class.name,
19
- 'a' => [ first, last, exclude_end? ]
20
- }
21
- end
22
-
23
- # Stores class name (Range) with JSON array of arguments <tt>a</tt> which
24
- # include <tt>first</tt> (integer), <tt>last</tt> (integer), and
25
- # <tt>exclude_end?</tt> (boolean) as JSON string.
26
- def to_json(*args)
27
- as_json.to_json(*args)
28
- end
29
- end
@@ -1,27 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
- defined?(::Rational) or require 'rational'
5
-
6
- class Rational
7
- # Deserializes JSON string by converting numerator value <tt>n</tt>,
8
- # denominator value <tt>d</tt>, to a Rational object.
9
- def self.json_create(object)
10
- Rational(object['n'], object['d'])
11
- end
12
-
13
- # Returns a hash, that will be turned into a JSON object and represent this
14
- # object.
15
- def as_json(*)
16
- {
17
- JSON.create_id => self.class.name,
18
- 'n' => numerator,
19
- 'd' => denominator,
20
- }
21
- end
22
-
23
- # Stores class name (Rational) along with numerator value <tt>n</tt> and denominator value <tt>d</tt> as JSON string
24
- def to_json(*)
25
- as_json.to_json
26
- end
27
- end
@@ -1,30 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
-
5
- # Regexp serialization/deserialization
6
- class Regexp
7
-
8
- # Deserializes JSON string by constructing new Regexp object with source
9
- # <tt>s</tt> (Regexp or String) and options <tt>o</tt> serialized by
10
- # <tt>to_json</tt>
11
- def self.json_create(object)
12
- new(object['s'], object['o'])
13
- end
14
-
15
- # Returns a hash, that will be turned into a JSON object and represent this
16
- # object.
17
- def as_json(*)
18
- {
19
- JSON.create_id => self.class.name,
20
- 'o' => options,
21
- 's' => source,
22
- }
23
- end
24
-
25
- # Stores class name (Regexp) with options <tt>o</tt> and source <tt>s</tt>
26
- # (Regexp or String) as JSON string
27
- def to_json(*)
28
- as_json.to_json
29
- end
30
- end
@@ -1,30 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
-
5
- # Struct serialization/deserialization
6
- class Struct
7
-
8
- # Deserializes JSON string by constructing new Struct object with values
9
- # <tt>v</tt> serialized by <tt>to_json</tt>.
10
- def self.json_create(object)
11
- new(*object['v'])
12
- end
13
-
14
- # Returns a hash, that will be turned into a JSON object and represent this
15
- # object.
16
- def as_json(*)
17
- klass = self.class.name
18
- klass.to_s.empty? and raise JSON::JSONError, "Only named structs are supported!"
19
- {
20
- JSON.create_id => klass,
21
- 'v' => values,
22
- }
23
- end
24
-
25
- # Stores class name (Struct) with Struct values <tt>v</tt> as a JSON string.
26
- # Only named structs are supported.
27
- def to_json(*args)
28
- as_json.to_json(*args)
29
- end
30
- end
@@ -1,25 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
-
5
- # Symbol serialization/deserialization
6
- class Symbol
7
- # Returns a hash, that will be turned into a JSON object and represent this
8
- # object.
9
- def as_json(*)
10
- {
11
- JSON.create_id => self.class.name,
12
- 's' => to_s,
13
- }
14
- end
15
-
16
- # Stores class name (Symbol) with String representation of Symbol as a JSON string.
17
- def to_json(*a)
18
- as_json.to_json(*a)
19
- end
20
-
21
- # Deserializes JSON string by converting the <tt>string</tt> value stored in the object to a Symbol
22
- def self.json_create(o)
23
- o['s'].to_sym
24
- end
25
- end
@@ -1,38 +0,0 @@
1
- unless defined?(::JSON::JSON_LOADED) and ::JSON::JSON_LOADED
2
- require 'json'
3
- end
4
-
5
- # Time serialization/deserialization
6
- class Time
7
-
8
- # Deserializes JSON string by converting time since epoch to Time
9
- def self.json_create(object)
10
- if usec = object.delete('u') # used to be tv_usec -> tv_nsec
11
- object['n'] = usec * 1000
12
- end
13
- if method_defined?(:tv_nsec)
14
- at(object['s'], Rational(object['n'], 1000))
15
- else
16
- at(object['s'], object['n'] / 1000)
17
- end
18
- end
19
-
20
- # Returns a hash, that will be turned into a JSON object and represent this
21
- # object.
22
- def as_json(*)
23
- nanoseconds = [ tv_usec * 1000 ]
24
- respond_to?(:tv_nsec) and nanoseconds << tv_nsec
25
- nanoseconds = nanoseconds.max
26
- {
27
- JSON.create_id => self.class.name,
28
- 's' => tv_sec,
29
- 'n' => nanoseconds,
30
- }
31
- end
32
-
33
- # Stores class name (Time) with number of seconds since epoch and number of
34
- # microseconds for Time as JSON string
35
- def to_json(*args)
36
- as_json.to_json(*args)
37
- end
38
- end