vmdk: Clean up control flow in vmdk_parse_extents() a bit
Factor out loop stepping to turn a while-loop with goto into a for-loop with continue. Cc: Fam Zheng <famz@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Fam Zheng <famz@redhat.com> Message-Id: <1450452927-8346-18-git-send-email-armbru@redhat.com>
This commit is contained in:
parent
9af9e0fed7
commit
e4937694b6
28
block/vmdk.c
28
block/vmdk.c
@ -760,6 +760,17 @@ static int vmdk_open_sparse(BlockDriverState *bs, BdrvChild *file, int flags,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *next_line(const char *s)
|
||||||
|
{
|
||||||
|
while (*s) {
|
||||||
|
if (*s == '\n') {
|
||||||
|
return s + 1;
|
||||||
|
}
|
||||||
|
s++;
|
||||||
|
}
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
||||||
const char *desc_file_path, QDict *options,
|
const char *desc_file_path, QDict *options,
|
||||||
Error **errp)
|
Error **errp)
|
||||||
@ -769,7 +780,7 @@ static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
|||||||
char access[11];
|
char access[11];
|
||||||
char type[11];
|
char type[11];
|
||||||
char fname[512];
|
char fname[512];
|
||||||
const char *p = desc;
|
const char *p;
|
||||||
int64_t sectors = 0;
|
int64_t sectors = 0;
|
||||||
int64_t flat_offset;
|
int64_t flat_offset;
|
||||||
char *extent_path;
|
char *extent_path;
|
||||||
@ -779,7 +790,7 @@ static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
|||||||
char extent_opt_prefix[32];
|
char extent_opt_prefix[32];
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
|
|
||||||
while (*p) {
|
for (p = desc; *p; p = next_line(p)) {
|
||||||
/* parse extent line in one of below formats:
|
/* parse extent line in one of below formats:
|
||||||
*
|
*
|
||||||
* RW [size in sectors] FLAT "file-name.vmdk" OFFSET
|
* RW [size in sectors] FLAT "file-name.vmdk" OFFSET
|
||||||
@ -791,7 +802,7 @@ static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
|||||||
matches = sscanf(p, "%10s %" SCNd64 " %10s \"%511[^\n\r\"]\" %" SCNd64,
|
matches = sscanf(p, "%10s %" SCNd64 " %10s \"%511[^\n\r\"]\" %" SCNd64,
|
||||||
access, §ors, type, fname, &flat_offset);
|
access, §ors, type, fname, &flat_offset);
|
||||||
if (matches < 4 || strcmp(access, "RW")) {
|
if (matches < 4 || strcmp(access, "RW")) {
|
||||||
goto next_line;
|
continue;
|
||||||
} else if (!strcmp(type, "FLAT")) {
|
} else if (!strcmp(type, "FLAT")) {
|
||||||
if (matches != 5 || flat_offset < 0) {
|
if (matches != 5 || flat_offset < 0) {
|
||||||
error_setg(errp, "Invalid extent lines: \n%s", p);
|
error_setg(errp, "Invalid extent lines: \n%s", p);
|
||||||
@ -813,7 +824,7 @@ static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
|||||||
(strcmp(type, "FLAT") && strcmp(type, "SPARSE") &&
|
(strcmp(type, "FLAT") && strcmp(type, "SPARSE") &&
|
||||||
strcmp(type, "VMFS") && strcmp(type, "VMFSSPARSE")) ||
|
strcmp(type, "VMFS") && strcmp(type, "VMFSSPARSE")) ||
|
||||||
(strcmp(access, "RW"))) {
|
(strcmp(access, "RW"))) {
|
||||||
goto next_line;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!path_is_absolute(fname) && !path_has_protocol(fname) &&
|
if (!path_is_absolute(fname) && !path_has_protocol(fname) &&
|
||||||
@ -870,15 +881,6 @@ static int vmdk_parse_extents(const char *desc, BlockDriverState *bs,
|
|||||||
return -ENOTSUP;
|
return -ENOTSUP;
|
||||||
}
|
}
|
||||||
extent->type = g_strdup(type);
|
extent->type = g_strdup(type);
|
||||||
next_line:
|
|
||||||
/* move to next line */
|
|
||||||
while (*p) {
|
|
||||||
if (*p == '\n') {
|
|
||||||
p++;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
p++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user