forked from pool/debugedit
Accepting request 919738 from home:gmbr3:rpm4.17
RPM 4.17 OBS-URL: https://build.opensuse.org/request/show/919738 OBS-URL: https://build.opensuse.org/package/show/Base:System/debugedit?expand=0&rev=1
This commit is contained in:
commit
67adf9ff94
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
## Default LFS
|
||||
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||
*.png filter=lfs diff=lfs merge=lfs -text
|
||||
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||
*.zst filter=lfs diff=lfs merge=lfs -text
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
.osc
|
BIN
debugedit-5.0.tar.xz
(Stored with Git LFS)
Normal file
BIN
debugedit-5.0.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
debugedit-5.0.tar.xz.sig
Normal file
BIN
debugedit-5.0.tar.xz.sig
Normal file
Binary file not shown.
11
debugedit.changes
Normal file
11
debugedit.changes
Normal file
@ -0,0 +1,11 @@
|
||||
-------------------------------------------------------------------
|
||||
Wed Jun 30 13:06:47 UTC 2021 - Callum Farmer <gmbr3@opensuse.org>
|
||||
|
||||
- initial version 5.0
|
||||
- Added patches from rpm:
|
||||
* finddebuginfo.patch
|
||||
* finddebuginfo-absolute-links.patch
|
||||
* debugsubpkg.patch
|
||||
* debuglink.patch
|
||||
* debuginfo-mono.patch
|
||||
- Add patch to fix bad shift: remove-bad-shift.patch
|
BIN
debugedit.keyring
Normal file
BIN
debugedit.keyring
Normal file
Binary file not shown.
66
debugedit.spec
Normal file
66
debugedit.spec
Normal file
@ -0,0 +1,66 @@
|
||||
#
|
||||
# spec file for package debugedit
|
||||
#
|
||||
# Copyright (c) 2021 SUSE LLC
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
# upon. The license for this file, and modifications and additions to the
|
||||
# file, is the same license as for the pristine package itself (unless the
|
||||
# license for the pristine package is not an Open Source License, in which
|
||||
# case the license is the MIT License). An "Open Source License" is a
|
||||
# license that conforms to the Open Source Definition (Version 1.9)
|
||||
# published by the Open Source Initiative.
|
||||
|
||||
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||
#
|
||||
|
||||
Name: debugedit
|
||||
Version: 5.0
|
||||
Release: 0
|
||||
Summary: Debuginfo extraction
|
||||
License: GPL-3.0-or-later
|
||||
Group: System/Packages
|
||||
URL: https://www.sourceware.org/debugedit
|
||||
Source0: https://sourceware.org/ftp/%{name}/%{version}/%{name}-%{version}.tar.xz
|
||||
Source1: https://sourceware.org/ftp/%{name}/%{version}/%{name}-%{version}.tar.xz.sig
|
||||
Source2: %{name}.keyring
|
||||
Patch0: finddebuginfo.patch
|
||||
Patch1: finddebuginfo-absolute-links.patch
|
||||
Patch2: debugsubpkg.patch
|
||||
Patch3: debuglink.patch
|
||||
Patch4: debuginfo-mono.patch
|
||||
Patch5: remove-bad-shift.patch
|
||||
BuildRequires: autoconf
|
||||
BuildRequires: automake
|
||||
BuildRequires: help2man
|
||||
BuildRequires: pkgconfig(libelf)
|
||||
BuildRequires: pkgconfig(libdw)
|
||||
|
||||
%description
|
||||
debugedit provides programs and scripts for creating debuginfo and source file distributions,
|
||||
collect build-ids and rewrite source paths in DWARF data for debugging, tracing and profiling.
|
||||
|
||||
%prep
|
||||
%autosetup -p1
|
||||
|
||||
%build
|
||||
autoreconf -fiv
|
||||
%configure
|
||||
%make_build
|
||||
|
||||
%install
|
||||
%make_install
|
||||
|
||||
|
||||
%files
|
||||
%license COPYING3
|
||||
%doc README
|
||||
%{_bindir}/debugedit
|
||||
%{_bindir}/find-debuginfo
|
||||
%{_bindir}/sepdebugcrcfix
|
||||
%{_mandir}/man1/debugedit.1%{?ext_man}
|
||||
%{_mandir}/man1/find-debuginfo.1%{?ext_man}
|
||||
%{_mandir}/man1/sepdebugcrcfix.1%{?ext_man}
|
||||
|
||||
%changelog
|
19
debuginfo-mono.patch
Normal file
19
debuginfo-mono.patch
Normal file
@ -0,0 +1,19 @@
|
||||
--- ./scripts/find-debuginfo.in.orig 2017-12-01 15:40:27.006764372 +0000
|
||||
+++ ./scripts/find-debuginfo.in 2017-12-01 15:41:17.270619182 +0000
|
||||
@@ -348,6 +348,16 @@ while read nlinks inum f; do
|
||||
;;
|
||||
*) continue ;;
|
||||
esac
|
||||
+ # double check that we really have an ELF file,
|
||||
+ # to handle monodevelop-debugger-gdb and monodevelop-debugger-mdb
|
||||
+ ftype=`/usr/bin/file $f | cut -d: -f2-`
|
||||
+ case $ftype in
|
||||
+ *ELF*) ;;
|
||||
+ *)
|
||||
+ echo "$f is not an ELF file, skipping"
|
||||
+ continue
|
||||
+ ;;
|
||||
+ esac
|
||||
if [ $nlinks -gt 1 ]; then
|
||||
var=seen_$inum
|
||||
if test -n "${!var}"; then
|
11
debuglink.patch
Normal file
11
debuglink.patch
Normal file
@ -0,0 +1,11 @@
|
||||
--- ./scripts/find-debuginfo.in.orig 2017-12-01 15:39:07.239994681 +0000
|
||||
+++ ./scripts/find-debuginfo.in 2017-12-01 15:39:34.942914702 +0000
|
||||
@@ -321,7 +321,7 @@ debug_link()
|
||||
get_debugfn()
|
||||
{
|
||||
dn=$(dirname "${1#$RPM_BUILD_ROOT}")
|
||||
- bn=$(basename "$1" .debug)${unique_debug_suffix}.debug
|
||||
+ bn=$(basename "$1")${unique_debug_suffix}.debug
|
||||
debugdn=${debugdir}${dn}
|
||||
debugfn=${debugdn}/${bn}
|
||||
}
|
41
debugsubpkg.patch
Normal file
41
debugsubpkg.patch
Normal file
@ -0,0 +1,41 @@
|
||||
--- ./scripts/find-debuginfo.in.orig 2017-12-01 15:35:59.023537837 +0000
|
||||
+++ ./scripts/find-debuginfo.in 2017-12-01 15:36:30.351447397 +0000
|
||||
@@ -548,19 +548,25 @@ if $run_dwz \
|
||||
fi
|
||||
fi
|
||||
|
||||
-# For each symlink whose target has a .debug file,
|
||||
-# make a .debug symlink to that file.
|
||||
-find "$RPM_BUILD_ROOT" ! -path "${debugdir}/*" -type l -print |
|
||||
-while read f
|
||||
-do
|
||||
- t=$(readlink -m "$f").debug
|
||||
- f=${f#$RPM_BUILD_ROOT}
|
||||
- t=${t#$RPM_BUILD_ROOT}
|
||||
- if [ -f "$debugdir$t" ]; then
|
||||
- echo "symlinked /usr/lib/debug$t to /usr/lib/debug${f}.debug"
|
||||
- debug_link "/usr/lib/debug$t" "${f}.debug"
|
||||
- fi
|
||||
-done
|
||||
+# We used to make a .debug symlink for each symlink whose target
|
||||
+# has a .debug file to that file. This is not necessary because
|
||||
+# the debuglink section contains only the destination of those links.
|
||||
+# Creating those links anyway results in debuginfo packages for
|
||||
+# devel packages just because of the .so symlinks in them.
|
||||
+
|
||||
+## For each symlink whose target has a .debug file,
|
||||
+## make a .debug symlink to that file.
|
||||
+#find "$RPM_BUILD_ROOT" ! -path "${debugdir}/*" -type l -print |
|
||||
+#while read f
|
||||
+#do
|
||||
+# t=$(readlink -m "$f").debug
|
||||
+# f=${f#$RPM_BUILD_ROOT}
|
||||
+# t=${t#$RPM_BUILD_ROOT}
|
||||
+# if [ -f "$debugdir$t" ]; then
|
||||
+# echo "symlinked /usr/lib/debug$t to /usr/lib/debug${f}.debug"
|
||||
+# debug_link "/usr/lib/debug$t" "${f}.debug"
|
||||
+# fi
|
||||
+#done
|
||||
|
||||
if [ -s "$SOURCEFILE" ]; then
|
||||
# See also debugedit invocation. Directories must match up.
|
30
finddebuginfo-absolute-links.patch
Normal file
30
finddebuginfo-absolute-links.patch
Normal file
@ -0,0 +1,30 @@
|
||||
From: Jan Blunck <jblunck@suse.de>
|
||||
Subject: Do the symbolic links right in the first place
|
||||
|
||||
Since brp-symlink relinks symbolic links to enforce a certain policy we should
|
||||
do it right in the first place. So this patch changes find-debuginfo.sh scripts
|
||||
behavior to reflect that policy.
|
||||
|
||||
Signed-off-by: Jan Blunck <jblunck@suse.de>
|
||||
|
||||
--- ./scripts/find-debuginfo.in.orig 2017-12-01 15:26:21.939199791 +0000
|
||||
+++ ./scripts/find-debuginfo.in 2017-12-01 15:27:03.153081225 +0000
|
||||
@@ -305,7 +305,17 @@ debug_link()
|
||||
local l="/usr/lib/debug$2"
|
||||
local t="$1"
|
||||
echo >> "$LINKSFILE" "$l $t"
|
||||
- link_relative "$t" "$l" "$RPM_BUILD_ROOT"
|
||||
+
|
||||
+ # this should correspond to what brp-symlink is doing
|
||||
+ case $t in
|
||||
+ /usr*)
|
||||
+ link_relative "$t" "$l" "$RPM_BUILD_ROOT"
|
||||
+ ;;
|
||||
+ *)
|
||||
+ mkdir -p "$(dirname "$RPM_BUILD_ROOT$l")" && \
|
||||
+ ln -snf "$t" "$RPM_BUILD_ROOT$l"
|
||||
+ ;;
|
||||
+ esac
|
||||
}
|
||||
|
||||
get_debugfn()
|
89
finddebuginfo.patch
Normal file
89
finddebuginfo.patch
Normal file
@ -0,0 +1,89 @@
|
||||
--- ./scripts/find-debuginfo.in.orig 2019-09-09 07:56:53.377788842 +0000
|
||||
+++ ./scripts/find-debuginfo.in 2019-10-02 11:11:56.878979662 +0000
|
||||
@@ -348,12 +348,18 @@ trap 'rm -rf "$temp"' EXIT
|
||||
|
||||
# Build a list of unstripped ELF files and their hardlinks
|
||||
touch "$temp/primary"
|
||||
-find "$RPM_BUILD_ROOT" ! -path "${debugdir}/*.debug" -type f \
|
||||
- \( -perm -0100 -or -perm -0010 -or -perm -0001 \) \
|
||||
- -print | LC_ALL=C sort |
|
||||
-file -N -f - | sed -n -e 's/^\(.*\):[ ]*.*ELF.*, not stripped.*/\1/p' |
|
||||
-xargs --no-run-if-empty stat -c '%h %D_%i %n' |
|
||||
+find "$RPM_BUILD_ROOT" ! -path "${debugdir}/*.debug" -type f \( -perm /111 -or -name "*.so*" -or -name "*.ko" \) ! -name "*.a" -print0 | LC_ALL=C sort -z |
|
||||
+xargs --no-run-if-empty -0 stat -c '%h %D_%i %n' |
|
||||
while read nlinks inum f; do
|
||||
+ case $(objdump -h $f 2>/dev/null | egrep -o '(debug[\.a-z_]*|gnu.version)') in
|
||||
+ *debuglink*) continue ;;
|
||||
+ *debug*) ;;
|
||||
+ *gnu.version*)
|
||||
+ echo "WARNING: "`echo $f | sed -e "s,^$RPM_BUILD_ROOT/*,/,"`" is already stripped!"
|
||||
+ continue
|
||||
+ ;;
|
||||
+ *) continue ;;
|
||||
+ esac
|
||||
if [ $nlinks -gt 1 ]; then
|
||||
var=seen_$inum
|
||||
if test -n "${!var}"; then
|
||||
@@ -386,6 +392,8 @@ do_file()
|
||||
if [ "$no_recompute_build_id" = "true" ]; then
|
||||
no_recompute="-n"
|
||||
fi
|
||||
+ mode=$(stat -c %a "$f")
|
||||
+ chmod +w "$f"
|
||||
id=$(${install_dir}/debugedit -b "$debug_base_name" -d "$debug_dest_name" \
|
||||
$no_recompute -i \
|
||||
${build_id_seed:+--build-id-seed="$build_id_seed"} \
|
||||
@@ -413,17 +421,30 @@ do_file()
|
||||
# just has its file names collected and adjusted.
|
||||
case "$dn" in
|
||||
/usr/lib/debug/*)
|
||||
+ chmod $mode "$f"
|
||||
return ;;
|
||||
esac
|
||||
|
||||
mkdir -p "${debugdn}"
|
||||
- if test -w "$f"; then
|
||||
- strip_to_debug "${debugfn}" "$f"
|
||||
- else
|
||||
- chmod u+w "$f"
|
||||
- strip_to_debug "${debugfn}" "$f"
|
||||
- chmod u-w "$f"
|
||||
- fi
|
||||
+ objcopy --only-keep-debug "$f" "$debugfn" || :
|
||||
+ (
|
||||
+ shopt -s extglob
|
||||
+ strip_option="--strip-all"
|
||||
+ case "$f" in
|
||||
+ *.ko)
|
||||
+ strip_option="--strip-debug" ;;
|
||||
+ *$STRIP_KEEP_SYMTAB*)
|
||||
+ if test -n "$STRIP_KEEP_SYMTAB"; then
|
||||
+ strip_option="--strip-debug"
|
||||
+ fi
|
||||
+ ;;
|
||||
+ esac
|
||||
+ if test "$NO_DEBUGINFO_STRIP_DEBUG" = true ; then
|
||||
+ strip_option=
|
||||
+ fi
|
||||
+ objcopy --add-gnu-debuglink="$debugfn" -R .comment -R .GCC.command.line $strip_option "$f"
|
||||
+ chmod $mode "$f"
|
||||
+ ) || :
|
||||
|
||||
# strip -g implies we have full symtab, don't add mini symtab in that case.
|
||||
# It only makes sense to add a minisymtab for executables and shared
|
||||
@@ -581,12 +602,14 @@ if [ -s "$SOURCEFILE" ]; then
|
||||
# and non-standard modes may be inherented from original directories, fixup
|
||||
find "${RPM_BUILD_ROOT}${debug_dest_name}" -type d -print0 |
|
||||
xargs --no-run-if-empty -0 chmod 0755
|
||||
+ find "${RPM_BUILD_ROOT}${debug_dest_name}" -type f -print0 |
|
||||
+ xargs --no-run-if-empty -0 chmod a+r
|
||||
fi
|
||||
|
||||
if [ -d "${RPM_BUILD_ROOT}/usr/lib" ] || [ -d "${RPM_BUILD_ROOT}/usr/src" ]; then
|
||||
((nout > 0)) ||
|
||||
test ! -d "${RPM_BUILD_ROOT}/usr/lib" ||
|
||||
- (cd "${RPM_BUILD_ROOT}/usr/lib"; find debug -type d) |
|
||||
+ (cd "${RPM_BUILD_ROOT}/usr/lib"; test ! -d debug || find debug -type d) |
|
||||
sed 's,^,%dir /usr/lib/,' >> "$LISTFILE"
|
||||
|
||||
(cd "${RPM_BUILD_ROOT}/usr"
|
10
remove-bad-shift.patch
Normal file
10
remove-bad-shift.patch
Normal file
@ -0,0 +1,10 @@
|
||||
--- ./scripts/find-debuginfo.in.orig 2017-12-01 15:40:27.006764372 +0000
|
||||
+++ ./scripts/find-debuginfo.in 2017-12-01 15:41:17.270619182 +0000
|
||||
@@ -168,7 +168,6 @@
|
||||
;;
|
||||
--dwz-single-file-mode)
|
||||
dwz_single_file_mode=true
|
||||
- shift
|
||||
;;
|
||||
--build-id-seed)
|
||||
build_id_seed=$2
|
Loading…
Reference in New Issue
Block a user