Mike Slinn

NuGem

Published 2024-01-10. Last modified 2024-12-22.
Time to read: 4 minutes.

This page is part of the ruby collection.

NuGem creates a scaffold project for a new gem in a new Git repository. After you add your special code to the gem scaffold, the project is ready to be released to a public or private gem server.

Features

This gem generates a new working Visual Studio Code project with the following features:

  • Compatible with rbenv.
  • Gemfile and .gemspec files set up.
  • Generates a README with badges.
  • Visual Studio Code project is set up with current Ruby extensions.
    • Rubocop configured.
    • Shellcheck configured.
    • Markdown lint configured.
    • Launch configurations set up for testing.
  • Can automatically create a public or private Git repository on GitHub for your new gem.
  • Creates a test infrastructure based on rspec.
  • Your gem can be publicly released to rubygems.org.
  • Optionally create the gem as:
    • A plain old gem.
    • A Jekyll plugin (tag or block tag).

The following features are still in development, so they probably do not work yet:

  • Automatically creates Git repositories on BitBucket or Geminabox.
  • Creates a test infrastructure based on minitest and minitest-reporters.
  • Your gem can be privately released to a Geminabox gem server.
  • Your gem can include a Thor-based executable.
  • Optionally create the gem as:
    • A Jekyll plugin (filter, generator, or hooks).
    • A Rails plugin, possibly with a mountable engine.

Installation

Shell
$ gem install nugem

If you are using rbenv to manage Ruby instances, type:

Shell
$ rbenv rehash

To update the program:

Shell
$ gem update nugem

Subcommands and Options

NuGem has 4 subcommands gem, jekyll, help and rails. Currently, only gem, jekyll and help have been properly tested.

help Subcommand

The following lists the available subcommands:

Shell
$ nugem help

The following provides detailed help for the specified subcommand:

Shell
$ nugem help SUBCOMMAND

Common Options

The gem, jekyll and rails subcommands have common options.

The default option values assume that:

  • You do not want an executable for your gem scaffold
  • The gem project will be hosted on a public GitHub Git repository
  • The gem will be released to rubygems.org

Common options for the gem, jekyll and rails subcommands are:

--executable
add an executable based on Thor.
--host
specifies the Git host; possible values are bitbucket, github and geminabox.
--out_dir
specifies the directory to write the generated gem to. The default is generated/.
--private
the remote repository is made private, and on release the gem will be pushed to a private Geminabox server.
--quiet
reduces verbosity.
--no-todos
do not generate TODO: strings in generated code.

Common Behavior

The gem, jekyll and rails subcommands have common behavior.

Gem scaffolds are created within the generated/ directory of the current directory by default.

If your user name is not already stored in your Git global config, you will be asked for your GitHub or BitBucket user name. You will also be asked to enter your GitHub or BitBucket password when the remote repository is created for you.

After you create the gem, edit the gemspec and change the summary and the description. Then commit the changes to Git and invoke rake release, and your gem will be published.

gem Subcommand

Shell
$ nugem gem NAME [COMMON_OPTIONS] [--test-framework=minitest|rspec]

NAME is the name of the gem to be generated.

The default test framework for the gem subcommand is rspec, but you can specify minitest instead like this: (Warning: this has not been properly tested)

Shell
$ nugem gem my_gem --test-framework=minitest

jekyll Subcommand

The jekyll subcommand extends the gem subcommand and creates a new Jekyll plugin with the given NAME:

Shell
$ nugem jekyll NAME [OPTIONS]

NAME is the name of the Jekyll plugin gem to be generated.

In addition to the common options, the jekyll-specific OPTIONS are:

--block, --blockn, --filter, --hooks, --tag, and --tagn. (Warning: only ‑‑block and ‑‑tag been properly tested.)

Each of these options causes nugem to prompt the user for additional input.

The test framework for jekyll plugins is rspec.

All of the above options can be specified more than once, except the ‑‑hooks option. For example:

Shell
$ nugem jekyll test_tags --tag my_tag1 --tag my_tag2

The above creates a Jekyll plugin called test_tags, which defines Jekyll tags called my_tag1 and my_tag2. You might use these tags in an HTML document like this:

my_page.html
<pre>
my_tag1 usage: {% my_tag1 %}
my_tag2 usage: {% my_tag2 %}
</pre>

For more information, type:

Shell
$ nugem help jekyll

rails Subcommand

The rails subcommand extends the gem subcommand and creates a new Rails plugin with the given NAME:

Shell
$ nugem rails NAME [OPTIONS]

NAME is the name of the Ruby on Rails plugin gem to be generated.

In addition to the common options, rails OPTIONS are --engine and --mountable.

You can specify if the plugin should be an engine (--engine) or a mountable engine (--mountable).

Each of these options causes nugem to prompt the user for additional input.

The test framework for rails gems is minitest.

For more information, type:

Shell
$ nugem help rails

Did It Work?

The following shows all files that were committed to the newly created Git repository, after nugem jekyll finished making two tag blocks:

Shell
$ git ls-tree --name-only --full-tree -r HEAD
.envrc
.gitignore
.rspec
.rubocop.yml
.simplecov
.travis.yml
.vscode/extensions.json
.vscode/launch.json
.vscode/settings.json
CHANGELOG.md
Gemfile
LICENCE.txt
README.md
Rakefile
bin/attach
bin/console
bin/rake
bin/setup
demo/Gemfile
demo/_bin/debug
demo/_config.yml
demo/_drafts/2022/2022-05-01-test2.html
demo/_includes/block_tag_template_wrapper
demo/_layouts/default.html
demo/_posts/2022/2022-01-02-redact-test.html
demo/assets/css/style.css
demo/assets/images/404-error.png
demo/assets/images/404-error.webp
demo/assets/images/favicon.png
demo/assets/images/jekyll.png
demo/assets/images/jekyll.webp
demo/assets/js/clipboard.min.js
demo/assets/js/jquery-3.4.1.min.js
demo/blog/blogs.html#by_pub_date
demo/blog/index.html
demo/index.html
jekyll_test.code-workspace
jekyll_test.gemspec
lib/jekyll_test.rb
lib/jekyll_test/version.rb
lib/my_block1.rb
lib/my_block2.rb
spec/jekyll_test_spec.rb
spec/spec_helper.rb
test/jekyll_test_test.rb
test/test_helper.rb 

Visual Studio Code Support

Nugem Project

Plugins

If you have not installed the Snippets extension, Visual Studio Code will suggest that you do so the first time you open this project with Visual Studio Code. You can also review the list of suggested extensions of with the CTRL-P Extensions: Show Recommended Extensions command.

Snippets

The predefined snippets for nugem are defined in .vscode/nugem.json.code-snippets. These snippets are focused on maintaining nugem itself.

File Associations

.vscode/settings.json defines file associations for various flavors of Thor templates in the "files.associations" section. You can disable them by commenting some or all of those definitions.

Generated Projects

Plugins

Similarly, for each gem project generated by nugem, Visual Studio Code will suggest the user install missing extensions the first time those projects are opened.

Snippets

The predefined snippets for gem projects generated by nugem are defined in their .vscode/gem.json.code-snippets file. These snippets are focused on writing Jekyll plugins.

Development

After checking out the repository, run bin/setup to install dependencies. Then, run rake test to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run:

Shell
$ exec rake install

To release a new version, run:

Shell
$ exec rake release

The above will create a Git tag for the version, push Git commits and tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at github.com/mslinn/nugem.

See Also

* indicates a required field.

Please select the following to receive Mike Slinn’s newsletter:

You can unsubscribe at any time by clicking the link in the footer of emails.

Mike Slinn uses Mailchimp as his marketing platform. By clicking below to subscribe, you acknowledge that your information will be transferred to Mailchimp for processing. Learn more about Mailchimp’s privacy practices.