Initial commit
This commit is contained in:
@@ -0,0 +1,88 @@
|
||||
SUMMARY = "GNU cpio is a program to manage archives of files"
|
||||
DESCRIPTION = "GNU cpio is a tool for creating and extracting archives, or copying files from one place to \
|
||||
another. It handles a number of cpio formats as well as reading and writing tar files."
|
||||
HOMEPAGE = "http://www.gnu.org/software/cpio/"
|
||||
SECTION = "base"
|
||||
LICENSE = "GPL-3.0-only"
|
||||
LIC_FILES_CHKSUM = "file://COPYING;md5=f27defe1e96c2e1ecd4e0c9be8967949"
|
||||
|
||||
SRC_URI = "${GNU_MIRROR}/cpio/cpio-${PV}.tar.gz \
|
||||
file://0001-configure-Include-needed-header-for-major-minor-macr.patch \
|
||||
file://run-ptest \
|
||||
file://test.sh \
|
||||
"
|
||||
|
||||
SRC_URI[sha256sum] = "145a340fd9d55f0b84779a44a12d5f79d77c99663967f8cfa168d7905ca52454"
|
||||
|
||||
inherit autotools gettext texinfo ptest
|
||||
|
||||
CVE_STATUS[CVE-2010-4226] = "not-applicable-platform: Issue applies to use of cpio in SUSE/OBS"
|
||||
|
||||
EXTRA_OECONF += "DEFAULT_RMT_DIR=${sbindir}"
|
||||
|
||||
do_install () {
|
||||
autotools_do_install
|
||||
if [ "${base_bindir}" != "${bindir}" ]; then
|
||||
install -d ${D}${base_bindir}/
|
||||
mv "${D}${bindir}/cpio" "${D}${base_bindir}/cpio"
|
||||
if [ "${sbindir}" != "${bindir}" ]; then
|
||||
rmdir ${D}${bindir}/
|
||||
fi
|
||||
fi
|
||||
|
||||
# Avoid conflicts with the version from tar
|
||||
mv "${D}${mandir}/man8/rmt.8" "${D}${mandir}/man8/rmt-cpio.8"
|
||||
}
|
||||
|
||||
do_compile_ptest() {
|
||||
oe_runmake -C ${B}/gnu/ check
|
||||
oe_runmake -C ${B}/lib/ check
|
||||
oe_runmake -C ${B}/rmt/ check
|
||||
oe_runmake -C ${B}/src/ check
|
||||
oe_runmake -C ${B}/tests/ genfile
|
||||
}
|
||||
|
||||
do_install_ptest() {
|
||||
install -d ${D}${PTEST_PATH}/tests/
|
||||
sed -i "/abs_/d" ${B}/tests/atconfig
|
||||
install --mode=755 ${B}/tests/atconfig ${D}${PTEST_PATH}/tests/
|
||||
sed -i "s%${B}/tests:%%g" ${B}/tests/atlocal
|
||||
sed -i "s%${B}/src:%%g" ${B}/tests/atlocal
|
||||
install --mode=755 ${B}/tests/atlocal ${D}${PTEST_PATH}/tests/
|
||||
install --mode=755 ${B}/tests/genfile ${D}${PTEST_PATH}/tests/
|
||||
install --mode=755 ${S}/tests/testsuite ${D}${PTEST_PATH}/tests/
|
||||
install --mode=755 ${WORKDIR}/test.sh ${D}${PTEST_PATH}/test.sh
|
||||
sed -i "s#@PTEST_PATH@#${PTEST_PATH}#g" ${D}${PTEST_PATH}/test.sh
|
||||
}
|
||||
|
||||
# ptest.bbclass currently chowns the ptest directory explicitly, so we need to
|
||||
# change permission after that has happened so the ptest user can write a
|
||||
# temporary directory.
|
||||
do_install_ptest_base:append() {
|
||||
chgrp -R ptest ${D}${PTEST_PATH}/
|
||||
chmod -R g+w ${D}${PTEST_PATH}/
|
||||
}
|
||||
|
||||
# The tests need to run as a non-root user, so pull in the ptest user
|
||||
DEPENDS:append:class-target = "${@bb.utils.contains('PTEST_ENABLED', '1', ' ptest-runner', '', d)}"
|
||||
PACKAGE_WRITE_DEPS:append:class-target = " ${MLPREFIX}ptest-runner"
|
||||
|
||||
RDEPENDS:${PN}-ptest += "ptest-runner"
|
||||
|
||||
PACKAGES =+ "${PN}-rmt"
|
||||
|
||||
FILES:${PN}-rmt = "${sbindir}/rmt*"
|
||||
|
||||
inherit update-alternatives
|
||||
|
||||
ALTERNATIVE_PRIORITY = "100"
|
||||
|
||||
ALTERNATIVE:${PN} = "cpio"
|
||||
ALTERNATIVE:${PN}-rmt = "rmt"
|
||||
|
||||
ALTERNATIVE_LINK_NAME[cpio] = "${base_bindir}/cpio"
|
||||
|
||||
ALTERNATIVE_PRIORITY[rmt] = "50"
|
||||
ALTERNATIVE_LINK_NAME[rmt] = "${sbindir}/rmt"
|
||||
|
||||
BBCLASSEXTEND = "native nativesdk"
|
||||
+48
@@ -0,0 +1,48 @@
|
||||
From 8179be21e664cedb2e9d238cc2f6d04965e97275 Mon Sep 17 00:00:00 2001
|
||||
From: Sergey Poznyakoff <gray@gnu.org>
|
||||
Date: Thu, 11 May 2023 10:18:44 +0300
|
||||
Subject: [PATCH] configure: Include needed header for major/minor macros
|
||||
|
||||
This helps in avoiding the warning about implicit function declaration
|
||||
which is elevated as error with newer compilers e.g. clang 16
|
||||
|
||||
Signed-off-by: Khem Raj <raj.khem@gmail.com>
|
||||
|
||||
Upstream-Status: Backport
|
||||
Signed-off-by: Ross Burton <ross.burton@arm.com>
|
||||
---
|
||||
configure.ac | 18 ++++++++++++++++--
|
||||
1 file changed, 16 insertions(+), 2 deletions(-)
|
||||
|
||||
diff --git a/configure.ac b/configure.ac
|
||||
index de479e7..c601029 100644
|
||||
--- a/configure.ac
|
||||
+++ b/configure.ac
|
||||
@@ -43,8 +43,22 @@ AC_TYPE_UID_T
|
||||
AC_CHECK_TYPE(gid_t, int)
|
||||
|
||||
AC_HEADER_DIRENT
|
||||
-AX_COMPILE_CHECK_RETTYPE([major], [0])
|
||||
-AX_COMPILE_CHECK_RETTYPE([minor], [0])
|
||||
+AX_COMPILE_CHECK_RETTYPE([major], [0], [
|
||||
+#include <sys/types.h>
|
||||
+#ifdef MAJOR_IN_MKDEV
|
||||
+# include <sys/mkdev.h>
|
||||
+#endif
|
||||
+#ifdef MAJOR_IN_SYSMACROS
|
||||
+# include <sys/sysmacros.h>
|
||||
+#endif])
|
||||
+AX_COMPILE_CHECK_RETTYPE([minor], [0], [
|
||||
+#include <sys/types.h>
|
||||
+#ifdef MAJOR_IN_MKDEV
|
||||
+# include <sys/mkdev.h>
|
||||
+#endif
|
||||
+#ifdef MAJOR_IN_SYSMACROS
|
||||
+# include <sys/sysmacros.h>
|
||||
+#endif])
|
||||
|
||||
AC_CHECK_FUNCS([fchmod fchown])
|
||||
# This is needed for mingw build
|
||||
--
|
||||
2.34.1
|
||||
|
||||
+3
@@ -0,0 +1,3 @@
|
||||
#!/bin/sh
|
||||
|
||||
su -c ./test.sh ptest
|
||||
@@ -0,0 +1,10 @@
|
||||
#!/bin/sh
|
||||
|
||||
# Define cpio test work dir
|
||||
WORKDIR=@PTEST_PATH@/tests/
|
||||
|
||||
# Run test
|
||||
cd ${WORKDIR}
|
||||
./atconfig ./atlocal ./testsuite
|
||||
|
||||
./testsuite 2>&1 | grep -E '[0-9]{1,3}: ' | sed -e 's/^.....//' -e '/[ok]$/s/^/PASS: /;/FAILED (.*)/s/^/FAIL: /;/skipped (.*)/s/^/SKIP: /;/expected failure/ s/^/PASS: /;/UNEXPECTED PASS/s/^/FAIL: /' -e 's/ok$//g' -e 's/FAILED.*//g' -e 's/skipped.*//g' -e 's/expected failure.*//g' -e 's/UNEXPECTED PASS.*//g'
|
||||
Reference in New Issue
Block a user