diff options
author | Boris Nagaev <bnagaev@gmail.com> | 2015-10-27 00:15:37 (GMT) |
---|---|---|
committer | Boris Nagaev <bnagaev@gmail.com> | 2015-10-27 23:45:37 (GMT) |
commit | f50add7fc08856505b364232975addcd1349e2cf (patch) | |
tree | d85683b5b05b0d637c74a7fe13182809d2e0c403 /tools | |
parent | ac1543115b0e96154e01ae3e36e2598fe2deaf06 (diff) | |
download | mxe-f50add7fc08856505b364232975addcd1349e2cf.zip mxe-f50add7fc08856505b364232975addcd1349e2cf.tar.gz mxe-f50add7fc08856505b364232975addcd1349e2cf.tar.bz2 |
build-pkg: refactor package building function
Move common code (making a directory, control file, running tar,
dpkg-deb, etc) to function makePackage(). This function is used
by functions makeDeb() and makeMxeRequirementsDeb().
Diffstat (limited to 'tools')
-rwxr-xr-x | tools/build-pkg.lua | 132 |
1 files changed, 58 insertions, 74 deletions
diff --git a/tools/build-pkg.lua b/tools/build-pkg.lua index 84e5e5c..e68af3a 100755 --- a/tools/build-pkg.lua +++ b/tools/build-pkg.lua @@ -156,6 +156,12 @@ local function fileExists(name) end end +local function writeFile(filename, data) + local file = io.open(filename, 'w') + file:write(data) + file:close() +end + local NATIVE_TARGET = trim(shell("ext/config.guess")) local function isCross(target) return target ~= NATIVE_TARGET @@ -385,11 +391,6 @@ local function protectVersion(ver) end end -local function listFile(item) - local target, pkg = parseItem(item) - return ('%s-%s.list'):format(target, pkg) -end - local CONTROL = [[Package: %s Version: %s Section: devel @@ -418,63 +419,60 @@ local function debianControl(options) ) end -local D1 = "MXE package %s for %s" -local D2 = "This package contains the files for MXE package %s" - -local function makeDeb(item, list_path, deps, ver) - local target, pkg = parseItem(item) - local deb_pkg = nameToDebian(item) - local dirname = ('%s_%s'):format(deb_pkg, +local function makePackage(name, files, deps, ver, d1, d2, dst) + local dst = dst or '.' + local dirname = ('%s/%s_%s'):format(dst, name, protectVersion(ver)) + -- make .list file + local list_path = ('%s/%s.list'):format(dst, name) + writeFile(list_path, table.concat(files, "\n")) -- make .tar.xz file local tar_name = dirname .. '.tar.xz' local cmd = '%s -T %s --owner=root --group=root -cJf %s' os.execute(cmd:format(tool 'tar', list_path, tar_name)) - -- unpack .tar.xz to the path for Debian - local usr = dirname .. MXE_DIR - os.execute(('mkdir -p %s'):format(usr)) - -- use tar to copy files with paths - local cmd = '%s -C %s -xf %s' - if not no_debs then - cmd = 'fakeroot -s deb.fakeroot ' .. cmd - end - os.execute(cmd:format(tool 'tar', usr, tar_name)) - -- prepare dependencies - local deb_deps = {'mxe-requirements'} - for _, dep in ipairs(deps) do - table.insert(deb_deps, nameToDebian(dep)) - end -- make DEBIAN/control file - os.execute(('mkdir -p %s/DEBIAN'):format(dirname)) - local control_fname = dirname .. '/DEBIAN/control' - local control = io.open(control_fname, 'w') - control:write(debianControl { - package = deb_pkg, + local control_text = debianControl { + package = name, version = protectVersion(ver), arch = ARCH, - deps = deb_deps, - description1 = D1:format(pkg, target), - description2 = D2:format(pkg), - }) - control:close() - -- keep a copy of control file - local cmd = 'cp %s %s.deb-control' - os.execute(cmd:format(control_fname, dirname)) + deps = deps, + description1 = d1, + description2 = d2, + } + writeFile(dirname .. ".deb-control", control_text) if not no_debs then + -- unpack .tar.xz to the path for Debian + local usr = dirname .. MXE_DIR + os.execute(('mkdir -p %s'):format(usr)) + os.execute(('mkdir -p %s/DEBIAN'):format(dirname)) + -- use tar to copy files with paths + local cmd = '%s -C %s -xf %s' + cmd = 'fakeroot -s deb.fakeroot ' .. cmd + os.execute(cmd:format(tool 'tar', usr, tar_name)) + -- make DEBIAN/control file + local control_fname = dirname .. '/DEBIAN/control' + writeFile(control_fname, control_text) -- make .deb file local cmd = 'fakeroot -i deb.fakeroot dpkg-deb -b %s' os.execute(cmd:format(dirname)) + -- cleanup + os.execute(('rm -fr %s deb.fakeroot'):format(dirname)) end - -- cleanup - os.execute(('rm -fr %s deb.fakeroot'):format(dirname)) end -local function saveFileList(list_file, list) - local file = io.open(list_file, 'w') - for _, installed_file in ipairs(list) do - file:write(installed_file .. '\n') +local D1 = "MXE package %s for %s" +local D2 = "This package contains the files for MXE package %s" + +local function makeDeb(item, files, deps, ver) + local target, pkg = parseItem(item) + local deb_pkg = nameToDebian(item) + local d1 = D1:format(pkg, target) + local d2 = D2:format(pkg) + local deb_deps = {'mxe-requirements'} + for _, dep in ipairs(deps) do + table.insert(deb_deps, nameToDebian(dep)) end - file:close() + makePackage(deb_pkg, files, deb_deps, ver, d1, d2) end local function isBuilt(item, files) @@ -494,6 +492,7 @@ local function buildPackages(items, item2deps) local broken = {} local unbroken = {} local file2item = {} + local item2files = {} local function brokenDep(item) for _, dep in ipairs(item2deps[item]) do if broken[dep] then @@ -506,7 +505,7 @@ local function buildPackages(items, item2deps) if not brokenDep(item) then local files = buildItem(item, item2deps, file2item) if isBuilt(item, files) then - saveFileList(listFile(item), files) + item2files[item] = files table.insert(unbroken, item) else -- broken package @@ -519,15 +518,15 @@ local function buildPackages(items, item2deps) item, brokenDep(item)) end end - return unbroken + return unbroken, item2files end -local function makeDebs(items, item2deps, item2ver) +local function makeDebs(items, item2deps, item2ver, item2files) for _, item in ipairs(items) do local deps = assert(item2deps[item], item) local ver = assert(item2ver[item], item) - local list_path = listFile(item) - makeDeb(item, list_path, deps, ver) + local files = assert(item2files[item], item) + makeDeb(item, files, deps, ver) end end @@ -543,6 +542,7 @@ local MXE_REQUIREMENTS_DESCRIPTION2 = Other MXE packages depend on this package.]] local function makeMxeRequirementsDeb(release) + os.execute(('mkdir -p %s'):format(release)) local name = 'mxe-requirements' local ver = getMxeVersion() .. release -- dependencies @@ -560,27 +560,11 @@ local function makeMxeRequirementsDeb(release) -- Jessie+ table.insert(deps, 'libtool-bin') end - -- directory - local DIRNAME = '%s/%s_%s_%s' - local dirname = DIRNAME:format(release, name, ver, ARCH) - -- make DEBIAN/control file - os.execute(('mkdir -p %s/DEBIAN'):format(dirname)) - local control_fname = dirname .. '/DEBIAN/control' - local control = io.open(control_fname, 'w') - control:write(debianControl { - package = name, - version = ver, - arch = ARCH, - deps = deps, - description1 = "MXE requirements package", - description2 = MXE_REQUIREMENTS_DESCRIPTION2, - }) - control:close() - -- make .deb file - local cmd = 'dpkg-deb -b %s' - os.execute(cmd:format(dirname)) - -- cleanup - os.execute(('rm -fr %s'):format(dirname)) + local files = {} + local d1 = "MXE requirements package" + local d2 = MXE_REQUIREMENTS_DESCRIPTION2 + local dst = release + makePackage(name, files, deps, ver, d1, d2, dst) end assert(trim(shell('pwd')) == MXE_DIR, @@ -594,8 +578,8 @@ gitInit() local items, item2deps, item2ver = getItems() local build_list = sortForBuild(items, item2deps) build_list = sliceArray(build_list, max_items) -local unbroken = buildPackages(build_list, item2deps) -makeDebs(unbroken, item2deps, item2ver) +local unbroken, item2files = buildPackages(build_list, item2deps) +makeDebs(unbroken, item2deps, item2ver, item2files) if not no_debs then makeMxeRequirementsDeb('wheezy') makeMxeRequirementsDeb('jessie') |