top: properly handle an improper $HOME environment variable
Since its inception, this top has improperly handled an empty HOME environment variable. Under those conditions a path to the root directory would have been constructed. That caused no real harm upon startup since the display defaults would have been employed. However, except for root, it would have been impossible to save the rc file. This commit keeps the promise made in the documentation.
This commit is contained in:
parent
bc6b99e8ff
commit
9573a6fe5b
@ -2148,13 +2148,13 @@ static void configs_read (void) {
|
|||||||
RCF_t rcdef = DEF_RCFILE;
|
RCF_t rcdef = DEF_RCFILE;
|
||||||
#endif
|
#endif
|
||||||
float tmp_delay = DEF_DELAY;
|
float tmp_delay = DEF_DELAY;
|
||||||
char fbuf[LRGBUFSIZ];
|
char fbuf[LRGBUFSIZ], *p;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int i, x;
|
int i, x;
|
||||||
char id;
|
char id;
|
||||||
|
|
||||||
if (!getenv("HOME")) snprintf(Rc_name, sizeof(Rc_name), ".%src", Myname);
|
p = getenv("HOME");
|
||||||
else snprintf(Rc_name, sizeof(Rc_name), "%s/.%src", getenv("HOME"), Myname);
|
snprintf(Rc_name, sizeof(Rc_name), "%s/.%src", (p && *p) ? p : ".", Myname);
|
||||||
|
|
||||||
fp = fopen(SYS_RCFILESPEC, "r");
|
fp = fopen(SYS_RCFILESPEC, "r");
|
||||||
if (fp) {
|
if (fp) {
|
||||||
|
Loading…
Reference in New Issue
Block a user