bake 0.17.0 → 0.18.2
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
- checksums.yaml.gz.sig +0 -0
- data/bake/input.rb +47 -0
- data/bake/output.rb +42 -0
- data/lib/bake/arguments.rb +7 -4
- data/lib/bake/command/call.rb +1 -16
- data/lib/bake/context.rb +1 -1
- data/lib/bake/documentation.rb +1 -1
- data/lib/bake/loaders.rb +2 -0
- data/lib/bake/recipe.rb +12 -2
- data/lib/bake/types/decimal.rb +2 -2
- data/lib/bake/types/float.rb +2 -2
- data/lib/bake/types/integer.rb +2 -2
- data/lib/bake/types/string.rb +2 -2
- data/lib/bake/version.rb +1 -1
- data.tar.gz.sig +0 -0
- metadata +5 -3
- metadata.gz.sig +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a3bcf5cd8672eaa2a698d0df26ac16b853d574ff386f2134e2540b6a601cfaa1
|
4
|
+
data.tar.gz: d06efeba9bd097c2f5bad7adf529a970a8fe9e010540a6b1d8449d1d3897b005
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 8fa7311b0fd77dc5388801f2aeca08395ad9499df10008b087b1bbc172ec131cf57827aceb19dff1d1365d4cbce58975f9cb9addbed830971546297e35411e41
|
7
|
+
data.tar.gz: 7ca9417bfb9d2659113c517e4f8ef530bd4fd7d54617e6ea1931694ab2b036dba4d18f092d3403a6cd76ea930b67cc0dc2112c8058cc947bcd67a7f240d27356
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data/bake/input.rb
ADDED
@@ -0,0 +1,47 @@
|
|
1
|
+
|
2
|
+
FORMATS = {
|
3
|
+
json: ->(file){require 'json'; JSON.parse(file.read)},
|
4
|
+
yaml: ->(file){require 'yaml'; YAML.load(file.read)},
|
5
|
+
}
|
6
|
+
|
7
|
+
# Parse an input file (defaulting to stdin) in the specified format. The format can be extracted from the file extension if left unspecified.
|
8
|
+
# @parameter file [Input] The input file.
|
9
|
+
# @parameter format [Symbol] The input format, e.g. json, yaml.
|
10
|
+
def input(file: $stdin, format: nil)
|
11
|
+
if format = format_for(file, format)
|
12
|
+
format.call(file)
|
13
|
+
else
|
14
|
+
raise "Unable to determine input format of #{file}!"
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
# Parse some input text in the specified format (defaulting to JSON).
|
19
|
+
# @parameter text [String] The input text.
|
20
|
+
# @parameter format [Symbol] The input format, e.g. json, yaml.
|
21
|
+
def parse(text, format: :json)
|
22
|
+
file = StringIO.new(text)
|
23
|
+
|
24
|
+
if format = format_for(nil, format)
|
25
|
+
format.call(file)
|
26
|
+
else
|
27
|
+
raise "Unable to determine input format!"
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
private
|
32
|
+
|
33
|
+
def format_for(file, name)
|
34
|
+
if file.respond_to?(:path) and path = file.path
|
35
|
+
name ||= file_type(path)
|
36
|
+
end
|
37
|
+
|
38
|
+
FORMATS[name]
|
39
|
+
end
|
40
|
+
|
41
|
+
def file_type(path)
|
42
|
+
if extension = File.extname(path)
|
43
|
+
extension.sub!(/\A\./, '')
|
44
|
+
return if extension.empty?
|
45
|
+
return extension.to_sym
|
46
|
+
end
|
47
|
+
end
|
data/bake/output.rb
ADDED
@@ -0,0 +1,42 @@
|
|
1
|
+
|
2
|
+
FORMATS = {
|
3
|
+
json: ->(file, value){require 'json'; file.puts(JSON.pretty_generate(value))},
|
4
|
+
pp: ->(file, value){require 'pp'; PP.pp(value, file)},
|
5
|
+
raw: ->(file, value){file.puts(value)},
|
6
|
+
yaml: ->(file, value){require 'yaml'; file.puts(YAML.dump(value))},
|
7
|
+
}
|
8
|
+
|
9
|
+
# Dump the last result to the specified file (defaulting to stdout) in the specified format (defaulting to Ruby's pretty print).
|
10
|
+
# @parameter file [Output] The input file.
|
11
|
+
# @parameter format [Symbol] The output format.
|
12
|
+
def output(input:, file: $stdout, format: nil)
|
13
|
+
if format = format_for(file, format)
|
14
|
+
format.call(file, input)
|
15
|
+
else
|
16
|
+
raise "Unable to determine output format!"
|
17
|
+
end
|
18
|
+
|
19
|
+
# Allow chaining of output processing:
|
20
|
+
return input
|
21
|
+
end
|
22
|
+
|
23
|
+
private
|
24
|
+
|
25
|
+
def format_for(file, name)
|
26
|
+
if file.respond_to?(:path) and path = file.path
|
27
|
+
name ||= file_type(path)
|
28
|
+
end
|
29
|
+
|
30
|
+
# Default to pretty print:
|
31
|
+
name ||= :pp
|
32
|
+
|
33
|
+
FORMATS[name]
|
34
|
+
end
|
35
|
+
|
36
|
+
def file_type(path)
|
37
|
+
if extension = File.extname(path)
|
38
|
+
extension.sub!(/\A\./, '')
|
39
|
+
return if extension.empty?
|
40
|
+
return extension.to_sym
|
41
|
+
end
|
42
|
+
end
|
data/lib/bake/arguments.rb
CHANGED
@@ -26,11 +26,14 @@ require_relative 'documentation'
|
|
26
26
|
module Bake
|
27
27
|
# Structured access to arguments.
|
28
28
|
class Arguments
|
29
|
-
def self.extract(recipe, arguments)
|
30
|
-
|
29
|
+
def self.extract(recipe, arguments, **defaults)
|
30
|
+
# Only supply defaults that match the recipe option names:
|
31
|
+
defaults = defaults.slice(*recipe.required_options)
|
32
|
+
|
33
|
+
self.new(recipe, defaults).extract(arguments)
|
31
34
|
end
|
32
35
|
|
33
|
-
def initialize(recipe)
|
36
|
+
def initialize(recipe, defaults)
|
34
37
|
@recipe = recipe
|
35
38
|
|
36
39
|
@types = recipe.types
|
@@ -38,7 +41,7 @@ module Bake
|
|
38
41
|
@arity = recipe.arity
|
39
42
|
|
40
43
|
@ordered = []
|
41
|
-
@options =
|
44
|
+
@options = defaults
|
42
45
|
end
|
43
46
|
|
44
47
|
attr :ordered
|
data/lib/bake/command/call.rb
CHANGED
@@ -32,17 +32,6 @@ module Bake
|
|
32
32
|
class Call < Samovar::Command
|
33
33
|
self.description = "Execute one or more commands."
|
34
34
|
|
35
|
-
OUTPUT = {
|
36
|
-
json: ->(value){require 'json'; $stdout.puts(JSON.pretty_generate(value))},
|
37
|
-
pp: ->(value){require 'pp'; PP.pp(value, $stdout)},
|
38
|
-
raw: ->(value){$stdout.puts(value)},
|
39
|
-
yaml: ->(value){require 'yaml'; $stdout.puts(YAML.dump(value))},
|
40
|
-
}
|
41
|
-
|
42
|
-
options do
|
43
|
-
option "-o/--output <format>", "Output the result of the last task in the given format: #{OUTPUT.keys.join(", ")}.", type: Symbol
|
44
|
-
end
|
45
|
-
|
46
35
|
def bakefile
|
47
36
|
@parent.bakefile
|
48
37
|
end
|
@@ -58,11 +47,7 @@ module Bake
|
|
58
47
|
def call
|
59
48
|
context = @parent.context
|
60
49
|
|
61
|
-
|
62
|
-
|
63
|
-
if output = @options[:output]
|
64
|
-
format(output, last_result)
|
65
|
-
end
|
50
|
+
context.call(*@commands)
|
66
51
|
end
|
67
52
|
end
|
68
53
|
end
|
data/lib/bake/context.rb
CHANGED
@@ -118,7 +118,7 @@ module Bake
|
|
118
118
|
|
119
119
|
while command = commands.shift
|
120
120
|
if recipe = @recipes[command]
|
121
|
-
arguments, options = recipe.prepare(commands)
|
121
|
+
arguments, options = recipe.prepare(commands, last_result)
|
122
122
|
last_result = recipe.call(*arguments, **options)
|
123
123
|
else
|
124
124
|
raise ArgumentError, "Could not find recipe for #{command}!"
|
data/lib/bake/documentation.rb
CHANGED
@@ -81,7 +81,7 @@ module Bake
|
|
81
81
|
end
|
82
82
|
end
|
83
83
|
|
84
|
-
PARAMETER = /\A
|
84
|
+
PARAMETER = /\A@param(eter)?\s+(?<name>.*?)\s+\[(?<type>.*?)\](\s+(?<details>.*?))?\z/
|
85
85
|
|
86
86
|
# The parameter lines of the comment block.
|
87
87
|
# e.g. `@parameter value [String] The value.`
|
data/lib/bake/loaders.rb
CHANGED
@@ -83,6 +83,8 @@ module Bake
|
|
83
83
|
# @parameter current [String] The path to start searching from.
|
84
84
|
def append_from_root(current = Dir.pwd, **options)
|
85
85
|
while current
|
86
|
+
Console.logger.debug(self) {"Checking current #{current}..."}
|
87
|
+
|
86
88
|
append_path(current, **options)
|
87
89
|
|
88
90
|
parent = File.dirname(current)
|
data/lib/bake/recipe.rb
CHANGED
@@ -85,6 +85,16 @@ module Bake
|
|
85
85
|
end
|
86
86
|
end
|
87
87
|
|
88
|
+
def required_options
|
89
|
+
if parameters = self.parameters
|
90
|
+
parameters.map do |(type, name)|
|
91
|
+
if type == :keyreq
|
92
|
+
name
|
93
|
+
end
|
94
|
+
end.compact
|
95
|
+
end
|
96
|
+
end
|
97
|
+
|
88
98
|
# The command name for this recipe.
|
89
99
|
def command
|
90
100
|
@command ||= compute_command
|
@@ -107,8 +117,8 @@ module Bake
|
|
107
117
|
# @parameter arguments [Array(String)] The command line arguments
|
108
118
|
# @returns ordered [Array]
|
109
119
|
# @returns options [Hash]
|
110
|
-
def prepare(arguments)
|
111
|
-
Arguments.extract(self, arguments)
|
120
|
+
def prepare(arguments, last_result = nil)
|
121
|
+
Arguments.extract(self, arguments, input: last_result)
|
112
122
|
end
|
113
123
|
|
114
124
|
# Call the recipe with the specified arguments and options.
|
data/lib/bake/types/decimal.rb
CHANGED
data/lib/bake/types/float.rb
CHANGED
data/lib/bake/types/integer.rb
CHANGED
data/lib/bake/types/string.rb
CHANGED
data/lib/bake/version.rb
CHANGED
data.tar.gz.sig
CHANGED
Binary file
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: bake
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.18.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Samuel Williams
|
@@ -37,7 +37,7 @@ cert_chain:
|
|
37
37
|
RAOsIl+HOBTb252nx1kIRN5hqQx272AJCbCjKx8egcUQKffFVVCI0nye09v5CK+a
|
38
38
|
HiLJ8VOFx6w=
|
39
39
|
-----END CERTIFICATE-----
|
40
|
-
date: 2022-05-
|
40
|
+
date: 2022-05-22 00:00:00.000000000 Z
|
41
41
|
dependencies:
|
42
42
|
- !ruby/object:Gem::Dependency
|
43
43
|
name: samovar
|
@@ -102,6 +102,8 @@ executables:
|
|
102
102
|
extensions: []
|
103
103
|
extra_rdoc_files: []
|
104
104
|
files:
|
105
|
+
- bake/input.rb
|
106
|
+
- bake/output.rb
|
105
107
|
- bin/bake
|
106
108
|
- lib/bake.rb
|
107
109
|
- lib/bake/arguments.rb
|
@@ -151,7 +153,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
151
153
|
- !ruby/object:Gem::Version
|
152
154
|
version: '0'
|
153
155
|
requirements: []
|
154
|
-
rubygems_version: 3.
|
156
|
+
rubygems_version: 3.3.7
|
155
157
|
signing_key:
|
156
158
|
specification_version: 4
|
157
159
|
summary: A replacement for rake with a simpler syntax.
|
metadata.gz.sig
CHANGED
Binary file
|