aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--vncviewer/vncviewer.cxx31
1 files changed, 25 insertions, 6 deletions
diff --git a/vncviewer/vncviewer.cxx b/vncviewer/vncviewer.cxx
index d9f85f5a..8a60c42b 100644
--- a/vncviewer/vncviewer.cxx
+++ b/vncviewer/vncviewer.cxx
@@ -531,28 +531,47 @@ migrateDeprecatedOptions()
static void
create_base_dirs()
{
- char *confdir = strdup(os::getvncconfigdir());
+ const char *dir;
+
+ dir = os::getvncconfigdir();
+ if (dir == NULL) {
+ vlog.error(_("Could not determine VNC config directory path"));
+ return;
+ }
+
#ifndef WIN32
- char *dotdir = strrchr(confdir, '.');
+ const char *dotdir = strrchr(dir, '.');
if (dotdir != NULL && strcmp(dotdir, ".vnc") == 0)
vlog.info(_("~/.vnc is deprecated, please consult 'man vncviewer' for paths to migrate to."));
#else
- char *vncdir = strrchr(confdir, '\\');
+ const char *vncdir = strrchr(dir, '\\');
if (vncdir != NULL && strcmp(vncdir, "vnc") == 0)
vlog.info(_("%%APPDATA%%\\vnc is deprecated, please switch to the %%APPDATA%%\\TigerVNC location."));
#endif
- if (os::mkdir_p(os::getvncconfigdir(), 0755) == -1) {
+ if (os::mkdir_p(dir, 0755) == -1) {
if (errno != EEXIST)
vlog.error(_("Could not create VNC config directory: %s"), strerror(errno));
}
- if (os::mkdir_p(os::getvncdatadir(), 0755) == -1) {
+ dir = os::getvncdatadir();
+ if (dir == NULL) {
+ vlog.error(_("Could not determine VNC data directory path"));
+ return;
+ }
+
+ if (os::mkdir_p(dir, 0755) == -1) {
if (errno != EEXIST)
vlog.error(_("Could not create VNC data directory: %s"), strerror(errno));
}
- if (os::mkdir_p(os::getvncstatedir(), 0755) == -1) {
+ dir = os::getvncstatedir();
+ if (dir == NULL) {
+ vlog.error(_("Could not determine VNC state directory path"));
+ return;
+ }
+
+ if (os::mkdir_p(dir, 0755) == -1) {
if (errno != EEXIST)
vlog.error(_("Could not create VNC state directory: %s"), strerror(errno));
}