Class: Git::Status::StatusFile

Inherits:
Object
  • Object
show all
Defined in:
lib/git/status.rb

Overview

Represents a single file's status in the git repository. Each instance holds information about a file's state in the index and working tree.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(base, hash) ⇒ StatusFile

Initialize a new StatusFile with the given git object and data hash

Parameters:

  • base (Git::Repository)

    the git object

  • hash (Hash)

    raw status data for this file



244
245
246
247
248
249
250
251
252
253
254
# File 'lib/git/status.rb', line 244

def initialize(base, hash)
  @base       = base
  @path       = hash[:path]
  @type       = hash[:type]
  @stage      = hash[:stage]
  @mode_index = hash[:mode_index]
  @mode_repo  = hash[:mode_repo]
  @sha_index  = hash[:sha_index]
  @sha_repo   = hash[:sha_repo]
  @untracked  = hash[:untracked]
end

Instance Attribute Details

#mode_indexString? (readonly)

The file mode recorded in the index

Returns:

  • (String, nil)

    the octal file mode (e.g. "100644"), or nil



216
217
218
# File 'lib/git/status.rb', line 216

def mode_index
  @mode_index
end

#mode_repoString? (readonly)

The file mode recorded in HEAD

Returns:

  • (String, nil)

    the octal file mode (e.g. "100644"), or nil



221
222
223
# File 'lib/git/status.rb', line 221

def mode_repo
  @mode_repo
end

#pathString (readonly)

The repository-relative file path

Returns:

  • (String)

    the path



199
200
201
# File 'lib/git/status.rb', line 199

def path
  @path
end

#sha_indexString? (readonly)

The SHA of the index version of this file

Returns:

  • (String, nil)

    the SHA-1 hex digest, or nil if unavailable



226
227
228
# File 'lib/git/status.rb', line 226

def sha_index
  @sha_index
end

#sha_repoString? (readonly)

The SHA of the HEAD version of this file

Returns:

  • (String, nil)

    the SHA-1 hex digest, or nil if unavailable



231
232
233
# File 'lib/git/status.rb', line 231

def sha_repo
  @sha_repo
end

#stageString? (readonly)

The merge stage for this file

Returns:

  • (String, nil)

    "0" for normal entries, or a non-zero value during a merge conflict



211
212
213
# File 'lib/git/status.rb', line 211

def stage
  @stage
end

#typeString? (readonly)

The change type for this file

Returns:

  • (String, nil)

    "M" for modified, "A" for added, "D" for deleted, or nil when not applicable



205
206
207
# File 'lib/git/status.rb', line 205

def type
  @type
end

#untrackedBoolean? (readonly)

Whether this file is untracked

Returns:

  • (Boolean, nil)

    true when the file is not tracked by git



236
237
238
# File 'lib/git/status.rb', line 236

def untracked
  @untracked
end

Instance Method Details

#blob(type = :index) ⇒ Git::Object::Blob?

Return a blob object for the index or repo version of this file

Parameters:

  • type (Symbol) (defaults to: :index)

    :index (default) for the index version, or :repo for the HEAD version

Returns:

  • (Git::Object::Blob, nil)

    the blob object, or nil if no SHA is available for the requested version



264
265
266
267
# File 'lib/git/status.rb', line 264

def blob(type = :index)
  sha = type == :repo ? sha_repo : (sha_index || sha_repo)
  @base.object(sha) if sha
end