Module: Bundler::BuildMetadata

Defined in:
lib/bundler/build_metadata.rb

Overview

Represents metadata from when the Bundler gem was built.

Class Method Summary collapse

Class Method Details

.built_atObject

A string representing the date the bundler gem was built.



22
23
24
# File 'lib/bundler/build_metadata.rb', line 22

def self.built_at
  @built_at ||= Time.now.utc.strftime("%Y-%m-%d").freeze
end

.git_commit_shaObject

The SHA for the git commit the bundler gem was built from.



27
28
29
30
31
32
33
34
35
36
37
38
# File 'lib/bundler/build_metadata.rb', line 27

def self.git_commit_sha
  return @git_commit_sha if instance_variable_defined? :@git_commit_sha

  # If Bundler has been installed without its .git directory and without a
  # commit instance variable then we can't determine its commits SHA.
  git_dir = File.expand_path("../../../.git", __dir__)
  if File.directory?(git_dir)
    return @git_commit_sha = IO.popen(%w[git rev-parse --short HEAD], { chdir: git_dir }, &:read).strip.freeze
  end

  @git_commit_sha ||= "unknown"
end

.release?Boolean

Whether this is an official release build of Bundler.

Returns:

  • (Boolean)


41
42
43
# File 'lib/bundler/build_metadata.rb', line 41

def self.release?
  @release
end

.to_hObject

A hash representation of the build metadata.



13
14
15
16
17
18
19
# File 'lib/bundler/build_metadata.rb', line 13

def self.to_h
  {
    "Built At" => built_at,
    "Git SHA" => git_commit_sha,
    "Released Version" => release?,
  }
end