gemsmith 21.10.0 → 22.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/README.adoc +4 -4
- data/gemsmith.gemspec +9 -9
- data/lib/gemsmith/builders/bundler.rb +5 -3
- data/lib/gemsmith/builders/circle_ci.rb +7 -6
- data/lib/gemsmith/builders/cli.rb +25 -8
- data/lib/gemsmith/builders/console.rb +4 -4
- data/lib/gemsmith/builders/documentation/readme.rb +15 -15
- data/lib/gemsmith/builders/git/ignore.rb +3 -3
- data/lib/gemsmith/builders/rspec/helper.rb +9 -5
- data/lib/gemsmith/builders/specification.rb +2 -2
- data/lib/gemsmith/cli/actions/cli.rb +3 -3
- data/lib/gemsmith/cli/actions/edit.rb +1 -1
- data/lib/gemsmith/cli/actions/publish.rb +3 -3
- data/lib/gemsmith/cli/actions/view.rb +1 -1
- data/lib/gemsmith/cli/commands/build.rb +38 -39
- data/lib/gemsmith/container.rb +31 -22
- data/lib/gemsmith/templates/%project_name%/%project_name%.gemspec.erb +38 -38
- data/lib/gemsmith/templates/%project_name%/exe/%project_name%.erb +2 -2
- data/lib/gemsmith/templates/%project_name%/lib/%project_path%/cli/shell.rb.erb +1 -1
- data/lib/gemsmith/templates/%project_name%/lib/%project_path%/configuration/defaults.yml.erb +1 -0
- data/lib/gemsmith/templates/%project_name%/lib/%project_path%/configuration/model.rb.erb +1 -1
- data/lib/gemsmith/templates/%project_name%/lib/%project_path%/container.rb.erb +7 -10
- data/lib/gemsmith/templates/%project_name%/spec/lib/%project_path%/cli/shell_spec.rb.erb +20 -5
- data/lib/gemsmith/templates/%project_name%/spec/support/shared_contexts/application_dependencies.rb.erb +17 -6
- data/lib/gemsmith/tools/versioner.rb +1 -7
- data.tar.gz.sig +0 -0
- metadata +19 -19
- 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: d49495c8c8032e854185873001478f3d125a00668945008277b803c93bd0e866
|
4
|
+
data.tar.gz: a9810bc571423a2d2a7d1f551d46f26e2ae6c693d4382806443c48c652a8a532
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b9bd244dd94f167c8065d34b9dad609cd28b421b526571fb72dfac17d854c6c4ca1670ee89b56f264da8c0bf1de1dbe0242914f7f531b24d436abbd3a38821a0
|
7
|
+
data.tar.gz: 142dc5ed6017f7c54a2797716a501946396b99ed3ea99e7d01fc0a67ed4748c181e38a2223fbc818371575b7d1a47ccb6a68be1063baff90cc128278e988d00a
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data/README.adoc
CHANGED
@@ -164,8 +164,8 @@ the following:
|
|
164
164
|
|
165
165
|
[source,yaml]
|
166
166
|
----
|
167
|
-
|
168
|
-
|
167
|
+
build:
|
168
|
+
cli: false
|
169
169
|
----
|
170
170
|
|
171
171
|
It is recommended that you provide URLs for your project which would be all keys found in this
|
@@ -173,8 +173,8 @@ section:
|
|
173
173
|
|
174
174
|
[source,yaml]
|
175
175
|
----
|
176
|
-
|
177
|
-
:
|
176
|
+
project:
|
177
|
+
uri:
|
178
178
|
# Add sub-key values here.
|
179
179
|
----
|
180
180
|
|
data/gemsmith.gemspec
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
Gem::Specification.new do |spec|
|
4
4
|
spec.name = "gemsmith"
|
5
|
-
spec.version = "
|
5
|
+
spec.version = "22.1.0"
|
6
6
|
spec.authors = ["Brooke Kuhlmann"]
|
7
7
|
spec.email = ["brooke@alchemists.io"]
|
8
8
|
spec.homepage = "https://alchemists.io/projects/gemsmith"
|
@@ -24,17 +24,17 @@ Gem::Specification.new do |spec|
|
|
24
24
|
|
25
25
|
spec.required_ruby_version = "~> 3.3"
|
26
26
|
spec.add_dependency "cogger", "~> 0.21"
|
27
|
-
spec.add_dependency "containable", "~> 0.
|
27
|
+
spec.add_dependency "containable", "~> 0.2"
|
28
28
|
spec.add_dependency "core", "~> 1.0"
|
29
29
|
spec.add_dependency "dry-monads", "~> 1.6"
|
30
30
|
spec.add_dependency "dry-schema", "~> 1.13"
|
31
|
-
spec.add_dependency "etcher", "~> 1
|
32
|
-
spec.add_dependency "infusible", "~> 3.
|
33
|
-
spec.add_dependency "milestoner", "~>
|
34
|
-
spec.add_dependency "refinements", "~> 12.
|
35
|
-
spec.add_dependency "rubysmith", "~>
|
36
|
-
spec.add_dependency "runcom", "~> 11.
|
37
|
-
spec.add_dependency "sod", "~> 0.
|
31
|
+
spec.add_dependency "etcher", "~> 2.1"
|
32
|
+
spec.add_dependency "infusible", "~> 3.8"
|
33
|
+
spec.add_dependency "milestoner", "~> 18.0"
|
34
|
+
spec.add_dependency "refinements", "~> 12.7"
|
35
|
+
spec.add_dependency "rubysmith", "~> 7.1"
|
36
|
+
spec.add_dependency "runcom", "~> 11.5"
|
37
|
+
spec.add_dependency "sod", "~> 0.12"
|
38
38
|
spec.add_dependency "spek", "~> 3.0"
|
39
39
|
spec.add_dependency "zeitwerk", "~> 2.6"
|
40
40
|
|
@@ -5,18 +5,20 @@ require "refinements/struct"
|
|
5
5
|
module Gemsmith
|
6
6
|
module Builders
|
7
7
|
# Builds project skeleton with Gemfile configuration.
|
8
|
-
class Bundler < Rubysmith::Builders::
|
8
|
+
class Bundler < Rubysmith::Builders::Bundler
|
9
9
|
using Refinements::Struct
|
10
10
|
|
11
11
|
def call
|
12
|
-
|
12
|
+
super
|
13
|
+
|
14
|
+
builder.call(settings.merge(template_path: "%project_name%/Gemfile.erb"))
|
13
15
|
.insert_after("source", "\ngemspec\n")
|
14
16
|
.replace(/spec\n\n\Z/m, "spec\n")
|
15
17
|
.replace(/.+refinements.+/, "")
|
16
18
|
.replace(/.+zeitwerk.+/, "")
|
17
19
|
.replace("\n\n\n\n", "\n")
|
18
20
|
|
19
|
-
|
21
|
+
true
|
20
22
|
end
|
21
23
|
end
|
22
24
|
end
|
@@ -4,23 +4,24 @@ require "refinements/struct"
|
|
4
4
|
|
5
5
|
module Gemsmith
|
6
6
|
module Builders
|
7
|
-
# Builds project skeleton Circle CI
|
8
|
-
class CircleCI < Rubysmith::Builders::
|
7
|
+
# Builds project skeleton Circle CI settings.
|
8
|
+
class CircleCI < Rubysmith::Builders::CircleCI
|
9
9
|
using Refinements::Struct
|
10
10
|
|
11
11
|
def call
|
12
|
-
return
|
12
|
+
return false unless settings.build_circle_ci
|
13
13
|
|
14
|
-
|
14
|
+
super
|
15
|
+
builder.call(settings.merge(template_path: "%project_name%/.circleci/config.yml.erb"))
|
15
16
|
.replace %({{checksum "Gemfile.lock"}}),
|
16
17
|
%({{checksum "Gemfile"}}-{{checksum "#{project_name}.gemspec"}})
|
17
18
|
|
18
|
-
|
19
|
+
true
|
19
20
|
end
|
20
21
|
|
21
22
|
private
|
22
23
|
|
23
|
-
def project_name =
|
24
|
+
def project_name = settings.project_name
|
24
25
|
end
|
25
26
|
end
|
26
27
|
end
|
@@ -9,10 +9,10 @@ module Gemsmith
|
|
9
9
|
using Refinements::Struct
|
10
10
|
|
11
11
|
def call
|
12
|
-
return
|
12
|
+
return false unless settings.build_cli
|
13
13
|
|
14
14
|
render
|
15
|
-
|
15
|
+
true
|
16
16
|
end
|
17
17
|
|
18
18
|
private
|
@@ -20,13 +20,13 @@ module Gemsmith
|
|
20
20
|
def render = private_methods.sort.grep(/render_/).each { |method| __send__ method }
|
21
21
|
|
22
22
|
def render_exe
|
23
|
-
builder.call(
|
23
|
+
builder.call(settings.merge(template_path: "%project_name%/exe/%project_name%.erb"))
|
24
24
|
.render
|
25
25
|
.permit 0o755
|
26
26
|
end
|
27
27
|
|
28
28
|
def render_core
|
29
|
-
content =
|
29
|
+
content = settings.merge template_path: "%project_name%/lib/%project_path%.rb.erb"
|
30
30
|
|
31
31
|
builder.call(content)
|
32
32
|
.insert_before(/tag/, %( loader.inflector.inflect "cli" => "CLI"\n))
|
@@ -39,21 +39,38 @@ module Gemsmith
|
|
39
39
|
"%project_name%/lib/%project_path%/configuration/defaults.yml.erb",
|
40
40
|
"%project_name%/lib/%project_path%/container.rb.erb",
|
41
41
|
"%project_name%/lib/%project_path%/import.rb.erb"
|
42
|
-
].each { |path| builder.call(
|
42
|
+
].each { |path| builder.call(settings.merge(template_path: path)).render }
|
43
43
|
end
|
44
44
|
|
45
45
|
def render_shell
|
46
46
|
path = "%project_name%/lib/%project_path%/cli/shell.rb.erb"
|
47
|
-
builder.call(
|
47
|
+
builder.call(settings.merge(template_path: path)).render
|
48
|
+
end
|
49
|
+
|
50
|
+
def render_requirements
|
51
|
+
return if settings.build_zeitwerk
|
52
|
+
|
53
|
+
builder.call(settings.merge(template_path: "%project_name%/lib/%project_path%.rb.erb"))
|
54
|
+
.render
|
55
|
+
.prepend <<~CONTENT
|
56
|
+
require "demo/configuration/contract"
|
57
|
+
require "demo/configuration/model"
|
58
|
+
require "demo/container"
|
59
|
+
require "demo/import"
|
60
|
+
|
61
|
+
require "demo/cli/shell"
|
62
|
+
|
63
|
+
# Main namespace.
|
64
|
+
CONTENT
|
48
65
|
end
|
49
66
|
|
50
67
|
def render_specs
|
51
|
-
return unless
|
68
|
+
return unless settings.build_rspec
|
52
69
|
|
53
70
|
[
|
54
71
|
"%project_name%/spec/lib/%project_path%/cli/shell_spec.rb.erb",
|
55
72
|
"%project_name%/spec/support/shared_contexts/application_dependencies.rb.erb"
|
56
|
-
].each { |path| builder.call(
|
73
|
+
].each { |path| builder.call(settings.merge(template_path: path)).render }
|
57
74
|
end
|
58
75
|
end
|
59
76
|
end
|
@@ -9,13 +9,13 @@ module Gemsmith
|
|
9
9
|
using Refinements::Struct
|
10
10
|
|
11
11
|
def call
|
12
|
-
return
|
12
|
+
return false unless settings.build_console
|
13
13
|
|
14
14
|
super
|
15
|
-
builder.call(
|
16
|
-
.replace(/require Bundler.root.+/, %(require "#{
|
15
|
+
builder.call(settings.merge(template_path: "%project_name%/bin/console.erb"))
|
16
|
+
.replace(/require Bundler.root.+/, %(require "#{settings.project_path}"))
|
17
17
|
|
18
|
-
|
18
|
+
true
|
19
19
|
end
|
20
20
|
end
|
21
21
|
end
|
@@ -10,25 +10,25 @@ module Gemsmith
|
|
10
10
|
using Refinements::Struct
|
11
11
|
|
12
12
|
def call
|
13
|
-
return
|
13
|
+
return false unless settings.build_readme
|
14
14
|
|
15
15
|
super
|
16
|
-
builder.call(
|
16
|
+
builder.call(settings.merge(template_path: "%project_name%/README.#{kind}.erb"))
|
17
17
|
.replace(/Setup.+Usage/m, setup)
|
18
18
|
.replace("Rubysmith", "Gemsmith")
|
19
19
|
.replace("rubysmith", "gemsmith")
|
20
20
|
|
21
|
-
|
21
|
+
true
|
22
22
|
end
|
23
23
|
|
24
24
|
private
|
25
25
|
|
26
26
|
def setup = kind == "adoc" ? ascii_setup : markdown_setup
|
27
27
|
|
28
|
-
def ascii_setup =
|
28
|
+
def ascii_setup = settings.build_security ? ascii_secure : ascii_insecure
|
29
29
|
|
30
30
|
def ascii_secure
|
31
|
-
project_name =
|
31
|
+
project_name = settings.project_name
|
32
32
|
|
33
33
|
<<~CONTENT.strip
|
34
34
|
Setup
|
@@ -38,7 +38,7 @@ module Gemsmith
|
|
38
38
|
[source,bash]
|
39
39
|
----
|
40
40
|
# 💡 Skip this line if you already have the public certificate installed.
|
41
|
-
gem cert --add <(curl --compressed --location #{
|
41
|
+
gem cert --add <(curl --compressed --location #{settings.organization_uri}/gems.pem)
|
42
42
|
gem install #{project_name} --trust-policy HighSecurity
|
43
43
|
----
|
44
44
|
|
@@ -61,7 +61,7 @@ module Gemsmith
|
|
61
61
|
|
62
62
|
[source,bash]
|
63
63
|
----
|
64
|
-
gem install #{
|
64
|
+
gem install #{settings.project_name}
|
65
65
|
----
|
66
66
|
|
67
67
|
#{ascii_common}
|
@@ -74,24 +74,24 @@ module Gemsmith
|
|
74
74
|
|
75
75
|
[source,bash]
|
76
76
|
----
|
77
|
-
bundle add #{
|
77
|
+
bundle add #{settings.project_name}
|
78
78
|
----
|
79
79
|
|
80
80
|
Once the gem is installed, you only need to require it:
|
81
81
|
|
82
82
|
[source,ruby]
|
83
83
|
----
|
84
|
-
require "#{
|
84
|
+
require "#{settings.project_path}"
|
85
85
|
----
|
86
86
|
|
87
87
|
== Usage
|
88
88
|
CONTENT
|
89
89
|
end
|
90
90
|
|
91
|
-
def markdown_setup =
|
91
|
+
def markdown_setup = settings.build_security ? markdown_secure : markdown_insecure
|
92
92
|
|
93
93
|
def markdown_secure
|
94
|
-
project_name =
|
94
|
+
project_name = settings.project_name
|
95
95
|
|
96
96
|
<<~CONTENT.strip
|
97
97
|
Setup
|
@@ -99,7 +99,7 @@ module Gemsmith
|
|
99
99
|
To install _with_ security, run:
|
100
100
|
|
101
101
|
# 💡 Skip this line if you already have the public certificate installed.
|
102
|
-
gem cert --add <(curl --compressed --location #{
|
102
|
+
gem cert --add <(curl --compressed --location #{settings.organization_uri}/gems.pem)
|
103
103
|
gem install #{project_name} --trust-policy HighSecurity
|
104
104
|
|
105
105
|
To install _without_ security, run:
|
@@ -116,7 +116,7 @@ module Gemsmith
|
|
116
116
|
|
117
117
|
To install, run:
|
118
118
|
|
119
|
-
gem install #{
|
119
|
+
gem install #{settings.project_name}
|
120
120
|
|
121
121
|
#{markdown_common}
|
122
122
|
CONTENT
|
@@ -126,11 +126,11 @@ module Gemsmith
|
|
126
126
|
<<~CONTENT.strip
|
127
127
|
You can also add the gem directly to your project:
|
128
128
|
|
129
|
-
bundle add #{
|
129
|
+
bundle add #{settings.project_name}
|
130
130
|
|
131
131
|
Once the gem is installed, you only need to require it:
|
132
132
|
|
133
|
-
require "#{
|
133
|
+
require "#{settings.project_path}"
|
134
134
|
|
135
135
|
## Usage
|
136
136
|
CONTENT
|
@@ -10,9 +10,9 @@ module Gemsmith
|
|
10
10
|
using Refinements::Struct
|
11
11
|
|
12
12
|
def call
|
13
|
-
return
|
13
|
+
return false unless settings.build_git
|
14
14
|
|
15
|
-
builder.call(
|
15
|
+
builder.call(settings.merge(template_path: "%project_name%/.gitignore.erb"))
|
16
16
|
.touch
|
17
17
|
.prepend("*.gem\n")
|
18
18
|
.insert_before "tmp\n", <<~CONTENT
|
@@ -20,7 +20,7 @@ module Gemsmith
|
|
20
20
|
pkg
|
21
21
|
CONTENT
|
22
22
|
|
23
|
-
|
23
|
+
true
|
24
24
|
end
|
25
25
|
end
|
26
26
|
end
|
@@ -6,16 +6,20 @@ module Gemsmith
|
|
6
6
|
module Builders
|
7
7
|
module RSpec
|
8
8
|
# Builds RSpec spec helper for project skeleton.
|
9
|
-
class Helper < Rubysmith::Builders::
|
9
|
+
class Helper < Rubysmith::Builders::RSpec::Helper
|
10
10
|
using Refinements::Struct
|
11
11
|
|
12
12
|
def call
|
13
|
-
return
|
13
|
+
return false unless settings.build_rspec
|
14
14
|
|
15
|
-
|
16
|
-
|
15
|
+
super
|
16
|
+
|
17
|
+
return false unless settings.build_cli
|
18
|
+
|
19
|
+
builder.call(settings.merge(template_path: "%project_name%/spec/spec_helper.rb.erb"))
|
17
20
|
.replace("%r(^/spec/)", "%r((.+/container\\.rb|^/spec/))")
|
18
|
-
|
21
|
+
|
22
|
+
true
|
19
23
|
end
|
20
24
|
end
|
21
25
|
end
|
@@ -9,7 +9,7 @@ module Gemsmith
|
|
9
9
|
using Refinements::Struct
|
10
10
|
|
11
11
|
def call
|
12
|
-
config =
|
12
|
+
config = settings.merge template_path: "%project_name%/%project_name%.gemspec.erb"
|
13
13
|
|
14
14
|
builder.call(config)
|
15
15
|
.render
|
@@ -19,7 +19,7 @@ module Gemsmith
|
|
19
19
|
.replace(" spec", " spec")
|
20
20
|
.replace(/\}\s+s/m, "}\n\n s")
|
21
21
|
|
22
|
-
|
22
|
+
true
|
23
23
|
end
|
24
24
|
end
|
25
25
|
end
|
@@ -7,15 +7,15 @@ module Gemsmith
|
|
7
7
|
module Actions
|
8
8
|
# Stores CLI flag.
|
9
9
|
class CLI < Sod::Action
|
10
|
-
include Import[:
|
10
|
+
include Import[:settings]
|
11
11
|
|
12
12
|
description "Add command line interface."
|
13
13
|
|
14
14
|
on "--[no-]cli"
|
15
15
|
|
16
|
-
default { Container[:
|
16
|
+
default { Container[:settings].build_cli }
|
17
17
|
|
18
|
-
def call(value = nil) =
|
18
|
+
def call(value = nil) = settings.build_cli = value
|
19
19
|
end
|
20
20
|
end
|
21
21
|
end
|
@@ -9,7 +9,7 @@ module Gemsmith
|
|
9
9
|
module Actions
|
10
10
|
# Handles the edit action for editing an installed gem.
|
11
11
|
class Edit < Sod::Action
|
12
|
-
include Import[:
|
12
|
+
include Import[:logger]
|
13
13
|
include Dry::Monads[:result]
|
14
14
|
|
15
15
|
description "Edit installed gem in default editor."
|
@@ -30,8 +30,8 @@ module Gemsmith
|
|
30
30
|
def call name = nil
|
31
31
|
case publisher.call loader.call("#{name || default}.gemspec")
|
32
32
|
in Success(spec) then logger.info { "Published: #{spec.package_name}." }
|
33
|
-
in Failure(message) then log_error
|
34
|
-
else log_error
|
33
|
+
in Failure(message) then log_error message
|
34
|
+
else log_error "Publish failed, unable to parse result."
|
35
35
|
end
|
36
36
|
end
|
37
37
|
|
@@ -39,7 +39,7 @@ module Gemsmith
|
|
39
39
|
|
40
40
|
attr_reader :publisher, :loader
|
41
41
|
|
42
|
-
def log_error(
|
42
|
+
def log_error(message) = logger.error { message }
|
43
43
|
end
|
44
44
|
end
|
45
45
|
end
|
@@ -9,7 +9,7 @@ module Gemsmith
|
|
9
9
|
module Actions
|
10
10
|
# Handles the view action for viewing an installed gem in default browser.
|
11
11
|
class View < Sod::Action
|
12
|
-
include Import[:
|
12
|
+
include Import[:logger]
|
13
13
|
include Dry::Monads[:result]
|
14
14
|
|
15
15
|
description "View installed gem in default browser."
|
@@ -7,7 +7,7 @@ module Gemsmith
|
|
7
7
|
module Commands
|
8
8
|
# Handles the build action.
|
9
9
|
class Build < Sod::Command
|
10
|
-
include Import[:
|
10
|
+
include Import[:settings, :logger]
|
11
11
|
|
12
12
|
# Order is important.
|
13
13
|
BUILDERS = [
|
@@ -21,23 +21,22 @@ module Gemsmith
|
|
21
21
|
Rubysmith::Builders::Documentation::License,
|
22
22
|
Rubysmith::Builders::Documentation::Version,
|
23
23
|
Rubysmith::Builders::Git::Setup,
|
24
|
-
Rubysmith::Builders::Git::Ignore,
|
25
|
-
Rubysmith::Builders::Git::Safe,
|
26
24
|
Builders::Git::Ignore,
|
27
|
-
Rubysmith::Builders::
|
25
|
+
Rubysmith::Builders::Git::Safe,
|
28
26
|
Builders::Bundler,
|
29
27
|
Builders::CLI,
|
30
|
-
Rubysmith::Builders::Rake,
|
28
|
+
Rubysmith::Builders::Rake::Binstub,
|
29
|
+
Rubysmith::Builders::Rake::Configuration,
|
31
30
|
Builders::Console,
|
32
|
-
Rubysmith::Builders::CircleCI,
|
33
31
|
Builders::CircleCI,
|
34
32
|
Rubysmith::Builders::Setup,
|
35
|
-
Rubysmith::Builders::GitHub,
|
33
|
+
Rubysmith::Builders::GitHub::Template,
|
34
|
+
Rubysmith::Builders::GitHub::Funding,
|
35
|
+
Rubysmith::Builders::GitHub::CI,
|
36
36
|
Rubysmith::Builders::Guard,
|
37
37
|
Rubysmith::Builders::Reek,
|
38
38
|
Rubysmith::Builders::RSpec::Binstub,
|
39
39
|
Rubysmith::Builders::RSpec::Context,
|
40
|
-
Rubysmith::Builders::RSpec::Helper,
|
41
40
|
Builders::RSpec::Helper,
|
42
41
|
Rubysmith::Builders::Caliber,
|
43
42
|
Rubysmith::Extensions::Bundler,
|
@@ -51,36 +50,36 @@ module Gemsmith
|
|
51
50
|
|
52
51
|
description "Build new project."
|
53
52
|
|
54
|
-
on Rubysmith::CLI::Actions::Name,
|
55
|
-
on Rubysmith::CLI::Actions::AmazingPrint,
|
56
|
-
on Rubysmith::CLI::Actions::Caliber,
|
57
|
-
on Rubysmith::CLI::Actions::CircleCI,
|
58
|
-
on Rubysmith::CLI::Actions::Citation,
|
53
|
+
on Rubysmith::CLI::Actions::Name, settings: Container[:settings]
|
54
|
+
on Rubysmith::CLI::Actions::AmazingPrint, settings: Container[:settings]
|
55
|
+
on Rubysmith::CLI::Actions::Caliber, settings: Container[:settings]
|
56
|
+
on Rubysmith::CLI::Actions::CircleCI, settings: Container[:settings]
|
57
|
+
on Rubysmith::CLI::Actions::Citation, settings: Container[:settings]
|
59
58
|
on Actions::CLI
|
60
|
-
on Rubysmith::CLI::Actions::Community,
|
61
|
-
on Rubysmith::CLI::Actions::Conduct,
|
62
|
-
on Rubysmith::CLI::Actions::Console,
|
63
|
-
on Rubysmith::CLI::Actions::Contributions,
|
64
|
-
on Rubysmith::CLI::Actions::Debug,
|
65
|
-
on Rubysmith::CLI::Actions::Funding,
|
66
|
-
on Rubysmith::CLI::Actions::Git,
|
67
|
-
on Rubysmith::CLI::Actions::GitHub,
|
68
|
-
on Rubysmith::CLI::Actions::GitHubCI,
|
69
|
-
on Rubysmith::CLI::Actions::GitLint,
|
70
|
-
on Rubysmith::CLI::Actions::Guard,
|
71
|
-
on Rubysmith::CLI::Actions::License,
|
72
|
-
on Rubysmith::CLI::Actions::Maximum,
|
73
|
-
on Rubysmith::CLI::Actions::Minimum,
|
74
|
-
on Rubysmith::CLI::Actions::Rake,
|
75
|
-
on Rubysmith::CLI::Actions::Readme,
|
76
|
-
on Rubysmith::CLI::Actions::Reek,
|
77
|
-
on Rubysmith::CLI::Actions::Refinements,
|
78
|
-
on Rubysmith::CLI::Actions::RSpec,
|
79
|
-
on Rubysmith::CLI::Actions::Security,
|
80
|
-
on Rubysmith::CLI::Actions::Setup,
|
81
|
-
on Rubysmith::CLI::Actions::SimpleCov,
|
82
|
-
on Rubysmith::CLI::Actions::Versions,
|
83
|
-
on Rubysmith::CLI::Actions::Zeitwerk,
|
59
|
+
on Rubysmith::CLI::Actions::Community, settings: Container[:settings]
|
60
|
+
on Rubysmith::CLI::Actions::Conduct, settings: Container[:settings]
|
61
|
+
on Rubysmith::CLI::Actions::Console, settings: Container[:settings]
|
62
|
+
on Rubysmith::CLI::Actions::Contributions, settings: Container[:settings]
|
63
|
+
on Rubysmith::CLI::Actions::Debug, settings: Container[:settings]
|
64
|
+
on Rubysmith::CLI::Actions::Funding, settings: Container[:settings]
|
65
|
+
on Rubysmith::CLI::Actions::Git, settings: Container[:settings]
|
66
|
+
on Rubysmith::CLI::Actions::GitHub, settings: Container[:settings]
|
67
|
+
on Rubysmith::CLI::Actions::GitHubCI, settings: Container[:settings]
|
68
|
+
on Rubysmith::CLI::Actions::GitLint, settings: Container[:settings]
|
69
|
+
on Rubysmith::CLI::Actions::Guard, settings: Container[:settings]
|
70
|
+
on Rubysmith::CLI::Actions::License, settings: Container[:settings]
|
71
|
+
on Rubysmith::CLI::Actions::Maximum, settings: Container[:settings]
|
72
|
+
on Rubysmith::CLI::Actions::Minimum, settings: Container[:settings]
|
73
|
+
on Rubysmith::CLI::Actions::Rake, settings: Container[:settings]
|
74
|
+
on Rubysmith::CLI::Actions::Readme, settings: Container[:settings]
|
75
|
+
on Rubysmith::CLI::Actions::Reek, settings: Container[:settings]
|
76
|
+
on Rubysmith::CLI::Actions::Refinements, settings: Container[:settings]
|
77
|
+
on Rubysmith::CLI::Actions::RSpec, settings: Container[:settings]
|
78
|
+
on Rubysmith::CLI::Actions::Security, settings: Container[:settings]
|
79
|
+
on Rubysmith::CLI::Actions::Setup, settings: Container[:settings]
|
80
|
+
on Rubysmith::CLI::Actions::SimpleCov, settings: Container[:settings]
|
81
|
+
on Rubysmith::CLI::Actions::Versions, settings: Container[:settings]
|
82
|
+
on Rubysmith::CLI::Actions::Zeitwerk, settings: Container[:settings]
|
84
83
|
|
85
84
|
def initialize(builders: BUILDERS, **)
|
86
85
|
super(**)
|
@@ -88,8 +87,8 @@ module Gemsmith
|
|
88
87
|
end
|
89
88
|
|
90
89
|
def call
|
91
|
-
log_info "Building project skeleton: #{
|
92
|
-
builders.each { |
|
90
|
+
log_info "Building project skeleton: #{settings.project_name}..."
|
91
|
+
builders.each { |constant| constant.new(settings:).call }
|
93
92
|
log_info "Project skeleton complete!"
|
94
93
|
end
|
95
94
|
|
data/lib/gemsmith/container.rb
CHANGED
@@ -12,36 +12,45 @@ module Gemsmith
|
|
12
12
|
module Container
|
13
13
|
extend Containable
|
14
14
|
|
15
|
-
register :
|
16
|
-
|
17
|
-
|
18
|
-
end
|
19
|
-
|
20
|
-
register :defaults do
|
21
|
-
registry = Etcher::Registry.new contract: Rubysmith::Configuration::Contract,
|
22
|
-
model: Rubysmith::Configuration::Model
|
15
|
+
register :registry do
|
16
|
+
contract = Rubysmith::Configuration::Contract
|
17
|
+
model = Rubysmith::Configuration::Model
|
23
18
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
19
|
+
Etcher::Registry.new(contract:, model:)
|
20
|
+
.add_loader(:yaml, self[:defaults_path])
|
21
|
+
.add_loader(:yaml, self[:xdg_config].active)
|
22
|
+
.add_transformer(Rubysmith::Configuration::Transformers::GitHubUser.new)
|
23
|
+
.add_transformer(Rubysmith::Configuration::Transformers::GitEmail.new)
|
24
|
+
.add_transformer(Rubysmith::Configuration::Transformers::GitUser.new)
|
25
|
+
.add_transformer(Rubysmith::Configuration::Transformers::TemplateRoot.new)
|
26
|
+
.add_transformer(
|
27
|
+
Rubysmith::Configuration::Transformers::TemplateRoot.new(
|
28
|
+
default: Pathname(__dir__).join("templates")
|
29
|
+
)
|
30
|
+
)
|
31
|
+
.add_transformer(:root, :target_root)
|
32
|
+
.add_transformer(:format, :author_uri)
|
33
|
+
.add_transformer(:format, :project_uri_community)
|
34
|
+
.add_transformer(:format, :project_uri_conduct)
|
35
|
+
.add_transformer(:format, :project_uri_contributions)
|
36
|
+
.add_transformer(:format, :project_uri_download, :project_name)
|
37
|
+
.add_transformer(:format, :project_uri_funding)
|
38
|
+
.add_transformer(:format, :project_uri_home, :project_name)
|
39
|
+
.add_transformer(:format, :project_uri_issues, :project_name)
|
40
|
+
.add_transformer(:format, :project_uri_license)
|
41
|
+
.add_transformer(:format, :project_uri_security)
|
42
|
+
.add_transformer(:format, :project_uri_source, :project_name)
|
43
|
+
.add_transformer(:format, :project_uri_versions, :project_name)
|
44
|
+
.add_transformer(:time, :loaded_at)
|
36
45
|
end
|
37
46
|
|
47
|
+
register(:settings) { Etcher.call(self[:registry]).dup }
|
38
48
|
register(:specification) { Spek::Loader.call "#{__dir__}/../../gemsmith.gemspec" }
|
39
|
-
register(:input) { self[:configuration].dup }
|
40
49
|
register(:defaults_path) { Rubysmith::Container[:defaults_path] }
|
41
50
|
register(:xdg_config) { Runcom::Config.new "gemsmith/configuration.yml" }
|
42
51
|
register :environment, ENV
|
43
52
|
register(:logger) { Cogger.new id: :gemsmith }
|
44
53
|
register :executor, Open3
|
45
|
-
register :
|
54
|
+
register :io, STDOUT
|
46
55
|
end
|
47
56
|
end
|
@@ -1,74 +1,74 @@
|
|
1
1
|
Gem::Specification.new do |spec|
|
2
|
-
spec.name = "<%=
|
3
|
-
spec.version = "<%=
|
4
|
-
spec.authors = ["<%=
|
5
|
-
spec.email = ["<%=
|
6
|
-
spec.homepage = "<%=
|
2
|
+
spec.name = "<%= settings.project_name %>"
|
3
|
+
spec.version = "<%= settings.project_version %>"
|
4
|
+
spec.authors = ["<%= settings.author_name %>"]
|
5
|
+
spec.email = ["<%= settings.author_email %>"]
|
6
|
+
spec.homepage = "<%= settings.computed_project_uri_home %>"
|
7
7
|
spec.summary = ""
|
8
|
-
spec.license = "<%=
|
8
|
+
spec.license = "<%= settings.license_label_version %>"
|
9
9
|
|
10
10
|
spec.metadata = {
|
11
|
-
<% unless
|
12
|
-
"bug_tracker_uri" => "<%=
|
11
|
+
<% unless settings.computed_project_uri_issues.empty? %>
|
12
|
+
"bug_tracker_uri" => "<%= settings.computed_project_uri_issues %>",
|
13
13
|
<% end %>
|
14
|
-
<% unless
|
15
|
-
"changelog_uri" => "<%=
|
14
|
+
<% unless settings.computed_project_uri_versions.empty? %>
|
15
|
+
"changelog_uri" => "<%= settings.computed_project_uri_versions %>",
|
16
16
|
<% end %>
|
17
|
-
<% unless
|
18
|
-
"documentation_uri" => "<%=
|
17
|
+
<% unless settings.computed_project_uri_home.empty? %>
|
18
|
+
"documentation_uri" => "<%= settings.computed_project_uri_home %>",
|
19
19
|
<% end %>
|
20
|
-
<% unless
|
21
|
-
"funding_uri" => "<%=
|
20
|
+
<% unless settings.computed_project_uri_funding.empty? %>
|
21
|
+
"funding_uri" => "<%= settings.computed_project_uri_funding %>",
|
22
22
|
<% end %>
|
23
|
-
"label" => "<%=
|
24
|
-
<%
|
25
|
-
"rubygems_mfa_required" => "true"
|
26
|
-
<% else %>
|
23
|
+
"label" => "<%= settings.project_label %>",
|
24
|
+
<% unless settings.computed_project_uri_source.empty? %>
|
27
25
|
"rubygems_mfa_required" => "true",
|
28
|
-
"source_code_uri" => "<%=
|
26
|
+
"source_code_uri" => "<%= settings.computed_project_uri_source %>"
|
27
|
+
<% else %>
|
28
|
+
"rubygems_mfa_required" => "true"
|
29
29
|
<% end %>
|
30
30
|
}
|
31
31
|
|
32
|
-
<% if
|
32
|
+
<% if settings.build_security %>
|
33
33
|
spec.signing_key = Gem.default_key_path
|
34
34
|
spec.cert_chain = [Gem.default_cert_path]
|
35
35
|
<% end %>
|
36
36
|
|
37
37
|
spec.required_ruby_version = "~> <%= RUBY_VERSION[/\d+\.\d+/] %>"
|
38
|
-
<% if
|
38
|
+
<% if settings.build_cli %>
|
39
39
|
spec.add_dependency "cogger", "~> 0.21"
|
40
40
|
<% end %>
|
41
|
-
<% if
|
42
|
-
spec.add_dependency "containable", "~> 0.
|
41
|
+
<% if settings.build_cli %>
|
42
|
+
spec.add_dependency "containable", "~> 0.2"
|
43
43
|
<% end %>
|
44
|
-
<% if
|
44
|
+
<% if settings.build_cli %>
|
45
45
|
spec.add_dependency "dry-monads", "~> 1.6"
|
46
46
|
<% end %>
|
47
|
-
<% if
|
48
|
-
spec.add_dependency "etcher", "~> 1
|
47
|
+
<% if settings.build_cli %>
|
48
|
+
spec.add_dependency "etcher", "~> 2.1"
|
49
49
|
<% end %>
|
50
|
-
<% if
|
51
|
-
spec.add_dependency "infusible", "~> 3.
|
50
|
+
<% if settings.build_cli %>
|
51
|
+
spec.add_dependency "infusible", "~> 3.8"
|
52
52
|
<% end %>
|
53
|
-
<% if
|
54
|
-
spec.add_dependency "refinements", "~> 12.
|
53
|
+
<% if settings.build_refinements %>
|
54
|
+
spec.add_dependency "refinements", "~> 12.7"
|
55
55
|
<% end %>
|
56
|
-
<% if
|
57
|
-
spec.add_dependency "runcom", "~> 11.
|
56
|
+
<% if settings.build_cli %>
|
57
|
+
spec.add_dependency "runcom", "~> 11.5"
|
58
58
|
<% end %>
|
59
|
-
<% if
|
60
|
-
spec.add_dependency "sod", "~> 0.
|
59
|
+
<% if settings.build_cli %>
|
60
|
+
spec.add_dependency "sod", "~> 0.12"
|
61
61
|
<% end %>
|
62
|
-
<% if
|
62
|
+
<% if settings.build_cli %>
|
63
63
|
spec.add_dependency "spek", "~> 3.0"
|
64
64
|
<% end %>
|
65
|
-
<% if
|
65
|
+
<% if settings.build_zeitwerk %>
|
66
66
|
spec.add_dependency "zeitwerk", "~> 2.6"
|
67
67
|
<% end %>
|
68
68
|
|
69
|
-
<% if
|
69
|
+
<% if settings.build_cli %>
|
70
70
|
spec.bindir = "exe"
|
71
|
-
spec.executables << "<%=
|
71
|
+
spec.executables << "<%= settings.project_name %>"
|
72
72
|
<% end %>
|
73
73
|
spec.extra_rdoc_files = Dir["README*", "LICENSE*"]
|
74
74
|
spec.files = Dir["*.gemspec", "lib/**/*"]
|
@@ -21,7 +21,7 @@ require "sod"
|
|
21
21
|
def cli
|
22
22
|
context = build_context
|
23
23
|
|
24
|
-
dsl.new <%=
|
24
|
+
dsl.new <%= settings.project_levels.positive? ? settings.project_name.inspect : settings.project_name.to_sym.inspect %>, banner: specification.banner do
|
25
25
|
on(Sod::Prefabs::Commands::Config, context:)
|
26
26
|
on(Sod::Prefabs::Actions::Version, context:)
|
27
27
|
on Sod::Prefabs::Actions::Help, self
|
data/lib/gemsmith/templates/%project_name%/lib/%project_path%/configuration/defaults.yml.erb
CHANGED
@@ -0,0 +1 @@
|
|
1
|
+
todo: "Add your own attributes here."
|
@@ -9,20 +9,17 @@ require "spek"
|
|
9
9
|
module Container
|
10
10
|
extend Containable
|
11
11
|
|
12
|
-
register :
|
13
|
-
self[:defaults].add_loader(:yaml, self[:xdg_config].active)
|
14
|
-
.then { |registry| Etcher.call registry }
|
15
|
-
end
|
16
|
-
|
17
|
-
register :defaults do
|
12
|
+
register :registry do
|
18
13
|
Etcher::Registry.new(contract: Configuration::Contract, model: Configuration::Model)
|
19
14
|
.add_loader(:yaml, self[:defaults_path])
|
15
|
+
.add_loader(:yaml, self[:xdg_config].active)
|
20
16
|
end
|
21
17
|
|
22
|
-
register(:
|
18
|
+
register(:settings) { Etcher.call(self[:registry]).dup }
|
19
|
+
register(:specification) { Spek::Loader.call "#{__dir__}/<%= Array.new(2 + settings.project_levels, "../").join %><%= settings.project_name %>.gemspec" }
|
23
20
|
register(:defaults_path) { Pathname(__dir__).join("configuration/defaults.yml") }
|
24
|
-
register(:xdg_config) { Runcom::Config.new "<%=
|
25
|
-
register(:logger) { Cogger.new id: "<%=
|
26
|
-
register :
|
21
|
+
register(:xdg_config) { Runcom::Config.new "<%= settings.project_path %>/configuration.yml" }
|
22
|
+
register(:logger) { Cogger.new id: "<%= settings.project_name %>" }
|
23
|
+
register :io, STDOUT
|
27
24
|
end
|
28
25
|
<% end %>
|
@@ -1,30 +1,45 @@
|
|
1
1
|
require "spec_helper"
|
2
2
|
|
3
|
-
RSpec.describe <%=
|
3
|
+
RSpec.describe <%= settings.project_namespaced_class %>::CLI::Shell do
|
4
|
+
<% if settings.build_refinements %>
|
4
5
|
using Refinements::Pathname
|
6
|
+
using Refinements::StringIO
|
7
|
+
<% end %>
|
5
8
|
|
6
9
|
subject(:shell) { described_class.new }
|
7
10
|
|
8
11
|
include_context "with application dependencies"
|
9
12
|
|
10
|
-
before { Sod::Container.stub!
|
13
|
+
before { Sod::Container.stub! logger:, io: }
|
11
14
|
|
12
15
|
after { Sod::Container.restore }
|
13
16
|
|
14
17
|
describe "#call" do
|
15
18
|
it "prints configuration usage" do
|
16
19
|
shell.call %w[config]
|
17
|
-
|
20
|
+
<% if settings.build_refinements %>
|
21
|
+
expect(io.reread).to match(/Manage configuration.+/m)
|
22
|
+
<% else %>
|
23
|
+
expect(io.tap(&:rewind).read).to match(/Manage configuration.+/m)
|
24
|
+
<% end %>
|
18
25
|
end
|
19
26
|
|
20
27
|
it "prints version" do
|
21
28
|
shell.call %w[--version]
|
22
|
-
|
29
|
+
<% if settings.build_refinements %>
|
30
|
+
expect(io.reread).to match(/<%= settings.project_label.gsub(" ", "\\s") %>\s\d+\.\d+\.\d+/)
|
31
|
+
<% else %>
|
32
|
+
expect(io.tap(&:rewind).read).to match(/<%= settings.project_label.gsub(" ", "\\s") %>\s\d+\.\d+\.\d+/)
|
33
|
+
<% end %>
|
23
34
|
end
|
24
35
|
|
25
36
|
it "prints help" do
|
26
37
|
shell.call %w[--help]
|
27
|
-
|
38
|
+
<% if settings.build_refinements %>
|
39
|
+
expect(io.reread).to match(/<%= settings.project_label.gsub(" ", "\\s") %>.+USAGE.+/m)
|
40
|
+
<% else %>
|
41
|
+
expect(io.tap(&:rewind).read).to match(/<%= settings.project_label.gsub(" ", "\\s") %>.+USAGE.+/m)
|
42
|
+
<% end %>
|
28
43
|
end
|
29
44
|
end
|
30
45
|
end
|
@@ -1,9 +1,20 @@
|
|
1
1
|
RSpec.shared_context "with application dependencies" do
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
let(:logger) { Cogger.new id: "<%= configuration.project_name %>", io: StringIO.new, level: :debug }
|
2
|
+
<% if settings.build_refinements %>
|
3
|
+
using Refinements::Struct
|
4
|
+
<% end %>
|
6
5
|
|
7
|
-
|
8
|
-
|
6
|
+
let(:settings) { <%= settings.project_namespaced_class %>::Container[:settings] }
|
7
|
+
let(:logger) { Cogger.new id: "<%= settings.project_name %>", io: StringIO.new, level: :debug }
|
8
|
+
let(:io) { StringIO.new }
|
9
|
+
|
10
|
+
<% if settings.build_refinements %>
|
11
|
+
before do
|
12
|
+
settings.merge! Etcher.call(<%= settings.project_namespaced_class %>::Container[:registry].remove_loader(1))
|
13
|
+
<%= settings.project_namespaced_class %>::Container.stub! logger:, io:
|
14
|
+
end
|
15
|
+
<% else %>
|
16
|
+
before { Demo::Container.stub! logger:, io: }
|
17
|
+
<% end %>
|
18
|
+
|
19
|
+
after { <%= settings.project_namespaced_class %>::Container.restore }
|
9
20
|
end
|
@@ -7,7 +7,6 @@ module Gemsmith
|
|
7
7
|
module Tools
|
8
8
|
# Versions (tags: local and remote) current project.
|
9
9
|
class Versioner
|
10
|
-
include Import[:configuration]
|
11
10
|
include Dry::Monads[:result]
|
12
11
|
|
13
12
|
def initialize(
|
@@ -20,12 +19,7 @@ module Gemsmith
|
|
20
19
|
@model = model
|
21
20
|
end
|
22
21
|
|
23
|
-
def call specification
|
24
|
-
publisher.call specification.version
|
25
|
-
Success specification
|
26
|
-
rescue Milestoner::Error => error
|
27
|
-
Failure error.message
|
28
|
-
end
|
22
|
+
def call(specification) = publisher.call(specification.version).fmap { specification }
|
29
23
|
|
30
24
|
private
|
31
25
|
|
data.tar.gz.sig
CHANGED
Binary file
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: gemsmith
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version:
|
4
|
+
version: 22.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Brooke Kuhlmann
|
@@ -35,7 +35,7 @@ cert_chain:
|
|
35
35
|
3n5C8/6Zh9DYTkpcwPSuIfAga6wf4nXc9m6JAw8AuMLaiWN/r/2s4zJsUHYERJEu
|
36
36
|
gZGm4JqtuSg8pYjPeIJxS960owq+SfuC+jxqmRA54BisFCv/0VOJi7tiJVY=
|
37
37
|
-----END CERTIFICATE-----
|
38
|
-
date: 2024-
|
38
|
+
date: 2024-07-24 00:00:00.000000000 Z
|
39
39
|
dependencies:
|
40
40
|
- !ruby/object:Gem::Dependency
|
41
41
|
name: cogger
|
@@ -57,14 +57,14 @@ dependencies:
|
|
57
57
|
requirements:
|
58
58
|
- - "~>"
|
59
59
|
- !ruby/object:Gem::Version
|
60
|
-
version: '0.
|
60
|
+
version: '0.2'
|
61
61
|
type: :runtime
|
62
62
|
prerelease: false
|
63
63
|
version_requirements: !ruby/object:Gem::Requirement
|
64
64
|
requirements:
|
65
65
|
- - "~>"
|
66
66
|
- !ruby/object:Gem::Version
|
67
|
-
version: '0.
|
67
|
+
version: '0.2'
|
68
68
|
- !ruby/object:Gem::Dependency
|
69
69
|
name: core
|
70
70
|
requirement: !ruby/object:Gem::Requirement
|
@@ -113,98 +113,98 @@ dependencies:
|
|
113
113
|
requirements:
|
114
114
|
- - "~>"
|
115
115
|
- !ruby/object:Gem::Version
|
116
|
-
version: '1
|
116
|
+
version: '2.1'
|
117
117
|
type: :runtime
|
118
118
|
prerelease: false
|
119
119
|
version_requirements: !ruby/object:Gem::Requirement
|
120
120
|
requirements:
|
121
121
|
- - "~>"
|
122
122
|
- !ruby/object:Gem::Version
|
123
|
-
version: '1
|
123
|
+
version: '2.1'
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: infusible
|
126
126
|
requirement: !ruby/object:Gem::Requirement
|
127
127
|
requirements:
|
128
128
|
- - "~>"
|
129
129
|
- !ruby/object:Gem::Version
|
130
|
-
version: '3.
|
130
|
+
version: '3.8'
|
131
131
|
type: :runtime
|
132
132
|
prerelease: false
|
133
133
|
version_requirements: !ruby/object:Gem::Requirement
|
134
134
|
requirements:
|
135
135
|
- - "~>"
|
136
136
|
- !ruby/object:Gem::Version
|
137
|
-
version: '3.
|
137
|
+
version: '3.8'
|
138
138
|
- !ruby/object:Gem::Dependency
|
139
139
|
name: milestoner
|
140
140
|
requirement: !ruby/object:Gem::Requirement
|
141
141
|
requirements:
|
142
142
|
- - "~>"
|
143
143
|
- !ruby/object:Gem::Version
|
144
|
-
version: '
|
144
|
+
version: '18.0'
|
145
145
|
type: :runtime
|
146
146
|
prerelease: false
|
147
147
|
version_requirements: !ruby/object:Gem::Requirement
|
148
148
|
requirements:
|
149
149
|
- - "~>"
|
150
150
|
- !ruby/object:Gem::Version
|
151
|
-
version: '
|
151
|
+
version: '18.0'
|
152
152
|
- !ruby/object:Gem::Dependency
|
153
153
|
name: refinements
|
154
154
|
requirement: !ruby/object:Gem::Requirement
|
155
155
|
requirements:
|
156
156
|
- - "~>"
|
157
157
|
- !ruby/object:Gem::Version
|
158
|
-
version: '12.
|
158
|
+
version: '12.7'
|
159
159
|
type: :runtime
|
160
160
|
prerelease: false
|
161
161
|
version_requirements: !ruby/object:Gem::Requirement
|
162
162
|
requirements:
|
163
163
|
- - "~>"
|
164
164
|
- !ruby/object:Gem::Version
|
165
|
-
version: '12.
|
165
|
+
version: '12.7'
|
166
166
|
- !ruby/object:Gem::Dependency
|
167
167
|
name: rubysmith
|
168
168
|
requirement: !ruby/object:Gem::Requirement
|
169
169
|
requirements:
|
170
170
|
- - "~>"
|
171
171
|
- !ruby/object:Gem::Version
|
172
|
-
version: '
|
172
|
+
version: '7.1'
|
173
173
|
type: :runtime
|
174
174
|
prerelease: false
|
175
175
|
version_requirements: !ruby/object:Gem::Requirement
|
176
176
|
requirements:
|
177
177
|
- - "~>"
|
178
178
|
- !ruby/object:Gem::Version
|
179
|
-
version: '
|
179
|
+
version: '7.1'
|
180
180
|
- !ruby/object:Gem::Dependency
|
181
181
|
name: runcom
|
182
182
|
requirement: !ruby/object:Gem::Requirement
|
183
183
|
requirements:
|
184
184
|
- - "~>"
|
185
185
|
- !ruby/object:Gem::Version
|
186
|
-
version: '11.
|
186
|
+
version: '11.5'
|
187
187
|
type: :runtime
|
188
188
|
prerelease: false
|
189
189
|
version_requirements: !ruby/object:Gem::Requirement
|
190
190
|
requirements:
|
191
191
|
- - "~>"
|
192
192
|
- !ruby/object:Gem::Version
|
193
|
-
version: '11.
|
193
|
+
version: '11.5'
|
194
194
|
- !ruby/object:Gem::Dependency
|
195
195
|
name: sod
|
196
196
|
requirement: !ruby/object:Gem::Requirement
|
197
197
|
requirements:
|
198
198
|
- - "~>"
|
199
199
|
- !ruby/object:Gem::Version
|
200
|
-
version: '0.
|
200
|
+
version: '0.12'
|
201
201
|
type: :runtime
|
202
202
|
prerelease: false
|
203
203
|
version_requirements: !ruby/object:Gem::Requirement
|
204
204
|
requirements:
|
205
205
|
- - "~>"
|
206
206
|
- !ruby/object:Gem::Version
|
207
|
-
version: '0.
|
207
|
+
version: '0.12'
|
208
208
|
- !ruby/object:Gem::Dependency
|
209
209
|
name: spek
|
210
210
|
requirement: !ruby/object:Gem::Requirement
|
@@ -311,7 +311,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
311
311
|
- !ruby/object:Gem::Version
|
312
312
|
version: '0'
|
313
313
|
requirements: []
|
314
|
-
rubygems_version: 3.5.
|
314
|
+
rubygems_version: 3.5.16
|
315
315
|
signing_key:
|
316
316
|
specification_version: 4
|
317
317
|
summary: A command line interface for smithing Ruby gems.
|
metadata.gz.sig
CHANGED
Binary file
|