thor 0.20.3 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
data/thor.gemspec CHANGED
@@ -4,7 +4,7 @@ $LOAD_PATH.unshift lib unless $LOAD_PATH.include?(lib)
4
4
  require "thor/version"
5
5
 
6
6
  Gem::Specification.new do |spec|
7
- spec.add_development_dependency "bundler", "~> 1.0"
7
+ spec.add_development_dependency "bundler", ">= 1.0", "< 3"
8
8
  spec.authors = ["Yehuda Katz", "José Valim"]
9
9
  spec.description = "Thor is a toolkit for building powerful command-line interfaces."
10
10
  spec.email = "ruby-thor@googlegroups.com"
@@ -13,8 +13,15 @@ Gem::Specification.new do |spec|
13
13
  spec.homepage = "http://whatisthor.com/"
14
14
  spec.licenses = %w(MIT)
15
15
  spec.name = "thor"
16
+ spec.metadata = {
17
+ "bug_tracker_uri" => "https://github.com/rails/thor/issues",
18
+ "changelog_uri" => "https://github.com/rails/thor/releases/tag/v#{Thor::VERSION}",
19
+ "documentation_uri" => "http://whatisthor.com/",
20
+ "source_code_uri" => "https://github.com/rails/thor/tree/v#{Thor::VERSION}",
21
+ "wiki_uri" => "https://github.com/rails/thor/wiki"
22
+ }
16
23
  spec.require_paths = %w(lib)
17
- spec.required_ruby_version = ">= 1.8.7"
24
+ spec.required_ruby_version = ">= 2.0.0"
18
25
  spec.required_rubygems_version = ">= 1.3.5"
19
26
  spec.summary = spec.description
20
27
  spec.version = Thor::VERSION
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: thor
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.20.3
4
+ version: 1.2.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Yehuda Katz
@@ -9,22 +9,28 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2018-11-10 00:00:00.000000000 Z
12
+ date: 2022-01-04 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: bundler
16
16
  requirement: !ruby/object:Gem::Requirement
17
17
  requirements:
18
- - - "~>"
18
+ - - ">="
19
19
  - !ruby/object:Gem::Version
20
20
  version: '1.0'
21
+ - - "<"
22
+ - !ruby/object:Gem::Version
23
+ version: '3'
21
24
  type: :development
22
25
  prerelease: false
23
26
  version_requirements: !ruby/object:Gem::Requirement
24
27
  requirements:
25
- - - "~>"
28
+ - - ">="
26
29
  - !ruby/object:Gem::Version
27
30
  version: '1.0'
31
+ - - "<"
32
+ - !ruby/object:Gem::Version
33
+ version: '3'
28
34
  description: Thor is a toolkit for building powerful command-line interfaces.
29
35
  email: ruby-thor@googlegroups.com
30
36
  executables:
@@ -33,7 +39,6 @@ extensions: []
33
39
  extra_rdoc_files: []
34
40
  files:
35
41
  - ".document"
36
- - CHANGELOG.md
37
42
  - CONTRIBUTING.md
38
43
  - LICENSE.md
39
44
  - README.md
@@ -49,14 +54,13 @@ files:
49
54
  - lib/thor/base.rb
50
55
  - lib/thor/command.rb
51
56
  - lib/thor/core_ext/hash_with_indifferent_access.rb
52
- - lib/thor/core_ext/io_binary_read.rb
53
- - lib/thor/core_ext/ordered_hash.rb
54
57
  - lib/thor/error.rb
55
58
  - lib/thor/group.rb
56
59
  - lib/thor/invocation.rb
57
60
  - lib/thor/line_editor.rb
58
61
  - lib/thor/line_editor/basic.rb
59
62
  - lib/thor/line_editor/readline.rb
63
+ - lib/thor/nested_context.rb
60
64
  - lib/thor/parser.rb
61
65
  - lib/thor/parser/argument.rb
62
66
  - lib/thor/parser/arguments.rb
@@ -74,7 +78,12 @@ files:
74
78
  homepage: http://whatisthor.com/
75
79
  licenses:
76
80
  - MIT
77
- metadata: {}
81
+ metadata:
82
+ bug_tracker_uri: https://github.com/rails/thor/issues
83
+ changelog_uri: https://github.com/rails/thor/releases/tag/v1.2.0
84
+ documentation_uri: http://whatisthor.com/
85
+ source_code_uri: https://github.com/rails/thor/tree/v1.2.0
86
+ wiki_uri: https://github.com/rails/thor/wiki
78
87
  post_install_message:
79
88
  rdoc_options: []
80
89
  require_paths:
@@ -83,15 +92,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
83
92
  requirements:
84
93
  - - ">="
85
94
  - !ruby/object:Gem::Version
86
- version: 1.8.7
95
+ version: 2.0.0
87
96
  required_rubygems_version: !ruby/object:Gem::Requirement
88
97
  requirements:
89
98
  - - ">="
90
99
  - !ruby/object:Gem::Version
91
100
  version: 1.3.5
92
101
  requirements: []
93
- rubyforge_project:
94
- rubygems_version: 2.7.6
102
+ rubygems_version: 3.2.32
95
103
  signing_key:
96
104
  specification_version: 4
97
105
  summary: Thor is a toolkit for building powerful command-line interfaces.
data/CHANGELOG.md DELETED
@@ -1,204 +0,0 @@
1
- # 0.20.3
2
- * Support old versions of `did_you_mean`.
3
-
4
- # 0.20.2
5
- * Fix `did_you_mean` support.
6
-
7
- # 0.20.1
8
- * Support new versions fo ERB.
9
- * Fix `check_unknown_options!` to not check the content that was not parsed, i.e. after a `--` or after the first unknown with `stop_on_unknown_option!`
10
- * Add `did_you_mean` support.
11
-
12
- ## 0.20.0
13
- * Add `check_default_type!` to check if the default value of an option matches the defined type.
14
- It removes the warning on usage and gives the command authors the possibility to check for programming errors.
15
-
16
- * Add `disable_required_check!` to disable check for required options in some commands.
17
- It is a substitute of `disable_class_options` that was not working as intended.
18
-
19
- * Add `inject_into_module`.
20
-
21
- ## 0.19.4, release 2016-11-28
22
- * Rename `Thor::Base#thor_reserved_word?` to `#is_thor_reserved_word?`
23
-
24
- ## 0.19.3, release 2016-11-27
25
- * Output a warning instead of raising an exception when a default option value doesn't match its specified type
26
-
27
- ## 0.19.2, release 2016-11-26
28
- * Fix bug with handling of colors passed to `ask` (and methods like `yes?` and `no?` which it underpins)
29
- * Allow numeric arguments to be negative
30
- * Ensure that default option values are of the specified type (e.g. you can't specify `"foo"` as the default for a numeric option), but make symbols and strings interchangeable
31
- * Add `Thor::Shell::Basic#indent` method for intending output
32
- * Fix `remove_command` for an inherited command (see #451)
33
- * Allow hash arguments to only have each key provided once (see #455)
34
- * Allow commands to disable class options, for instance for "help" commands (see #363)
35
- * Do not generate a negative option (`--no-no-foo`) for already negative boolean options (`--no-foo`)
36
- * Improve compatibility of `Thor::CoreExt::HashWithIndifferentAccess` with Ruby standard library `Hash`
37
- * Allow specifying a custom binding for template evaluation (e.g. `#key?` and `#fetch`)
38
- * Fix support for subcommand-specific "help"s
39
- * Use a string buffer when handling ERB for Ruby 2.3 compatibility
40
- * Update dependencies
41
-
42
- ## 0.19.1, release 2014-03-24
43
- * Fix `say` non-String break regression
44
-
45
- ## 0.19.0, release 2014-03-22
46
- * Add support for a default to #ask
47
- * Avoid @namespace not initialized warning
48
- * Avoid private attribute? warning
49
- * Fix initializing with unknown options
50
- * Loosen required_rubygems_version for compatibility with Ubuntu 10.04
51
- * Shell#ask: support a noecho option for stdin
52
- * Shell#ask: change API to be :echo => false
53
- * Display a message without a stack trace for ambiguous commands
54
- * Make say and say_status thread safe
55
- * Dependency for console io version check
56
- * Alias --help to help on subcommands
57
- * Use mime-types 1.x for Ruby 1.8.7 compatibility for Ruby 1.8 only
58
- * Accept .tt files as templates
59
- * Check if numeric value is in enum
60
- * Use Readline for user input
61
- * Fix dispatching of subcommands (concerning :help and *args)
62
- * Fix warnings when running specs with `$VERBOSE = true`
63
- * Make subcommand help more consistent
64
- * Make the current command chain accessible in command
65
-
66
- ## 0.18.1, release 2013-03-30
67
- * Revert regressions found in 0.18.0
68
-
69
- ## 0.18.0, release 2013-03-26
70
- * Remove rake2thor
71
- * Only display colors if output medium supports colors
72
- * Pass parent_options to subcommands
73
- * Fix non-dash-prefixed aliases
74
- * Make error messages more helpful
75
- * Rename "task" to "command"
76
- * Add the method to allow for custom package name
77
-
78
- ## 0.17.0, release 2013-01-24
79
- * Add better support for tasks that accept arbitrary additional arguments (e.g. things like `bundle exec`)
80
- * Add #stop_on_unknown_option!
81
- * Only strip from stdin.gets if it wasn't ended with EOF
82
- * Allow "send" as a task name
83
- * Allow passing options as arguments after "--"
84
- * Autoload Thor::Group
85
-
86
- ## 0.16.0, release 2012-08-14
87
- * Add enum to string arguments
88
-
89
- ## 0.15.4, release 2012-06-29
90
- * Fix regression when destination root contains reserved regexp characters
91
-
92
- ## 0.15.3, release 2012-06-18
93
- * Support strict_args_position! for backwards compatibility
94
- * Escape Dir glob characters in paths
95
-
96
- ## 0.15.2, released 2012-05-07
97
- * Added print_in_columns
98
- * Exposed terminal_width as a public API
99
-
100
- ## 0.15.1, release 2012-05-06
101
- * Fix Ruby 1.8 truncation bug with unicode chars
102
- * Fix shell delegate methods to pass their block
103
- * Don't output trailing spaces when printing the last column in a table
104
-
105
- ## 0.15, released 2012-04-29
106
- * Alias method_options to options
107
- * Refactor say to allow multiple colors
108
- * Exposed error as a public API
109
- * Exposed file_collision as a public API
110
- * Exposed print_wrapped as a public API
111
- * Exposed set_color as a public API
112
- * Fix number-formatting bugs in print_table
113
- * Fix "indent" typo in print_table
114
- * Fix Errno::EPIPE when piping tasks to `head`
115
- * More friendly error messages
116
-
117
- ## 0.14, released 2010-07-25
118
- * Added CreateLink class and #link_file method
119
- * Made Thor::Actions#run use system as default method for system calls
120
- * Allow use of private methods from superclass as tasks
121
- * Added mute(&block) method which allows to run block without any output
122
- * Removed config[:pretend]
123
- * Enabled underscores for command line switches
124
- * Added Thor::Base.basename which is used by both Thor.banner and Thor::Group.banner
125
- * Deprecated invoke() without arguments
126
- * Added :only and :except to check_unknown_options
127
-
128
- ## 0.13, released 2010-02-03
129
- * Added :lazy_default which is only triggered if a switch is given
130
- * Added Thor::Shell::HTML
131
- * Added subcommands
132
- * Decoupled Thor::Group and Thor, so it's easier to vendor
133
- * Added check_unknown_options! in case you want error messages to be raised in valid switches
134
- * run(command) should return the results of command
135
-
136
- ## 0.12, released 2010-01-02
137
- * Methods generated by attr_* are automatically not marked as tasks
138
- * inject_into_file does not add the same content twice, unless :force is set
139
- * Removed rr in favor to rspec mock framework
140
- * Improved output for thor -T
141
- * [#7] Do not force white color on status
142
- * [#8] Yield a block with the filename on directory
143
-
144
- ## 0.11, released 2009-07-01
145
- * Added a rake compatibility layer. It allows you to use spec and rdoc tasks on
146
- Thor classes.
147
- * BACKWARDS INCOMPATIBLE: aliases are not generated automatically anymore
148
- since it may cause wrong behavior in the invocation system.
149
- * thor help now show information about any class/task. All those calls are
150
- possible:
151
-
152
- thor help describe
153
- thor help describe:amazing
154
- Or even with default namespaces:
155
-
156
- thor help :spec
157
- * Thor::Runner now invokes the default task if none is supplied:
158
-
159
- thor describe # invokes the default task, usually help
160
- * Thor::Runner now works with mappings:
161
-
162
- thor describe -h
163
- * Added some documentation and code refactoring.
164
-
165
- ## 0.9.8, released 2008-10-20
166
- * Fixed some tiny issues that were introduced lately.
167
-
168
- ## 0.9.7, released 2008-10-13
169
- * Setting global method options on the initialize method works as expected:
170
- All other tasks will accept these global options in addition to their own.
171
- * Added 'group' notion to Thor task sets (class Thor); by default all tasks
172
- are in the 'standard' group. Running 'thor -T' will only show the standard
173
- tasks - adding --all will show all tasks. You can also filter on a specific
174
- group using the --group option: thor -T --group advanced
175
-
176
- ## 0.9.6, released 2008-09-13
177
- * Generic improvements
178
-
179
- ## 0.9.5, released 2008-08-27
180
- * Improve Windows compatibility
181
- * Update (incorrect) README and task.thor sample file
182
- * Options hash is now frozen (once returned)
183
- * Allow magic predicates on options object. For instance: `options.force?`
184
- * Add support for :numeric type
185
- * BACKWARDS INCOMPATIBLE: Refactor Thor::Options. You cannot access shorthand forms in options hash anymore (for instance, options[:f])
186
- * Allow specifying optional args with default values: method_options(:user => "mislav")
187
- * Don't write options for nil or false values. This allows, for example, turning color off when running specs.
188
- * Exit with the status of the spec command to help CI stuff out some.
189
-
190
- ## 0.9.4, released 2008-08-13
191
- * Try to add Windows compatibility.
192
- * BACKWARDS INCOMPATIBLE: options hash is now accessed as a property in your class and is not passed as last argument anymore
193
- * Allow options at the beginning of the argument list as well as the end.
194
- * Make options available with symbol keys in addition to string keys.
195
- * Allow true to be passed to Thor#method_options to denote a boolean option.
196
- * If loading a thor file fails, don't give up, just print a warning and keep going.
197
- * Make sure that we re-raise errors if they happened further down the pipe than we care about.
198
- * Only delete the old file on updating when the installation of the new one is a success
199
- * Make it Ruby 1.8.5 compatible.
200
- * Don't raise an error if a boolean switch is defined multiple times.
201
- * Thor::Options now doesn't parse through things that look like options but aren't.
202
- * Add URI detection to install task, and make sure we don't append ".thor" to URIs
203
- * Add rake2thor to the gem binfiles.
204
- * Make sure local Thorfiles override system-wide ones.
@@ -1,12 +0,0 @@
1
- class IO #:nodoc:
2
- class << self
3
- unless method_defined? :binread
4
- def binread(file, *args)
5
- raise ArgumentError, "wrong number of arguments (#{1 + args.size} for 1..3)" unless args.size < 3
6
- File.open(file, "rb") do |f|
7
- f.read(*args)
8
- end
9
- end
10
- end
11
- end
12
- end
@@ -1,129 +0,0 @@
1
- class Thor
2
- module CoreExt
3
- class OrderedHash < ::Hash
4
- if RUBY_VERSION < "1.9"
5
- def initialize(*args, &block)
6
- super
7
- @keys = []
8
- end
9
-
10
- def initialize_copy(other)
11
- super
12
- # make a deep copy of keys
13
- @keys = other.keys
14
- end
15
-
16
- def []=(key, value)
17
- @keys << key unless key?(key)
18
- super
19
- end
20
-
21
- def delete(key)
22
- if key? key
23
- index = @keys.index(key)
24
- @keys.delete_at index
25
- end
26
- super
27
- end
28
-
29
- def delete_if
30
- super
31
- sync_keys!
32
- self
33
- end
34
-
35
- alias_method :reject!, :delete_if
36
-
37
- def reject(&block)
38
- dup.reject!(&block)
39
- end
40
-
41
- def keys
42
- @keys.dup
43
- end
44
-
45
- def values
46
- @keys.map { |key| self[key] }
47
- end
48
-
49
- def to_hash
50
- self
51
- end
52
-
53
- def to_a
54
- @keys.map { |key| [key, self[key]] }
55
- end
56
-
57
- def each_key
58
- return to_enum(:each_key) unless block_given?
59
- @keys.each { |key| yield(key) }
60
- self
61
- end
62
-
63
- def each_value
64
- return to_enum(:each_value) unless block_given?
65
- @keys.each { |key| yield(self[key]) }
66
- self
67
- end
68
-
69
- def each
70
- return to_enum(:each) unless block_given?
71
- @keys.each { |key| yield([key, self[key]]) }
72
- self
73
- end
74
-
75
- def each_pair
76
- return to_enum(:each_pair) unless block_given?
77
- @keys.each { |key| yield(key, self[key]) }
78
- self
79
- end
80
-
81
- alias_method :select, :find_all
82
-
83
- def clear
84
- super
85
- @keys.clear
86
- self
87
- end
88
-
89
- def shift
90
- k = @keys.first
91
- v = delete(k)
92
- [k, v]
93
- end
94
-
95
- def merge!(other_hash)
96
- if block_given?
97
- other_hash.each { |k, v| self[k] = key?(k) ? yield(k, self[k], v) : v }
98
- else
99
- other_hash.each { |k, v| self[k] = v }
100
- end
101
- self
102
- end
103
-
104
- alias_method :update, :merge!
105
-
106
- def merge(other_hash, &block)
107
- dup.merge!(other_hash, &block)
108
- end
109
-
110
- # When replacing with another hash, the initial order of our keys must come from the other hash -ordered or not.
111
- def replace(other)
112
- super
113
- @keys = other.keys
114
- self
115
- end
116
-
117
- def inspect
118
- "#<#{self.class} #{super}>"
119
- end
120
-
121
- private
122
-
123
- def sync_keys!
124
- @keys.delete_if { |k| !key?(k) }
125
- end
126
- end
127
- end
128
- end
129
- end