summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWanlong Gao <gaowanlong@cn.fujitsu.com>2012-01-09 15:22:42 +0800
committerRichard W.M. Jones <rjones@redhat.com>2012-01-09 10:23:18 +0000
commit6f6485ec34f29401bbab65dd4275a3b564ed11b3 (patch)
tree8b268231923caf7ffc9f70c0cde70f8bf6a8e948
parentda13c1c0e6980f4838090be9e775b4d5c35662b7 (diff)
downloadlibguestfs-6f6485ec34f29401bbab65dd4275a3b564ed11b3.tar.gz
libguestfs-6f6485ec34f29401bbab65dd4275a3b564ed11b3.tar.xz
libguestfs-6f6485ec34f29401bbab65dd4275a3b564ed11b3.zip
launch: add a goto label when add_drive error
Code cleanup. Add a goto label to simplify the code. Signed-off-by: Wanlong Gao <gaowanlong@cn.fujitsu.com>
-rw-r--r--src/launch.c29
1 files changed, 11 insertions, 18 deletions
diff --git a/src/launch.c b/src/launch.c
index ca89b638..588ace11 100644
--- a/src/launch.c
+++ b/src/launch.c
@@ -304,18 +304,12 @@ guestfs__add_drive_opts (guestfs_h *g, const char *filename,
if (format && !valid_format_iface (format)) {
error (g, _("%s parameter is empty or contains disallowed characters"),
"format");
- free (format);
- free (iface);
- free (name);
- return -1;
+ goto err_out;
}
if (!valid_format_iface (iface)) {
error (g, _("%s parameter is empty or contains disallowed characters"),
"iface");
- free (format);
- free (iface);
- free (name);
- return -1;
+ goto err_out;
}
/* For writable files, see if we can use cache=off. This also
@@ -323,20 +317,13 @@ guestfs__add_drive_opts (guestfs_h *g, const char *filename,
* to do the check explicitly.
*/
use_cache_off = readonly ? 0 : test_cache_off (g, filename);
- if (use_cache_off == -1) {
- free (format);
- free (iface);
- free (name);
- return -1;
- }
+ if (use_cache_off == -1)
+ goto err_out;
if (readonly) {
if (access (filename, R_OK) == -1) {
perrorf (g, "%s", filename);
- free (format);
- free (iface);
- free (name);
- return -1;
+ goto err_out;
}
}
@@ -353,6 +340,12 @@ guestfs__add_drive_opts (guestfs_h *g, const char *filename,
(*i)->use_cache_off = use_cache_off;
return 0;
+
+err_out:
+ free (format);
+ free (iface);
+ free (name);
+ return -1;
}
int