Partition type strings that we hand out we should also be able to handle. I.e.

we need to parse the "Unrecognized Type ..." strings we produce for partition
type IDs we can't match to a name. This fixes the "Failed to prepare
modifications" error the userland tools would produce when a partition with
such a type was encountered.


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@31453 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2009-07-08 01:32:09 +00:00
parent f612278f55
commit f379415697

View File

@ -49,6 +49,9 @@ struct partition_type {
const char *name; const char *name;
}; };
static const char* const kUnrecognizedTypeString = "Unrecognized Type ";
static const size_t kUnrecognizedTypeStringLength = 18;
static const struct partition_type kPartitionTypes[] = { static const struct partition_type kPartitionTypes[] = {
// these entries must be sorted by type (currently not) // these entries must be sorted by type (currently not)
// TODO: Standardize naming. // TODO: Standardize naming.
@ -120,7 +123,7 @@ get_partition_type_string(uint8 type, char* buffer)
if (const char* typeString = partition_type_string(type)) if (const char* typeString = partition_type_string(type))
strcpy(buffer, typeString); strcpy(buffer, typeString);
else else
sprintf(buffer, "Unrecognized Type 0x%x", type); sprintf(buffer, "%s0x%x", kUnrecognizedTypeString, type);
} }
} }
@ -215,6 +218,18 @@ PartitionType::SetType(const char *typeName)
return fValid; return fValid;
} }
} }
// If this is an unrecognized type, parse the type number.
if (strncmp(typeName, kUnrecognizedTypeString,
kUnrecognizedTypeStringLength) == 0) {
long type = strtol(typeName + kUnrecognizedTypeStringLength, NULL, 0);
if (type != 0 && type <= 255) {
fType = type;
fValid = true;
return fValid;
}
}
fValid = false; fValid = false;
return fValid; return fValid;
} }