thor 1.1.0 → 1.2.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 +4 -4
- data/README.md +1 -7
- data/lib/thor/actions/file_manipulation.rb +5 -5
- data/lib/thor/actions/inject_into_file.rb +5 -3
- data/lib/thor/actions.rb +6 -2
- data/lib/thor/core_ext/hash_with_indifferent_access.rb +6 -0
- data/lib/thor/error.rb +9 -4
- data/lib/thor/parser/options.rb +19 -1
- data/lib/thor/shell/basic.rb +22 -4
- data/lib/thor/shell.rb +1 -1
- data/lib/thor/util.rb +1 -1
- data/lib/thor/version.rb +1 -1
- data/thor.gemspec +4 -4
- metadata +10 -11
- data/CHANGELOG.md +0 -228
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: e94d00b16790c1908982c0fc76113f047ef1d190cba38b28269bff4be8d29191
|
4
|
+
data.tar.gz: 73c43412813c252302cc88b3aa3b5deee87ba9d1db20e2d6661714a7a4e88843
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5071358360989a17de4daa7f141b4d4f411d5914cf2d25e2856c4f95815f6ad6ecbaaec52a5a385a96d5277005cd61fec34c9401918b62de8c767cdae36a924d
|
7
|
+
data.tar.gz: 49a99cc7a21d9f9f90aef59325c543c8d82e9f22cff26fecfdfd3071d82c3ead068b82818b1cbe67ba7e3235edf29b0db0f74334723cbad5cd00808997bc1147
|
data/README.md
CHANGED
@@ -2,14 +2,8 @@ Thor
|
|
2
2
|
====
|
3
3
|
|
4
4
|
[][gem]
|
5
|
-
[][travis]
|
6
|
-
[][codeclimate]
|
7
|
-
[][coveralls]
|
8
5
|
|
9
6
|
[gem]: https://rubygems.org/gems/thor
|
10
|
-
[travis]: http://travis-ci.org/erikhuda/thor
|
11
|
-
[codeclimate]: https://codeclimate.com/github/erikhuda/thor
|
12
|
-
[coveralls]: https://coveralls.io/r/erikhuda/thor
|
13
7
|
|
14
8
|
Description
|
15
9
|
-----------
|
@@ -35,7 +29,7 @@ Usage and documentation
|
|
35
29
|
-----------------------
|
36
30
|
Please see the [wiki][] for basic usage and other documentation on using Thor. You can also checkout the [official homepage][homepage].
|
37
31
|
|
38
|
-
[wiki]: https://github.com/
|
32
|
+
[wiki]: https://github.com/rails/thor/wiki
|
39
33
|
[homepage]: http://whatisthor.com/
|
40
34
|
|
41
35
|
Contributing
|
@@ -210,9 +210,9 @@ class Thor
|
|
210
210
|
#
|
211
211
|
# ==== Examples
|
212
212
|
#
|
213
|
-
# inject_into_class "app/controllers/application_controller.rb", ApplicationController, " filter_parameter :password\n"
|
213
|
+
# inject_into_class "app/controllers/application_controller.rb", "ApplicationController", " filter_parameter :password\n"
|
214
214
|
#
|
215
|
-
# inject_into_class "app/controllers/application_controller.rb", ApplicationController do
|
215
|
+
# inject_into_class "app/controllers/application_controller.rb", "ApplicationController" do
|
216
216
|
# " filter_parameter :password\n"
|
217
217
|
# end
|
218
218
|
#
|
@@ -233,9 +233,9 @@ class Thor
|
|
233
233
|
#
|
234
234
|
# ==== Examples
|
235
235
|
#
|
236
|
-
# inject_into_module "app/helpers/application_helper.rb", ApplicationHelper, " def help; 'help'; end\n"
|
236
|
+
# inject_into_module "app/helpers/application_helper.rb", "ApplicationHelper", " def help; 'help'; end\n"
|
237
237
|
#
|
238
|
-
# inject_into_module "app/helpers/application_helper.rb", ApplicationHelper do
|
238
|
+
# inject_into_module "app/helpers/application_helper.rb", "ApplicationHelper" do
|
239
239
|
# " def help; 'help'; end\n"
|
240
240
|
# end
|
241
241
|
#
|
@@ -331,7 +331,7 @@ class Thor
|
|
331
331
|
path = File.expand_path(path, destination_root)
|
332
332
|
|
333
333
|
say_status :remove, relative_to_original_destination_root(path), config.fetch(:verbose, true)
|
334
|
-
if !options[:pretend] && File.exist?(path)
|
334
|
+
if !options[:pretend] && (File.exist?(path) || File.symlink?(path))
|
335
335
|
require "fileutils"
|
336
336
|
::FileUtils.rm_rf(path)
|
337
337
|
end
|
@@ -106,12 +106,14 @@ class Thor
|
|
106
106
|
# Adds the content to the file.
|
107
107
|
#
|
108
108
|
def replace!(regexp, string, force)
|
109
|
-
return if pretend?
|
110
109
|
content = File.read(destination)
|
111
|
-
|
110
|
+
before, after = content.split(regexp, 2)
|
111
|
+
snippet = (behavior == :after ? after : before).to_s
|
112
|
+
|
113
|
+
if force || !snippet.include?(replacement)
|
112
114
|
success = content.gsub!(regexp, string)
|
113
115
|
|
114
|
-
File.open(destination, "wb") { |file| file.write(content) }
|
116
|
+
File.open(destination, "wb") { |file| file.write(content) } unless pretend?
|
115
117
|
success
|
116
118
|
end
|
117
119
|
end
|
data/lib/thor/actions.rb
CHANGED
@@ -161,6 +161,8 @@ class Thor
|
|
161
161
|
# to the block you provide. The path is set back to the previous path when
|
162
162
|
# the method exits.
|
163
163
|
#
|
164
|
+
# Returns the value yielded by the block.
|
165
|
+
#
|
164
166
|
# ==== Parameters
|
165
167
|
# dir<String>:: the directory to move to.
|
166
168
|
# config<Hash>:: give :verbose => true to log and use padding.
|
@@ -179,16 +181,18 @@ class Thor
|
|
179
181
|
FileUtils.mkdir_p(destination_root)
|
180
182
|
end
|
181
183
|
|
184
|
+
result = nil
|
182
185
|
if pretend
|
183
186
|
# In pretend mode, just yield down to the block
|
184
|
-
block.arity == 1 ? yield(destination_root) : yield
|
187
|
+
result = block.arity == 1 ? yield(destination_root) : yield
|
185
188
|
else
|
186
189
|
require "fileutils"
|
187
|
-
FileUtils.cd(destination_root) { block.arity == 1 ? yield(destination_root) : yield }
|
190
|
+
FileUtils.cd(destination_root) { result = block.arity == 1 ? yield(destination_root) : yield }
|
188
191
|
end
|
189
192
|
|
190
193
|
@destination_stack.pop
|
191
194
|
shell.padding -= 1 if verbose
|
195
|
+
result
|
192
196
|
end
|
193
197
|
|
194
198
|
# Goes to the root and execute the given block.
|
data/lib/thor/error.rb
CHANGED
@@ -102,9 +102,14 @@ class Thor
|
|
102
102
|
end
|
103
103
|
|
104
104
|
if Correctable
|
105
|
-
DidYouMean
|
106
|
-
|
107
|
-
|
108
|
-
|
105
|
+
if DidYouMean.respond_to?(:correct_error)
|
106
|
+
DidYouMean.correct_error(Thor::UndefinedCommandError, UndefinedCommandError::SpellChecker)
|
107
|
+
DidYouMean.correct_error(Thor::UnknownArgumentError, UnknownArgumentError::SpellChecker)
|
108
|
+
else
|
109
|
+
DidYouMean::SPELL_CHECKERS.merge!(
|
110
|
+
'Thor::UndefinedCommandError' => UndefinedCommandError::SpellChecker,
|
111
|
+
'Thor::UnknownArgumentError' => UnknownArgumentError::SpellChecker
|
112
|
+
)
|
113
|
+
end
|
109
114
|
end
|
110
115
|
end
|
data/lib/thor/parser/options.rb
CHANGED
@@ -45,6 +45,7 @@ class Thor
|
|
45
45
|
@switches = {}
|
46
46
|
@extra = []
|
47
47
|
@stopped_parsing_after_extra_index = nil
|
48
|
+
@is_treated_as_value = false
|
48
49
|
|
49
50
|
options.each do |option|
|
50
51
|
@switches[option.switch_name] = option
|
@@ -74,8 +75,19 @@ class Thor
|
|
74
75
|
end
|
75
76
|
end
|
76
77
|
|
78
|
+
def shift
|
79
|
+
@is_treated_as_value = false
|
80
|
+
super
|
81
|
+
end
|
82
|
+
|
83
|
+
def unshift(arg, is_value: false)
|
84
|
+
@is_treated_as_value = is_value
|
85
|
+
super(arg)
|
86
|
+
end
|
87
|
+
|
77
88
|
def parse(args) # rubocop:disable MethodLength
|
78
89
|
@pile = args.dup
|
90
|
+
@is_treated_as_value = false
|
79
91
|
@parsing_options = true
|
80
92
|
|
81
93
|
while peek
|
@@ -88,7 +100,10 @@ class Thor
|
|
88
100
|
when SHORT_SQ_RE
|
89
101
|
unshift($1.split("").map { |f| "-#{f}" })
|
90
102
|
next
|
91
|
-
when EQ_RE
|
103
|
+
when EQ_RE
|
104
|
+
unshift($2, is_value: true)
|
105
|
+
switch = $1
|
106
|
+
when SHORT_NUM
|
92
107
|
unshift($2)
|
93
108
|
switch = $1
|
94
109
|
when LONG_RE, SHORT_RE
|
@@ -148,6 +163,7 @@ class Thor
|
|
148
163
|
# Two booleans are returned. The first is true if the current value
|
149
164
|
# starts with a hyphen; the second is true if it is a registered switch.
|
150
165
|
def current_is_switch?
|
166
|
+
return [false, false] if @is_treated_as_value
|
151
167
|
case peek
|
152
168
|
when LONG_RE, SHORT_RE, EQ_RE, SHORT_NUM
|
153
169
|
[true, switch?($1)]
|
@@ -159,6 +175,7 @@ class Thor
|
|
159
175
|
end
|
160
176
|
|
161
177
|
def current_is_switch_formatted?
|
178
|
+
return false if @is_treated_as_value
|
162
179
|
case peek
|
163
180
|
when LONG_RE, SHORT_RE, EQ_RE, SHORT_NUM, SHORT_SQ_RE
|
164
181
|
true
|
@@ -168,6 +185,7 @@ class Thor
|
|
168
185
|
end
|
169
186
|
|
170
187
|
def current_is_value?
|
188
|
+
return true if @is_treated_as_value
|
171
189
|
peek && (!parsing_options? || super)
|
172
190
|
end
|
173
191
|
|
data/lib/thor/shell/basic.rb
CHANGED
@@ -103,6 +103,23 @@ class Thor
|
|
103
103
|
stdout.flush
|
104
104
|
end
|
105
105
|
|
106
|
+
# Say (print) an error to the user. If the sentence ends with a whitespace
|
107
|
+
# or tab character, a new line is not appended (print + flush). Otherwise
|
108
|
+
# are passed straight to puts (behavior got from Highline).
|
109
|
+
#
|
110
|
+
# ==== Example
|
111
|
+
# say_error("error: something went wrong")
|
112
|
+
#
|
113
|
+
def say_error(message = "", color = nil, force_new_line = (message.to_s !~ /( |\t)\Z/))
|
114
|
+
return if quiet?
|
115
|
+
|
116
|
+
buffer = prepare_message(message, *color)
|
117
|
+
buffer << "\n" if force_new_line && !message.to_s.end_with?("\n")
|
118
|
+
|
119
|
+
stderr.print(buffer)
|
120
|
+
stderr.flush
|
121
|
+
end
|
122
|
+
|
106
123
|
# Say a status with the given color and appends the message. Since this
|
107
124
|
# method is used frequently by actions, it allows nil or false to be given
|
108
125
|
# in log_status, avoiding the message from being shown. If a Symbol is
|
@@ -111,13 +128,14 @@ class Thor
|
|
111
128
|
def say_status(status, message, log_status = true)
|
112
129
|
return if quiet? || log_status == false
|
113
130
|
spaces = " " * (padding + 1)
|
114
|
-
color = log_status.is_a?(Symbol) ? log_status : :green
|
115
|
-
|
116
131
|
status = status.to_s.rjust(12)
|
132
|
+
margin = " " * status.length + spaces
|
133
|
+
|
134
|
+
color = log_status.is_a?(Symbol) ? log_status : :green
|
117
135
|
status = set_color status, color, true if color
|
118
136
|
|
119
|
-
|
120
|
-
buffer = "#{
|
137
|
+
message = message.to_s.chomp.gsub(/(?<!\A)^/, margin)
|
138
|
+
buffer = "#{status}#{spaces}#{message}\n"
|
121
139
|
|
122
140
|
stdout.print(buffer)
|
123
141
|
stdout.flush
|
data/lib/thor/shell.rb
CHANGED
@@ -21,7 +21,7 @@ class Thor
|
|
21
21
|
end
|
22
22
|
|
23
23
|
module Shell
|
24
|
-
SHELL_DELEGATED_METHODS = [:ask, :error, :set_color, :yes?, :no?, :say, :say_status, :print_in_columns, :print_table, :print_wrapped, :file_collision, :terminal_width]
|
24
|
+
SHELL_DELEGATED_METHODS = [:ask, :error, :set_color, :yes?, :no?, :say, :say_error, :say_status, :print_in_columns, :print_table, :print_wrapped, :file_collision, :terminal_width]
|
25
25
|
attr_writer :shell
|
26
26
|
|
27
27
|
autoload :Basic, File.expand_path("shell/basic", __dir__)
|
data/lib/thor/util.rb
CHANGED
@@ -211,7 +211,7 @@ class Thor
|
|
211
211
|
#
|
212
212
|
def globs_for(path)
|
213
213
|
path = escape_globs(path)
|
214
|
-
["#{path}/Thorfile", "#{path}/*.thor", "#{path}/tasks/*.thor", "#{path}/lib/tasks
|
214
|
+
["#{path}/Thorfile", "#{path}/*.thor", "#{path}/tasks/*.thor", "#{path}/lib/tasks/**/*.thor"]
|
215
215
|
end
|
216
216
|
|
217
217
|
# Return the path to the ruby interpreter taking into account multiple
|
data/lib/thor/version.rb
CHANGED
data/thor.gemspec
CHANGED
@@ -14,11 +14,11 @@ Gem::Specification.new do |spec|
|
|
14
14
|
spec.licenses = %w(MIT)
|
15
15
|
spec.name = "thor"
|
16
16
|
spec.metadata = {
|
17
|
-
"bug_tracker_uri" => "https://github.com/
|
18
|
-
"changelog_uri" => "https://github.com/
|
17
|
+
"bug_tracker_uri" => "https://github.com/rails/thor/issues",
|
18
|
+
"changelog_uri" => "https://github.com/rails/thor/releases/tag/v#{Thor::VERSION}",
|
19
19
|
"documentation_uri" => "http://whatisthor.com/",
|
20
|
-
"source_code_uri" => "https://github.com/
|
21
|
-
"wiki_uri" => "https://github.com/
|
20
|
+
"source_code_uri" => "https://github.com/rails/thor/tree/v#{Thor::VERSION}",
|
21
|
+
"wiki_uri" => "https://github.com/rails/thor/wiki"
|
22
22
|
}
|
23
23
|
spec.require_paths = %w(lib)
|
24
24
|
spec.required_ruby_version = ">= 2.0.0"
|
metadata
CHANGED
@@ -1,15 +1,15 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: thor
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Yehuda Katz
|
8
8
|
- José Valim
|
9
|
-
autorequire:
|
9
|
+
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date:
|
12
|
+
date: 2022-01-04 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: bundler
|
@@ -39,7 +39,6 @@ extensions: []
|
|
39
39
|
extra_rdoc_files: []
|
40
40
|
files:
|
41
41
|
- ".document"
|
42
|
-
- CHANGELOG.md
|
43
42
|
- CONTRIBUTING.md
|
44
43
|
- LICENSE.md
|
45
44
|
- README.md
|
@@ -80,12 +79,12 @@ homepage: http://whatisthor.com/
|
|
80
79
|
licenses:
|
81
80
|
- MIT
|
82
81
|
metadata:
|
83
|
-
bug_tracker_uri: https://github.com/
|
84
|
-
changelog_uri: https://github.com/
|
82
|
+
bug_tracker_uri: https://github.com/rails/thor/issues
|
83
|
+
changelog_uri: https://github.com/rails/thor/releases/tag/v1.2.0
|
85
84
|
documentation_uri: http://whatisthor.com/
|
86
|
-
source_code_uri: https://github.com/
|
87
|
-
wiki_uri: https://github.com/
|
88
|
-
post_install_message:
|
85
|
+
source_code_uri: https://github.com/rails/thor/tree/v1.2.0
|
86
|
+
wiki_uri: https://github.com/rails/thor/wiki
|
87
|
+
post_install_message:
|
89
88
|
rdoc_options: []
|
90
89
|
require_paths:
|
91
90
|
- lib
|
@@ -100,8 +99,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
100
99
|
- !ruby/object:Gem::Version
|
101
100
|
version: 1.3.5
|
102
101
|
requirements: []
|
103
|
-
rubygems_version: 3.2.
|
104
|
-
signing_key:
|
102
|
+
rubygems_version: 3.2.32
|
103
|
+
signing_key:
|
105
104
|
specification_version: 4
|
106
105
|
summary: Thor is a toolkit for building powerful command-line interfaces.
|
107
106
|
test_files: []
|
data/CHANGELOG.md
DELETED
@@ -1,228 +0,0 @@
|
|
1
|
-
# 1.1.0
|
2
|
-
* Don't use ANSI colors when terminal is dumb.
|
3
|
-
* Ensure default option/argument is not erroneously aliased.
|
4
|
-
* Fixes a bug in the calculation of the print_wrapped method.
|
5
|
-
* Obey `:mute` and `options[:quiet]` in `Shell#say`.
|
6
|
-
* Support Ruby 3.0.
|
7
|
-
* Add force option to the `gsub_file` action.
|
8
|
-
|
9
|
-
# 1.0.1
|
10
|
-
* Fix thor when `thor/base` and `thor/group` are required without `thor.rb`.
|
11
|
-
* Handle relative source path in `create_link`.
|
12
|
-
|
13
|
-
# 1.0.0
|
14
|
-
* Drop support to Ruby 1.8 and 1.9.
|
15
|
-
* Deprecate relying on default `exit_on_failure?`.
|
16
|
-
In preparation to make Thor commands exit when there is a failure we are deprecating
|
17
|
-
defining a command without defining what behavior is expected when there is a failure.
|
18
|
-
|
19
|
-
To fix the deprecation you need to define a class method called `exit_on_failure?` returning
|
20
|
-
|
21
|
-
`false` if you want the current behavior or `true` if you want the new behavior.
|
22
|
-
* Deprecate defining an option with the default value using a different type as defined in the option.
|
23
|
-
* Allow options to be repeatable. See #674.
|
24
|
-
|
25
|
-
# 0.20.3
|
26
|
-
* Support old versions of `did_you_mean`.
|
27
|
-
|
28
|
-
# 0.20.2
|
29
|
-
* Fix `did_you_mean` support.
|
30
|
-
|
31
|
-
# 0.20.1
|
32
|
-
* Support new versions of ERB.
|
33
|
-
* 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!`
|
34
|
-
* Add `did_you_mean` support.
|
35
|
-
|
36
|
-
## 0.20.0
|
37
|
-
* Add `check_default_type!` to check if the default value of an option matches the defined type.
|
38
|
-
It removes the warning on usage and gives the command authors the possibility to check for programming errors.
|
39
|
-
|
40
|
-
* Add `disable_required_check!` to disable check for required options in some commands.
|
41
|
-
It is a substitute of `disable_class_options` that was not working as intended.
|
42
|
-
|
43
|
-
* Add `inject_into_module`.
|
44
|
-
|
45
|
-
## 0.19.4, release 2016-11-28
|
46
|
-
* Rename `Thor::Base#thor_reserved_word?` to `#is_thor_reserved_word?`
|
47
|
-
|
48
|
-
## 0.19.3, release 2016-11-27
|
49
|
-
* Output a warning instead of raising an exception when a default option value doesn't match its specified type
|
50
|
-
|
51
|
-
## 0.19.2, release 2016-11-26
|
52
|
-
* Fix bug with handling of colors passed to `ask` (and methods like `yes?` and `no?` which it underpins)
|
53
|
-
* Allow numeric arguments to be negative
|
54
|
-
* 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
|
55
|
-
* Add `Thor::Shell::Basic#indent` method for intending output
|
56
|
-
* Fix `remove_command` for an inherited command (see #451)
|
57
|
-
* Allow hash arguments to only have each key provided once (see #455)
|
58
|
-
* Allow commands to disable class options, for instance for "help" commands (see #363)
|
59
|
-
* Do not generate a negative option (`--no-no-foo`) for already negative boolean options (`--no-foo`)
|
60
|
-
* Improve compatibility of `Thor::CoreExt::HashWithIndifferentAccess` with Ruby standard library `Hash`
|
61
|
-
* Allow specifying a custom binding for template evaluation (e.g. `#key?` and `#fetch`)
|
62
|
-
* Fix support for subcommand-specific "help"s
|
63
|
-
* Use a string buffer when handling ERB for Ruby 2.3 compatibility
|
64
|
-
* Update dependencies
|
65
|
-
|
66
|
-
## 0.19.1, release 2014-03-24
|
67
|
-
* Fix `say` non-String break regression
|
68
|
-
|
69
|
-
## 0.19.0, release 2014-03-22
|
70
|
-
* Add support for a default to #ask
|
71
|
-
* Avoid @namespace not initialized warning
|
72
|
-
* Avoid private attribute? warning
|
73
|
-
* Fix initializing with unknown options
|
74
|
-
* Loosen required_rubygems_version for compatibility with Ubuntu 10.04
|
75
|
-
* Shell#ask: support a noecho option for stdin
|
76
|
-
* Shell#ask: change API to be :echo => false
|
77
|
-
* Display a message without a stack trace for ambiguous commands
|
78
|
-
* Make say and say_status thread safe
|
79
|
-
* Dependency for console io version check
|
80
|
-
* Alias --help to help on subcommands
|
81
|
-
* Use mime-types 1.x for Ruby 1.8.7 compatibility for Ruby 1.8 only
|
82
|
-
* Accept .tt files as templates
|
83
|
-
* Check if numeric value is in enum
|
84
|
-
* Use Readline for user input
|
85
|
-
* Fix dispatching of subcommands (concerning :help and *args)
|
86
|
-
* Fix warnings when running specs with `$VERBOSE = true`
|
87
|
-
* Make subcommand help more consistent
|
88
|
-
* Make the current command chain accessible in command
|
89
|
-
|
90
|
-
## 0.18.1, release 2013-03-30
|
91
|
-
* Revert regressions found in 0.18.0
|
92
|
-
|
93
|
-
## 0.18.0, release 2013-03-26
|
94
|
-
* Remove rake2thor
|
95
|
-
* Only display colors if output medium supports colors
|
96
|
-
* Pass parent_options to subcommands
|
97
|
-
* Fix non-dash-prefixed aliases
|
98
|
-
* Make error messages more helpful
|
99
|
-
* Rename "task" to "command"
|
100
|
-
* Add the method to allow for custom package name
|
101
|
-
|
102
|
-
## 0.17.0, release 2013-01-24
|
103
|
-
* Add better support for tasks that accept arbitrary additional arguments (e.g. things like `bundle exec`)
|
104
|
-
* Add #stop_on_unknown_option!
|
105
|
-
* Only strip from stdin.gets if it wasn't ended with EOF
|
106
|
-
* Allow "send" as a task name
|
107
|
-
* Allow passing options as arguments after "--"
|
108
|
-
* Autoload Thor::Group
|
109
|
-
|
110
|
-
## 0.16.0, release 2012-08-14
|
111
|
-
* Add enum to string arguments
|
112
|
-
|
113
|
-
## 0.15.4, release 2012-06-29
|
114
|
-
* Fix regression when destination root contains reserved regexp characters
|
115
|
-
|
116
|
-
## 0.15.3, release 2012-06-18
|
117
|
-
* Support strict_args_position! for backwards compatibility
|
118
|
-
* Escape Dir glob characters in paths
|
119
|
-
|
120
|
-
## 0.15.2, released 2012-05-07
|
121
|
-
* Added print_in_columns
|
122
|
-
* Exposed terminal_width as a public API
|
123
|
-
|
124
|
-
## 0.15.1, release 2012-05-06
|
125
|
-
* Fix Ruby 1.8 truncation bug with unicode chars
|
126
|
-
* Fix shell delegate methods to pass their block
|
127
|
-
* Don't output trailing spaces when printing the last column in a table
|
128
|
-
|
129
|
-
## 0.15, released 2012-04-29
|
130
|
-
* Alias method_options to options
|
131
|
-
* Refactor say to allow multiple colors
|
132
|
-
* Exposed error as a public API
|
133
|
-
* Exposed file_collision as a public API
|
134
|
-
* Exposed print_wrapped as a public API
|
135
|
-
* Exposed set_color as a public API
|
136
|
-
* Fix number-formatting bugs in print_table
|
137
|
-
* Fix "indent" typo in print_table
|
138
|
-
* Fix Errno::EPIPE when piping tasks to `head`
|
139
|
-
* More friendly error messages
|
140
|
-
|
141
|
-
## 0.14, released 2010-07-25
|
142
|
-
* Added CreateLink class and #link_file method
|
143
|
-
* Made Thor::Actions#run use system as default method for system calls
|
144
|
-
* Allow use of private methods from superclass as tasks
|
145
|
-
* Added mute(&block) method which allows to run block without any output
|
146
|
-
* Removed config[:pretend]
|
147
|
-
* Enabled underscores for command line switches
|
148
|
-
* Added Thor::Base.basename which is used by both Thor.banner and Thor::Group.banner
|
149
|
-
* Deprecated invoke() without arguments
|
150
|
-
* Added :only and :except to check_unknown_options
|
151
|
-
|
152
|
-
## 0.13, released 2010-02-03
|
153
|
-
* Added :lazy_default which is only triggered if a switch is given
|
154
|
-
* Added Thor::Shell::HTML
|
155
|
-
* Added subcommands
|
156
|
-
* Decoupled Thor::Group and Thor, so it's easier to vendor
|
157
|
-
* Added check_unknown_options! in case you want error messages to be raised in valid switches
|
158
|
-
* run(command) should return the results of command
|
159
|
-
|
160
|
-
## 0.12, released 2010-01-02
|
161
|
-
* Methods generated by attr_* are automatically not marked as tasks
|
162
|
-
* inject_into_file does not add the same content twice, unless :force is set
|
163
|
-
* Removed rr in favor to rspec mock framework
|
164
|
-
* Improved output for thor -T
|
165
|
-
* [#7] Do not force white color on status
|
166
|
-
* [#8] Yield a block with the filename on directory
|
167
|
-
|
168
|
-
## 0.11, released 2009-07-01
|
169
|
-
* Added a rake compatibility layer. It allows you to use spec and rdoc tasks on
|
170
|
-
Thor classes.
|
171
|
-
* BACKWARDS INCOMPATIBLE: aliases are not generated automatically anymore
|
172
|
-
since it may cause wrong behavior in the invocation system.
|
173
|
-
* thor help now show information about any class/task. All those calls are
|
174
|
-
possible:
|
175
|
-
|
176
|
-
thor help describe
|
177
|
-
thor help describe:amazing
|
178
|
-
Or even with default namespaces:
|
179
|
-
|
180
|
-
thor help :spec
|
181
|
-
* Thor::Runner now invokes the default task if none is supplied:
|
182
|
-
|
183
|
-
thor describe # invokes the default task, usually help
|
184
|
-
* Thor::Runner now works with mappings:
|
185
|
-
|
186
|
-
thor describe -h
|
187
|
-
* Added some documentation and code refactoring.
|
188
|
-
|
189
|
-
## 0.9.8, released 2008-10-20
|
190
|
-
* Fixed some tiny issues that were introduced lately.
|
191
|
-
|
192
|
-
## 0.9.7, released 2008-10-13
|
193
|
-
* Setting global method options on the initialize method works as expected:
|
194
|
-
All other tasks will accept these global options in addition to their own.
|
195
|
-
* Added 'group' notion to Thor task sets (class Thor); by default all tasks
|
196
|
-
are in the 'standard' group. Running 'thor -T' will only show the standard
|
197
|
-
tasks - adding --all will show all tasks. You can also filter on a specific
|
198
|
-
group using the --group option: thor -T --group advanced
|
199
|
-
|
200
|
-
## 0.9.6, released 2008-09-13
|
201
|
-
* Generic improvements
|
202
|
-
|
203
|
-
## 0.9.5, released 2008-08-27
|
204
|
-
* Improve Windows compatibility
|
205
|
-
* Update (incorrect) README and task.thor sample file
|
206
|
-
* Options hash is now frozen (once returned)
|
207
|
-
* Allow magic predicates on options object. For instance: `options.force?`
|
208
|
-
* Add support for :numeric type
|
209
|
-
* BACKWARDS INCOMPATIBLE: Refactor Thor::Options. You cannot access shorthand forms in options hash anymore (for instance, options[:f])
|
210
|
-
* Allow specifying optional args with default values: method_options(:user => "mislav")
|
211
|
-
* Don't write options for nil or false values. This allows, for example, turning color off when running specs.
|
212
|
-
* Exit with the status of the spec command to help CI stuff out some.
|
213
|
-
|
214
|
-
## 0.9.4, released 2008-08-13
|
215
|
-
* Try to add Windows compatibility.
|
216
|
-
* BACKWARDS INCOMPATIBLE: options hash is now accessed as a property in your class and is not passed as last argument anymore
|
217
|
-
* Allow options at the beginning of the argument list as well as the end.
|
218
|
-
* Make options available with symbol keys in addition to string keys.
|
219
|
-
* Allow true to be passed to Thor#method_options to denote a boolean option.
|
220
|
-
* If loading a thor file fails, don't give up, just print a warning and keep going.
|
221
|
-
* Make sure that we re-raise errors if they happened further down the pipe than we care about.
|
222
|
-
* Only delete the old file on updating when the installation of the new one is a success
|
223
|
-
* Make it Ruby 1.8.5 compatible.
|
224
|
-
* Don't raise an error if a boolean switch is defined multiple times.
|
225
|
-
* Thor::Options now doesn't parse through things that look like options but aren't.
|
226
|
-
* Add URI detection to install task, and make sure we don't append ".thor" to URIs
|
227
|
-
* Add rake2thor to the gem binfiles.
|
228
|
-
* Make sure local Thorfiles override system-wide ones.
|