Browse Source

create casks with `brew cask edit foo --create`

phinze 12 years ago
parent
commit
bf33643526
  1. 24
      lib/cask/cli.rb
  2. 6
      lib/cask/cli/edit.rb
  3. 13
      test/cli/edit_test.rb
  4. 21
      test/cli/options_test.rb

24
lib/cask/cli.rb

@ -38,17 +38,29 @@ class Cask::CLI
} }
list.sort list.sort
end end
def self.process_options(args) def self.parser
allrgs = Shellwords.shellsplit(ENV['HOMEBREW_CASK_OPTS'] || "") + args @parser ||= OptionParser.new do |opts|
OptionParser.new do |opts|
opts.on("--appdir=MANDATORY") do |v| opts.on("--appdir=MANDATORY") do |v|
Cask.appdir = Pathname.new File.expand_path(v) Cask.appdir = Pathname.new File.expand_path(v)
end end
end.parse!(allrgs) end
return allrgs
end end
def self.process_options(args)
all_args = Shellwords.shellsplit(ENV['HOMEBREW_CASK_OPTS'] || "") + args
remaining = []
while !all_args.empty?
begin
head = all_args.shift
remaining.concat(parser.parse([head]))
rescue OptionParser::InvalidOption
remaining << head
retry
end
end
remaining
end
class NullCommand class NullCommand
def initialize(attempted_name) def initialize(attempted_name)

6
lib/cask/cli/edit.rb

@ -1,8 +1,10 @@
module Cask::CLI::Edit module Cask::CLI::Edit
def self.run(*arguments) def self.run(*arguments)
cask_name, *_ = *arguments cask_name, *args = *arguments
cask_path = Cask.path(cask_name) cask_path = Cask.path(cask_name)
raise CaskUnavailableError, cask_name + ".rb" if cask_path.nil? || !cask_path.file? unless cask_path.exist? || args.include?('--create')
raise CaskUnavailableError, "#{cask_name}, add --create to make a new cask with this name"
end
exec_editor cask_path exec_editor cask_path
end end

13
test/cli/edit_test.rb

@ -36,4 +36,17 @@ describe Cask::CLI::Edit do
[Cask.path('adium')] [Cask.path('adium')]
] ]
end end
it 'raises an exception when the cask doesnt exist' do
lambda {
Cask::CLI::Edit.run('notacask')
}.must_raise CaskUnavailableError
end
it 'allows new casks to be created with the --create flag' do
Cask::CLI::Edit.run('brand-spankin-new', '--create')
Cask::CLI::Edit.editor_commands.must_equal [
[Cask.tapspath.join(Cask.default_tap, 'Casks', 'brand-spankin-new.rb')]
]
end
end end

21
test/cli/options_test.rb

@ -2,21 +2,24 @@ require 'test_helper'
describe Cask::CLI do describe Cask::CLI do
it "supports setting the appdir" do it "supports setting the appdir" do
shutup do Cask::CLI.process_options %w{help --appdir=/some/path/foo}
Cask::CLI.process %w{help --appdir=/some/path}
end
Cask.appdir.must_equal Pathname.new File.expand_path "/some/path" Cask.appdir.must_equal Pathname('/some/path/foo')
end end
it "supports setting the appdir from ENV" do it "supports setting the appdir from ENV" do
ENV['HOMEBREW_CASK_OPTS'] = "--appdir=/some/path" ENV['HOMEBREW_CASK_OPTS'] = "--appdir=/some/path/bar"
shutup do Cask::CLI.process_options %w{help}
Cask::CLI.process %w{help}
end
Cask.appdir.must_equal Pathname.new File.expand_path "/some/path" Cask.appdir.must_equal Pathname('/some/path/bar')
end
it "allows additional options to be passed through" do
rest = Cask::CLI.process_options %w{edit foo --create --appdir=/some/path/qux}
Cask.appdir.must_equal Pathname('/some/path/qux')
rest.must_equal %w{edit foo --create}
end end
after do after do

Loading…
Cancel
Save