class Juwelier class Generator class Options < Hash attr_reader :opts, :orig_args def initialize(args) super() @orig_args = args.clone self[:testing_framework] = :shoulda self[:documentation_framework] = :rdoc self[:use_bundler] = true self[:user_name] = ENV['GIT_AUTHOR_NAME'] || ENV['GIT_COMMITTER_NAME'] || git_config['user.name'] self[:user_email] = ENV['GIT_AUTHOR_EMAIL'] || ENV['GIT_COMMITTER_EMAIL'] || git_config['user.email'] self[:github_username] = git_config['github.user'] require 'optparse' @opts = OptionParser.new do |o| o.banner = "Usage: #{File.basename($0)} [options] reponame\ne.g. #{File.basename($0)} the-perfect-gem" o.on('--directory [DIRECTORY]', 'specify the directory to generate into (deprecated)') do |directory| warn "--directory is deprecated and will be removed in 2.0.0. Please specify an absolute path to a directory as the last argument instead" # DEPRECATE self[:directory] = directory end o.separator "" o.on('--rspec', 'generate rspec code examples') do self[:testing_framework] = :rspec end o.on('--shoulda', 'generate shoulda tests') do self[:testing_framework] = :shoulda end o.on('--testunit', 'generate test/unit tests') do self[:testing_framework] = :testunit end o.on('--bacon', 'generate bacon specifications') do self[:testing_framework] = :bacon end o.on('--testspec', 'generate test/spec tests') do self[:testing_framework] = :testspec end o.on('--minitest', 'generate minitest tests') do self[:testing_framework] = :minitest end o.on('--micronaut', 'generate micronaut examples') do self[:testing_framework] = :micronaut end o.on('--riot', 'generate riot tests') do self[:testing_framework] = :riot end o.on('--shindo', 'generate shindo tests') do self[:testing_framework] = :shindo end o.separator "" o.on('--[no-]bundler', 'use bundler for managing dependencies') do |v| self[:use_bundler] = v end o.on('--cucumber', 'generate cucumber stories in addition to the other tests') do self[:use_cucumber] = true end o.separator "" o.on('--reek', 'generate rake task for reek') do self[:use_reek] = true end o.on('--roodi', 'generate rake task for roodi') do self[:use_roodi] = true end o.separator "" o.on('--summary [SUMMARY]', 'specify the summary of the project') do |summary| self[:summary] = summary end o.on('--description [DESCRIPTION]', 'specify a description of the project') do |description| self[:description] = description end o.separator "" o.on('--user-name [USER_NAME]', "the user's name, ie that is credited in the LICENSE") do |user_name| self[:user_name] = user_name end o.on('--user-email [USER_EMAIL]', "the user's email, ie that is credited in the Gem specification") do |user_email| self[:user_email] = user_email end o.separator "" o.on('--github-username [GITHUB_USERNAME]', "name of the user on GitHub to set the project up under") do |github_username| self[:github_username] = github_username end o.on('--git-remote [GIT_REMOTE]', 'URI to set the git origin remote to') do |git_remote| self[:git_remote] = git_remote end o.on('--homepage [HOMEPAGE]', "the homepage for your project (defaults to the GitHub repo)") do |homepage| self[:homepage] = homepage end o.on('--create-repo', 'create the repository on GitHub') do self[:create_repo] = true end o.separator "" o.on('--yard', 'use yard for documentation') do self[:documentation_framework] = :yard end o.on('--rdoc', 'use rdoc for documentation') do self[:documentation_framework] = :rdoc end o.on('-v', '--version', 'show version') do self[:show_version] = true end o.on_tail('-h', '--help', 'display this help and exit') do self[:show_help] = true end end begin @opts.parse!(args) self[:project_name] = args.shift rescue OptionParser::InvalidOption => e self[:invalid_argument] = e.message end end def merge(other) self.class.new(@orig_args + other.orig_args) end # Expose git config here, so we can stub it out for test environments def self.git_config @git_config ||= if Pathname.new("~/.gitconfig").expand_path.exist? Git.global_config else {} end end def git_config self.class.git_config end end end end