[pacman-dev] [PATCH 2/2] Provide source files for useful debug packages

Dave Reisner d at falconindy.com
Tue Dec 6 20:17:31 UTC 2016


On Mon, Dec 05, 2016 at 03:02:10PM +1000, Allan McRae wrote:
> Debug packages are fairly useless currently because the soucre files needed
> for stepping through code etc are not packaged with them. This patch adds the
> needed source files to the debug package and adjusts the debug info to look at
> the /usr/src/debug/ directory for them rather than the build location.  This
> requires using the "debugedit" program which is provided as part of the RPM
> sources.

...will pacman provide a copy of debugedit?

> Signed-off-by: Allan McRae <allan at archlinux.org>
> ---
>  scripts/libmakepkg/tidy/strip.sh.in | 21 ++++++++++++++++++++-
>  1 file changed, 20 insertions(+), 1 deletion(-)
> 
> diff --git a/scripts/libmakepkg/tidy/strip.sh.in b/scripts/libmakepkg/tidy/strip.sh.in
> index 9baed9f..ff75cb4 100644
> --- a/scripts/libmakepkg/tidy/strip.sh.in
> +++ b/scripts/libmakepkg/tidy/strip.sh.in
> @@ -35,6 +35,11 @@ build_id() {
>  	LANG=C readelf -n $1 | sed -n '/Build ID/ { s/.*: //p; q; }'
>  }
>  
> +source_files() {
> +	LANG=C readelf $1 --debug-dump | \

"$1"

> +		awk '/DW_AT_name +:/{name=$8}/DW_AT_comp_dir +:/{print $8 "/" name}'
> +}
> +
>  strip_file() {
>  	local binary=$1; shift
>  
> @@ -50,6 +55,18 @@ strip_file() {
>  			return
>  		fi
>  
> +		# copy source files to debug directory
> +		local f t
> +		for f in $(source_files "$binary"); do

http://mywiki.wooledge.org/DontReadLinesWithFor

while read -r f; do
  ...
done < <(source_files "$binary")

> +			t=${f/$srcdir/$dbgsrc}

t=${f/"$srcdir"/$dbgsrc}

> +			mkdir -p "${t%/*}"
> +			cp "$f" "$t"

cp -- "$f" "$t"

> +		done
> +
> +		# adjust debug symbols to point at sources
> +		debugedit -b "${srcdir}" -d /usr/src/debug/ -i "$binary" &> /dev/null
> +
> +		# copy debug symbols to debug directory
>  		mkdir -p "$dbgdir/${binary%/*}"
>  		objcopy --only-keep-debug "$binary" "$dbgdir/$binary.debug"
>  		objcopy --add-gnu-debuglink="$dbgdir/${binary#/}.debug" "$binary"
> @@ -88,8 +105,10 @@ tidy_strip() {
>  		[[ -z ${STRIP_STATIC+x} ]] && STRIP_STATIC="-S"
>  
>  		if check_option "debug" "y"; then
> +
>  			dbgdir="$pkgdirbase/$pkgbase- at DEBUGSUFFIX@/usr/lib/debug"
> -			mkdir -p "$dbgdir"
> +			dbgsrc="$pkgdirbase/$pkgbase- at DEBUGSUFFIX@/usr/src/debug"
> +			mkdir -p "$dbgdir" "$dbgsrc"
>  		fi
>  
>  		local binary strip_flags
> -- 
> 2.10.2


More information about the pacman-dev mailing list