bashly 1.1.9 → 1.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/bashly/extensions/string.rb +1 -1
- data/lib/bashly/libraries/settings/settings.yml +9 -0
- data/lib/bashly/libraries/strings/strings.yml +2 -0
- data/lib/bashly/script/base.rb +1 -1
- data/lib/bashly/script/catch_all.rb +1 -1
- data/lib/bashly/script/command.rb +9 -3
- data/lib/bashly/settings.rb +10 -0
- data/lib/bashly/version.rb +1 -1
- data/lib/bashly/views/command/examples_on_error.gtx +8 -0
- data/lib/bashly/views/command/long_usage.gtx +2 -1
- data/lib/bashly/views/command/normalize_input.gtx +4 -27
- data/lib/bashly/views/command/normalize_input_function.gtx +39 -0
- data/lib/bashly/views/command/normalize_input_simple.gtx +6 -0
- data/lib/bashly/views/command/required_args_filter.gtx +2 -2
- data/lib/bashly/views/command/usage.gtx +9 -14
- metadata +7 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 5000e81ecf047c31547832097355e0d1b5de630041ef2533a80ce70f146e8282
|
4
|
+
data.tar.gz: 9c03b8ef9215a317ebfd75333304065c271e77296a55753de65e612f9d1a8432
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: c6dc6b49075f6e250aec3204f6b9ff2bd6e4236da1bcc5229691565dcc8a4ff4c1d1c06a139c092eae33c61123753cdb542583a69596caf299f87c6ccf3d4f07
|
7
|
+
data.tar.gz: ab9d9fc13a779bfd4d71adbae49e66961c697a46e5cb386875dac1d9e1b021828a2821332f2687d16b87b3fb820cdc006b61d86e7425dd6fdb37ac7aceb12b33
|
@@ -42,6 +42,11 @@ tab_indent: false
|
|
42
42
|
# `-abc` as if it is `-a -b -c`.
|
43
43
|
compact_short_flags: true
|
44
44
|
|
45
|
+
# When true, the generated script will consider any argument in the form of
|
46
|
+
# `--flag=value` and `-f=value` as if it is `--flag value` and `-f value`
|
47
|
+
# respectively.
|
48
|
+
conjoined_flag_args: true
|
49
|
+
|
45
50
|
# Set to 'production' or 'development':
|
46
51
|
# env: production Generate a smaller script, without file markers
|
47
52
|
# env: development Generate with file markers
|
@@ -50,6 +55,10 @@ env: development
|
|
50
55
|
# The extension to use when reading/writing partial script snippets
|
51
56
|
partials_extension: sh
|
52
57
|
|
58
|
+
# Show command examples (if any) whenever the user does not provide the
|
59
|
+
# required arguments
|
60
|
+
show_examples_on_error: false
|
61
|
+
|
53
62
|
# Display various usage elements in color by providing the name of the color
|
54
63
|
# function. The value for each property is a name of a function that is
|
55
64
|
# available in your script, for example: `green` or `bold`.
|
@@ -4,6 +4,7 @@
|
|
4
4
|
# Usage captions
|
5
5
|
usage: "Usage:"
|
6
6
|
options: "Options:"
|
7
|
+
global_options: "Global Options:"
|
7
8
|
arguments: "Arguments:"
|
8
9
|
commands: "Commands:"
|
9
10
|
examples: "Examples:"
|
@@ -32,6 +33,7 @@ missing_required_argument: "missing required argument: %{arg}\\nusage: %{usage}"
|
|
32
33
|
missing_required_flag: "missing required flag: %{usage}"
|
33
34
|
missing_required_environment_variable: "missing required environment variable: %{var}"
|
34
35
|
missing_dependency: "missing dependency: %{dependency}"
|
36
|
+
examples_caption_on_error: 'examples:'
|
35
37
|
disallowed_flag: "%{name} must be one of: %{allowed}"
|
36
38
|
disallowed_argument: "%{name} must be one of: %{allowed}"
|
37
39
|
disallowed_environment_variable: "%{name} environment variable must be one of: %{allowed}"
|
data/lib/bashly/script/base.rb
CHANGED
@@ -307,11 +307,12 @@ module Bashly
|
|
307
307
|
|
308
308
|
# Returns a constructed string suitable for Usage pattern
|
309
309
|
def usage_string
|
310
|
-
result = [
|
310
|
+
result = [base_usage_pattern]
|
311
|
+
command_string = default_command&.default == 'force' ? '[COMMAND]' : 'COMMAND'
|
311
312
|
|
312
313
|
result.push case mode
|
313
|
-
when :global_flags then ['[OPTIONS]',
|
314
|
-
when :commands then [
|
314
|
+
when :global_flags then ['[OPTIONS]', command_string]
|
315
|
+
when :commands then [command_string]
|
315
316
|
when :args_and_flags then usage_string_args + ['[OPTIONS]']
|
316
317
|
when :args then usage_string_args
|
317
318
|
when :flags then ['[OPTIONS]']
|
@@ -326,6 +327,11 @@ module Bashly
|
|
326
327
|
args.map(&:usage_string)
|
327
328
|
end
|
328
329
|
|
330
|
+
def base_usage_pattern
|
331
|
+
usage_pattern = default ? "[#{name}]" : name
|
332
|
+
parents.any? ? (parents + [usage_pattern]).join(' ') : usage_pattern
|
333
|
+
end
|
334
|
+
|
329
335
|
# Returns an array of files to include as is inside the script
|
330
336
|
# This is meant to provide the user with the ability to add custom
|
331
337
|
# functions
|
data/lib/bashly/settings.rb
CHANGED
@@ -6,9 +6,11 @@ module Bashly
|
|
6
6
|
attr_writer(
|
7
7
|
:commands_dir,
|
8
8
|
:compact_short_flags,
|
9
|
+
:conjoined_flag_args,
|
9
10
|
:config_path,
|
10
11
|
:lib_dir,
|
11
12
|
:partials_extension,
|
13
|
+
:show_examples_on_error,
|
12
14
|
:source_dir,
|
13
15
|
:strict,
|
14
16
|
:tab_indent,
|
@@ -24,6 +26,10 @@ module Bashly
|
|
24
26
|
@compact_short_flags ||= get :compact_short_flags
|
25
27
|
end
|
26
28
|
|
29
|
+
def conjoined_flag_args
|
30
|
+
@conjoined_flag_args ||= get :conjoined_flag_args
|
31
|
+
end
|
32
|
+
|
27
33
|
def config_path
|
28
34
|
@config_path ||= get(:config_path) % { source_dir: source_dir }
|
29
35
|
end
|
@@ -52,6 +58,10 @@ module Bashly
|
|
52
58
|
env == :production
|
53
59
|
end
|
54
60
|
|
61
|
+
def show_examples_on_error
|
62
|
+
@show_examples_on_error ||= get :show_examples_on_error
|
63
|
+
end
|
64
|
+
|
55
65
|
def source_dir
|
56
66
|
@source_dir ||= get :source_dir
|
57
67
|
end
|
data/lib/bashly/version.rb
CHANGED
@@ -1,7 +1,8 @@
|
|
1
1
|
= view_marker
|
2
2
|
|
3
3
|
> if [[ -n $long_usage ]]; then
|
4
|
-
|
4
|
+
options_caption = public_commands.any? && public_flags.any? ? strings[:global_options] : strings[:options]
|
5
|
+
> printf "%s\n" "{{ options_caption.color(:caption) }}"
|
5
6
|
>
|
6
7
|
= render(:usage_flags).indent 2 if public_flags.any?
|
7
8
|
= render(:usage_fixed_flags).indent 2
|
@@ -1,30 +1,7 @@
|
|
1
1
|
= view_marker
|
2
2
|
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
> arg="$1"
|
8
|
-
> if [[ $arg =~ ^(--[a-zA-Z0-9_\-]+)=(.+)$ ]]; then
|
9
|
-
> input+=("${BASH_REMATCH[1]}")
|
10
|
-
> input+=("${BASH_REMATCH[2]}")
|
11
|
-
> elif [[ $arg =~ ^(-[a-zA-Z0-9])=(.+)$ ]]; then
|
12
|
-
> input+=("${BASH_REMATCH[1]}")
|
13
|
-
> input+=("${BASH_REMATCH[2]}")
|
14
|
-
|
15
|
-
if Settings.compact_short_flags
|
16
|
-
> elif [[ $arg =~ ^-([a-zA-Z0-9][a-zA-Z0-9]+)$ ]]; then
|
17
|
-
> flags="${BASH_REMATCH[1]}"
|
18
|
-
> for ((i = 0; i < ${#flags}; i++)); do
|
19
|
-
> input+=("-${flags:i:1}")
|
20
|
-
> done
|
3
|
+
if Settings.compact_short_flags || Settings.conjoined_flag_args
|
4
|
+
= render :normalize_input_function
|
5
|
+
else
|
6
|
+
= render :normalize_input_simple
|
21
7
|
end
|
22
|
-
|
23
|
-
> else
|
24
|
-
> input+=("$arg")
|
25
|
-
> fi
|
26
|
-
>
|
27
|
-
> shift
|
28
|
-
> done
|
29
|
-
> }
|
30
|
-
>
|
@@ -0,0 +1,39 @@
|
|
1
|
+
= view_marker
|
2
|
+
|
3
|
+
> normalize_input() {
|
4
|
+
> local arg flags passthru
|
5
|
+
> passthru=false
|
6
|
+
>
|
7
|
+
> while [[ $# -gt 0 ]]; do
|
8
|
+
> arg="$1"
|
9
|
+
> if [[ $passthru == true ]]; then
|
10
|
+
> input+=("$arg")
|
11
|
+
|
12
|
+
if Settings.conjoined_flag_args
|
13
|
+
> elif [[ $arg =~ ^(--[a-zA-Z0-9_\-]+)=(.+)$ ]]; then
|
14
|
+
> input+=("${BASH_REMATCH[1]}")
|
15
|
+
> input+=("${BASH_REMATCH[2]}")
|
16
|
+
> elif [[ $arg =~ ^(-[a-zA-Z0-9])=(.+)$ ]]; then
|
17
|
+
> input+=("${BASH_REMATCH[1]}")
|
18
|
+
> input+=("${BASH_REMATCH[2]}")
|
19
|
+
end
|
20
|
+
|
21
|
+
if Settings.compact_short_flags
|
22
|
+
> elif [[ $arg =~ ^-([a-zA-Z0-9][a-zA-Z0-9]+)$ ]]; then
|
23
|
+
> flags="${BASH_REMATCH[1]}"
|
24
|
+
> for ((i = 0; i < ${#flags}; i++)); do
|
25
|
+
> input+=("-${flags:i:1}")
|
26
|
+
> done
|
27
|
+
end
|
28
|
+
|
29
|
+
> elif [[ "$arg" == "--" ]]; then
|
30
|
+
> passthru=true
|
31
|
+
> input+=("$arg")
|
32
|
+
> else
|
33
|
+
> input+=("$arg")
|
34
|
+
> fi
|
35
|
+
>
|
36
|
+
> shift
|
37
|
+
> done
|
38
|
+
> }
|
39
|
+
>
|
@@ -4,10 +4,10 @@ if required_args.any?
|
|
4
4
|
required_args.each do |arg|
|
5
5
|
> if [[ -z ${args['{{ arg.name }}']+x} ]]; then
|
6
6
|
> printf "{{ strings[:missing_required_argument] % { arg: arg.name.upcase, usage: usage_string } }}\n" >&2
|
7
|
+
= render(:examples_on_error).indent 2
|
7
8
|
> exit 1
|
8
9
|
> fi
|
9
10
|
end
|
10
11
|
|
11
12
|
>
|
12
|
-
|
13
|
-
end
|
13
|
+
end
|
@@ -1,24 +1,17 @@
|
|
1
1
|
= view_marker
|
2
2
|
|
3
3
|
> {{ function_name }}_usage() {
|
4
|
-
> if [[ -n $long_usage ]]; then
|
5
|
-
|
6
4
|
if summary == help
|
7
|
-
>
|
8
|
-
> echo
|
5
|
+
> printf "{{ caption_string.sanitize_for_print }}\n\n"
|
9
6
|
else
|
10
|
-
>
|
11
|
-
>
|
12
|
-
> printf "{{ help.wrap(78).indent(2).sanitize_for_print }}\n"
|
13
|
-
>
|
7
|
+
> if [[ -n $long_usage ]]; then
|
8
|
+
> printf "{{ full_name }}\n\n"
|
9
|
+
> printf "{{ help.wrap(78).indent(2).sanitize_for_print }}\n\n"
|
10
|
+
> else
|
11
|
+
> printf "{{ caption_string.sanitize_for_print }}\n\n"
|
12
|
+
> fi
|
14
13
|
end
|
15
14
|
|
16
|
-
> else
|
17
|
-
> printf "{{ caption_string.sanitize_for_print }}\n"
|
18
|
-
> echo
|
19
|
-
> fi
|
20
|
-
>
|
21
|
-
|
22
15
|
if alt&.any?
|
23
16
|
> printf "{{ strings[:command_alias] % { alias: alt.join(', ') } }}\n"
|
24
17
|
> echo
|
@@ -48,3 +41,5 @@ end
|
|
48
41
|
commands.each do |command|
|
49
42
|
= command.render 'usage'
|
50
43
|
end
|
44
|
+
|
45
|
+
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: bashly
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Danny Ben Shitrit
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-07-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: colsole
|
@@ -240,6 +240,7 @@ files:
|
|
240
240
|
- lib/bashly/views/command/dependencies_filter.gtx
|
241
241
|
- lib/bashly/views/command/environment_variables_default.gtx
|
242
242
|
- lib/bashly/views/command/environment_variables_filter.gtx
|
243
|
+
- lib/bashly/views/command/examples_on_error.gtx
|
243
244
|
- lib/bashly/views/command/fixed_flags_filter.gtx
|
244
245
|
- lib/bashly/views/command/footer.gtx
|
245
246
|
- lib/bashly/views/command/function.gtx
|
@@ -248,6 +249,8 @@ files:
|
|
248
249
|
- lib/bashly/views/command/long_usage.gtx
|
249
250
|
- lib/bashly/views/command/master_script.gtx
|
250
251
|
- lib/bashly/views/command/normalize_input.gtx
|
252
|
+
- lib/bashly/views/command/normalize_input_function.gtx
|
253
|
+
- lib/bashly/views/command/normalize_input_simple.gtx
|
251
254
|
- lib/bashly/views/command/parse_requirements.gtx
|
252
255
|
- lib/bashly/views/command/parse_requirements_case.gtx
|
253
256
|
- lib/bashly/views/command/parse_requirements_case_catch_all.gtx
|
@@ -298,14 +301,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
298
301
|
requirements:
|
299
302
|
- - ">="
|
300
303
|
- !ruby/object:Gem::Version
|
301
|
-
version: '3.
|
304
|
+
version: '3.1'
|
302
305
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
303
306
|
requirements:
|
304
307
|
- - ">="
|
305
308
|
- !ruby/object:Gem::Version
|
306
309
|
version: '0'
|
307
310
|
requirements: []
|
308
|
-
rubygems_version: 3.5.
|
311
|
+
rubygems_version: 3.5.14
|
309
312
|
signing_key:
|
310
313
|
specification_version: 4
|
311
314
|
summary: Bash Command Line Tool Generator
|