diff options
author | Thomas Adam <thomas@xteddy.org> | 2017-02-14 20:01:12 +0000 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2017-02-14 20:01:12 +0000 |
commit | ba3c1534e08b495fc308ed0085148587e8ead3d0 (patch) | |
tree | a3161a2413826aeecaeca8b93b8abe7428163c6b /server-client.c | |
parent | 02e04477de73d01bb3ef12cb43a03cfc4c2e546c (diff) | |
parent | e340df2034c04591e3bbdcbcc22af1301cf74b09 (diff) | |
download | rtmux-ba3c1534e08b495fc308ed0085148587e8ead3d0.tar.gz rtmux-ba3c1534e08b495fc308ed0085148587e8ead3d0.tar.bz2 rtmux-ba3c1534e08b495fc308ed0085148587e8ead3d0.zip |
Merge branch 'obsd-master'
Diffstat (limited to 'server-client.c')
-rw-r--r-- | server-client.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/server-client.c b/server-client.c index 048a138b..1f64ac4a 100644 --- a/server-client.c +++ b/server-client.c @@ -1667,3 +1667,32 @@ server_client_add_message(struct client *c, const char *fmt, ...) free(msg); } } + +/* Get client working directory. */ +const char * +server_client_get_cwd(struct client *c) +{ + struct session *s; + + if (c != NULL && c->session == NULL && c->cwd != NULL) + return (c->cwd); + if (c != NULL && (s = c->session) != NULL && s->cwd != NULL) + return (s->cwd); + return ("."); +} + +/* Resolve an absolute path or relative to client working directory. */ +char * +server_client_get_path(struct client *c, const char *file) +{ + char *path, resolved[PATH_MAX]; + + if (*file == '/') + path = xstrdup(file); + else + xasprintf(&path, "%s/%s", server_client_get_cwd(c), file); + if (realpath(path, resolved) == NULL) + return (path); + free(path); + return (xstrdup(resolved)); +} |