2018-07-23 20:59:21 +02:00
|
|
|
module UnpackStrategy
|
|
|
|
class Fossil
|
|
|
|
include UnpackStrategy
|
|
|
|
|
2018-07-29 10:04:51 +02:00
|
|
|
using Magic
|
|
|
|
|
|
|
|
def self.can_extract?(path)
|
|
|
|
return false unless path.magic_number.match?(/\ASQLite format 3\000/n)
|
2018-07-23 20:59:21 +02:00
|
|
|
|
|
|
|
# Fossil database is made up of artifacts, so the `artifact` table must exist.
|
|
|
|
query = "select count(*) from sqlite_master where type = 'view' and name = 'artifact'"
|
2018-07-23 23:04:49 +02:00
|
|
|
system_command("sqlite3", args: [path, query]).stdout.to_i == 1
|
2018-07-23 20:59:21 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def extract_to_dir(unpack_dir, basename:, verbose:)
|
|
|
|
args = if @ref_type && @ref
|
|
|
|
[@ref]
|
|
|
|
else
|
|
|
|
[]
|
|
|
|
end
|
|
|
|
|
2018-07-23 23:04:49 +02:00
|
|
|
system_command! "fossil",
|
|
|
|
args: ["open", path, *args],
|
|
|
|
chdir: unpack_dir,
|
|
|
|
env: { "PATH" => PATH.new(Formula["fossil"].opt_bin, ENV["PATH"]) }
|
2018-07-23 20:59:21 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|