Fix property type conversions to ObjectStore types

This commit is contained in:
Thomas Goyne 2017-08-30 12:48:07 -07:00
parent 4a926278ad
commit e0a439e6eb

View File

@ -83,19 +83,16 @@ Property Schema<T>::parse_property(ContextType ctx, ValueType attributes, std::s
ObjectType property_object = {}; ObjectType property_object = {};
std::string type; std::string type;
using realm::PropertyType;
PropertyType is_optional = PropertyType::Required;
if (Value::is_object(ctx, attributes)) { if (Value::is_object(ctx, attributes)) {
property_object = Value::validated_to_object(ctx, attributes); property_object = Value::validated_to_object(ctx, attributes);
type = Object::validated_get_string(ctx, property_object, type_string); type = Object::validated_get_string(ctx, property_object, type_string);
ValueType optional_value = Object::get_property(ctx, property_object, optional_string); ValueType optional_value = Object::get_property(ctx, property_object, optional_string);
if (!Value::is_undefined(ctx, optional_value)) { if (!Value::is_undefined(ctx, optional_value) && Value::validated_to_boolean(ctx, optional_value, "optional")) {
auto isNullableValue = Value::validated_to_boolean(ctx, optional_value, "optional"); is_optional = PropertyType::Nullable;
if (isNullableValue) {
prop.type |= realm::PropertyType::Nullable;
}
else {
prop.type &= ~realm::PropertyType::Nullable;
}
} }
} }
else { else {
@ -103,35 +100,35 @@ Property Schema<T>::parse_property(ContextType ctx, ValueType attributes, std::s
} }
if (type == "bool") { if (type == "bool") {
prop.type = realm::PropertyType::Bool; prop.type = PropertyType::Bool | is_optional;
} }
else if (type == "int") { else if (type == "int") {
prop.type = realm::PropertyType::Int; prop.type = PropertyType::Int | is_optional;
} }
else if (type == "float") { else if (type == "float") {
prop.type = realm::PropertyType::Float; prop.type = PropertyType::Float | is_optional;
} }
else if (type == "double") { else if (type == "double") {
prop.type = realm::PropertyType::Double; prop.type = PropertyType::Double | is_optional;
} }
else if (type == "string") { else if (type == "string") {
prop.type = realm::PropertyType::String; prop.type = PropertyType::String | is_optional;
} }
else if (type == "date") { else if (type == "date") {
prop.type = realm::PropertyType::Date; prop.type = PropertyType::Date | is_optional;
} }
else if (type == "data") { else if (type == "data") {
prop.type = realm::PropertyType::Data; prop.type = PropertyType::Data | is_optional;
} }
else if (type == "list") { else if (type == "list") {
if (!Value::is_valid(property_object)) { if (!Value::is_valid(property_object)) {
throw std::runtime_error("List property must specify 'objectType'"); throw std::runtime_error("List property must specify 'objectType'");
} }
prop.type = realm::PropertyType::Array; prop.type = PropertyType::Object | PropertyType::Array;
prop.object_type = Object::validated_get_string(ctx, property_object, object_type_string); prop.object_type = Object::validated_get_string(ctx, property_object, object_type_string);
} }
else if (type == "linkingObjects") { else if (type == "linkingObjects") {
prop.type = realm::PropertyType::LinkingObjects; prop.type = PropertyType::LinkingObjects | PropertyType::Array;
if (!Value::is_valid(property_object)) { if (!Value::is_valid(property_object)) {
throw std::runtime_error("Object property must specify 'objectType'"); throw std::runtime_error("Object property must specify 'objectType'");
@ -140,8 +137,7 @@ Property Schema<T>::parse_property(ContextType ctx, ValueType attributes, std::s
prop.link_origin_property_name = Object::validated_get_string(ctx, property_object, property_string); prop.link_origin_property_name = Object::validated_get_string(ctx, property_object, property_string);
} }
else if (type == "object") { else if (type == "object") {
prop.type = realm::PropertyType::Object; prop.type = PropertyType::Object | PropertyType::Nullable;
prop.type |= realm::PropertyType::Nullable;
if (!Value::is_valid(property_object)) { if (!Value::is_valid(property_object)) {
throw std::runtime_error("Object property must specify 'objectType'"); throw std::runtime_error("Object property must specify 'objectType'");
@ -150,8 +146,7 @@ Property Schema<T>::parse_property(ContextType ctx, ValueType attributes, std::s
} }
else { else {
// The type could be the name of another object type in the same schema. // The type could be the name of another object type in the same schema.
prop.type = realm::PropertyType::Object; prop.type = PropertyType::Object | PropertyType::Nullable;
prop.type |= realm::PropertyType::Nullable;
prop.object_type = type; prop.object_type = type;
} }
@ -296,7 +291,7 @@ typename T::Object Schema<T>::object_for_property(ContextType ctx, const Propert
Object::set_property(ctx, object, name_string, Value::from_string(ctx, property.name)); Object::set_property(ctx, object, name_string, Value::from_string(ctx, property.name));
static const String type_string = "type"; static const String type_string = "type";
const std::string type = property.type != realm::PropertyType::Array ? string_for_property_type(property.type) : "list"; const std::string type = is_array(property.type) ? "list" : string_for_property_type(property.type);
Object::set_property(ctx, object, type_string, Value::from_string(ctx, type)); Object::set_property(ctx, object, type_string, Value::from_string(ctx, type));
static const String object_type_string = "objectType"; static const String object_type_string = "objectType";