public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Michael Tremer <michael.tremer@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] tar: Update to 1.30 (V2)
Date: Tue, 29 May 2018 20:36:01 +0100	[thread overview]
Message-ID: <a2ec878e040118bd01600f4ee6a70f3f3bf83a9f.camel@ipfire.org> (raw)
In-Reply-To: <20180529184258.29492-1-matthias.fischer@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 6359 bytes --]

Hi,

On Tue, 2018-05-29 at 20:42 +0200, Matthias Fischer wrote:
> For details see:
> https://www.gnu.org/software/tar/
> 
> Second attempt to update 'tar' to 1.30.
> 
> Since new 'tar' has changes in commandline option parsing, the first
> commit broke cdrom build and probably some others. Sorry for the noise...
> 
> Thanks to Marcel for tips and diffs and Arne for reverting.
> 
> Here, these patches built without any errors, I hope it's all right now.
> 
> Could somebody please have a look at this?
> 
> Best,
> Matthias
> 
> Signed-off-by: Matthias Fischer <matthias.fischer(a)ipfire.org>
> ---
>  lfs/Config       | 8 +++-----
>  lfs/cdrom        | 5 ++---
>  lfs/core-updates | 7 +++----
>  lfs/tar          | 6 +++---
>  make.sh          | 4 ++--
>  5 files changed, 13 insertions(+), 17 deletions(-)
> 
> diff --git a/lfs/Config b/lfs/Config
> index cf70f81f9..8e8e5879b 100644
> --- a/lfs/Config
> +++ b/lfs/Config
> @@ -205,13 +205,11 @@ define PAK
>  	sed -e 's/BUILDTARGET/$(BUILDTARGET)/g' -e 's/KVER/$(KVER)/g' -e
> 's/MACHINE/$(BUILD_ARCH)/g' -i /install/packages/package/ROOTFILES
>  	sed -e 's/xxxKVERxxx/$(KVER)/g' -i
> /install/packages/package/install.sh
>  	chmod 755 /install/packages/package/{{,un}install,update}.sh
> -	cd / && tar cf /install/packages/package/files.tmp --files-
> from=/install/packages/package/ROOTFILES --exclude='#*' \
> -		-p --numeric-owner
> +	cd / && tar cfp /install/packages/package/files.tmp --numeric-owner
> --exclude='#*' --files-from=/install/packages/package/ROOTFILES
>  	# Double tar to remove double files
> -	tar xf /install/packages/package/files.tmp -C
> /install/packages/package/tmp/ \
> -		-p --numeric-owner
> +	tar xfp /install/packages/package/files.tmp --numeric-owner -C
> /install/packages/package/tmp/
>  	rm -f /install/packages/package/files.tmp
> -	cd /install/packages/package/tmp/ && tar cf - -p --numeric-owner * |
> xz $(XZ_OPT) > /install/packages/package/files.tar.xz
> +	cd /install/packages/package/tmp/ && tar cJp --numeric-owner * | xz
> $(XZ_OPT) > /install/packages/package/files.tar.xz

You are introducing another -J parameter here again which will cause the tarball
to be compressed twice.

>  	rm -r /install/packages/package/tmp
>  	-cat /install/packages/package/ROOTFILES | grep -v "#" >
> /install/packages/package/ROOTFILES.tmp
>  	mv /install/packages/package/ROOTFILES.tmp
> /install/packages/package/ROOTFILES
> diff --git a/lfs/cdrom b/lfs/cdrom
> index 00f185d81..6382034b5 100644
> --- a/lfs/cdrom
> +++ b/lfs/cdrom
> @@ -65,9 +65,8 @@ $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
>  
>  	# Compress root filesystem
>  	# Reason for this tar+untar+tar is removing of entries listed two or
> more in src/ROOTFILES
> -	tar -c -C / --files-from=/tmp/ROOTFILES \
> -		-f /$(SNAME).tar --exclude='#*' --exclude='dev/pts/*' \
> -		--exclude='proc/*' --exclude='tmp/ROOTFILES'
> +	tar -c --exclude='#*' --exclude='proc/*' --exclude='dev/pts/*' --
> exclude='tmp/ROOTFILES' \
> +		-C / --files-from=/tmp/ROOTFILES -f /$(SNAME).tar
>  	rm -f /tmp/ROOTFILES
>  	tar -x -C /tmp -f /$(SNAME).tar
>  	rm -f /$(SNAME).tar
> diff --git a/lfs/core-updates b/lfs/core-updates
> index d34926967..3d12d40b1 100644
> --- a/lfs/core-updates
> +++ b/lfs/core-updates
> @@ -72,10 +72,9 @@ core/%:
>  	sed -e "s/KVER/$(KVER)/g" -i /tmp/ROOTFILES
>  
>  	#Remove doubled files with tar/untar/tar to save space
> -	tar -c -C / --files-from=/tmp/ROOTFILES \
> -		-f /$(SNAME).tar --exclude='#*' --exclude='dev/pts/*' \
> -		--exclude='proc/*' --exclude='tmp/ROOTFILES' \
> -		--exclude-from=$(DIR_SRC)/config/rootfiles/$@/exclude
> +	tar -c --exclude='proc/*' --exclude='tmp/ROOTFILES' --exclude='#*' --
> exclude='dev/pts/*' \
> +		--exclude-from=$(DIR_SRC)/config/rootfiles/$@/exclude \
> +		-C / --files-from=/tmp/ROOTFILES -f /$(SNAME).tar
>  	mv -f /tmp/ROOTFILES /install/packages/package/ROOTFILES
>  	tar -p --numeric-owner -x  -C /tmp -f /$(SNAME).tar
>  	rm -f /$(SNAME).tar
> diff --git a/lfs/tar b/lfs/tar
> index 6a949a003..4e914b535 100644
> --- a/lfs/tar
> +++ b/lfs/tar
> @@ -1,7 +1,7 @@
>  #############################################################################
> ##
>  #                                                                            
>  #
>  # IPFire.org - A linux based
> firewall                                         #
> -# Copyright (C) 2007  Michael Tremer & Christian
> Schmidt                      #
> +# Copyright (C) 2018  Michael Tremer & Christian
> Schmidt                      #
>  #                                                                            
>  #
>  # This program is free software: you can redistribute it and/or
> modify        #
>  # it under the terms of the GNU General Public License as published
> by        #
> @@ -24,7 +24,7 @@
>  
>  include Config
>  
> -VER        = 1.28
> +VER        = 1.30
>  
>  THISAPP    = tar-$(VER)
>  DL_FILE    = $(THISAPP).tar.bz2
> @@ -50,7 +50,7 @@ objects = $(DL_FILE)
>  
>  $(DL_FILE) = $(DL_FROM)/$(DL_FILE)
>  
> -$(DL_FILE)_MD5 = 8f32b2bc1ed7ddf4cf4e4a39711341b0
> +$(DL_FILE)_MD5 = 8404e4c1fc5a3000228ab2b8ad674a65
>  
>  install : $(TARGET)
>  
> diff --git a/make.sh b/make.sh
> index bfcfbc3e4..1050eb03b 100755
> --- a/make.sh
> +++ b/make.sh
> @@ -1785,8 +1785,8 @@ toolchain)
>  	buildtoolchain
>  	echo "`date -u '+%b %e %T'`: Create toolchain image for
> ${BUILD_ARCH}" | tee -a $LOGFILE
>  	test -d $BASEDIR/cache/toolchains || mkdir -p
> $BASEDIR/cache/toolchains
> -	cd $BASEDIR && tar -cf- --exclude='log/_build.*.log'
> build/${TOOLS_DIR} build/bin/sh log | xz ${XZ_OPT} \
> -		> cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-
> ${BUILD_ARCH}.tar.xz
> +	cd $BASEDIR && XZ_OPT="$(XZ_OPT)" tar -Jc --
> exclude='log/_build.*.log' -f cache/toolchains/$SNAME-$VERSION-toolchain-
> $TOOLCHAINVER-${BUILD_ARCH}.tar.xz --xz \
> +		build/${TOOLS_DIR} build/bin/sh log >> $LOGFILE

This bit also reverts some of the previous changes.

Are you sure you worked on next?

-Michael

>  	md5sum cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-
> ${BUILD_ARCH}.tar.xz \
>  		> cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-
> ${BUILD_ARCH}.md5
>  	stdumount

  reply	other threads:[~2018-05-29 19:36 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-29 18:42 Matthias Fischer
2018-05-29 19:36 ` Michael Tremer [this message]
     [not found] <fb10fb9d-c59d-1e47-6287-bb4948c528e3@ipfire.org>
2018-06-06 12:32 ` Michael Tremer
2018-06-06 19:49   ` Matthias Fischer
2018-06-06 19:55     ` Matthias Fischer
2018-06-07 19:33       ` Michael Tremer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=a2ec878e040118bd01600f4ee6a70f3f3bf83a9f.camel@ipfire.org \
    --to=michael.tremer@ipfire.org \
    --cc=development@lists.ipfire.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox