ESX: Fallback to the preliminary name if the datastore cannot be found.

This allows to use domain-xml-from-native with VMX files that reference
unavailable datastores.

* src/esx/esx_vmx.c: fallback to the preliminary name if the datastore
  cannot be found
This commit is contained in:
Matthias Bolte 2009-10-17 01:42:05 +02:00
parent fc8d199188
commit b7abcf9d71

View File

@ -606,34 +606,37 @@ esxVMX_AbsolutePathToDatastoreRelatedPath(virConnectPtr conn,
if (ctx != NULL) { if (ctx != NULL) {
if (esxVI_LookupDatastoreByName(conn, ctx, preliminaryDatastoreName, if (esxVI_LookupDatastoreByName(conn, ctx, preliminaryDatastoreName,
NULL, &datastore, NULL, &datastore,
esxVI_Occurence_RequiredItem) < 0) { esxVI_Occurence_OptionalItem) < 0) {
goto failure; goto failure;
} }
for (dynamicProperty = datastore->propSet; dynamicProperty != NULL; if (datastore != NULL) {
dynamicProperty = dynamicProperty->_next) { for (dynamicProperty = datastore->propSet; dynamicProperty != NULL;
if (STREQ(dynamicProperty->name, "summary.accessible")) { dynamicProperty = dynamicProperty->_next) {
/* Ignore it */ if (STREQ(dynamicProperty->name, "summary.accessible")) {
} else if (STREQ(dynamicProperty->name, "summary.name")) { /* Ignore it */
if (esxVI_AnyType_ExpectType(conn, dynamicProperty->val, } else if (STREQ(dynamicProperty->name, "summary.name")) {
esxVI_Type_String) < 0) { if (esxVI_AnyType_ExpectType(conn, dynamicProperty->val,
goto failure; esxVI_Type_String) < 0) {
} goto failure;
}
datastoreName = dynamicProperty->val->string; datastoreName = dynamicProperty->val->string;
break; break;
} else if (STREQ(dynamicProperty->name, "summary.url")) { } else if (STREQ(dynamicProperty->name, "summary.url")) {
/* Ignore it */ /* Ignore it */
} else { } else {
VIR_WARN("Unexpected '%s' property", dynamicProperty->name); VIR_WARN("Unexpected '%s' property", dynamicProperty->name);
}
} }
} }
if (datastoreName == NULL) { if (datastoreName == NULL) {
ESX_ERROR(conn, VIR_ERR_INTERNAL_ERROR, VIR_WARN("Could not retrieve datastore name for absolute "
"Could not retrieve datastore name for absolute path '%s'", "path '%s', falling back to preliminary name '%s'",
absolutePath); absolutePath, preliminaryDatastoreName);
goto failure;
datastoreName = preliminaryDatastoreName;
} }
} else { } else {
datastoreName = preliminaryDatastoreName; datastoreName = preliminaryDatastoreName;