From 7f69c4a541318610bef76295163cf4d7907d2339 Mon Sep 17 00:00:00 2001 From: Laszlo Ersek Date: Wed, 31 Jul 2013 14:03:25 +0200 Subject: [PATCH 04/28] qga: create state directory on win32 RH-Author: Laszlo Ersek Message-id: <1375279407-13573-5-git-send-email-lersek@redhat.com> Patchwork-id: 52867 O-Subject: [RHEL-7 qemu-kvm PATCH 4/6] qga: create state directory on win32 Bugzilla: 964304 RH-Acked-by: Michal Novotny RH-Acked-by: Luiz Capitulino RH-Acked-by: Paolo Bonzini On Win32 the local state directory is application specific and users might expect qemu-ga to create it automatically. Signed-off-by: Laszlo Ersek Signed-off-by: Michael Roth (cherry picked from commit bf12c1fa8c78e3c667f2fe2ecc656f4f3cfb914e) --- qga/main.c | 14 ++++++++++++++ 1 files changed, 14 insertions(+), 0 deletions(-) Signed-off-by: Miroslav Rezanina --- qga/main.c | 14 ++++++++++++++ 1 files changed, 14 insertions(+), 0 deletions(-) diff --git a/qga/main.c b/qga/main.c index 050b968..e49a6dd 100644 --- a/qga/main.c +++ b/qga/main.c @@ -1042,6 +1042,20 @@ int main(int argc, char **argv) } } +#ifdef _WIN32 + /* On win32 the state directory is application specific (be it the default + * or a user override). We got past the command line parsing; let's create + * the directory (with any intermediate directories). If we run into an + * error later on, we won't try to clean up the directory, it is considered + * persistent. + */ + if (g_mkdir_with_parents(state_dir, S_IRWXU) == -1) { + g_critical("unable to create (an ancestor of) the state directory" + " '%s': %s", state_dir, strerror(errno)); + return EXIT_FAILURE; + } +#endif + s = g_malloc0(sizeof(GAState)); s->log_level = log_level; s->log_file = stderr; -- 1.7.1