nugem 0.8.1 → 0.9.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.
Files changed (77) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +8 -6
  3. data/CHANGELOG.md +34 -0
  4. data/Gemfile +26 -0
  5. data/README.md +49 -27
  6. data/exe/nugem +3 -3
  7. data/lib/nugem/cli/cli_gem.rb +15 -15
  8. data/lib/nugem/cli/cli_jekyll.rb +38 -34
  9. data/lib/nugem/cli/cli_rails.rb +7 -7
  10. data/lib/nugem/cli.rb +65 -44
  11. data/lib/nugem/git.rb +62 -59
  12. data/lib/nugem/repository.rb +4 -3
  13. data/lib/nugem/version.rb +1 -1
  14. data/lib/nugem.rb +10 -23
  15. data/lib/util.rb +27 -0
  16. data/nugem.gemspec +33 -12
  17. data/spec/spec_helper.rb +1 -4
  18. data/templates/common/executable_scaffold/exe/%gem_name%.tt +2 -2
  19. data/templates/common/executable_scaffold/lib/%gem_name%/cli.rb.tt +17 -9
  20. data/templates/common/executable_scaffold/lib/%gem_name%/options.rb.tt +31 -0
  21. data/templates/common/gem_scaffold/%gem_name%.gemspec.tt +4 -4
  22. data/templates/common/gem_scaffold/.bundle/config +2 -0
  23. data/templates/common/gem_scaffold/.gitignore.tt +27 -0
  24. data/templates/common/gem_scaffold/.markdownlint.json +8 -0
  25. data/templates/common/gem_scaffold/.rspec +2 -0
  26. data/templates/common/gem_scaffold/.rubocop.yml.tt +78 -0
  27. data/templates/common/gem_scaffold/.shellcheckrc +5 -0
  28. data/templates/common/gem_scaffold/.vscode/%gem_name%.json.code-snippets.tt +19 -0
  29. data/templates/common/gem_scaffold/.vscode/extensions.json +22 -0
  30. data/templates/common/gem_scaffold/.vscode/launch.json +68 -0
  31. data/templates/common/gem_scaffold/.vscode/settings.json +5 -0
  32. data/templates/common/gem_scaffold/CHANGELOG.md.tt +4 -1
  33. data/templates/common/gem_scaffold/Gemfile.tt +16 -26
  34. data/templates/common/gem_scaffold/README.md.tt +53 -13
  35. data/templates/common/gem_scaffold/bin/attach +2 -1
  36. data/templates/common/gem_scaffold/bin/build +7 -0
  37. data/templates/common/gem_scaffold/bin/reset +4 -0
  38. data/templates/common/gem_scaffold/bin/setup.tt +6 -3
  39. data/templates/common/gem_scaffold/lib/%gem_name%.rb.tt +2 -0
  40. data/templates/common/gem_scaffold/test/test_helper.rb.tt +3 -3
  41. data/templates/jekyll/block_no_arg_scaffold/lib/%block_name%.rb.tt +1 -1
  42. data/templates/jekyll/block_scaffold/lib/%block_name%.rb.tt +32 -10
  43. data/templates/jekyll/common_scaffold/spec/spec_helper.rb +1 -1
  44. data/templates/jekyll/demo/demo/Gemfile.tt +6 -5
  45. data/templates/jekyll/demo/demo/_bin/debug +7 -16
  46. data/templates/jekyll/demo/demo/_layouts/default.html.tt +1 -1
  47. data/templates/jekyll/hooks_scaffold/lib/dumpers.rb +1 -1
  48. data/templates/jekyll/tag_no_arg_scaffold/lib/%tag_name%.rb.tt +1 -1
  49. data/templates/jekyll/tag_scaffold/lib/%tag_name%.rb.tt +38 -11
  50. data/templates/rails/engine_scaffold/app/assets/images/%gem_name%/.keep +0 -0
  51. data/templates/rails/engine_scaffold/app/assets/javascripts/%gem_name%/.keep +0 -0
  52. data/templates/rails/engine_scaffold/app/assets/stylesheets/%gem_name%/.keep +0 -0
  53. data/templates/rails/engine_scaffold/app/controllers/.keep +0 -0
  54. data/templates/rails/engine_scaffold/app/helpers/.keep +0 -0
  55. data/templates/rails/engine_scaffold/app/mailers/.keep +0 -0
  56. data/templates/rails/engine_scaffold/app/models/.keep +0 -0
  57. data/templates/rails/engine_scaffold/app/views/.keep +0 -0
  58. data/templates/rails/plugin_scaffold/.envrc +1 -0
  59. data/templates/rails/plugin_scaffold/.simplecov.tt +18 -0
  60. data/templates/rails/plugin_scaffold/.travis.yml +4 -0
  61. data/templates/rails/plugin_scaffold/test/dummy/.envrc +1 -0
  62. data/templates/rails/plugin_scaffold/test/dummy/app/assets/images/.keep +0 -0
  63. data/templates/rails/plugin_scaffold/test/dummy/app/controllers/concerns/.keep +0 -0
  64. data/templates/rails/plugin_scaffold/test/dummy/app/models/.keep +0 -0
  65. data/templates/rails/plugin_scaffold/test/dummy/app/models/concerns/.keep +0 -0
  66. data/templates/rails/plugin_scaffold/test/dummy/bin/setup +1 -1
  67. data/templates/rails/plugin_scaffold/test/dummy/lib/assets/.keep +0 -0
  68. data/templates/rails/plugin_scaffold/test/dummy/log/.keep +0 -0
  69. data/templates/rails/rails_scaffold/test/dummy/.envrc +1 -0
  70. data/templates/rails/rails_scaffold/test/dummy/app/assets/images/.keep +0 -0
  71. data/templates/rails/rails_scaffold/test/dummy/app/controllers/concerns/.keep +0 -0
  72. data/templates/rails/rails_scaffold/test/dummy/app/models/.keep +0 -0
  73. data/templates/rails/rails_scaffold/test/dummy/app/models/concerns/.keep +0 -0
  74. data/templates/rails/rails_scaffold/test/dummy/bin/setup +1 -1
  75. data/templates/rails/rails_scaffold/test/dummy/lib/assets/.keep +0 -0
  76. data/templates/rails/rails_scaffold/test/dummy/log/.keep +0 -0
  77. metadata +62 -7
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: aec69f699e43e3648a4e01a6b82142c29df26cc655d0391e45aa64d1cfca53eb
4
- data.tar.gz: ed6d1d27b7ca1b63409c1123bae4b0128abfa63fa9cb4562e9b4e854d697e41e
3
+ metadata.gz: 4c209ec58ac03b1b550972ec5abe2fc6f3846b59dec92b9d8f84f1aedd6f1405
4
+ data.tar.gz: 525e8795a8b7b4217c0f92f2fc3c08084503f09e776f6e155c52a23afe8074f0
5
5
  SHA512:
6
- metadata.gz: 145bb85a469d0fb62fa1b841f81e143f6d3d208ed0c6bdf843295eaa632950fd5dd7adab1dfde67f26d9122c53efadd1334cbc916d1244c585e839893ce0ec74
7
- data.tar.gz: 1ee0b25be2d1e54f06ca5186f98f89ac90c8456cbb2763e16268cde0a52e56272432b43ab44e3c3829aa68fa3e9f978b92e48d3f3d46f8a30f4569ab983414be
6
+ metadata.gz: 915b02fdcc9176e48ffd0ea85147545140fe5407c3da1a27fb22c02522252de88427b4d0aa4155bafa03214b494bf171778187f4d4745ad952c5d082cd7331c6
7
+ data.tar.gz: 1b036270d8ba39dbcc9ddf4b8188feb5a5c50c17761fb58c999c461bba369452a838b5b48a0aac451675ab12ec607d4a648facfd3a8eaabfe37dac9ba4dee0ff
data/.rubocop.yml CHANGED
@@ -1,6 +1,6 @@
1
1
  require:
2
- # - rubocop-jekyll
3
2
  - rubocop-md
3
+ - rubocop-minitest
4
4
  - rubocop-performance
5
5
  - rubocop-rake
6
6
  - rubocop-rspec
@@ -16,7 +16,6 @@ AllCops:
16
16
  - Rakefile
17
17
  - README.md
18
18
  NewCops: enable
19
- TargetRubyVersion: 3.1.3
20
19
 
21
20
  Gemspec/DeprecatedAttributeAssignment:
22
21
  Enabled: false
@@ -24,8 +23,11 @@ Gemspec/DeprecatedAttributeAssignment:
24
23
  Gemspec/RequireMFA:
25
24
  Enabled: false
26
25
 
26
+ Gemspec/RequiredRubyVersion:
27
+ Enabled: false
28
+
27
29
  Layout/ArgumentAlignment:
28
- EnforcedStyle: with_fixed_indentation
30
+ EnforcedStyle: with_first_argument
29
31
 
30
32
  Layout/HashAlignment:
31
33
  EnforcedColonStyle: table
@@ -38,7 +40,8 @@ Layout/MultilineMethodCallIndentation:
38
40
  EnforcedStyle: indented_relative_to_receiver
39
41
 
40
42
  Metrics/AbcSize:
41
- Max: 45
43
+ Enabled: false
44
+ Max: 50
42
45
 
43
46
  Metrics/BlockLength:
44
47
  Exclude:
@@ -80,9 +83,8 @@ Style/TrailingCommaInHashLiteral:
80
83
  Style/TrailingCommaInArrayLiteral:
81
84
  EnforcedStyleForMultiline: comma
82
85
 
83
- RSpec/FilePath:
86
+ RSpec/SpecFilePathFormat:
84
87
  IgnoreMethods: true
85
- SpecSuffixOnly: true
86
88
 
87
89
  RSpec/ExampleLength:
88
90
  Enabled: false
data/CHANGELOG.md CHANGED
@@ -1,5 +1,38 @@
1
1
  # Change Log
2
2
 
3
+ ## 0.9.0
4
+
5
+ * Added `OptionParser` starter for gems in `templates/common/executable_scaffold/lib/%gem_name%/options.rb.tt`.
6
+ * Renamed 'plain' to 'gem'
7
+ * Reorganized generated gem files so they all enhance the same module
8
+ * All generated Ruby files are included on startup
9
+ * Rails apps are deprecated, will be removed soon
10
+
11
+
12
+ ## 0.8.5
13
+
14
+ * Added `-y` option to suppress confirmation messages and default to `yes`.
15
+ * Suppresses the huge chunk of JSON that used to be displayed after the remote repository was created.
16
+
17
+
18
+ ## 0.8.4
19
+
20
+ * Added `-o` option for specifying output directory
21
+ * Added aliases for class options
22
+
23
+
24
+ ## 0.8.3
25
+
26
+ * Added more files to generated projects.
27
+ * Improved generated scripts and settings.
28
+ * `plain` command has been tested.
29
+ * `jekyll` and `rails` commands are not ready yet.
30
+
31
+ ## 0.8.2
32
+
33
+ * Added `.markdownlint.json` to generated projects and this project.
34
+
35
+
3
36
  ## 0.8.1
4
37
 
5
38
  * Corrected broken gemspec.
@@ -16,6 +49,7 @@
16
49
  * Changed the default for including an executable to `false`.
17
50
  * Added the `--quiet` and `--todos` options, common to the `plain`, `jekyll` and `rails` subcommands.
18
51
 
52
+
19
53
  ## 0.7.4
20
54
 
21
55
  * Last release was 7 years prior without a change history.
data/Gemfile ADDED
@@ -0,0 +1,26 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Runtime gem dependencies are specified in nugem.gemspec
4
+ gemspec
5
+
6
+ group :development do
7
+ gem 'erb_lint'
8
+ gem 'gem-release', require: false
9
+ gem 'rubocop', require: false
10
+ gem 'rubocop-md', require: false
11
+ gem 'rubocop-minitest', require: false
12
+ gem 'rubocop-performance', require: false
13
+ gem 'rubocop-rake', require: false
14
+ gem 'rubocop-rspec', require: false
15
+ end
16
+
17
+ group :test, :development do
18
+ gem 'bundler', require: false
19
+ gem 'coveralls', require: false
20
+ gem 'debug', '>= 1.0.0', require: false
21
+ gem 'geminabox', require: false
22
+ gem 'minitest', require: false
23
+ gem 'minitest-reporters', require: false
24
+ gem 'rake', require: false
25
+ gem 'rspec', require: false
26
+ end
data/README.md CHANGED
@@ -1,23 +1,35 @@
1
1
  # `Nugem` [![Gem Version](https://badge.fury.io/rb/nugem.svg)](https://badge.fury.io/rb/nugem)
2
2
 
3
- ## WORK IN PROGRESS
4
-
5
3
  `Nugem` creates a scaffold project for a new gem in a new git repository.
6
4
  After you add your special code to the gem scaffold,
7
5
  the project is ready to be released to a public or private gem server.
8
6
 
9
- This gem generates a scaffold with all files you need to start,
10
- with the following features:
7
+ This gem generates a new working Visual Studio Code project with the following features:
11
8
 
9
+ - Compatible with `rbenv`.
10
+ - `Gemfile` and `.gemspec` files set up.
12
11
  - Generates a README with badges.
13
- - Automatically creates local and remote git repositories (on GitHub, BitBucket or Geminabox) for your new gem.
14
- - Remote repositories can be private or public.
15
- - Can include a [Thor-based executable](https://github.com/rails/thor).
16
- - Creates a test infrastructure based on `rspec` or `minitest` and `minitest-reporters`.
17
- - Ready to publicly release to `rubygems.org` or to a private Geminabox gem server.
12
+ - Visual Studio Code project is set up with current Ruby extensions.
13
+ - Rubocop configured.
14
+ - Shellcheck configured.
15
+ - Markdown lint configured.
16
+ - Launch configurations set up for testing.
17
+ - Can automatically create a public or private git repository on GitHub for your new gem.
18
+ - Creates a test infrastructure based on `rspec`.
19
+ - Your gem can be publicly released to `rubygems.org`.
18
20
  - Optionally create the gem as:
21
+ - A plain old gem.
22
+ - A Jekyll plugin (tag or block tag).
23
+
24
+ The following features are still in development, so they probably do not work yet:
25
+
26
+ - Automatically creates git repositories on BitBucket or Geminabox.
27
+ - Creates a test infrastructure based on `minitest` and `minitest-reporters`.
28
+ - Your gem can be privately released to a Geminabox gem server.
29
+ - Your gem can include a [Thor-based executable](https://github.com/rails/thor).
30
+ - Optionally create the gem as:
31
+ - A Jekyll plugin (filter, generator, or hooks).
19
32
  - A Rails plugin, possibly with a mountable engine.
20
- - A Jekyll plugin (tag, block tag, filter, generator, or hooks).
21
33
 
22
34
 
23
35
  ## Installation
@@ -41,7 +53,9 @@ $ gem update nugem
41
53
 
42
54
  ## Subcommands and Options
43
55
 
44
- `Nugem` has 4 subcommands `plain`, `jekyll`, `help` and `rails`:
56
+ `Nugem` has 4 subcommands `gem`, `jekyll`, `help` and `rails`.
57
+ Currently, only `gem`, `jekyll` and `help` have been properly tested.
58
+
45
59
 
46
60
  ### `help` Subcommand
47
61
 
@@ -60,7 +74,7 @@ $ nugem help [SUBCOMMAND]
60
74
 
61
75
  ### Common Options
62
76
 
63
- The `plain`, `jekyll` and `rails` subcommands have common options.
77
+ The `gem`, `jekyll` and `rails` subcommands have common options.
64
78
 
65
79
  The default option values assume that:
66
80
 
@@ -68,7 +82,7 @@ The default option values assume that:
68
82
  - The gem project will be hosted on a public GitHub git repository
69
83
  - The gem will be released to `rubygems.org`
70
84
 
71
- Common options for the `plain`, `jekyll` and `rails` subcommands are:
85
+ Common options for the `gem`, `jekyll` and `rails` subcommands are:
72
86
 
73
87
  <dl>
74
88
  <dt><code>--executable</code></dt>
@@ -76,7 +90,14 @@ Common options for the `plain`, `jekyll` and `rails` subcommands are:
76
90
 
77
91
  <dt><code>--host</code></dt>
78
92
  <dd>
79
- specifies the git host; possible values are <code>bitbucket</code>, <code>github</code> and <code>geminabox</code>.
93
+ specifies the git host; possible values are <code>bitbucket</code>,
94
+ <code>github</code> and <code>geminabox</code>.
95
+ </dd>
96
+
97
+ <dt><code>--out_dir</code></dt>
98
+ <dd>
99
+ specifies the directory to write the generated gem to.
100
+ The default is <code>generated/</code>.
80
101
  </dd>
81
102
 
82
103
  <dt><code>--private</code></dt>
@@ -94,9 +115,9 @@ Common options for the `plain`, `jekyll` and `rails` subcommands are:
94
115
 
95
116
  ### Common Behavior
96
117
 
97
- The `plain`, `jekyll` and `rails` subcommands have common behavior.
118
+ The `gem`, `jekyll` and `rails` subcommands have common behavior.
98
119
 
99
- Gem scaffolds are created within the `generated/` directory.
120
+ Gem scaffolds are created within the `generated/` directory of the current directory.
100
121
 
101
122
  If your user name is not already stored in your git global config,
102
123
  you will be asked for your GitHub or BitBucket user name.
@@ -107,25 +128,25 @@ Then commit the changes to git and invoke `rake release`,
107
128
  and your gem will be published.
108
129
 
109
130
 
110
- ### `plain` Subcommand
131
+ ### `gem` Subcommand
111
132
 
112
133
  ```shell
113
- $ nugem plain NAME [COMMON_OPTIONS] [--test-framework=minitest|rspec]
134
+ $ nugem gem NAME [COMMON_OPTIONS] [--test-framework=minitest|rspec]
114
135
  ```
115
136
 
116
137
  `NAME` is the name of the gem to be generated.
117
138
 
118
- The default test framework for the `plain` subcommand is `rspec`,
139
+ The default test framework for the `gem` subcommand is `rspec`,
119
140
  but you can specify `minitest` instead like this:
120
141
 
121
142
  ```shell
122
- $ nugem plain my_gem --test-framework=minitest
143
+ $ nugem gem my_gem --test-framework=minitest
123
144
  ```
124
145
 
125
146
 
126
147
  ### `jekyll` Subcommand
127
148
 
128
- The `jekyll` subcommand extends the `plain` subcommand and creates a new Jekyll plugin with the given NAME:
149
+ The `jekyll` subcommand extends the `gem` subcommand and creates a new Jekyll plugin with the given NAME:
129
150
 
130
151
  ```shell
131
152
  $ nugem jekyll NAME [OPTIONS]
@@ -137,12 +158,13 @@ In addition to the common options, the `jekyll`-specific `OPTIONS` are:
137
158
 
138
159
  `--block`, `--blockn`, `--filter`, `--hooks`, `--tag`, and `--tagn`.
139
160
 
161
+ (Warning: only `--block` and `--tag` been properly tested.)
162
+
140
163
  Each of these options causes `nugem` to prompt the user for additional input.
141
164
 
142
165
  The test framework for `jekyll` plugins is `rspec`.
143
166
 
144
- All of the above options can be specified more than once,
145
- except the `--hooks` option.
167
+ All of the above options can be specified more than once, except the `--hooks` option.
146
168
  For example:
147
169
 
148
170
  ```shell
@@ -160,7 +182,7 @@ my_tag2 usage: {% my_tag2 %}
160
182
  </pre>
161
183
  ```
162
184
 
163
- For more information, type
185
+ For more information, type:
164
186
 
165
187
  ```shell
166
188
  $ nugem help jekyll
@@ -169,7 +191,7 @@ $ nugem help jekyll
169
191
 
170
192
  ### `rails` Subcommand
171
193
 
172
- The `rails` subcommand extends the `plain` subcommand and creates a new Rails plugin with the given NAME:
194
+ The `rails` subcommand extends the `gem` subcommand and creates a new Rails plugin with the given NAME:
173
195
 
174
196
  ```shell
175
197
  $ nugem rails NAME [OPTIONS]
@@ -186,7 +208,7 @@ Each of these options causes `nugem` to prompt the user for additional input.
186
208
 
187
209
  The test framework for `rails` gems is `minitest`.
188
210
 
189
- For more information, type
211
+ For more information, type:
190
212
 
191
213
  ```shell
192
214
  $ nugem help rails
@@ -295,7 +317,7 @@ After checking out the repository, run `bin/setup` to install dependencies.
295
317
  Then, run `rake test` to run the tests.
296
318
  You can also run `bin/console` for an interactive prompt that will allow you to experiment.
297
319
 
298
- To install this gem onto your local machine, run
320
+ To install this gem onto your local machine, run:
299
321
 
300
322
  ```shell
301
323
  $ bundle exec rake install
data/exe/nugem CHANGED
@@ -1,9 +1,9 @@
1
1
  #!/usr/bin/env ruby
2
2
 
3
- if File.exist? 'lib/nugem/cli.rb'
4
- require_relative '../lib/nugem/cli'
3
+ if ENV['VO_DEBUGGING']
4
+ require_relative '../lib/nugem'
5
5
  else
6
- require 'nugem/cli'
6
+ require 'nugem'
7
7
  end
8
8
 
9
9
  Nugem::Cli.start
@@ -1,17 +1,13 @@
1
1
  require 'thor'
2
2
 
3
- # Nugem::Cli is a Thor class that is invoked when a user runs a nugem executable
4
- require_relative '../cli'
5
-
6
3
  module Nugem
7
4
  class Cli < Thor
8
5
  include Thor::Actions
9
- include Nugem::Git
10
6
 
11
- desc 'plain NAME', 'Creates a new plain gem scaffold.'
7
+ desc 'gem NAME', 'Creates a new gem scaffold.'
12
8
 
13
9
  long_desc <<~END_DESC
14
- Creates a new plain gem scaffold with the given NAME,
10
+ Creates a new gem scaffold with the given NAME,
15
11
  by default hosted by GitHub and published on RubyGems.
16
12
  END_DESC
17
13
 
@@ -21,12 +17,18 @@ module Nugem
21
17
  method_option :private, type: :boolean, default: false,
22
18
  desc: 'Publish the gem in a private repository.'
23
19
 
24
- def plain(gem_name)
25
- @dir = Nugem.dest_root gem_name
20
+ def gem(gem_name)
21
+ # puts set_color("gem_name=#{gem_name}", :yellow)
22
+ super if gem_name.empty?
23
+
24
+ @executable = options[:executable]
25
+ @host = options[:host] # FIXME: conflicts with @host in create_gem_scaffold()
26
+ @out_dir = options[:out_dir]
27
+ @private = options[:private]
28
+ @test_framework = options[:test_framework]
29
+ @yes = options[:yes]
26
30
 
27
- @host = options['host']
28
- @private = options['private']
29
- @test_framework = options['test_framework']
31
+ @dir = Nugem.dest_root @out_dir, gem_name
30
32
 
31
33
  create_plain_scaffold gem_name
32
34
  initialize_repository gem_name
@@ -37,11 +39,8 @@ module Nugem
37
39
  # Defines globals for templates
38
40
  def create_plain_scaffold(gem_name)
39
41
  @gem_name = gem_name
40
- say "Creating a scaffold for a new plain Ruby gem named #{@gem_name} in #{@dir}.", :green
41
42
  @class_name = Nugem.camel_case @gem_name
42
- @executable = options[:executable]
43
- @host = options[:bitbucket] ? :bitbucket : :github
44
- @private = options[:private]
43
+ @host = options[:bitbucket] ? :bitbucket : :github # FIXME: conflicts with @host in gem()
45
44
  @repository = Nugem::Repository.new(
46
45
  host: @host,
47
46
  user: git_repository_user_name(@host),
@@ -49,6 +48,7 @@ module Nugem
49
48
  gem_server_url: gem_server_url(@private),
50
49
  private: @private
51
50
  )
51
+ puts set_color("Creating a scaffold for a new Ruby gem named #{@gem_name} in #{@dir}.", :green)
52
52
  exclude_pattern = case @test_framework
53
53
  when 'minitest' then /spec.*/
54
54
  when 'rspec' then /test.*/
@@ -4,7 +4,6 @@ require_relative 'jekyll_demo'
4
4
  module Nugem
5
5
  class Cli < Thor # rubocop:disable Metrics/ClassLength
6
6
  include Thor::Actions
7
- include Nugem::Git
8
7
 
9
8
  attr_accessor :class_name, :filter_params, :trailing_args, :trailing_dump, :trailing_params
10
9
 
@@ -27,8 +26,7 @@ module Nugem
27
26
  method_option :generator, type: :string, repeatable: true,
28
27
  desc: 'Specifies a Jekyll generator.'
29
28
 
30
- method_option :hooks, type: :string,
31
- desc: 'Specifies Jekyll hooks.'
29
+ method_option :hooks, type: :string, desc: 'Specifies Jekyll hooks.'
32
30
 
33
31
  method_option :tag, name: :string, repeatable: true,
34
32
  desc: 'Specifies the name of a Jekyll tag.'
@@ -39,29 +37,33 @@ module Nugem
39
37
  test_option 'rspec'
40
38
 
41
39
  def jekyll(gem_name)
42
- @gem_name = gem_name
43
- @dir = Nugem.dest_root @gem_name
44
- @class_name = Nugem.camel_case @gem_name
45
- @jekyll = true
46
- @rspec = true
47
-
40
+ # options is frozen, so it cannot be modified.
41
+ # extracted values are ignored in the case statement below instead.
48
42
  @host = options['host']
43
+ @out_dir = options['out_dir']
49
44
  @private = options['private']
50
45
  @test_framework = options['test_framework']
51
46
  @todos = options['todos']
47
+ @yes = options['yes']
48
+
49
+ @gem_name = gem_name
50
+ @dir = Nugem.dest_root @out_dir, @gem_name
51
+ @class_name = Nugem.camel_case @gem_name
52
+ @jekyll = true
53
+ @rspec = true
52
54
 
53
55
  create_plain_scaffold @gem_name
54
56
  create_jekyll_scaffold
55
57
  options.each do |option|
56
58
  case option.first
57
- when 'block' then option[1].each { |name| create_jekyll_block_scaffold name }
58
- when 'blockn' then option[1].each { |name| create_jekyll_block_no_arg_scaffold name }
59
- when 'filter' then option[1].each { |name| create_jekyll_filter_scaffold name }
59
+ when 'block' then option[1].each { |name| create_jekyll_block_scaffold name }
60
+ when 'blockn' then option[1].each { |name| create_jekyll_block_no_arg_scaffold name }
61
+ when 'filter' then option[1].each { |name| create_jekyll_filter_scaffold name }
60
62
  when 'generator' then option[1].each { |name| create_jekyll_generator_scaffold name }
61
- when 'tag' then option[1].each { |name| create_jekyll_tag_scaffold name }
62
- when 'tagn' then option[1].each { |name| create_jekyll_tag_no_arg_scaffold name }
63
- when 'hooks' then create_jekyll_hooks_scaffold option[1]
64
- when 'host', 'executable', 'private', 'test_framework', 'todos', 'quiet' then next
63
+ when 'tag' then option[1].each { |name| create_jekyll_tag_scaffold name }
64
+ when 'tagn' then option[1].each { |name| create_jekyll_tag_no_arg_scaffold name }
65
+ when 'hooks' then create_jekyll_hooks_scaffold option[1]
66
+ when 'host', 'executable', 'out_dir', 'private', 'test_framework', 'todos', 'quiet' then next
65
67
  else puts "Warning: Unrecognized option: #{option}"
66
68
  end
67
69
  end
@@ -73,7 +75,7 @@ module Nugem
73
75
  # Invoked by directory action when processing Jekyll tags and block tags
74
76
  def parse_jekyll_parameters
75
77
  content = @jekyll_parameter_names_types.map do |name, _type|
76
- "@#{name} = @helper.parameter_specified? '#{name}' # Obtain the value of parameter #{name}"
78
+ "@#{name} = @helper.parameter_specified?('#{name}') || nil # Obtain the value of parameter #{name}"
77
79
  end
78
80
  content.join "\n "
79
81
  end
@@ -93,16 +95,17 @@ module Nugem
93
95
  # list of pairs that describe each Jekyll/Liquid tag invocation option:
94
96
  # [[name1, type1], ... [nameN, typeN]]
95
97
  def ask_option_names_types(tag)
96
- names = ask("Please list the names of the options for the #{tag} Jekyll/Liquid tag:").split(/[ ,\t]/)
98
+ names = ask(set_color("Please list the names of the options for the #{tag} Jekyll/Liquid tag:", :green)).split(/[ ,\t]/)
97
99
  types = names.reject(&:empty?).map do |name|
98
- ask "What is the type of #{name}? (tab autocompletes)", default: 'string', limited_to: %w[boolean string numeric]
100
+ ask set_color("What is the type of #{name}? (tab autocompletes)", :green),
101
+ default: 'string', limited_to: %w[boolean string numeric]
99
102
  end
100
103
  @jekyll_parameter_names_types = names.zip types
101
104
  @jekyll_parameter_names_types
102
105
  end
103
106
 
104
107
  def create_jekyll_scaffold
105
- say "Creating a Jekyll scaffold for a new gem named #{@gem_name} in #{@dir}", :green
108
+ puts set_color("Creating a Jekyll scaffold for a new gem named #{@gem_name} in #{@dir}", :green)
106
109
  @mute = true
107
110
  directory 'jekyll/common_scaffold', @dir, force: true, mode: :preserve
108
111
  directory 'jekyll/demo', @dir, force: true, mode: :preserve
@@ -113,27 +116,28 @@ module Nugem
113
116
  @jekyll_class_name = Nugem.camel_case block_name
114
117
  ask_option_names_types block_name # Defines @jekyll_parameter_names_types, which is a nested array of name/value pairs:
115
118
  # [["opt1", "string"], ["opt2", "boolean"]]
116
- say "Creating Jekyll block tag #{@block_name} scaffold within #{@jekyll_class_name}", :green
119
+ puts set_color("Creating Jekyll block tag #{@block_name} scaffold within #{@jekyll_class_name}", :green)
117
120
  @mute = true
118
121
  directory 'jekyll/block_scaffold', @dir, force: true, mode: :preserve
119
- append_to_file "#{Nugem.dest_root gem_name}/demo/index.html", Cli.add_demo_example(block_name, @jekyll_parameter_names_types, :block)
122
+ append_to_file "#{Nugem.dest_root @out_dir, gem_name}/demo/index.html", Cli.add_demo_example(block_name, @jekyll_parameter_names_types, :block)
120
123
  end
121
124
 
122
125
  def create_jekyll_block_no_arg_scaffold(block_name)
123
126
  @block_name = block_name
124
127
  @jekyll_class_name = Nugem.camel_case block_name
125
- say "Creating Jekyll block tag no_arg #{@block_name} scaffold within #{@jekyll_class_name}", :green
128
+ puts set_color("Creating Jekyll block tag no_arg #{@block_name} scaffold within #{@jekyll_class_name}", :green)
126
129
  @mute = true
127
130
  directory 'jekyll/block_no_arg_scaffold', @dir, force: true, mode: :preserve
128
- append_to_file "#{Nugem.dest_root gem_name}/demo/index.html", Cli.add_demo_example(block_name, @jekyll_parameter_names_types, :block)
131
+ append_to_file "#{Nugem.dest_root @out_dir, gem_name}/demo/index.html", Cli.add_demo_example(block_name, @jekyll_parameter_names_types, :block)
129
132
  end
130
133
 
131
134
  def create_jekyll_filter_scaffold(filter_name)
132
135
  # rubocop:disable Style/StringConcatenation
133
136
  @filter_name = filter_name
134
137
  @jekyll_class_name = Nugem.camel_case filter_name
135
- @filter_params = ask('Jekyll filters have at least one input. ' \
136
- "What are the names of additional inputs for #{filter_name}, if any?")
138
+ prompt = set_color('Jekyll filters have at least one input. ' \
139
+ "What are the names of additional inputs for #{filter_name}, if any?", :green)
140
+ @filter_params = ask(prompt)
137
141
  .split(/[ ,\t]/)
138
142
  .reject(&:empty?)
139
143
  unless @filter_params.empty?
@@ -143,19 +147,19 @@ module Nugem
143
147
  lspace = "\n "
144
148
  @trailing_dump2 = lspace + @filter_params.map { |arg| "#{arg} = \#{#{arg}}" }.join(lspace) unless @filter_params.empty?
145
149
  end
146
- say "Creating a new Jekyll filter method scaffold #{@filter_name}", :green
150
+ puts set_color("Creating a new Jekyll filter method scaffold #{@filter_name}", :green)
147
151
  @mute = true
148
152
  directory 'jekyll/filter_scaffold', @dir, force: true, mode: :preserve
149
153
 
150
154
  tp = ': ' + @filter_params.map { |x| "'#{x}_value'" }.join(', ') unless @filter_params.empty?
151
- append_to_file "#{Nugem.dest_root gem_name}/demo/index.html", Cli.add_filter_example(filter_name, tp)
155
+ append_to_file "#{Nugem.dest_root @out_dir, gem_name}/demo/index.html", Cli.add_filter_example(filter_name, tp)
152
156
  # rubocop:enable Style/StringConcatenation
153
157
  end
154
158
 
155
159
  def create_jekyll_generator_scaffold(generator_name)
156
160
  @generator_name = generator_name
157
161
  @jekyll_class_name = Nugem.camel_case generator_name
158
- say "Creating a new Jekyll generator class scaffold #{@jekyll_class_name}", :green
162
+ puts set_color("Creating a new Jekyll generator class scaffold #{@jekyll_class_name}", :green)
159
163
  @mute = true
160
164
  directory 'jekyll/generator_scaffold', @dir, force: true, mode: :preserve
161
165
  end
@@ -163,7 +167,7 @@ module Nugem
163
167
  def create_jekyll_hooks_scaffold(plugin_name)
164
168
  @plugin_name = plugin_name
165
169
  @jekyll_class_name = Nugem.camel_case plugin_name
166
- say 'Creating a new Jekyll hook scaffold', :green
170
+ puts set_color('Creating a new Jekyll hook scaffold', :green)
167
171
  @mute = true
168
172
  directory 'jekyll/hooks_scaffold', @dir, force: true, mode: :preserve
169
173
  end
@@ -171,10 +175,10 @@ module Nugem
171
175
  def create_jekyll_tag_no_arg_scaffold(tag_name)
172
176
  @tag_name = tag_name
173
177
  @jekyll_class_name = Nugem.camel_case @tag_name
174
- say "Creating Jekyll tag no_arg #{@tag_name} scaffold within #{@jekyll_class_name}", :green
178
+ puts set_color("Creating Jekyll tag no_arg #{@tag_name} scaffold within #{@jekyll_class_name}", :green)
175
179
  @mute = true
176
180
  directory 'jekyll/tag_no_arg_scaffold', @dir, force: true, mode: :preserve
177
- append_to_file "#{Nugem.dest_root gem_name}/demo/index.html", Cli.add_demo_example(tag_name, @jekyll_parameter_names_types, :tag)
181
+ append_to_file "#{Nugem.dest_root @out_dir, gem_name}/demo/index.html", Cli.add_demo_example(tag_name, @jekyll_parameter_names_types, :tag)
178
182
  end
179
183
 
180
184
  def create_jekyll_tag_scaffold(tag_name)
@@ -182,11 +186,11 @@ module Nugem
182
186
  @jekyll_class_name = Nugem.camel_case @tag_name
183
187
  ask_option_names_types tag_name # Defines @jekyll_parameter_names_types, which is a nested array of name/value pairs:
184
188
  # [["opt1", "string"], ["opt2", "boolean"]]
185
- say "Creating Jekyll tag #{@tag_name} scaffold within #{@jekyll_class_name}", :green
189
+ puts set_color("Creating Jekyll tag #{@tag_name} scaffold within #{@jekyll_class_name}", :green)
186
190
  @mute = true
187
191
  # puts set_color("@jekyll_parameter_names_types=#{@jekyll_parameter_names_types}", :yellow)
188
192
  directory 'jekyll/tag_scaffold', @dir, force: true, mode: :preserve
189
- append_to_file "#{Nugem.dest_root gem_name}/demo/index.html", Cli.add_demo_example(tag_name, @jekyll_parameter_names_types, :tag)
193
+ append_to_file "#{Nugem.dest_root @out_dir, gem_name}/demo/index.html", Cli.add_demo_example(tag_name, @jekyll_parameter_names_types, :tag)
190
194
  end
191
195
  end
192
196
  end
@@ -3,12 +3,11 @@ require_relative '../cli'
3
3
  module Nugem
4
4
  class Cli < Thor
5
5
  include Thor::Actions
6
- include Nugem::Git
7
6
 
8
- desc 'rails NAME', 'Creates a new Rails rails scaffold.'
7
+ desc 'rails NAME', 'Creates a new Rails scaffold.'
9
8
 
10
9
  long_desc <<~END_DESC
11
- Creates a new Rails rails scaffold with the given NAME,
10
+ Creates a new Rails scaffold with the given NAME,
12
11
  by default hosted by GitHub and published on RubyGems.
13
12
  END_DESC
14
13
 
@@ -25,8 +24,9 @@ module Nugem
25
24
  @mountable = options['mountable']
26
25
  @private = options['private']
27
26
  @test_framework = options['test_framework']
27
+ @yes = options['yes']
28
28
 
29
- @dir = Nugem.dest_root gem_name
29
+ @dir = Nugem.dest_root @out_dir, gem_name
30
30
  @engine = @host || @mountable
31
31
  @rails = true
32
32
 
@@ -40,17 +40,17 @@ module Nugem
40
40
  private
41
41
 
42
42
  def create_engine_scaffold(gem_name)
43
- say "Creating a new Rails engine scaffold for a new gem named #{gem_name} in #{@dir}", :green
43
+ puts set_color("Creating a new Rails engine scaffold for a new gem named #{gem_name} in #{@dir}", :green)
44
44
  directory 'rails/engine_scaffold', @dir, force: true, mode: :preserve
45
45
  end
46
46
 
47
47
  def create_mountable_scaffold(gem_name)
48
- say "Creating a mountable Rails engine scaffold for a new gem named #{gem_name} in #{@dir}", :green
48
+ puts set_color("Creating a mountable Rails engine scaffold for a new gem named #{gem_name} in #{@dir}", :green)
49
49
  directory 'rails/mountable_scaffold', @dir, force: true, mode: :preserve
50
50
  end
51
51
 
52
52
  def create_rails_scaffold(gem_name)
53
- say "Creating a new Rails plugin scaffold as a gem named #{gem_name} in #{@dir}", :green
53
+ puts set_color("Creating a new Rails plugin scaffold as a gem named #{gem_name} in #{@dir}", :green)
54
54
  directory 'rails/rails_scaffold', @dir, force: true, mode: :preserve
55
55
  Dir.chdir @dir do
56
56
  run 'chmod +x test/dummy/bin/*' # TODO: fix me