X-Git-Url: https://pd.if.org/git/?a=blobdiff_plain;f=zpm-add.c;h=86b289d9748d836aff391c7ef4f32f6f3d20bb4c;hb=4b448fbc77510c589cc7f367c05bef63acc07858;hp=3cf7f17f51be829d1462f24b7380d451612ecf3f;hpb=8b1e91714de0575adeb202668d7983b7f987afc0;p=zpackage diff --git a/zpm-add.c b/zpm-add.c index 3cf7f17..86b289d 100644 --- a/zpm-add.c +++ b/zpm-add.c @@ -21,6 +21,7 @@ struct opts { int complete, addcontent, isconfig, opt_l, recursive, verbose; int followsymlinks; int xargs, noclear; + int striparg; mode_t clmode; char *cltype, *clhash, *clmtime, *prefix, *strip, *cltarget; @@ -212,9 +213,9 @@ int stat_file(struct zpm_file *file, char *path, struct opts *opt) { } if (opt->clmode) { - file->mode = opt->clmode; + file->mode = opt->clmode & 07777; } else { - file->mode = st.st_mode; + file->mode = st.st_mode & 07777; } if (opt->cluser) { @@ -400,6 +401,7 @@ int main(int ac, char **av) { case 'N': opt.addcontent = 0; break; case 'P': opt.prefix = optarg; break; case 'S': opt.strip = optarg; break; + case 's': opt.striparg = 1; break; case 'T': opt.cltarget = optarg; break; case 'c': opt.isconfig = 1; break; case 'f': dbfile = optarg; break; @@ -438,7 +440,6 @@ int main(int ac, char **av) { char *pkgid; pkgstr = av[optind++]; pkgid = zpm_findpkg(&zpm, pkgstr, NULL); - /* TODO if not found, error */ if (!pkgid) { die("package %s not found\n", pkgstr); } @@ -465,6 +466,10 @@ int main(int ac, char **av) { die("can't stat %s: %s", av[i], strerror(errno)); } file.data = av[i]; + if (opt.striparg) { + opt.strip = av[i]; + } + if (add_file(&zpm, &file, &opt)) { free_file(&file); } else {