diff options
author | Thomas <thomas@xteddy.org> | 2014-01-20 10:48:12 +0000 |
---|---|---|
committer | Thomas <thomas@xteddy.org> | 2014-01-20 10:48:12 +0000 |
commit | d02c4bda3a4b456f654fb0c1b454ba9724bff0f3 (patch) | |
tree | 95f3d17d7f1525e05ed298a015166af557988a0e /tmux.c | |
parent | ba014c1a605f78b301b47ef922dd24a3c5c2c4c1 (diff) | |
parent | 938768ed3de3e38cb96344b8ec7b794b5e828acf (diff) | |
download | rtmux-d02c4bda3a4b456f654fb0c1b454ba9724bff0f3.tar.gz rtmux-d02c4bda3a4b456f654fb0c1b454ba9724bff0f3.tar.bz2 rtmux-d02c4bda3a4b456f654fb0c1b454ba9724bff0f3.zip |
Merge branch 'obsd-master'
Diffstat (limited to 'tmux.c')
-rw-r--r-- | tmux.c | 21 |
1 files changed, 15 insertions, 6 deletions
@@ -205,8 +205,9 @@ int main(int argc, char **argv) { struct passwd *pw; - char *s, *path, *label, *home, **var, tmp[MAXPATHLEN]; + char *s, *path, *label, **var, tmp[MAXPATHLEN]; char in[256]; + const char *home; long long pid; int opt, flags, quiet, keys, session; @@ -331,11 +332,15 @@ main(int argc, char **argv) pw = getpwuid(getuid()); if (pw != NULL) home = pw->pw_dir; + else + home = NULL; } - xasprintf(&cfg_file, "%s/.tmux.conf", home); - if (access(cfg_file, R_OK) != 0 && errno == ENOENT) { - free(cfg_file); - cfg_file = NULL; + if (home != NULL) { + xasprintf(&cfg_file, "%s/.tmux.conf", home); + if (access(cfg_file, R_OK) != 0 && errno == ENOENT) { + free(cfg_file); + cfg_file = NULL; + } } } @@ -367,7 +372,11 @@ main(int argc, char **argv) } } free(label); - strlcpy(socket_path, path, sizeof socket_path); + + if (strlcpy(socket_path, path, sizeof socket_path) >= sizeof socket_path) { + fprintf(stderr, "socket path too long: %s\n", path); + exit(1); + } free(path); #ifdef HAVE_SETPROCTITLE |