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:



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

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



218
219
220
# File 'lib/git/status.rb', line 218

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



223
224
225
# File 'lib/git/status.rb', line 223

def mode_repo
  @mode_repo
end

#pathString (readonly)

The repository-relative file path

Returns:

  • (String)

    the path



201
202
203
# File 'lib/git/status.rb', line 201

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



228
229
230
# File 'lib/git/status.rb', line 228

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



233
234
235
# File 'lib/git/status.rb', line 233

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



213
214
215
# File 'lib/git/status.rb', line 213

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



207
208
209
# File 'lib/git/status.rb', line 207

def type
  @type
end

#untrackedBoolean? (readonly)

Whether this file is untracked

Returns:

  • (Boolean, nil)

    true when the file is not tracked by git



238
239
240
# File 'lib/git/status.rb', line 238

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



266
267
268
269
# File 'lib/git/status.rb', line 266

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