Class: Git::Branches

Inherits:
Object
  • Object
show all
Includes:
Enumerable
Defined in:
lib/git/branches.rb

Overview

object that holds all the available branches

Instance Method Summary collapse

Constructor Details

#initialize(base) ⇒ Branches

Returns a new instance of Branches.



10
11
12
13
14
15
16
17
18
# File 'lib/git/branches.rb', line 10

def initialize(base)
  @branches = {}

  @base = base

  @base.lib.branches_all.each do |b|
    @branches[b[0]] = Git::Branch.new(@base, b[0])
  end
end

Instance Method Details

#[](branch_name) ⇒ Git::Branch

Returns the target branch

Example: Given (git branch -a): master remotes/working/master

g.branches['master'].full #=> 'master' g.branches['working/master'].full => 'remotes/working/master' g.branches['remotes/working/master'].full => 'remotes/working/master'

Parameters:

  • branch_name (#to_s)

    the target branch name.

Returns:



51
52
53
54
55
56
57
58
59
60
61
# File 'lib/git/branches.rb', line 51

def [](branch_name)
  @branches.values.inject(@branches) do |branches, branch|
    branches[branch.full] ||= branch

    # This is how Git (version 1.7.9.5) works.
    # Lets you ignore the 'remotes' if its at the beginning of the branch full name (even if is not a real remote branch).
    branches[branch.full.sub('remotes/', '')] ||= branch if branch.full =~ /^remotes\/.+/

    branches
  end[branch_name.to_s]
end

#each(&block)



34
35
36
# File 'lib/git/branches.rb', line 34

def each(&block)
  @branches.values.each(&block)
end

#local



20
21
22
# File 'lib/git/branches.rb', line 20

def local
  self.select { |b| !b.remote }
end

#remote



24
25
26
# File 'lib/git/branches.rb', line 24

def remote
  self.select { |b| b.remote }
end

#size

array like methods



30
31
32
# File 'lib/git/branches.rb', line 30

def size
  @branches.size
end

#to_s



63
64
65
66
67
68
69
# File 'lib/git/branches.rb', line 63

def to_s
  out = ''
  @branches.each do |k, b|
    out << (b.current ? '* ' : '  ') << b.to_s << "\n"
  end
  out
end