Module: GitHub

Extended by:
GitHub
Included in:
GitHub
Defined in:
lib/github.rb,
lib/github/helper.rb,
lib/github/command.rb

Overview

Starting simple.

$ github <command> <args>

GitHub.command <command> do |*args|
  whatever 
end

We’ll probably want to use the choice gem for concise, tasty DSL arg parsing action.

Defined Under Namespace

Classes: Command, Helper

Constant Summary collapse

BasePath =
File.expand_path(File.dirname(__FILE__) + '/..')

Instance Method Summary collapse

Instance Method Details

#activate(args) ⇒ Object



56
57
58
59
60
61
62
# File 'lib/github.rb', line 56

def activate(args)
  @options = parse_options(args)
  @debug = @options[:debug]
  load 'helpers.rb'
  load 'commands.rb'
  invoke(args.shift, *args)
end

#command(command, &block) ⇒ Object



26
27
28
29
30
31
32
33
34
35
# File 'lib/github.rb', line 26

def command(command, &block)
  debug "Registered `#{command}`"
  descriptions[command] = @next_description if @next_description
  @next_description = nil
  flag_descriptions[command].update @next_flags if @next_flags
  usage_descriptions[command] = @next_usage if @next_usage
  @next_flags = nil
  @next_usage = []
  commands[command.to_s] = Command.new(block)
end

#commandsObject



70
71
72
# File 'lib/github.rb', line 70

def commands
  @commands ||= {}
end

#debug(*messages) ⇒ Object



116
117
118
# File 'lib/github.rb', line 116

def debug(*messages)
  puts *messages.map { |m| "== #{m}" } if debug?
end

#debug?Boolean

Returns:

  • (Boolean)


120
121
122
# File 'lib/github.rb', line 120

def debug?
  !!@debug
end

#desc(str) ⇒ Object



37
38
39
# File 'lib/github.rb', line 37

def desc(str)
  @next_description = str
end

#descriptionsObject



74
75
76
# File 'lib/github.rb', line 74

def descriptions
  @descriptions ||= {}
end

#flag_descriptionsObject



78
79
80
# File 'lib/github.rb', line 78

def flag_descriptions
  @flagdescs ||= Hash.new { |h, k| h[k] = {} }
end

#flags(hash) ⇒ Object



41
42
43
44
# File 'lib/github.rb', line 41

def flags(hash)
  @next_flags ||= {}
  @next_flags.update hash
end

#helper(command, &block) ⇒ Object



51
52
53
54
# File 'lib/github.rb', line 51

def helper(command, &block)
  debug "Helper'd `#{command}`"
  Helper.send :define_method, command, &block
end

#invoke(command, *args) ⇒ Object



64
65
66
67
68
# File 'lib/github.rb', line 64

def invoke(command, *args)
  block = commands[command.to_s] || commands['default']
  debug "Invoking `#{command}`"
  block.call(*args)
end

#load(file) ⇒ Object



110
111
112
113
114
# File 'lib/github.rb', line 110

def load(file)
  file[0] == ?/ ? path = file : path = BasePath + "/commands/#{file}"
  data = File.read(path)
  GitHub.module_eval data, path
end

#optionsObject



86
87
88
# File 'lib/github.rb', line 86

def options
  @options
end

#parse_options(args) ⇒ Object



90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
# File 'lib/github.rb', line 90

def parse_options(args)
  idx = 0
  args.clone.inject({}) do |memo, arg|
    case arg
    when /^--(.+?)=(.*)/
      args.delete_at(idx)
      memo.merge($1.to_sym => $2)
    when /^--(.+)/
      args.delete_at(idx)
      memo.merge($1.to_sym => true)
    when "--"
      args.delete_at(idx)
      return memo
    else
      idx += 1
      memo
    end
  end
end

#usage(string) ⇒ Object



46
47
48
49
# File 'lib/github.rb', line 46

def usage(string)
  @next_usage ||= []
  @next_usage << string
end

#usage_descriptionsObject



82
83
84
# File 'lib/github.rb', line 82

def usage_descriptions
  @usage_descriptions ||= Hash.new { |h, k| h[k] = [] }
end