Class: Grit::Blob
- Inherits:
-
Object
- Object
- Grit::Blob
- Defined in:
- lib/grit/blob.rb
Constant Summary collapse
- DEFAULT_MIME_TYPE =
"text/plain"
Instance Attribute Summary collapse
-
#id ⇒ Object
readonly
Returns the value of attribute id.
-
#mode ⇒ Object
readonly
Returns the value of attribute mode.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
Class Method Summary collapse
-
.blame(repo, commit, file) ⇒ Object
The blame information for the given file at the given commit.
-
.create(repo, atts) ⇒ Object
Create an unbaked Blob containing just the specified attributes
repo
is the Repoatts
is a Hash of instance variable data.
Instance Method Summary collapse
-
#<=>(other) ⇒ Object
Compares blobs by name.
- #basename ⇒ Object
-
#create_initialize(repo, atts) ⇒ Object
Initializer for Blob.create
repo
is the Repoatts
is a Hash of instance variable data. -
#data ⇒ Object
The binary contents of this blob.
-
#inspect ⇒ Object
Pretty object inspection.
-
#mime_type ⇒ Object
The mime type of this file (based on the filename).
-
#size ⇒ Object
The size of this blob in bytes.
Instance Attribute Details
#id ⇒ Object (readonly)
Returns the value of attribute id.
6 7 8 |
# File 'lib/grit/blob.rb', line 6 def id @id end |
#mode ⇒ Object (readonly)
Returns the value of attribute mode.
7 8 9 |
# File 'lib/grit/blob.rb', line 7 def mode @mode end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
8 9 10 |
# File 'lib/grit/blob.rb', line 8 def name @name end |
Class Method Details
.blame(repo, commit, file) ⇒ Object
The blame information for the given file at the given commit
Returns Array: [Grit::Commit, Array: [<line>]]
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 |
# File 'lib/grit/blob.rb', line 57 def self.blame(repo, commit, file) data = repo.git.blame({:p => true}, commit, '--', file) commits = {} blames = [] info = nil data.split("\n").each do |line| parts = line.split(/\s+/, 2) case parts.first when /^[0-9A-Fa-f]{40}$/ case line when /^([0-9A-Fa-f]{40}) (\d+) (\d+) (\d+)$/ _, id, origin_line, final_line, group_lines = *line.match(/^([0-9A-Fa-f]{40}) (\d+) (\d+) (\d+)$/) info = {:id => id} blames << [nil, []] when /^([0-9A-Fa-f]{40}) (\d+) (\d+)$/ _, id, origin_line, final_line = *line.match(/^([0-9A-Fa-f]{40}) (\d+) (\d+)$/) info = {:id => id} end when /^(author|committer)/ case parts.first when /^(.+)-mail$/ info["#{$1}_email".intern] = parts.last when /^(.+)-time$/ info["#{$1}_date".intern] = Time.at(parts.last.to_i) when /^(author|committer)$/ info[$1.intern] = parts.last end when /^filename/ info[:filename] = parts.last when /^summary/ info[:summary] = parts.last when '' c = commits[info[:id]] unless c c = Commit.create(repo, :id => info[:id], :author => Actor.from_string(info[:author] + ' ' + info[:author_email]), :authored_date => info[:author_date], :committer => Actor.from_string(info[:committer] + ' ' + info[:committer_email]), :committed_date => info[:committer_date], :message => info[:summary]) commits[info[:id]] = c end _, text = *line.match(/^\t(.*)$/) blames.last[0] = c blames.last[1] << text info = nil end end blames end |
.create(repo, atts) ⇒ Object
Create an unbaked Blob containing just the specified attributes
+repo+ is the Repo
+atts+ is a Hash of instance variable data
Returns Grit::Blob (unbaked)
15 16 17 |
# File 'lib/grit/blob.rb', line 15 def self.create(repo, atts) self.allocate.create_initialize(repo, atts) end |
Instance Method Details
#<=>(other) ⇒ Object
Compares blobs by name
121 122 123 |
# File 'lib/grit/blob.rb', line 121 def <=>(other) name <=> other.name end |
#basename ⇒ Object
111 112 113 |
# File 'lib/grit/blob.rb', line 111 def basename File.basename(name) end |
#create_initialize(repo, atts) ⇒ Object
Initializer for Blob.create
+repo+ is the Repo
+atts+ is a Hash of instance variable data
Returns Grit::Blob (unbaked)
24 25 26 27 28 29 30 |
# File 'lib/grit/blob.rb', line 24 def create_initialize(repo, atts) @repo = repo atts.each do |k, v| instance_variable_set("@#{k}".to_sym, v) end self end |
#data ⇒ Object
The binary contents of this blob.
Returns String
42 43 44 |
# File 'lib/grit/blob.rb', line 42 def data @data ||= @repo.git.cat_file({:p => true}, id) end |
#inspect ⇒ Object
Pretty object inspection
116 117 118 |
# File 'lib/grit/blob.rb', line 116 def inspect %Q{#<Grit::Blob "#{@id}">} end |
#mime_type ⇒ Object
The mime type of this file (based on the filename)
Returns String
49 50 51 52 |
# File 'lib/grit/blob.rb', line 49 def mime_type guesses = MIME::Types.type_for(self.name) rescue [] guesses.first ? guesses.first.simplified : DEFAULT_MIME_TYPE end |
#size ⇒ Object
The size of this blob in bytes
Returns Integer
35 36 37 |
# File 'lib/grit/blob.rb', line 35 def size @size ||= @repo.git.cat_file({:s => true}, id).chomp.to_i end |