summaryrefslogtreecommitdiffstats
path: root/pw
diff options
context:
space:
mode:
authorYuri Pankov <yuripv@FreeBSD.org>2018-10-15 20:11:53 +0000
committerYuri Pankov <yuripv@FreeBSD.org>2018-10-15 20:11:53 +0000
commiteb33f7f73f5a9995d6c1a3eb23f0aaa2de310a2c (patch)
treef5ef89db9a32a359a8453e7b9cd0bb842d167d66 /pw
parentbcfb085a8b157ca9c5e5943fd81ed045eb0e7ccc (diff)
downloadpw-darwin-eb33f7f73f5a9995d6c1a3eb23f0aaa2de310a2c.tar.gz
pw-darwin-eb33f7f73f5a9995d6c1a3eb23f0aaa2de310a2c.tar.zst
pw-darwin-eb33f7f73f5a9995d6c1a3eb23f0aaa2de310a2c.zip
pw: respect path specified using -V when writing pw.conf, and -C is not
explicitly specified. -V path is already used to determine which file to read default values from, so it's only logical to write them to the same file. PR: 231653 Reviewed by: eugen, bapt Approved by: re (gjb), kib (mentor) Differential Revision: https://reviews.freebsd.org/D17566
Diffstat (limited to 'pw')
-rw-r--r--pw/pw.h1
-rw-r--r--pw/pw_conf.c8
-rw-r--r--pw/pw_utils.c2
3 files changed, 8 insertions, 3 deletions
diff --git a/pw/pw.h b/pw/pw.h
index fde3ce3..d5e2c60 100644
--- a/pw/pw.h
+++ b/pw/pw.h
@@ -64,6 +64,7 @@ enum _which
};
#define _DEF_DIRMODE (S_IRWXU | S_IRWXG | S_IRWXO)
+#define _PW_CONF "pw.conf"
#define _PATH_PW_CONF "/etc/pw.conf"
#define _UC_MAXLINE 1024
#define _UC_MAXSHELLS 32
diff --git a/pw/pw_conf.c b/pw/pw_conf.c
index 36bb8b6..f7b98f1 100644
--- a/pw/pw_conf.c
+++ b/pw/pw_conf.c
@@ -417,9 +417,13 @@ write_userconfig(struct userconf *cnf, const char *file)
int i, j;
struct sbuf *buf;
FILE *fp;
+ char cfgfile[MAXPATHLEN];
- if (file == NULL)
- file = _PATH_PW_CONF;
+ if (file == NULL) {
+ snprintf(cfgfile, sizeof(cfgfile), "%s/" _PW_CONF,
+ conf.etcpath);
+ file = cfgfile;
+ }
if ((fd = open(file, O_CREAT|O_RDWR|O_TRUNC|O_EXLOCK, 0644)) == -1)
return (0);
diff --git a/pw/pw_utils.c b/pw/pw_utils.c
index e483977..fbf4a3f 100644
--- a/pw/pw_utils.c
+++ b/pw/pw_utils.c
@@ -71,7 +71,7 @@ get_userconfig(const char *config)
if (config != NULL)
return (read_userconfig(config));
- snprintf(defaultcfg, sizeof(defaultcfg), "%s/pw.conf", conf.etcpath);
+ snprintf(defaultcfg, sizeof(defaultcfg), "%s/" _PW_CONF, conf.etcpath);
return (read_userconfig(defaultcfg));
}