aboutsummaryrefslogtreecommitdiff
path: root/tmux.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2015-07-20 18:01:10 +0100
committerThomas Adam <thomas@xteddy.org>2015-07-20 18:01:10 +0100
commit18a64ad52d5b33e229783574a637268eb098b1f0 (patch)
treef4d783fbbb74236698b2898dbdb88cdf2e762f78 /tmux.c
parentdedd9edf7fbfa6bc98445f4d33d9d5a4e7c34854 (diff)
parent92af3766ecc456bd8ade8fe5746d27f4557fdaa8 (diff)
downloadrtmux-18a64ad52d5b33e229783574a637268eb098b1f0.tar.gz
rtmux-18a64ad52d5b33e229783574a637268eb098b1f0.tar.bz2
rtmux-18a64ad52d5b33e229783574a637268eb098b1f0.zip
Merge branch 'obsd-master'
Diffstat (limited to 'tmux.c')
-rw-r--r--tmux.c28
1 files changed, 19 insertions, 9 deletions
diff --git a/tmux.c b/tmux.c
index 39f344c0..61c95af8 100644
--- a/tmux.c
+++ b/tmux.c
@@ -200,10 +200,27 @@ shell_exec(const char *shell, const char *shellcmd)
fatal("execl failed");
}
+const char*
+find_home(void)
+{
+ struct passwd *pw;
+ const char *home;
+
+ home = getenv("HOME");
+ if (home == NULL || *home == '\0') {
+ pw = getpwuid(getuid());
+ if (pw != NULL)
+ home = pw->pw_dir;
+ else
+ home = NULL;
+ }
+
+ return home;
+}
+
int
main(int argc, char **argv)
{
- struct passwd *pw;
char *s, *path, *label, **var, tmp[PATH_MAX];
char in[256];
const char *home;
@@ -325,14 +342,7 @@ main(int argc, char **argv)
/* Locate the configuration file. */
if (cfg_file == NULL) {
- home = getenv("HOME");
- if (home == NULL || *home == '\0') {
- pw = getpwuid(getuid());
- if (pw != NULL)
- home = pw->pw_dir;
- else
- home = NULL;
- }
+ home = find_home();
if (home != NULL) {
xasprintf(&cfg_file, "%s/.tmux.conf", home);
if (access(cfg_file, R_OK) != 0 && errno == ENOENT) {