Class: FossilDownloadStrategy

Inherits:
VCSDownloadStrategy show all
Defined in:
download_strategy.rb

Overview

Strategy for downloading a Fossil repository.

Constant Summary

Constants inherited from VCSDownloadStrategy

VCSDownloadStrategy::REF_TYPES

Instance Attribute Summary

Attributes inherited from VCSDownloadStrategy

#cached_location

Attributes inherited from AbstractDownloadStrategy

#cache, #url

Instance Method Summary collapse

Methods inherited from VCSDownloadStrategy

#commit_outdated?, #fetch, #fetch_last_commit, #head?

Methods inherited from AbstractDownloadStrategy

#basename, #cached_location, #clear_cache, #fetch, #quiet!, #quiet?, #stage

Methods included from SystemCommand::Mixin

#system_command, #system_command!

Methods included from Context

current, current=, #debug?, #quiet?, #verbose?, #with_context

Constructor Details

#initialize(url, name, version, **meta) ⇒ void

This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.

Parameters:



1547
1548
1549
1550
# File 'download_strategy.rb', line 1547

def initialize(url, name, version, **meta)
  super
  @url = T.let(@url.sub(%r{^fossil://}, ""), String)
end

Instance Method Details

#last_commitString

Return last commit's unique identifier for the repository.

Returns:



1565
1566
1567
1568
# File 'download_strategy.rb', line 1565

def last_commit
  out = silent_command("fossil", args: ["info", "tip", "-R", cached_location]).stdout
  T.must(out[/^(hash|uuid): +(\h+) .+$/, 1])
end

#repo_valid?Boolean

This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.

Returns:

  • (Boolean)


1571
1572
1573
# File 'download_strategy.rb', line 1571

def repo_valid?
  silent_command("fossil", args: ["branch", "-R", cached_location]).success?
end

#source_modified_timeTime

Returns the most recent modified time for all files in the current working directory after stage.

Returns:



1556
1557
1558
1559
# File 'download_strategy.rb', line 1556

def source_modified_time
  out = silent_command("fossil", args: ["info", "tip", "-R", cached_location]).stdout
  Time.parse(T.must(out[/^(hash|uuid): +\h+ (.+)$/, 1]))
end