module Bundler::BuildMetadata

def self.built_at

A string representing the date the bundler gem was built.
def self.built_at
  @built_at
end

def self.git_commit_sha

The SHA for the git commit the bundler gem was built from.
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

def self.timestamp

current time if never built
A timestamp representing the date the bundler gem was built, or the
def self.timestamp
  @timestamp ||= @built_at || Time.now.utc.strftime("%Y-%m-%d").freeze
end

def self.to_h

A hash representation of the build metadata.
def self.to_h
  {
    "Timestamp" => timestamp,
    "Git SHA" => git_commit_sha,
  }
end