aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorElliott Hughes <enh@google.com>2019-06-24 22:35:29 -0700
committerRob Landley <rob@landley.net>2019-06-25 11:52:25 -0500
commit600baebaced399f4a5528515811ac43428a7bc30 (patch)
treeb730d5416aa0850c55b863ab0ea0b49e09cecc44
parent96231a5a77dc1c3c0e84eb78e6dd7574505928eb (diff)
downloadtoybox-600baebaced399f4a5528515811ac43428a7bc30.tar.gz
tar: implement --mode.
Used by build/make/tools/mktarball.sh in AOSP. (Which is why today's switch to toybox tar got reverted.)
-rw-r--r--tests/tar.test4
-rw-r--r--toys/posix/tar.c13
2 files changed, 12 insertions, 5 deletions
diff --git a/tests/tar.test b/tests/tar.test
index dbc3ad7c..f1703644 100644
--- a/tests/tar.test
+++ b/tests/tar.test
@@ -51,6 +51,10 @@ testing "pass mtime" \
"tar c --owner root --group root file | LST --full-time" \
"-rw-rw-r-- root/root 0 1987-01-23 12:34:56 file\n" "" ""
+testing "adjust mode" \
+ "tar c --owner root --group root --mode a+x file | LST --full-time" \
+ "-rwxrwxr-x root/root 0 1987-01-23 12:34:56 file\n" "" ""
+
mkdir dir
testing "create dir" "$TAR dir | $SUM" \
"05739c423d7d4a7f12b3dbb7c94149acb2bb4f8d\n" "" ""
diff --git a/toys/posix/tar.c b/toys/posix/tar.c
index 2819a355..f4f7a928 100644
--- a/toys/posix/tar.c
+++ b/toys/posix/tar.c
@@ -18,7 +18,7 @@
* Extract into dir same as filename, --restrict? "Tarball is splodey"
*
-USE_TAR(NEWTOY(tar, "&(restrict)(full-time)(no-recursion)(numeric-owner)(no-same-permissions)(overwrite)(exclude)*(mtime):(group):(owner):(to-command):o(no-same-owner)p(same-permissions)k(keep-old)c(create)|h(dereference)x(extract)|t(list)|v(verbose)J(xz)j(bzip2)z(gzip)S(sparse)O(to-stdout)m(touch)X(exclude-from)*T(files-from)*C(directory):f(file):a[!txc][!jzJa]", TOYFLAG_USR|TOYFLAG_BIN))
+USE_TAR(NEWTOY(tar, "&(restrict)(full-time)(no-recursion)(numeric-owner)(no-same-permissions)(overwrite)(exclude)*(mode):(mtime):(group):(owner):(to-command):o(no-same-owner)p(same-permissions)k(keep-old)c(create)|h(dereference)x(extract)|t(list)|v(verbose)J(xz)j(bzip2)z(gzip)S(sparse)O(to-stdout)m(touch)X(exclude-from)*T(files-from)*C(directory):f(file):a[!txc][!jzJa]", TOYFLAG_USR|TOYFLAG_BIN))
config TAR
bool "tar"
@@ -34,9 +34,11 @@ config TAR
o Ignore owner h Follow symlinks m Ignore mtime
J xz compression j bzip2 compression z gzip compression
O Extract to stdout X exclude names in FILE T include names in FILE
- --exclude FILENAME to exclude --full-time show seconds with -tv
- --mtime Use TIME for file timestamps --sparse Record sparse files
- --owner Set file owner to NAME --group Set file group to NAME
+
+ --exclude FILENAME to exclude --full-time Show seconds with -tv
+ --mode MODE Adjust modes --mtime TIME Override timestamps
+ --owner NAME Set file owner to NAME --group NAME Set file group to NAME
+ --sparse Record sparse files
--restrict All archive contents must extract under one subdirctory
--numeric-owner Save/use/display uid and gid, not user/group name
--no-recursion Don't store directory contents
@@ -48,7 +50,7 @@ config TAR
GLOBALS(
char *f, *C;
struct arg_list *T, *X;
- char *to_command, *owner, *group, *mtime;
+ char *to_command, *owner, *group, *mtime, *mode;
struct arg_list *exclude;
struct double_list *incl, *excl, *seen;
@@ -218,6 +220,7 @@ static int add_to_tar(struct dirtree *node)
if (TT.owner) st->st_uid = TT.ouid;
if (TT.group) st->st_gid = TT.ggid;
+ if (TT.mode) st->st_mode = string_to_mode(TT.mode, st->st_mode);
if (TT.mtime) st->st_mtime = TT.mtt;
memset(&hdr, 0, sizeof(hdr));