2013-09-17 21:25:38 -05:00
|
|
|
require 'forwardable'
|
|
|
|
require 'resource'
|
2013-09-14 10:16:52 -05:00
|
|
|
require 'checksum'
|
|
|
|
require 'version'
|
2013-09-21 19:27:24 -05:00
|
|
|
require 'build_options'
|
2013-09-21 19:27:24 -05:00
|
|
|
require 'dependency_collector'
|
2013-09-14 10:16:52 -05:00
|
|
|
|
|
|
|
class SoftwareSpec
|
2013-09-17 21:25:38 -05:00
|
|
|
extend Forwardable
|
2013-09-14 10:16:52 -05:00
|
|
|
|
2013-09-23 21:39:19 -05:00
|
|
|
attr_reader :name
|
2013-09-21 19:27:24 -05:00
|
|
|
attr_reader :build, :resources, :owner
|
2013-09-21 19:27:24 -05:00
|
|
|
attr_reader :dependency_collector
|
2013-09-17 21:25:39 -05:00
|
|
|
|
2013-09-17 21:25:38 -05:00
|
|
|
def_delegators :@resource, :stage, :fetch
|
|
|
|
def_delegators :@resource, :download_strategy, :verify_download_integrity
|
|
|
|
def_delegators :@resource, :checksum, :mirrors, :specs, :using, :downloader
|
2013-09-28 16:37:05 -05:00
|
|
|
def_delegators :@resource, :version, :mirror, *Checksum::TYPES
|
2013-09-14 10:16:52 -05:00
|
|
|
|
2013-09-23 21:39:19 -05:00
|
|
|
def initialize
|
|
|
|
@resource = Resource.new
|
2013-09-17 21:25:39 -05:00
|
|
|
@resources = {}
|
2013-09-21 19:27:24 -05:00
|
|
|
@build = BuildOptions.new(ARGV.options_only)
|
2013-09-21 19:27:24 -05:00
|
|
|
@dependency_collector = DependencyCollector.new
|
2013-09-17 21:25:39 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def owner= owner
|
2013-09-23 21:39:19 -05:00
|
|
|
@name = owner.name
|
2013-09-23 21:39:19 -05:00
|
|
|
@resource.owner = self
|
|
|
|
resources.each_value { |r| r.owner = self }
|
2013-09-17 21:25:39 -05:00
|
|
|
end
|
|
|
|
|
2013-09-28 16:37:05 -05:00
|
|
|
def url val=nil, specs={}
|
|
|
|
return @resource.url if val.nil?
|
|
|
|
@resource.url(val, specs)
|
|
|
|
dependency_collector.add(@resource)
|
|
|
|
end
|
|
|
|
|
2013-09-17 21:25:40 -05:00
|
|
|
def resource? name
|
|
|
|
resources.has_key?(name)
|
|
|
|
end
|
|
|
|
|
2013-09-17 21:25:39 -05:00
|
|
|
def resource name, &block
|
|
|
|
if block_given?
|
2013-09-17 21:25:40 -05:00
|
|
|
raise DuplicateResourceError.new(name) if resource?(name)
|
2013-09-17 21:25:39 -05:00
|
|
|
resources[name] = Resource.new(name, &block)
|
|
|
|
else
|
|
|
|
resources.fetch(name) { raise ResourceMissingError.new(owner, name) }
|
|
|
|
end
|
2013-09-14 10:16:52 -05:00
|
|
|
end
|
2013-09-21 19:27:24 -05:00
|
|
|
|
|
|
|
def option name, description=nil
|
2013-10-07 00:40:32 -07:00
|
|
|
name = 'c++11' if name == :cxx11
|
2013-09-21 19:27:24 -05:00
|
|
|
name = name.to_s if Symbol === name
|
|
|
|
raise "Option name is required." if name.empty?
|
|
|
|
raise "Options should not start with dashes." if name[0, 1] == "-"
|
|
|
|
build.add(name, description)
|
|
|
|
end
|
2013-09-21 19:27:24 -05:00
|
|
|
|
|
|
|
def depends_on spec
|
|
|
|
dep = dependency_collector.add(spec)
|
|
|
|
build.add_dep_option(dep) if dep
|
|
|
|
end
|
|
|
|
|
|
|
|
def deps
|
|
|
|
dependency_collector.deps
|
|
|
|
end
|
|
|
|
|
|
|
|
def requirements
|
|
|
|
dependency_collector.requirements
|
|
|
|
end
|
2013-09-14 10:16:52 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
class HeadSoftwareSpec < SoftwareSpec
|
2013-09-23 21:39:19 -05:00
|
|
|
def initialize
|
2013-09-14 10:16:52 -05:00
|
|
|
super
|
2013-09-23 21:39:19 -05:00
|
|
|
@resource.version = Version.new('HEAD')
|
2013-09-14 10:16:52 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def verify_download_integrity fn
|
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class Bottle < SoftwareSpec
|
|
|
|
attr_rw :root_url, :prefix, :cellar, :revision
|
|
|
|
|
2013-09-27 09:22:15 +01:00
|
|
|
def_delegators :@resource, :version=, :url=
|
2013-09-17 21:25:38 -05:00
|
|
|
|
2013-09-14 10:16:52 -05:00
|
|
|
def initialize
|
|
|
|
super
|
|
|
|
@revision = 0
|
|
|
|
@prefix = '/usr/local'
|
|
|
|
@cellar = '/usr/local/Cellar'
|
|
|
|
end
|
|
|
|
|
|
|
|
# Checksum methods in the DSL's bottle block optionally take
|
|
|
|
# a Hash, which indicates the platform the checksum applies on.
|
|
|
|
Checksum::TYPES.each do |cksum|
|
|
|
|
class_eval <<-EOS, __FILE__, __LINE__ + 1
|
|
|
|
def #{cksum}(val=nil)
|
|
|
|
return @#{cksum} if val.nil?
|
|
|
|
@#{cksum} ||= Hash.new
|
|
|
|
case val
|
|
|
|
when Hash
|
|
|
|
key, value = val.shift
|
|
|
|
@#{cksum}[value] = Checksum.new(:#{cksum}, key)
|
|
|
|
end
|
|
|
|
|
|
|
|
if @#{cksum}.has_key? bottle_tag
|
2013-09-17 21:25:38 -05:00
|
|
|
@resource.checksum = @#{cksum}[bottle_tag]
|
2013-09-14 10:16:52 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
EOS
|
|
|
|
end
|
2013-09-21 21:16:18 +01:00
|
|
|
|
|
|
|
def checksums
|
|
|
|
checksums = {}
|
|
|
|
Checksum::TYPES.each do |checksum_type|
|
|
|
|
checksum_os_versions = send checksum_type
|
|
|
|
next unless checksum_os_versions
|
|
|
|
os_versions = checksum_os_versions.keys
|
|
|
|
os_versions.map! {|osx| MacOS::Version.from_symbol osx }
|
|
|
|
os_versions.sort.reverse.each do |os_version|
|
|
|
|
osx = os_version.to_sym
|
|
|
|
checksum = checksum_os_versions[osx]
|
2013-09-23 17:30:47 +01:00
|
|
|
checksums[checksum_type] ||= []
|
|
|
|
checksums[checksum_type] << { checksum => osx }
|
2013-09-21 21:16:18 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
checksums
|
|
|
|
end
|
2013-09-14 10:16:52 -05:00
|
|
|
end
|