Sha256: 42fba46463ddc6616d3cc00e8b9d470c0d032a4a84c28e053a7950abdf1fbb4a
Contents?: true
Size: 1.96 KB
Versions: 3
Compression:
Stored size: 1.96 KB
Contents
module Git class Branch < Path attr_accessor :full, :remote, :name def initialize(base, name) @remote = nil @full = name.sub(/\Aremotes\//, '') @base = base @gcommit = nil @stashes = nil parts = @full.split('/') if parts[1] @remote = Git::Remote.new(@base, parts[0]) @name = parts[1] else @name = parts[0] end end def gcommit @gcommit ||= @base.gcommit(@full) @gcommit end def stashes @stashes ||= Git::Stashes.new(@base) end def checkout check_if_create @base.checkout(@full) end def archive(file, opts = {}) @base.lib.archive(@name, file, opts.merge(:remote => @remote)) end # g.branch('new_branch').in_branch do # # create new file # # do other stuff # return true # auto commits and switches back # end 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 create check_if_create end def delete @base.lib.branch_delete(@name) end def current determine_current end 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 update_ref(commit) @base.lib.update_ref(@full, commit) end def to_a [@full] end def to_s @full end private def check_if_create @base.lib.branch_new(@name) rescue nil end def determine_current @base.lib.branch_current == @name end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
blackwinter-git-1.2.7 | lib/git/branch.rb |
blackwinter-git-1.2.6 | lib/git/branch.rb |
blackwinter-git-1.2.5 | lib/git/branch.rb |