2019-07-02 03:50:50 +02:00
|
|
|
|
|
2019-07-03 05:23:48 +02:00
|
|
|
|
# FIXME: Where should this go? We can’t just leave it here. :(
|
|
|
|
|
def pkginfo(package)
|
|
|
|
|
du = `du -sk #{package.fake_root_directory}`
|
|
|
|
|
size = du.sub(/[ \t].*/, "").to_i * 1024
|
|
|
|
|
|
|
|
|
|
%{ # Generated by `package`.
|
|
|
|
|
pkgname = #{package.name}
|
|
|
|
|
pkgver = #{package.version}-r#{package.release}
|
|
|
|
|
url = #{package.url || ""}
|
|
|
|
|
size = #{size}
|
|
|
|
|
origin = #{package.recipe.name}
|
|
|
|
|
buildtype = host
|
|
|
|
|
builddate = #{Time.utc.to_unix}
|
|
|
|
|
}.gsub /^ */m, ""
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-03 03:35:35 +02:00
|
|
|
|
class Package::Backend::Packaging
|
|
|
|
|
getter name : String
|
|
|
|
|
|
|
|
|
|
def initialize(@name, &block : Proc(Package, Bool))
|
|
|
|
|
@callback = block
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def package(package : Package)
|
|
|
|
|
@callback.call package
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-02 03:50:50 +02:00
|
|
|
|
class Package::Context
|
|
|
|
|
property working_directory = "/tmp/package"
|
|
|
|
|
property sources_directory = Dir.current
|
|
|
|
|
property packages_directory = Dir.current
|
|
|
|
|
|
2019-07-03 03:48:31 +02:00
|
|
|
|
getter packaging_backends = [] of Backend::Packaging
|
|
|
|
|
getter building_backends = [] of Backend::Building
|
2019-07-03 03:35:35 +02:00
|
|
|
|
|
2019-07-03 05:23:48 +02:00
|
|
|
|
# Well, this will need configuration, auto-detection and conversion,
|
|
|
|
|
# but it’ll be kind of enough for now.
|
|
|
|
|
property architecture = "x86_64"
|
|
|
|
|
|
2019-07-02 03:50:50 +02:00
|
|
|
|
def initialize
|
2019-07-03 03:35:35 +02:00
|
|
|
|
@packaging_backends << Backend::Packaging.new "pkgutils" do |package|
|
2019-07-03 05:23:48 +02:00
|
|
|
|
puts "#{package.fake_root_directory} -> #{packages_directory}/#{package.name}##{package.version}-#{package.release}.pkg.tar.xz"
|
2019-07-03 03:35:35 +02:00
|
|
|
|
pp! r = run package.fake_root_directory, "tar", ["cJf", "#{packages_directory}/#{package.name}##{package.version}.pkg.tar.xz", "."]
|
|
|
|
|
|
|
|
|
|
r.exit_status == 0
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-03 05:23:48 +02:00
|
|
|
|
@packaging_backends << Backend::Packaging.new "apk" do |package|
|
|
|
|
|
# FIXME: This needs to have access to architecture (from Context?)
|
|
|
|
|
# to work properly.
|
|
|
|
|
old_cwd = Dir.current
|
|
|
|
|
|
|
|
|
|
puts "#{package.fake_root_directory} -> #{packages_directory}/#{package.name}-#{package.version}-r#{package.release}.apk"
|
|
|
|
|
|
|
|
|
|
run package.fake_root_directory, "find", [".."]
|
|
|
|
|
|
|
|
|
|
puts pkginfo package
|
|
|
|
|
File.write "#{package.fake_root_directory}/.PKGINFO", pkginfo package
|
|
|
|
|
|
|
|
|
|
# Create data.tar.gz here.
|
|
|
|
|
package_target = "#{packages_directory}/#{package.name}-#{package.version}-r#{package.release}.apk"
|
|
|
|
|
# FIXME: This shouldn’t have to be in users’ PATH. libexec?
|
|
|
|
|
r = run package.fake_root_directory, "assemble-apk.sh", [
|
|
|
|
|
package_target
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
r.exit_status == 0
|
|
|
|
|
end
|
|
|
|
|
|
2019-07-03 03:35:35 +02:00
|
|
|
|
@selected_packaging_backend = @packaging_backends[0]
|
2019-07-03 03:48:31 +02:00
|
|
|
|
|
|
|
|
|
@building_backends << Backend::Building.new "configure", "autotools" do |context, recipe|
|
|
|
|
|
Dir.cd recipe.dirname
|
|
|
|
|
|
|
|
|
|
unless File.exists? "configure"
|
|
|
|
|
next BuildStatus::Pass
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
child = context.run "./configure", ["--prefix=/package"]
|
|
|
|
|
|
|
|
|
|
if child.exit_status == 0
|
|
|
|
|
BuildStatus::Success
|
|
|
|
|
else
|
|
|
|
|
BuildStatus::Failed
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
@building_backends << Backend::Building.new "build", "make" do |context, recipe|
|
|
|
|
|
Dir.cd recipe.dirname
|
|
|
|
|
|
|
|
|
|
unless File.exists? "Makefile"
|
|
|
|
|
next BuildStatus::Pass
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
child = context.run "make"
|
|
|
|
|
|
|
|
|
|
if child.exit_status == 0
|
|
|
|
|
BuildStatus::Success
|
|
|
|
|
else
|
|
|
|
|
BuildStatus::Failed
|
|
|
|
|
end
|
|
|
|
|
end
|
2019-07-03 05:23:48 +02:00
|
|
|
|
|
|
|
|
|
@building_backends << Backend::Building.new "install", "make" do |context, recipe|
|
|
|
|
|
Dir.cd recipe.dirname
|
|
|
|
|
|
|
|
|
|
unless File.exists? "Makefile"
|
|
|
|
|
next BuildStatus::Pass
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
child = context.run "make", ["install", "DESTDIR=#{recipe.fake_root_directory}"]
|
|
|
|
|
|
|
|
|
|
if child.exit_status == 0
|
|
|
|
|
BuildStatus::Success
|
|
|
|
|
else
|
|
|
|
|
BuildStatus::Failed
|
|
|
|
|
end
|
|
|
|
|
end
|
2019-07-03 03:35:35 +02:00
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def packaging_backend=(name : String)
|
|
|
|
|
@selected_packaging_backend = @packaging_backends.find(&.name.==(name)).not_nil!
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def packaging_backend=(backend : Backend::Packaging)
|
|
|
|
|
@selected_packaging_backend = backend
|
2019-07-02 03:50:50 +02:00
|
|
|
|
end
|
2019-07-02 19:45:33 +02:00
|
|
|
|
|
|
|
|
|
def run(chdir, command, args)
|
|
|
|
|
Process.run command, args, chdir: chdir, output: Process::Redirect::Inherit, error: Process::Redirect::Inherit
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def run(command, args)
|
|
|
|
|
run nil, command, args
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def run(command)
|
|
|
|
|
run nil, command, nil
|
|
|
|
|
end
|
2019-07-03 03:17:01 +02:00
|
|
|
|
|
|
|
|
|
def package(package : Package) : Bool
|
2019-07-03 03:35:35 +02:00
|
|
|
|
@selected_packaging_backend.package package
|
2019-07-03 03:17:01 +02:00
|
|
|
|
end
|
2019-07-02 03:50:50 +02:00
|
|
|
|
end
|
|
|
|
|
|