toys 0.3.1 → 0.3.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.yardopts +0 -2
- data/CHANGELOG.md +20 -0
- data/README.md +4 -24
- data/bin/toys +1 -1
- data/{lib/toys/builtins → builtins}/do.rb +1 -1
- data/{lib/toys/builtins → builtins}/system.rb +0 -0
- data/lib/toys.rb +9 -14
- data/lib/toys/standard_cli.rb +151 -0
- data/lib/toys/version.rb +2 -2
- metadata +19 -28
- data/lib/toys/cli.rb +0 -271
- data/lib/toys/config_dsl.rb +0 -432
- data/lib/toys/context.rb +0 -278
- data/lib/toys/errors.rb +0 -42
- data/lib/toys/helpers.rb +0 -52
- data/lib/toys/helpers/exec.rb +0 -469
- data/lib/toys/helpers/file_utils.rb +0 -39
- data/lib/toys/loader.rb +0 -423
- data/lib/toys/middleware.rb +0 -55
- data/lib/toys/middleware/base.rb +0 -51
- data/lib/toys/middleware/set_verbosity.rb +0 -54
- data/lib/toys/middleware/show_group_usage.rb +0 -68
- data/lib/toys/middleware/show_tool_usage.rb +0 -64
- data/lib/toys/middleware/show_usage_errors.rb +0 -57
- data/lib/toys/template.rb +0 -123
- data/lib/toys/templates.rb +0 -55
- data/lib/toys/templates/clean.rb +0 -80
- data/lib/toys/templates/gem_build.rb +0 -115
- data/lib/toys/templates/minitest.rb +0 -108
- data/lib/toys/templates/rubocop.rb +0 -81
- data/lib/toys/templates/yardoc.rb +0 -95
- data/lib/toys/tool.rb +0 -831
- data/lib/toys/utils/module_lookup.rb +0 -101
- data/lib/toys/utils/usage.rb +0 -163
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 674d3b61ad2be8749dddafed99ab0ad70fbda515157024afd2fb7b3dc3c1108c
|
4
|
+
data.tar.gz: 83f446e5eb534360cbc50f1f032c758d6b457b97a280661887632f1016abd1f5
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f35911821abba0a114aabf8f6e4a1a5bd1d6727edb3ec8e8eb0f035fac8cb08fecb737ff38c561a9f09caddb5f697219c5a349fa6c4ace63db879df35fb33164
|
7
|
+
data.tar.gz: 6dafe20e17be9816913edd9c498856f01fc3bac19249c11e62836895fc2234aa7231d2ecd322adc825d58f8d1ab4d0c51c756110831e7ece22b0cdf8a155bff2
|
data/.yardopts
CHANGED
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,25 @@
|
|
1
1
|
# Release History
|
2
2
|
|
3
|
+
### 0.3.2 / 2018-05-07
|
4
|
+
|
5
|
+
* CHANGED: Split core engine out into separate "toys-core" gem. See the
|
6
|
+
toys-core changelog for additional changes in core.
|
7
|
+
* CHANGED: Tools can no longer be alias_of. However, alias_as still works, and
|
8
|
+
it is now possible to create an alias using alias_tool.
|
9
|
+
* IMPROVED: The root tool now responds to the "--version" switch.
|
10
|
+
* IMPROVED: Group help can now "--search" for subcommands.
|
11
|
+
* IMPROVED: Help shows the config file path on "--verbose".
|
12
|
+
* IMPROVED: You can now run a sub-instance of toys from an executor.
|
13
|
+
|
14
|
+
### 0.3.1 / 2018-05-02
|
15
|
+
|
16
|
+
* CHANGED: Subcommand display is now recursive by default.
|
17
|
+
* IMPROVED: Improved error messaging for bad switch syntax.
|
18
|
+
* FIXED: toys system update now reports experimental versions correctly.
|
19
|
+
* FIXED: Subtools of an overridden group are now properly deleted.
|
20
|
+
* DOCS: Completed a first pass on class and method documentation.
|
21
|
+
* INTERNAL: Adjusted naming of switch-related methods.
|
22
|
+
|
3
23
|
### 0.3.0 / 2018-04-30
|
4
24
|
|
5
25
|
* Initial generally usable release
|
data/README.md
CHANGED
@@ -1,21 +1,10 @@
|
|
1
1
|
# Toys
|
2
2
|
|
3
|
-
|
3
|
+
Toys is a command line binary that lets you build your own suite of command
|
4
|
+
line tools (with commands and subcommands) using a Ruby DSL. Commands can be
|
5
|
+
defined globally or scoped to directories.
|
4
6
|
|
5
|
-
|
6
|
-
command line suite of tools (with commands and subcommands) using a Ruby DSL.
|
7
|
-
You can define commands globally or configure special commands scoped to
|
8
|
-
individual directories.
|
9
|
-
|
10
|
-
## Installation
|
11
|
-
|
12
|
-
This software is distributed as a Ruby gem and may be installed using:
|
13
|
-
|
14
|
-
```
|
15
|
-
gem install toys
|
16
|
-
```
|
17
|
-
|
18
|
-
## Usage
|
7
|
+
## Quick Start
|
19
8
|
|
20
9
|
(TODO)
|
21
10
|
|
@@ -29,15 +18,6 @@ guidelines will be provided when the software stabilizes further.
|
|
29
18
|
The source can be found on Github at
|
30
19
|
[https://github.com/dazuma/toys](https://github.com/dazuma/toys)
|
31
20
|
|
32
|
-
### TODO items
|
33
|
-
|
34
|
-
* Decide about highline integration
|
35
|
-
* Output formats middleware
|
36
|
-
* System paths tool
|
37
|
-
* Search function in group help
|
38
|
-
* Split out toys-core gem
|
39
|
-
* Write overall documentation
|
40
|
-
|
41
21
|
## License
|
42
22
|
|
43
23
|
Copyright 2018 Daniel Azuma
|
data/bin/toys
CHANGED
File without changes
|
data/lib/toys.rb
CHANGED
@@ -34,20 +34,15 @@
|
|
34
34
|
# individual directories.
|
35
35
|
#
|
36
36
|
module Toys
|
37
|
-
##
|
38
|
-
# Namespace for common utility classes.
|
39
|
-
#
|
40
|
-
module Utils; end
|
41
37
|
end
|
42
38
|
|
43
|
-
require "toys/cli"
|
44
|
-
require "toys/config_dsl"
|
45
|
-
require "toys/context"
|
46
|
-
require "toys/errors"
|
47
|
-
require "toys/helpers"
|
48
|
-
require "toys/loader"
|
49
|
-
require "toys/middleware"
|
50
|
-
require "toys/template"
|
51
|
-
require "toys/templates"
|
52
|
-
require "toys/tool"
|
53
39
|
require "toys/version"
|
40
|
+
|
41
|
+
if ::ENV["TOYS_CORE_LIB_PATH"]
|
42
|
+
$LOAD_PATH.unshift(::ENV["TOYS_CORE_LIB_PATH"])
|
43
|
+
else
|
44
|
+
gem "toys-core", "= #{::Toys::VERSION}"
|
45
|
+
end
|
46
|
+
require "toys-core"
|
47
|
+
|
48
|
+
require "toys/standard_cli"
|
@@ -0,0 +1,151 @@
|
|
1
|
+
# Copyright 2018 Daniel Azuma
|
2
|
+
#
|
3
|
+
# All rights reserved.
|
4
|
+
#
|
5
|
+
# Redistribution and use in source and binary forms, with or without
|
6
|
+
# modification, are permitted provided that the following conditions are met:
|
7
|
+
#
|
8
|
+
# * Redistributions of source code must retain the above copyright notice,
|
9
|
+
# this list of conditions and the following disclaimer.
|
10
|
+
# * Redistributions in binary form must reproduce the above copyright notice,
|
11
|
+
# this list of conditions and the following disclaimer in the documentation
|
12
|
+
# and/or other materials provided with the distribution.
|
13
|
+
# * Neither the name of the copyright holder, nor the names of any other
|
14
|
+
# contributors to this software, may be used to endorse or promote products
|
15
|
+
# derived from this software without specific prior written permission.
|
16
|
+
#
|
17
|
+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
18
|
+
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
19
|
+
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
20
|
+
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
21
|
+
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
22
|
+
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
23
|
+
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
24
|
+
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
25
|
+
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
26
|
+
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
27
|
+
# POSSIBILITY OF SUCH DAMAGE.
|
28
|
+
;
|
29
|
+
|
30
|
+
require "logger"
|
31
|
+
|
32
|
+
require "toys/middleware/show_version"
|
33
|
+
|
34
|
+
module Toys
|
35
|
+
##
|
36
|
+
# Helpers that configure the toys-core CLI with the behavior for the
|
37
|
+
# standard Toys binary.
|
38
|
+
#
|
39
|
+
module StandardCLI
|
40
|
+
##
|
41
|
+
# Path to standard built-in tools
|
42
|
+
# @return [String]
|
43
|
+
#
|
44
|
+
BUILTINS_PATH = ::File.join(::File.dirname(::File.dirname(__dir__)), "builtins").freeze
|
45
|
+
|
46
|
+
##
|
47
|
+
# Standard toys configuration directory name
|
48
|
+
# @return [String]
|
49
|
+
#
|
50
|
+
CONFIG_DIR_NAME = ".toys".freeze
|
51
|
+
|
52
|
+
##
|
53
|
+
# Standard toys configuration file name
|
54
|
+
# @return [String]
|
55
|
+
#
|
56
|
+
CONFIG_FILE_NAME = ".toys.rb".freeze
|
57
|
+
|
58
|
+
##
|
59
|
+
# Standard index file name in a toys configuration
|
60
|
+
# @return [String]
|
61
|
+
#
|
62
|
+
INDEX_FILE_NAME = ".toys.rb".freeze
|
63
|
+
|
64
|
+
##
|
65
|
+
# Standard toys preload file name
|
66
|
+
# @return [String]
|
67
|
+
#
|
68
|
+
PRELOAD_FILE_NAME = ".preload.rb".freeze
|
69
|
+
|
70
|
+
##
|
71
|
+
# Name of standard toys binary
|
72
|
+
# @return [String]
|
73
|
+
#
|
74
|
+
BINARY_NAME = "toys".freeze
|
75
|
+
|
76
|
+
##
|
77
|
+
# Help text for the standard root tool
|
78
|
+
# @return [String]
|
79
|
+
#
|
80
|
+
DEFAULT_ROOT_DESC =
|
81
|
+
"Toys is your personal command line tool. You can add to the list of" \
|
82
|
+
" commands below by writing scripts in Ruby using a simple DSL, and" \
|
83
|
+
" toys will organize and document them, and make them available" \
|
84
|
+
" globally or scoped to specific directories that you choose." \
|
85
|
+
" For detailed information, see https://www.rubydoc.info/gems/toys".freeze
|
86
|
+
|
87
|
+
##
|
88
|
+
# Create a standard CLI, configured with the appropriate paths and
|
89
|
+
# middleware.
|
90
|
+
#
|
91
|
+
# @param [String,nil] directory Starting search directory for configs.
|
92
|
+
# Defaults to the current working directory.
|
93
|
+
# @return [Toys::CLI]
|
94
|
+
#
|
95
|
+
def self.create(directory: nil)
|
96
|
+
cli = CLI.new(
|
97
|
+
binary_name: BINARY_NAME,
|
98
|
+
config_dir_name: CONFIG_DIR_NAME,
|
99
|
+
config_file_name: CONFIG_FILE_NAME,
|
100
|
+
index_file_name: INDEX_FILE_NAME,
|
101
|
+
preload_file_name: PRELOAD_FILE_NAME,
|
102
|
+
middleware_stack: default_middleware_stack
|
103
|
+
)
|
104
|
+
add_standard_paths(cli, directory: directory)
|
105
|
+
cli
|
106
|
+
end
|
107
|
+
|
108
|
+
##
|
109
|
+
# Add paths for a toys standard CLI. Paths added, in order from high to
|
110
|
+
# low priority, are:
|
111
|
+
#
|
112
|
+
# * Search the current directory and all ancestors for config files and
|
113
|
+
# directories.
|
114
|
+
# * Read the `TOYS_PATH` environment variable and search for config files
|
115
|
+
# and directories in the given paths. If this variable is empty, use
|
116
|
+
# `$HOME:/etc` by default.
|
117
|
+
# * The builtins for the standard toys binary.
|
118
|
+
#
|
119
|
+
# @param [String,nil] directory Starting search directory for configs.
|
120
|
+
# Defaults to the current working directory.
|
121
|
+
# @param [Toys::CLI] cli Add paths to this CLI
|
122
|
+
#
|
123
|
+
def self.add_standard_paths(cli, directory: nil)
|
124
|
+
cli.add_search_path_hierarchy(start: directory)
|
125
|
+
paths = ::ENV["TOYS_PATH"].to_s.split(::File::PATH_SEPARATOR)
|
126
|
+
if paths.empty?
|
127
|
+
paths << ::ENV["HOME"] if ::ENV["HOME"]
|
128
|
+
paths << "/etc" if ::File.directory?("/etc") && ::File.readable?("/etc")
|
129
|
+
end
|
130
|
+
paths.each { |path| cli.add_search_path(path) }
|
131
|
+
cli.add_config_path(BUILTINS_PATH)
|
132
|
+
cli
|
133
|
+
end
|
134
|
+
|
135
|
+
##
|
136
|
+
# Returns a the middleware for the standard Toys CLI.
|
137
|
+
#
|
138
|
+
# @return [Array]
|
139
|
+
#
|
140
|
+
def self.default_middleware_stack
|
141
|
+
version_displayer = Middleware::ShowVersion.root_version_displayer(::Toys::VERSION)
|
142
|
+
[
|
143
|
+
[:set_default_descriptions, default_root_desc: DEFAULT_ROOT_DESC],
|
144
|
+
[:handle_usage_errors],
|
145
|
+
[:show_version, version_displayer: version_displayer],
|
146
|
+
[:show_usage],
|
147
|
+
[:add_verbosity_switches]
|
148
|
+
]
|
149
|
+
end
|
150
|
+
end
|
151
|
+
end
|
data/lib/toys/version.rb
CHANGED
metadata
CHANGED
@@ -1,15 +1,29 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: toys
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Daniel Azuma
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2018-05-
|
11
|
+
date: 2018-05-07 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: toys-core
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - '='
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: 0.3.2
|
20
|
+
type: :runtime
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - '='
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: 0.3.2
|
13
27
|
- !ruby/object:Gem::Dependency
|
14
28
|
name: minitest
|
15
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -93,33 +107,10 @@ files:
|
|
93
107
|
- LICENSE.md
|
94
108
|
- README.md
|
95
109
|
- bin/toys
|
110
|
+
- builtins/do.rb
|
111
|
+
- builtins/system.rb
|
96
112
|
- lib/toys.rb
|
97
|
-
- lib/toys/
|
98
|
-
- lib/toys/builtins/system.rb
|
99
|
-
- lib/toys/cli.rb
|
100
|
-
- lib/toys/config_dsl.rb
|
101
|
-
- lib/toys/context.rb
|
102
|
-
- lib/toys/errors.rb
|
103
|
-
- lib/toys/helpers.rb
|
104
|
-
- lib/toys/helpers/exec.rb
|
105
|
-
- lib/toys/helpers/file_utils.rb
|
106
|
-
- lib/toys/loader.rb
|
107
|
-
- lib/toys/middleware.rb
|
108
|
-
- lib/toys/middleware/base.rb
|
109
|
-
- lib/toys/middleware/set_verbosity.rb
|
110
|
-
- lib/toys/middleware/show_group_usage.rb
|
111
|
-
- lib/toys/middleware/show_tool_usage.rb
|
112
|
-
- lib/toys/middleware/show_usage_errors.rb
|
113
|
-
- lib/toys/template.rb
|
114
|
-
- lib/toys/templates.rb
|
115
|
-
- lib/toys/templates/clean.rb
|
116
|
-
- lib/toys/templates/gem_build.rb
|
117
|
-
- lib/toys/templates/minitest.rb
|
118
|
-
- lib/toys/templates/rubocop.rb
|
119
|
-
- lib/toys/templates/yardoc.rb
|
120
|
-
- lib/toys/tool.rb
|
121
|
-
- lib/toys/utils/module_lookup.rb
|
122
|
-
- lib/toys/utils/usage.rb
|
113
|
+
- lib/toys/standard_cli.rb
|
123
114
|
- lib/toys/version.rb
|
124
115
|
homepage: https://github.com/dazuma/toys
|
125
116
|
licenses:
|
data/lib/toys/cli.rb
DELETED
@@ -1,271 +0,0 @@
|
|
1
|
-
# Copyright 2018 Daniel Azuma
|
2
|
-
#
|
3
|
-
# All rights reserved.
|
4
|
-
#
|
5
|
-
# Redistribution and use in source and binary forms, with or without
|
6
|
-
# modification, are permitted provided that the following conditions are met:
|
7
|
-
#
|
8
|
-
# * Redistributions of source code must retain the above copyright notice,
|
9
|
-
# this list of conditions and the following disclaimer.
|
10
|
-
# * Redistributions in binary form must reproduce the above copyright notice,
|
11
|
-
# this list of conditions and the following disclaimer in the documentation
|
12
|
-
# and/or other materials provided with the distribution.
|
13
|
-
# * Neither the name of the copyright holder, nor the names of any other
|
14
|
-
# contributors to this software, may be used to endorse or promote products
|
15
|
-
# derived from this software without specific prior written permission.
|
16
|
-
#
|
17
|
-
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
18
|
-
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
19
|
-
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
20
|
-
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
21
|
-
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
22
|
-
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
23
|
-
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
24
|
-
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
25
|
-
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
26
|
-
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
27
|
-
# POSSIBILITY OF SUCH DAMAGE.
|
28
|
-
;
|
29
|
-
|
30
|
-
require "logger"
|
31
|
-
|
32
|
-
module Toys
|
33
|
-
##
|
34
|
-
# A Toys-based CLI.
|
35
|
-
#
|
36
|
-
# Use this class to implement a CLI using Toys.
|
37
|
-
#
|
38
|
-
class CLI
|
39
|
-
##
|
40
|
-
# Path to default builtins
|
41
|
-
# @return [String]
|
42
|
-
#
|
43
|
-
BUILTINS_PATH = ::File.join(__dir__, "builtins").freeze
|
44
|
-
|
45
|
-
##
|
46
|
-
# Default name of toys configuration directory
|
47
|
-
# @return [String]
|
48
|
-
#
|
49
|
-
DEFAULT_DIR_NAME = ".toys".freeze
|
50
|
-
|
51
|
-
##
|
52
|
-
# Default name of toys configuration file
|
53
|
-
# @return [String]
|
54
|
-
#
|
55
|
-
DEFAULT_FILE_NAME = ".toys.rb".freeze
|
56
|
-
|
57
|
-
##
|
58
|
-
# Default name of toys preload file
|
59
|
-
# @return [String]
|
60
|
-
#
|
61
|
-
DEFAULT_PRELOAD_NAME = ".preload.rb".freeze
|
62
|
-
|
63
|
-
##
|
64
|
-
# Default name of toys binary
|
65
|
-
# @return [String]
|
66
|
-
#
|
67
|
-
DEFAULT_BINARY_NAME = "toys".freeze
|
68
|
-
|
69
|
-
##
|
70
|
-
# Default help text for the root tool
|
71
|
-
# @return [String]
|
72
|
-
#
|
73
|
-
DEFAULT_ROOT_DESC =
|
74
|
-
"Toys is your personal command line tool. You can add to the list of" \
|
75
|
-
" commands below by writing scripts in Ruby using a simple DSL, and" \
|
76
|
-
" toys will organize and document them, and make them available" \
|
77
|
-
" globally or scoped to specific directories that you choose." \
|
78
|
-
" For detailed information, see https://www.rubydoc.info/gems/toys".freeze
|
79
|
-
|
80
|
-
##
|
81
|
-
# Create a CLI
|
82
|
-
#
|
83
|
-
# @param [String,nil] binary_name The binary name displayed in help text.
|
84
|
-
# Optional. Defaults to the ruby program name.
|
85
|
-
# @param [Logger,nil] logger The logger to use. If not provided, a default
|
86
|
-
# logger that writes to `STDERR` is used.
|
87
|
-
# @param [String,nil] config_dir_name A directory with this name that
|
88
|
-
# appears in the loader path, is treated as a configuration directory
|
89
|
-
# whose contents are loaded into the toys configuration. Optional.
|
90
|
-
# If not provided, toplevel configuration directories are disabled.
|
91
|
-
# The default toys CLI sets this to `".toys"`.
|
92
|
-
# @param [String,nil] config_file_name A file with this name that appears
|
93
|
-
# in the loader path, is treated as a toplevel configuration file
|
94
|
-
# whose contents are loaded into the toys configuration. Optional.
|
95
|
-
# If not provided, toplevel configuration files are disabled.
|
96
|
-
# The default toys CLI sets this to `".toys.rb"`.
|
97
|
-
# @param [String,nil] index_file_name A file with this name that appears
|
98
|
-
# in any configuration directory (not just a toplevel directory) is
|
99
|
-
# loaded first as a standalone configuration file. If not provided,
|
100
|
-
# standalone configuration files are disabled.
|
101
|
-
# The default toys CLI sets this to `".toys.rb"`.
|
102
|
-
# @param [String,nil] preload_file_name A file with this name that appears
|
103
|
-
# in any configuration directory (not just a toplevel directory) is
|
104
|
-
# loaded before any configuration files. It is not treated as a
|
105
|
-
# configuration file in that the configuration DSL is not honored. You
|
106
|
-
# may use such a file to define auxiliary Ruby modules and classes that
|
107
|
-
# used by the tools defined in that directory.
|
108
|
-
# @param [Array] middleware An array of middleware that will be used by
|
109
|
-
# default for all tools loaded by this CLI.
|
110
|
-
# @param [String] root_desc The description of the root tool.
|
111
|
-
#
|
112
|
-
def initialize(
|
113
|
-
binary_name: nil,
|
114
|
-
logger: nil,
|
115
|
-
config_dir_name: nil,
|
116
|
-
config_file_name: nil,
|
117
|
-
index_file_name: nil,
|
118
|
-
preload_file_name: nil,
|
119
|
-
middleware: [],
|
120
|
-
root_desc: nil
|
121
|
-
)
|
122
|
-
logger ||= self.class.default_logger
|
123
|
-
@loader = Loader.new(
|
124
|
-
config_dir_name: config_dir_name,
|
125
|
-
config_file_name: config_file_name,
|
126
|
-
index_file_name: index_file_name,
|
127
|
-
preload_file_name: preload_file_name,
|
128
|
-
middleware: middleware,
|
129
|
-
root_desc: root_desc
|
130
|
-
)
|
131
|
-
@context_base = Context::Base.new(@loader, binary_name, logger)
|
132
|
-
end
|
133
|
-
|
134
|
-
##
|
135
|
-
# Add one or more configuration files/directories to the loader.
|
136
|
-
#
|
137
|
-
# If a CLI has a default tool set, it might use this to point to the
|
138
|
-
# directory that defines those tools. For example, the default Toys CLI
|
139
|
-
# uses this to load the builtin tools from the `builtins` directory.
|
140
|
-
#
|
141
|
-
# @param [String,Array<String>] paths One or more paths to add.
|
142
|
-
#
|
143
|
-
def add_config_paths(paths)
|
144
|
-
@loader.add_config_paths(paths)
|
145
|
-
self
|
146
|
-
end
|
147
|
-
|
148
|
-
##
|
149
|
-
# Add one or more path directories to the loader. These directories are
|
150
|
-
# searched for config directories and config files. Typically a CLI may
|
151
|
-
# include the current directory, or the user's home directory, `/etc` or
|
152
|
-
# other configuration-centric directories here.
|
153
|
-
#
|
154
|
-
# @param [String,Array<String>] paths One or more paths to add.
|
155
|
-
#
|
156
|
-
def add_paths(paths)
|
157
|
-
@loader.add_paths(paths)
|
158
|
-
self
|
159
|
-
end
|
160
|
-
|
161
|
-
##
|
162
|
-
# Add the given path and all ancestor directories to the loader as paths.
|
163
|
-
# You may optionally provide a stopping point using the `base` argument,
|
164
|
-
# which, if present, will be the _last_ directory added.
|
165
|
-
#
|
166
|
-
# @param [String] path The first directory to add
|
167
|
-
# @param [String] base The last directory to add. Defaults to `"/"`.
|
168
|
-
#
|
169
|
-
def add_path_hierarchy(path = nil, base = "/")
|
170
|
-
path ||= ::Dir.pwd
|
171
|
-
paths = []
|
172
|
-
loop do
|
173
|
-
paths << path
|
174
|
-
break if !base || path == base
|
175
|
-
next_path = ::File.dirname(path)
|
176
|
-
break if next_path == path
|
177
|
-
path = next_path
|
178
|
-
end
|
179
|
-
@loader.add_paths(paths)
|
180
|
-
self
|
181
|
-
end
|
182
|
-
|
183
|
-
##
|
184
|
-
# Add a standard set of paths. This includes the contents of the
|
185
|
-
# `TOYS_PATH` environment variable if present, the current user's home
|
186
|
-
# directory, and any system configuration directories such as `/etc`.
|
187
|
-
#
|
188
|
-
def add_standard_paths
|
189
|
-
toys_path = ::ENV["TOYS_PATH"].to_s.split(::File::PATH_SEPARATOR)
|
190
|
-
if toys_path.empty?
|
191
|
-
toys_path << ::ENV["HOME"] if ::ENV["HOME"]
|
192
|
-
toys_path << "/etc" if ::File.directory?("/etc") && ::File.readable?("/etc")
|
193
|
-
end
|
194
|
-
@loader.add_paths(toys_path)
|
195
|
-
self
|
196
|
-
end
|
197
|
-
|
198
|
-
##
|
199
|
-
# Run the CLI with the given command line arguments.
|
200
|
-
#
|
201
|
-
def run(*args)
|
202
|
-
exit(@context_base.run(args.flatten, verbosity: 0))
|
203
|
-
end
|
204
|
-
|
205
|
-
class << self
|
206
|
-
##
|
207
|
-
# Configure and create the standard Toys CLI.
|
208
|
-
#
|
209
|
-
# @return [Toys::CLI]
|
210
|
-
#
|
211
|
-
def create_standard
|
212
|
-
cli = new(
|
213
|
-
binary_name: DEFAULT_BINARY_NAME,
|
214
|
-
config_dir_name: DEFAULT_DIR_NAME,
|
215
|
-
config_file_name: DEFAULT_FILE_NAME,
|
216
|
-
index_file_name: DEFAULT_FILE_NAME,
|
217
|
-
preload_file_name: DEFAULT_PRELOAD_NAME,
|
218
|
-
middleware: default_middleware_stack,
|
219
|
-
root_desc: DEFAULT_ROOT_DESC
|
220
|
-
)
|
221
|
-
cli.add_path_hierarchy
|
222
|
-
cli.add_standard_paths
|
223
|
-
cli.add_config_paths(BUILTINS_PATH)
|
224
|
-
cli
|
225
|
-
end
|
226
|
-
|
227
|
-
##
|
228
|
-
# Returns a default set of middleware used by the standard Toys CLI.
|
229
|
-
# This middleware handles usage errors, provides a behavior for groups
|
230
|
-
# that displays the group command list, provides a `--help` option for
|
231
|
-
# showing individual tool documentation, and provides `--verbose` and
|
232
|
-
# `--quiet` switches for setting the verbosity, which in turn controls
|
233
|
-
# the logger level.
|
234
|
-
#
|
235
|
-
# @return [Array]
|
236
|
-
#
|
237
|
-
def default_middleware_stack
|
238
|
-
[
|
239
|
-
Middleware.lookup(:show_usage_errors).new,
|
240
|
-
Middleware.lookup(:show_group_usage).new,
|
241
|
-
Middleware.lookup(:show_tool_usage).new,
|
242
|
-
Middleware.lookup(:set_verbosity).new
|
243
|
-
]
|
244
|
-
end
|
245
|
-
|
246
|
-
##
|
247
|
-
# Returns a default logger that logs to `STDERR`.
|
248
|
-
#
|
249
|
-
# @return [Logger]
|
250
|
-
#
|
251
|
-
def default_logger
|
252
|
-
logger = ::Logger.new(::STDERR)
|
253
|
-
logger.formatter = proc do |severity, time, _progname, msg|
|
254
|
-
msg_str =
|
255
|
-
case msg
|
256
|
-
when ::String
|
257
|
-
msg
|
258
|
-
when ::Exception
|
259
|
-
"#{msg.message} (#{msg.class})\n" << (msg.backtrace || []).join("\n")
|
260
|
-
else
|
261
|
-
msg.inspect
|
262
|
-
end
|
263
|
-
timestr = time.strftime("%Y-%m-%d %H:%M:%S")
|
264
|
-
format("[%s %5s] %s\n", timestr, severity, msg_str)
|
265
|
-
end
|
266
|
-
logger.level = ::Logger::WARN
|
267
|
-
logger
|
268
|
-
end
|
269
|
-
end
|
270
|
-
end
|
271
|
-
end
|