class Git::Branch
def archive(file, opts = {})
def archive(file, opts = {}) @base.lib.archive(@full, file, opts) end
def check_if_create
def check_if_create @base.lib.branch_new(@name) rescue nil end
def checkout
def checkout check_if_create @base.checkout(@full) end
def create
def create check_if_create end
def current
def current determine_current end
def delete
def delete @base.lib.branch_delete(@name) end
def determine_current
def determine_current @base.lib.branch_current == @name end
def gcommit
def gcommit @gcommit ||= @base.gcommit(@full) @gcommit end
def in_branch (message = 'in branch work')
return true # auto commits and switches back
# do other stuff
# create new file
g.branch('new_branch').in_branch do
def in_branch (message = 'in branch work') old_current = @base.lib.branch_current checkout if yield @base.commit_all(message) else @base.reset_hard end @base.checkout(old_current) end
def initialize(base, name)
def initialize(base, name) @remote = nil @full = name @base = base @gcommit = nil @stashes = nil parts = name.split('/') if parts[1] @remote = Git::Remote.new(@base, parts[0]) @name = parts[1] else @name = parts[0] end end
def merge(branch = nil, message = nil)
def merge(branch = nil, message = nil) if branch in_branch do @base.merge(branch, message) false end # merge a branch into this one else # merge this branch into the current one @base.merge(@name) end end
def stashes
def stashes @stashes ||= Git::Stashes.new(@base) end
def to_a
def to_a [@full] end
def to_s
def to_s @full end
def update_ref(commit)
def update_ref(commit) @base.lib.update_ref(@full, commit) end