rkwalify 1.4.0.pre.preview1
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 +7 -0
- data/.github/workflows/ruby.yml +39 -0
- data/.gitignore +61 -0
- data/.overcommit.yml +33 -0
- data/.rubocop.yml +9 -0
- data/.rubocop_todo.yml +1369 -0
- data/.ruby-version +1 -0
- data/Attic/README-0.7.2.md +53 -0
- data/Attic/features/cli.feature +9 -0
- data/Attic/features/step_definitions/validation_steps.rb +20 -0
- data/Attic/features/support/env.rb +4 -0
- data/Attic/features/validate_schema.feature +12 -0
- data/Attic/s+h +53 -0
- data/Attic/setup.rb +1556 -0
- data/Attic/spec/my_cli_tool_spec.rb +52 -0
- data/Attic/spec/rspec-ex_spec.rb +10 -0
- data/Attic/spec/spec_helper.rb +104 -0
- data/Attic/test-15.1.rb +28 -0
- data/CHANGELOG.md +292 -0
- data/CONTRIBUTING.md +23 -0
- data/CONTRIBUTORS.md +8 -0
- data/Gemfile +16 -0
- data/Gemfile.lock +146 -0
- data/MIT-LICENSE +21 -0
- data/README.md +53 -0
- data/ROLL-OUT-STRATEGY.md +77 -0
- data/Rakefile +11 -0
- data/bin/kwalify.rb +4167 -0
- data/bin/kwalify.schema.yaml +59 -0
- data/contrib/inline-require +181 -0
- data/contrib/kwalify +4167 -0
- data/contrib/kwalify-0.7.2 +4160 -0
- data/devbin/README.md +22 -0
- data/devbin/chk-rad-repo.sh +20 -0
- data/devbin/chkcopyrights.sh +42 -0
- data/devbin/chkspelling.sh +16 -0
- data/devbin/got-all-rel-numbers.sh +5 -0
- data/devbin/mkbig-rkwalify.sh +7 -0
- data/devbin/mkgem_file.sh +5 -0
- data/devbin/runtests.sh +6 -0
- data/devbin/ug-tests.golden +242 -0
- data/devbin/ug-tests.sh +145 -0
- data/devbin/update-rel-numbers.sh +7 -0
- data/doc/docstyle.css +188 -0
- data/doc/img/fig01.png +0 -0
- data/doc/users-guide.html +2051 -0
- data/doc-api/classes/CommandOptionError.html +184 -0
- data/doc-api/classes/CommandOptionParser.html +325 -0
- data/doc-api/classes/Kwalify/AssertionError.html +148 -0
- data/doc-api/classes/Kwalify/BaseError.html +297 -0
- data/doc-api/classes/Kwalify/BaseParser.html +461 -0
- data/doc-api/classes/Kwalify/CommandOptionError.html +168 -0
- data/doc-api/classes/Kwalify/ErrorHelper.html +223 -0
- data/doc-api/classes/Kwalify/HashInterface.html +118 -0
- data/doc-api/classes/Kwalify/Json.html +105 -0
- data/doc-api/classes/Kwalify/KwalifyError.html +111 -0
- data/doc-api/classes/Kwalify/Main.html +339 -0
- data/doc-api/classes/Kwalify/MetaValidator.html +448 -0
- data/doc-api/classes/Kwalify/Parser.html +155 -0
- data/doc-api/classes/Kwalify/PlainYamlParser/Alias.html +165 -0
- data/doc-api/classes/Kwalify/PlainYamlParser.html +523 -0
- data/doc-api/classes/Kwalify/Rule.html +433 -0
- data/doc-api/classes/Kwalify/SchemaError.html +148 -0
- data/doc-api/classes/Kwalify/SyntaxError.html +185 -0
- data/doc-api/classes/Kwalify/Types.html +302 -0
- data/doc-api/classes/Kwalify/Util/HashLike.html +246 -0
- data/doc-api/classes/Kwalify/Util/OrderedHash.html +330 -0
- data/doc-api/classes/Kwalify/Util.html +390 -0
- data/doc-api/classes/Kwalify/ValidationError.html +148 -0
- data/doc-api/classes/Kwalify/Validator.html +381 -0
- data/doc-api/classes/Kwalify/Yaml/Parser.html +1538 -0
- data/doc-api/classes/Kwalify/Yaml.html +194 -0
- data/doc-api/classes/Kwalify/YamlParser.html +542 -0
- data/doc-api/classes/Kwalify/YamlSyntaxError.html +119 -0
- data/doc-api/classes/Kwalify.html +292 -0
- data/doc-api/classes/Test/Unit.html +101 -0
- data/doc-api/classes/Test.html +107 -0
- data/doc-api/created.rid +1 -0
- data/doc-api/files/__/README_txt.html +153 -0
- data/doc-api/files/kwalify/errors_rb.html +114 -0
- data/doc-api/files/kwalify/main_rb.html +118 -0
- data/doc-api/files/kwalify/messages_rb.html +107 -0
- data/doc-api/files/kwalify/meta-validator_rb.html +117 -0
- data/doc-api/files/kwalify/parser/base_rb.html +116 -0
- data/doc-api/files/kwalify/parser/yaml_rb.html +117 -0
- data/doc-api/files/kwalify/rule_rb.html +116 -0
- data/doc-api/files/kwalify/types_rb.html +114 -0
- data/doc-api/files/kwalify/util/assert-text-equal_rb.html +115 -0
- data/doc-api/files/kwalify/util/hash-interface_rb.html +114 -0
- data/doc-api/files/kwalify/util/hashlike_rb.html +107 -0
- data/doc-api/files/kwalify/util/option-parser_rb.html +107 -0
- data/doc-api/files/kwalify/util/ordered-hash_rb.html +107 -0
- data/doc-api/files/kwalify/util/testcase-helper_rb.html +115 -0
- data/doc-api/files/kwalify/util_rb.html +107 -0
- data/doc-api/files/kwalify/validator_rb.html +117 -0
- data/doc-api/files/kwalify/yaml-parser_rb.html +117 -0
- data/doc-api/files/kwalify_rb.html +121 -0
- data/doc-api/fr_class_index.html +57 -0
- data/doc-api/fr_file_index.html +45 -0
- data/doc-api/fr_method_index.html +168 -0
- data/doc-api/index.html +24 -0
- data/doc-api/rdoc-style.css +208 -0
- data/examples/address-book/Makefile +10 -0
- data/examples/address-book/address-book.schema.yaml +45 -0
- data/examples/address-book/address-book.yaml +36 -0
- data/examples/data-binding/BABEL.data.yaml +63 -0
- data/examples/data-binding/BABEL.schema.yaml +31 -0
- data/examples/data-binding/Makefile +8 -0
- data/examples/data-binding/Rakefile +13 -0
- data/examples/data-binding/main.rb +25 -0
- data/examples/invoice/Makefile +9 -0
- data/examples/invoice/invoice.schema.yaml +43 -0
- data/examples/invoice/invoice.yaml +32 -0
- data/examples/tapkit/Makefile +10 -0
- data/examples/tapkit/main.rb +7 -0
- data/examples/tapkit/tapkit.schema.yaml +146 -0
- data/examples/tapkit/tapkit.yaml +85 -0
- data/lib/kwalify/errors.rb +127 -0
- data/lib/kwalify/kwalify.schema.yaml +58 -0
- data/lib/kwalify/main.rb +442 -0
- data/lib/kwalify/messages.rb +173 -0
- data/lib/kwalify/meta-validator.rb +276 -0
- data/lib/kwalify/parser/base.rb +128 -0
- data/lib/kwalify/parser/yaml.rb +841 -0
- data/lib/kwalify/rule.rb +562 -0
- data/lib/kwalify/templates/genclass-java.eruby +222 -0
- data/lib/kwalify/templates/genclass-php.eruby +104 -0
- data/lib/kwalify/templates/genclass-ruby.eruby +113 -0
- data/lib/kwalify/types.rb +156 -0
- data/lib/kwalify/util/assert-text-equal.rb +46 -0
- data/lib/kwalify/util/hash-interface.rb +18 -0
- data/lib/kwalify/util/hashlike.rb +51 -0
- data/lib/kwalify/util/option-parser.rb +220 -0
- data/lib/kwalify/util/ordered-hash.rb +57 -0
- data/lib/kwalify/util/testcase-helper.rb +112 -0
- data/lib/kwalify/util.rb +159 -0
- data/lib/kwalify/validator.rb +282 -0
- data/lib/kwalify/version.rb +5 -0
- data/lib/kwalify/yaml-parser.rb +871 -0
- data/lib/kwalify.rb +61 -0
- data/rkwalify.gemspec +26 -0
- data/test/Rookbook.yaml +15 -0
- data/test/data/users-guide/AddressBook.java.expected +40 -0
- data/test/data/users-guide/BABEL.data.yaml +24 -0
- data/test/data/users-guide/BABEL.schema.yaml +30 -0
- data/test/data/users-guide/ExampleAddressBook.java +47 -0
- data/test/data/users-guide/Group.java.expected +24 -0
- data/test/data/users-guide/Person.java.expected +44 -0
- data/test/data/users-guide/address_book.rb +52 -0
- data/test/data/users-guide/address_book.schema.yaml +28 -0
- data/test/data/users-guide/address_book.yaml +27 -0
- data/test/data/users-guide/answers-schema.yaml +12 -0
- data/test/data/users-guide/answers-validator.rb +53 -0
- data/test/data/users-guide/babel_genclass.result +26 -0
- data/test/data/users-guide/config.schema.yaml +7 -0
- data/test/data/users-guide/config.yaml +4 -0
- data/test/data/users-guide/document01a.yaml +3 -0
- data/test/data/users-guide/document01b.yaml +3 -0
- data/test/data/users-guide/document02a.yaml +4 -0
- data/test/data/users-guide/document02b.yaml +4 -0
- data/test/data/users-guide/document03a.yaml +6 -0
- data/test/data/users-guide/document03b.yaml +6 -0
- data/test/data/users-guide/document04a.yaml +9 -0
- data/test/data/users-guide/document04b.yaml +9 -0
- data/test/data/users-guide/document05a.yaml +11 -0
- data/test/data/users-guide/document05b.yaml +12 -0
- data/test/data/users-guide/document06a.yaml +15 -0
- data/test/data/users-guide/document06b.yaml +16 -0
- data/test/data/users-guide/document07a.yaml +9 -0
- data/test/data/users-guide/document07b.yaml +7 -0
- data/test/data/users-guide/document12a.json +10 -0
- data/test/data/users-guide/document12b.json +6 -0
- data/test/data/users-guide/document13a.yaml +17 -0
- data/test/data/users-guide/document14a.yaml +3 -0
- data/test/data/users-guide/document14b.yaml +3 -0
- data/test/data/users-guide/document15a.yaml +6 -0
- data/test/data/users-guide/document15b.yaml +5 -0
- data/test/data/users-guide/example_address_book.rb +11 -0
- data/test/data/users-guide/example_address_book_java.result +32 -0
- data/test/data/users-guide/example_address_book_ruby.result +31 -0
- data/test/data/users-guide/genclass_java.result +4 -0
- data/test/data/users-guide/howto-validation-with-parsing.rb +28 -0
- data/test/data/users-guide/howto-validation.rb +25 -0
- data/test/data/users-guide/howto3.rb +6 -0
- data/test/data/users-guide/howto3.result +5 -0
- data/test/data/users-guide/howto3.yaml +8 -0
- data/test/data/users-guide/howto5_databinding.result +111 -0
- data/test/data/users-guide/invalid01.result +3 -0
- data/test/data/users-guide/invalid02.result +5 -0
- data/test/data/users-guide/invalid03.result +5 -0
- data/test/data/users-guide/invalid04.result +4 -0
- data/test/data/users-guide/invalid05.result +11 -0
- data/test/data/users-guide/invalid06.result +4 -0
- data/test/data/users-guide/invalid07.result +3 -0
- data/test/data/users-guide/invalid08.result +3 -0
- data/test/data/users-guide/invalid12.json +8 -0
- data/test/data/users-guide/invalid14.result +4 -0
- data/test/data/users-guide/invalid15.result +4 -0
- data/test/data/users-guide/loadbabel.rb +27 -0
- data/test/data/users-guide/loadconfig.rb +17 -0
- data/test/data/users-guide/loadconfig.result +6 -0
- data/test/data/users-guide/models.rb +24 -0
- data/test/data/users-guide/option_ha.result +6 -0
- data/test/data/users-guide/option_ha_genclass_java.result +7 -0
- data/test/data/users-guide/schema01.yaml +3 -0
- data/test/data/users-guide/schema02.yaml +12 -0
- data/test/data/users-guide/schema03.yaml +9 -0
- data/test/data/users-guide/schema04.yaml +20 -0
- data/test/data/users-guide/schema05.yaml +29 -0
- data/test/data/users-guide/schema06.yaml +11 -0
- data/test/data/users-guide/schema12.json +12 -0
- data/test/data/users-guide/schema13.yaml +13 -0
- data/test/data/users-guide/schema14.yaml +5 -0
- data/test/data/users-guide/schema15.yaml +21 -0
- data/test/data/users-guide/valid01.result +2 -0
- data/test/data/users-guide/valid02.result +2 -0
- data/test/data/users-guide/valid03.result +2 -0
- data/test/data/users-guide/valid04.result +2 -0
- data/test/data/users-guide/valid05.result +2 -0
- data/test/data/users-guide/valid06.result +2 -0
- data/test/data/users-guide/valid07.result +2 -0
- data/test/data/users-guide/valid08.result +2 -0
- data/test/data/users-guide/valid12.result +2 -0
- data/test/data/users-guide/valid13.result +2 -0
- data/test/data/users-guide/valid14.result +2 -0
- data/test/data/users-guide/valid15.result +2 -0
- data/test/data/users-guide/validate08.rb +37 -0
- data/test/test-action.rb +73 -0
- data/test/test-action.yaml +738 -0
- data/test/test-databinding.rb +84 -0
- data/test/test-databinding.yaml +339 -0
- data/test/test-main.rb +156 -0
- data/test/test-main.yaml +409 -0
- data/test/test-metavalidator.rb +80 -0
- data/test/test-metavalidator.yaml +1179 -0
- data/test/test-parser-yaml.rb +57 -0
- data/test/test-parser-yaml.yaml +1750 -0
- data/test/test-rule.rb +26 -0
- data/test/test-rule.yaml +317 -0
- data/test/test-users-guide.rb +82 -0
- data/test/test-util.rb +125 -0
- data/test/test-validator.rb +95 -0
- data/test/test-validator.yaml +986 -0
- data/test/test-yaml-parser.rb +47 -0
- data/test/test-yaml-parser.yaml +1226 -0
- data/test/test.rb +75 -0
- metadata +293 -0
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
## $Rev$
|
|
3
|
+
## $Date$
|
|
4
|
+
## copyright(c) 2005-2010 kuwata-lab all rights reserved.
|
|
5
|
+
|
|
6
|
+
name: MAIN
|
|
7
|
+
type: map
|
|
8
|
+
required: yes
|
|
9
|
+
mapping: &main-rule
|
|
10
|
+
"name": { type: str }
|
|
11
|
+
"desc": { type: str }
|
|
12
|
+
"class": { type: str }
|
|
13
|
+
"type":
|
|
14
|
+
type: str
|
|
15
|
+
#required: yes
|
|
16
|
+
enum: [ seq, map, str, int, float, number, bool, text,
|
|
17
|
+
date, time, timestamp, any, scalar ]
|
|
18
|
+
"required": { type: bool } # equivarent to 'not-null'
|
|
19
|
+
"enum":
|
|
20
|
+
type: seq
|
|
21
|
+
sequence:
|
|
22
|
+
- type: scalar
|
|
23
|
+
unique: yes
|
|
24
|
+
"pattern": { type: str }
|
|
25
|
+
"assert": { type: str, pattern: /\bval\b/ }
|
|
26
|
+
"range":
|
|
27
|
+
type: map
|
|
28
|
+
mapping:
|
|
29
|
+
"max": { type: scalar }
|
|
30
|
+
"min": { type: scalar }
|
|
31
|
+
"max-ex": { type: scalar }
|
|
32
|
+
"min-ex": { type: scalar }
|
|
33
|
+
"length":
|
|
34
|
+
type: map
|
|
35
|
+
mapping:
|
|
36
|
+
"max": { type: int }
|
|
37
|
+
"min": { type: int }
|
|
38
|
+
"max-ex": { type: int }
|
|
39
|
+
"min-ex": { type: int }
|
|
40
|
+
"ident": { type: bool } # equivarent to 'primary-key' (undocumented)
|
|
41
|
+
"unique": { type: bool }
|
|
42
|
+
"default": { type: scalar } # used only in action's template
|
|
43
|
+
"sequence":
|
|
44
|
+
name: SEQUENCE
|
|
45
|
+
type: seq
|
|
46
|
+
sequence:
|
|
47
|
+
- type: map
|
|
48
|
+
mapping: *main-rule
|
|
49
|
+
name: MAIN
|
|
50
|
+
#required: yes
|
|
51
|
+
"mapping":
|
|
52
|
+
name: MAPPING
|
|
53
|
+
type: map
|
|
54
|
+
mapping:
|
|
55
|
+
=:
|
|
56
|
+
type: map
|
|
57
|
+
mapping: *main-rule
|
|
58
|
+
name: MAIN
|
|
59
|
+
#required: yes
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
#!/usr/bin/env ruby
|
|
2
|
+
|
|
3
|
+
###
|
|
4
|
+
### inline-require - expand 'require "foo"' into inline code
|
|
5
|
+
###
|
|
6
|
+
### usage: inline-require [-h] [-I path[,path2,..]] script
|
|
7
|
+
###
|
|
8
|
+
### copyright(c) 2005-2010 kuwata-lab all rights reserved.
|
|
9
|
+
### Release 1.4.0-preview1
|
|
10
|
+
### $Rev: 10 $
|
|
11
|
+
###
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class InlineRequire
|
|
15
|
+
|
|
16
|
+
def initialize(opts = {})
|
|
17
|
+
@opts = opts.dup
|
|
18
|
+
end
|
|
19
|
+
attr_accessor :opts
|
|
20
|
+
|
|
21
|
+
def expand(filename)
|
|
22
|
+
sbuf = ''
|
|
23
|
+
inlined = []
|
|
24
|
+
level = 0
|
|
25
|
+
expand_require(filename, sbuf, inlined, level)
|
|
26
|
+
return sbuf
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
private
|
|
30
|
+
|
|
31
|
+
def expand_require(filename, sbuf, inlined, level)
|
|
32
|
+
raise "*** assertion error" if inlined.include?(filename)
|
|
33
|
+
remove_comment = @opts[:remove_comment]
|
|
34
|
+
expand_indented = @opts[:expand_indented]
|
|
35
|
+
keep_filename = @opts[:keep_filename]
|
|
36
|
+
loaded_features = @opts[:loaded_features]
|
|
37
|
+
inlined << filename
|
|
38
|
+
prog = File.read(filename)
|
|
39
|
+
n = 0
|
|
40
|
+
flag_if_file = false
|
|
41
|
+
prog.each_line do |line|
|
|
42
|
+
n += 1
|
|
43
|
+
|
|
44
|
+
## comment out from 'if __FILE__ == $0' to 'end'
|
|
45
|
+
if level.positive?
|
|
46
|
+
if flag_if_file
|
|
47
|
+
sbuf << "#" << line
|
|
48
|
+
flag_if_file = false if line =~ /^end$/
|
|
49
|
+
next
|
|
50
|
+
end
|
|
51
|
+
if line =~ /^if\s+__FILE__\s*==\s*\$0(\s+then)?$/ || line =~ /^if\s+\$0\s*==\s*__FILE__(\s+then)?$/
|
|
52
|
+
flag_if_file = true
|
|
53
|
+
sbuf << "#" << line
|
|
54
|
+
next
|
|
55
|
+
end
|
|
56
|
+
end
|
|
57
|
+
|
|
58
|
+
## find 'require "foo"' and expand it to inline code
|
|
59
|
+
flag_inline = false
|
|
60
|
+
pattern = if expand_indented
|
|
61
|
+
/^[ \t]*require ['"](.*)["']\s*$/
|
|
62
|
+
else
|
|
63
|
+
/^require ['"](.*)["']\s*$/
|
|
64
|
+
end
|
|
65
|
+
if line =~ pattern
|
|
66
|
+
libname = ::Regexp.last_match(1)
|
|
67
|
+
libpath = find_library(libname)
|
|
68
|
+
warn "*** debug: libpath=#{libpath.inspect}" if $debug_mode
|
|
69
|
+
if libpath
|
|
70
|
+
flag_inline = true if libpath =~ /\.rb$/ && local_library?(libpath)
|
|
71
|
+
else
|
|
72
|
+
#raise "file '#{filename}'(line #{n}): library '#{libname}' not found."
|
|
73
|
+
warn "file '#{filename}'(line #{n}): library '#{libname}' not found."
|
|
74
|
+
end
|
|
75
|
+
end
|
|
76
|
+
if !flag_inline
|
|
77
|
+
sbuf << line unless remove_comment && line =~ /^[ \t]*\#/
|
|
78
|
+
elsif inlined.include?(libpath)
|
|
79
|
+
sbuf << "#--already included #{line}" unless remove_comment
|
|
80
|
+
else
|
|
81
|
+
if keep_filename
|
|
82
|
+
@n ||= 0
|
|
83
|
+
@n += 1
|
|
84
|
+
n = @n
|
|
85
|
+
end
|
|
86
|
+
sbuf << "#--begin of #{line}" unless remove_comment
|
|
87
|
+
sbuf << "$LOADED_FEATURES << '#{libname}.rb'\n" if loaded_features
|
|
88
|
+
sbuf << "eval <<'END_OF_SCRIPT__#{n}', TOPLEVEL_BINDING, '#{libpath}', 1\n" if keep_filename
|
|
89
|
+
expand_require(libpath, sbuf, inlined, level+1)
|
|
90
|
+
sbuf << "END_OF_SCRIPT__#{n}\n" if keep_filename
|
|
91
|
+
sbuf << "#--end of #{line}" unless remove_comment
|
|
92
|
+
end
|
|
93
|
+
end
|
|
94
|
+
#sbuf << "\n" if sbuf[-1] != ?\n
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
def local_library?(libpath)
|
|
98
|
+
return libpath !~ %r{^/}
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
def find_library(libname)
|
|
102
|
+
if libname =~ /^\.rb$/
|
|
103
|
+
libname_rb = libname
|
|
104
|
+
libname_so = nil
|
|
105
|
+
elsif libname =~ /^\.so$/
|
|
106
|
+
libname_rb = nil
|
|
107
|
+
libname_so = libname
|
|
108
|
+
else
|
|
109
|
+
libname_rb = libname + ".rb"
|
|
110
|
+
libname_so = libname + ".so"
|
|
111
|
+
end
|
|
112
|
+
$LOAD_PATH.each do |path|
|
|
113
|
+
if libname_rb
|
|
114
|
+
libpath = path + "/" + libname_rb
|
|
115
|
+
return libpath if test('f', libpath)
|
|
116
|
+
end
|
|
117
|
+
if libname_so
|
|
118
|
+
libpath = path + "/" + libname_so
|
|
119
|
+
return libpath if test('f', libpath)
|
|
120
|
+
end
|
|
121
|
+
end
|
|
122
|
+
return nil
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
if __FILE__ == $PROGRAM_NAME
|
|
128
|
+
|
|
129
|
+
begin
|
|
130
|
+
require "optparse"
|
|
131
|
+
op = OptionParser.new
|
|
132
|
+
options = {}
|
|
133
|
+
op.on("-h", "--help") { |v| options[:help] = v }
|
|
134
|
+
op.on("-I libpath") { |v| options[:libpath] = v }
|
|
135
|
+
op.on("-i") { |v| options[:expand_indented] = v }
|
|
136
|
+
op.on("-c") { |v| options[:remove_comment] = v }
|
|
137
|
+
op.on("-k") { |v| options[:keep_filename] = v }
|
|
138
|
+
op.on("-l") { |v| options[:loaded_features] = v }
|
|
139
|
+
op.on("-D") { |v| options[:debug] = v }
|
|
140
|
+
op.parse!()
|
|
141
|
+
|
|
142
|
+
$debug_mode = options[:debug]
|
|
143
|
+
|
|
144
|
+
if options[:help]
|
|
145
|
+
command = File.basename($PROGRAM_NAME)
|
|
146
|
+
puts "Usage: #{command} [-h] [-I path[,path2,..]] script"
|
|
147
|
+
puts " -h : help"
|
|
148
|
+
puts " -i : expand indented require(), too"
|
|
149
|
+
puts " -c : remove comment lines start with '#'"
|
|
150
|
+
puts " -k : keep filename (for debugging)"
|
|
151
|
+
puts " -l : append libs to $LOADED_FEATURES"
|
|
152
|
+
puts " -I path[,path2,...] : ruby library path"
|
|
153
|
+
exit(0)
|
|
154
|
+
end
|
|
155
|
+
|
|
156
|
+
rubylib_paths = if options[:libpath]
|
|
157
|
+
options[:libpath].split(',')
|
|
158
|
+
else
|
|
159
|
+
[]
|
|
160
|
+
end
|
|
161
|
+
warn "*** debug: rubylib_paths=#{rubylib_paths.inspect}" if $debug_mode
|
|
162
|
+
$LOAD_PATH.concat(rubylib_paths)
|
|
163
|
+
|
|
164
|
+
filenames = ARGV
|
|
165
|
+
|
|
166
|
+
opts = { expand_indented: options[:expand_indented],
|
|
167
|
+
remove_comment: options[:remove_comment],
|
|
168
|
+
keep_filename: options[:keep_filename],
|
|
169
|
+
loaded_features: options[:loaded_features] }
|
|
170
|
+
inline_require = InlineRequire.new(opts)
|
|
171
|
+
filenames.each do |filename|
|
|
172
|
+
print inline_require.expand(filename)
|
|
173
|
+
end
|
|
174
|
+
rescue StandardError => e
|
|
175
|
+
raise e if $debug_mode
|
|
176
|
+
|
|
177
|
+
|
|
178
|
+
warn e.message
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
end
|