mirror of
https://github.com/status-im/realm-js.git
synced 2025-01-11 14:54:33 +00:00
Merge pull request #150 from realm/al-os-feedback
Changes being made in response to feedback on the object store branch.
This commit is contained in:
commit
9f995d492b
@ -38,7 +38,7 @@ let propTypes = {};
|
|||||||
'LIST',
|
'LIST',
|
||||||
].forEach(function(type) {
|
].forEach(function(type) {
|
||||||
Object.defineProperty(propTypes, type, {
|
Object.defineProperty(propTypes, type, {
|
||||||
value: 'PropTypes' + type,
|
value: type.toLowerCase(),
|
||||||
enumerable: true,
|
enumerable: true,
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -10,24 +10,10 @@
|
|||||||
using RJSAccessor = realm::NativeAccessor<JSValueRef, JSContextRef>;
|
using RJSAccessor = realm::NativeAccessor<JSValueRef, JSContextRef>;
|
||||||
using namespace realm;
|
using namespace realm;
|
||||||
|
|
||||||
static inline List * RJSVerifiedList(JSObjectRef object) {
|
|
||||||
List *list = RJSGetInternal<List *>(object);
|
|
||||||
list->verify_attached();
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline List * RJSVerifiedMutableList(JSObjectRef object) {
|
|
||||||
List *list = RJSVerifiedList(object);
|
|
||||||
if (!list->realm()->is_in_transaction()) {
|
|
||||||
throw std::runtime_error("Can only mutate lists within a transaction.");
|
|
||||||
}
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
JSValueRef ListGetProperty(JSContextRef ctx, JSObjectRef object, JSStringRef propertyName, JSValueRef* jsException) {
|
JSValueRef ListGetProperty(JSContextRef ctx, JSObjectRef object, JSStringRef propertyName, JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
// index subscripting
|
// index subscripting
|
||||||
List *list = RJSVerifiedList(object);
|
List *list = RJSGetInternal<List *>(object);
|
||||||
size_t size = list->size();
|
size_t size = list->size();
|
||||||
|
|
||||||
std::string indexStr = RJSStringForJSString(propertyName);
|
std::string indexStr = RJSStringForJSString(propertyName);
|
||||||
@ -55,13 +41,13 @@ JSValueRef ListGetProperty(JSContextRef ctx, JSObjectRef object, JSStringRef pro
|
|||||||
|
|
||||||
bool ListSetProperty(JSContextRef ctx, JSObjectRef object, JSStringRef propertyName, JSValueRef value, JSValueRef* jsException) {
|
bool ListSetProperty(JSContextRef ctx, JSObjectRef object, JSStringRef propertyName, JSValueRef value, JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
List *list = RJSVerifiedMutableList(object);
|
List *list = RJSGetInternal<List *>(object);
|
||||||
std::string indexStr = RJSStringForJSString(propertyName);
|
std::string indexStr = RJSStringForJSString(propertyName);
|
||||||
if (indexStr == "length") {
|
if (indexStr == "length") {
|
||||||
throw std::runtime_error("The 'length' property is readonly.");
|
throw std::runtime_error("The 'length' property is readonly.");
|
||||||
}
|
}
|
||||||
|
|
||||||
list->set(RJSValidatedPositiveIndex(indexStr), RJSAccessor::to_object_index(ctx, list->realm(), const_cast<JSValueRef &>(value), list->object_schema.name, false));
|
list->set(ctx, value, RJSValidatedPositiveIndex(indexStr));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
catch (std::invalid_argument &exp) {
|
catch (std::invalid_argument &exp) {
|
||||||
@ -77,7 +63,7 @@ bool ListSetProperty(JSContextRef ctx, JSObjectRef object, JSStringRef propertyN
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ListPropertyNames(JSContextRef ctx, JSObjectRef object, JSPropertyNameAccumulatorRef propertyNames) {
|
void ListPropertyNames(JSContextRef ctx, JSObjectRef object, JSPropertyNameAccumulatorRef propertyNames) {
|
||||||
List *list = RJSVerifiedList(object);
|
List *list = RJSGetInternal<List *>(object);
|
||||||
size_t size = list->size();
|
size_t size = list->size();
|
||||||
|
|
||||||
char str[32];
|
char str[32];
|
||||||
@ -91,12 +77,12 @@ void ListPropertyNames(JSContextRef ctx, JSObjectRef object, JSPropertyNameAccum
|
|||||||
|
|
||||||
JSValueRef ListPush(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
JSValueRef ListPush(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
List *array = RJSVerifiedMutableList(thisObject);
|
List *list = RJSGetInternal<List *>(thisObject);
|
||||||
RJSValidateArgumentCountIsAtLeast(argumentCount, 1);
|
RJSValidateArgumentCountIsAtLeast(argumentCount, 1);
|
||||||
for (size_t i = 0; i < argumentCount; i++) {
|
for (size_t i = 0; i < argumentCount; i++) {
|
||||||
array->link_view()->add(RJSAccessor::to_object_index(ctx, array->realm(), const_cast<JSValueRef &>(arguments[i]), array->object_schema.name, false));
|
list->add(ctx, arguments[i]);
|
||||||
}
|
}
|
||||||
return JSValueMakeNumber(ctx, array->link_view()->size());
|
return JSValueMakeNumber(ctx, list->size());
|
||||||
}
|
}
|
||||||
catch (std::exception &exp) {
|
catch (std::exception &exp) {
|
||||||
if (jsException) {
|
if (jsException) {
|
||||||
@ -108,16 +94,17 @@ JSValueRef ListPush(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObje
|
|||||||
|
|
||||||
JSValueRef ListPop(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
JSValueRef ListPop(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
List *list = RJSVerifiedMutableList(thisObject);
|
List *list = RJSGetInternal<List *>(thisObject);
|
||||||
RJSValidateArgumentCount(argumentCount, 0);
|
RJSValidateArgumentCount(argumentCount, 0);
|
||||||
|
|
||||||
size_t size = list->size();
|
size_t size = list->size();
|
||||||
if (size == 0) {
|
if (size == 0) {
|
||||||
|
list->verify_in_tranaction();
|
||||||
return JSValueMakeUndefined(ctx);
|
return JSValueMakeUndefined(ctx);
|
||||||
}
|
}
|
||||||
size_t index = size - 1;
|
size_t index = size - 1;
|
||||||
JSValueRef obj = RJSObjectCreate(ctx, Object(list->realm(), list->object_schema, list->get(index)));
|
JSValueRef obj = RJSObjectCreate(ctx, Object(list->realm(), list->object_schema, list->get(index)));
|
||||||
list->link_view()->remove(index);
|
list->remove(index);
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
catch (std::exception &exp) {
|
catch (std::exception &exp) {
|
||||||
@ -130,12 +117,12 @@ JSValueRef ListPop(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObjec
|
|||||||
|
|
||||||
JSValueRef ListUnshift(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
JSValueRef ListUnshift(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
List *array = RJSVerifiedMutableList(thisObject);
|
List *list = RJSGetInternal<List *>(thisObject);
|
||||||
RJSValidateArgumentCountIsAtLeast(argumentCount, 1);
|
RJSValidateArgumentCountIsAtLeast(argumentCount, 1);
|
||||||
for (size_t i = 0; i < argumentCount; i++) {
|
for (size_t i = 0; i < argumentCount; i++) {
|
||||||
array->link_view()->insert(i, RJSAccessor::to_object_index(ctx, array->realm(), const_cast<JSValueRef &>(arguments[i]), array->object_schema.name, false));
|
list->insert(ctx, arguments[i], i);
|
||||||
}
|
}
|
||||||
return JSValueMakeNumber(ctx, array->link_view()->size());
|
return JSValueMakeNumber(ctx, list->size());
|
||||||
}
|
}
|
||||||
catch (std::exception &exp) {
|
catch (std::exception &exp) {
|
||||||
if (jsException) {
|
if (jsException) {
|
||||||
@ -147,13 +134,14 @@ JSValueRef ListUnshift(JSContextRef ctx, JSObjectRef function, JSObjectRef thisO
|
|||||||
|
|
||||||
JSValueRef ListShift(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
JSValueRef ListShift(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
List *list = RJSVerifiedMutableList(thisObject);
|
List *list = RJSGetInternal<List *>(thisObject);
|
||||||
RJSValidateArgumentCount(argumentCount, 0);
|
RJSValidateArgumentCount(argumentCount, 0);
|
||||||
if (list->size() == 0) {
|
if (list->size() == 0) {
|
||||||
|
list->verify_in_tranaction();
|
||||||
return JSValueMakeUndefined(ctx);
|
return JSValueMakeUndefined(ctx);
|
||||||
}
|
}
|
||||||
JSValueRef obj = RJSObjectCreate(ctx, Object(list->realm(), list->object_schema, list->get(0)));
|
JSValueRef obj = RJSObjectCreate(ctx, Object(list->realm(), list->object_schema, list->get(0)));
|
||||||
list->link_view()->remove(0);
|
list->remove(0);
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
catch (std::exception &exp) {
|
catch (std::exception &exp) {
|
||||||
@ -166,7 +154,7 @@ JSValueRef ListShift(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObj
|
|||||||
|
|
||||||
JSValueRef ListSplice(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
JSValueRef ListSplice(JSContextRef ctx, JSObjectRef function, JSObjectRef thisObject, size_t argumentCount, const JSValueRef arguments[], JSValueRef* jsException) {
|
||||||
try {
|
try {
|
||||||
List *list = RJSVerifiedMutableList(thisObject);
|
List *list = RJSGetInternal<List *>(thisObject);
|
||||||
size_t size = list->size();
|
size_t size = list->size();
|
||||||
|
|
||||||
RJSValidateArgumentCountIsAtLeast(argumentCount, 2);
|
RJSValidateArgumentCountIsAtLeast(argumentCount, 2);
|
||||||
@ -181,10 +169,10 @@ JSValueRef ListSplice(JSContextRef ctx, JSObjectRef function, JSObjectRef thisOb
|
|||||||
std::vector<JSObjectRef> removedObjects(remove);
|
std::vector<JSObjectRef> removedObjects(remove);
|
||||||
for (size_t i = 0; i < remove; i++) {
|
for (size_t i = 0; i < remove; i++) {
|
||||||
removedObjects[i] = RJSObjectCreate(ctx, Object(list->realm(), list->object_schema, list->get(index)));
|
removedObjects[i] = RJSObjectCreate(ctx, Object(list->realm(), list->object_schema, list->get(index)));
|
||||||
list->link_view()->remove(index);
|
list->remove(index);
|
||||||
}
|
}
|
||||||
for (size_t i = 2; i < argumentCount; i++) {
|
for (size_t i = 2; i < argumentCount; i++) {
|
||||||
list->link_view()->insert(index + i - 2, RJSAccessor::to_object_index(ctx, list->realm(), const_cast<JSValueRef &>(arguments[i]), list->object_schema.name, false));
|
list->insert(ctx, arguments[i], index + i - 2);
|
||||||
}
|
}
|
||||||
return JSObjectMakeArray(ctx, remove, removedObjects.data(), jsException);
|
return JSObjectMakeArray(ctx, remove, removedObjects.data(), jsException);
|
||||||
}
|
}
|
||||||
|
@ -50,35 +50,35 @@ static inline Property RJSParseProperty(JSContextRef ctx, JSObjectRef propertyOb
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string type = RJSValidatedStringProperty(ctx, propertyObject, typeString);
|
std::string type = RJSValidatedStringProperty(ctx, propertyObject, typeString);
|
||||||
if (type == "PropTypesBOOL") {
|
if (type == "bool") {
|
||||||
prop.type = PropertyTypeBool;
|
prop.type = PropertyTypeBool;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesINT") {
|
else if (type == "int") {
|
||||||
prop.type = PropertyTypeInt;
|
prop.type = PropertyTypeInt;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesFLOAT") {
|
else if (type == "float") {
|
||||||
prop.type = PropertyTypeFloat;
|
prop.type = PropertyTypeFloat;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesDOUBLE") {
|
else if (type == "double") {
|
||||||
prop.type = PropertyTypeDouble;
|
prop.type = PropertyTypeDouble;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesSTRING") {
|
else if (type == "string") {
|
||||||
prop.type = PropertyTypeString;
|
prop.type = PropertyTypeString;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesDATE") {
|
else if (type == "date") {
|
||||||
prop.type = PropertyTypeDate;
|
prop.type = PropertyTypeDate;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesDATA") {
|
else if (type == "data") {
|
||||||
prop.type = PropertyTypeData;
|
prop.type = PropertyTypeData;
|
||||||
}
|
}
|
||||||
else if (type == "PropTypesLIST") {
|
else if (type == "list") {
|
||||||
prop.type = PropertyTypeArray;
|
prop.type = PropertyTypeArray;
|
||||||
prop.object_type = RJSValidatedStringProperty(ctx, propertyObject, objectTypeString);
|
prop.object_type = RJSValidatedStringProperty(ctx, propertyObject, objectTypeString);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
prop.type = PropertyTypeObject;
|
prop.type = PropertyTypeObject;
|
||||||
prop.is_nullable = true;
|
prop.is_nullable = true;
|
||||||
prop.object_type = type == "PropTypesOBJECT" ? RJSValidatedStringProperty(ctx, propertyObject, objectTypeString) : type;
|
prop.object_type = type == "object" ? RJSValidatedStringProperty(ctx, propertyObject, objectTypeString) : type;
|
||||||
}
|
}
|
||||||
return prop;
|
return prop;
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,6 @@ JSClassRef RJSCreateWrapperClass(const char * name, JSObjectGetPropertyCallback
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string RJSTypeGet(realm::PropertyType propertyType);
|
std::string RJSTypeGet(realm::PropertyType propertyType);
|
||||||
std::string RJSTypeGet(std::string typeString);
|
|
||||||
|
|
||||||
std::string RJSStringForJSString(JSStringRef jsString);
|
std::string RJSStringForJSString(JSStringRef jsString);
|
||||||
std::string RJSStringForValue(JSContextRef ctx, JSValueRef value);
|
std::string RJSStringForValue(JSContextRef ctx, JSValueRef value);
|
||||||
|
@ -25,23 +25,19 @@ JSValueRef RJSMakeError(JSContextRef ctx, const std::string &message) {
|
|||||||
|
|
||||||
std::string RJSTypeGet(PropertyType propertyType) {
|
std::string RJSTypeGet(PropertyType propertyType) {
|
||||||
switch (propertyType) {
|
switch (propertyType) {
|
||||||
case PropertyTypeBool: return RJSTypeGet("BOOL");
|
case PropertyTypeBool: return "bool";
|
||||||
case PropertyTypeInt: return RJSTypeGet("INT");
|
case PropertyTypeInt: return "int";
|
||||||
case PropertyTypeFloat: return RJSTypeGet("FLOAT");
|
case PropertyTypeFloat: return "float";
|
||||||
case PropertyTypeDouble:return RJSTypeGet("DOUBLE");
|
case PropertyTypeDouble:return "double";
|
||||||
case PropertyTypeString:return RJSTypeGet("STRING");
|
case PropertyTypeString:return "string";
|
||||||
case PropertyTypeDate: return RJSTypeGet("DATE");
|
case PropertyTypeDate: return "date";
|
||||||
case PropertyTypeData: return RJSTypeGet("DATA");
|
case PropertyTypeData: return "data";
|
||||||
case PropertyTypeObject:return RJSTypeGet("OBJECT");
|
case PropertyTypeObject:return "object";
|
||||||
case PropertyTypeArray: return RJSTypeGet("LIST");
|
case PropertyTypeArray: return "list";
|
||||||
default: return nullptr;
|
default: return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string RJSTypeGet(std::string propertyTypeString) {
|
|
||||||
return "PropTypes" + propertyTypeString;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string RJSStringForJSString(JSStringRef jsString) {
|
std::string RJSStringForJSString(JSStringRef jsString) {
|
||||||
std::string str;
|
std::string str;
|
||||||
size_t maxSize = JSStringGetMaximumUTF8CStringSize(jsString);
|
size_t maxSize = JSStringGetMaximumUTF8CStringSize(jsString);
|
||||||
|
@ -9,9 +9,12 @@
|
|||||||
#import "RJSSchema.hpp"
|
#import "RJSSchema.hpp"
|
||||||
|
|
||||||
#include "shared_realm.hpp"
|
#include "shared_realm.hpp"
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
JSValueRef RJSTypeGet(JSContextRef ctx, JSObjectRef object, JSStringRef propertyName, JSValueRef* exception) {
|
JSValueRef RJSTypeGet(JSContextRef ctx, JSObjectRef object, JSStringRef propertyName, JSValueRef* exception) {
|
||||||
return RJSValueForString(ctx, RJSTypeGet(RJSStringForJSString(propertyName)));
|
std::string str = RJSStringForJSString(propertyName);
|
||||||
|
std::transform(str.begin(), str.end(), str.begin(), ::tolower);
|
||||||
|
return RJSValueForString(ctx, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
JSClassRef RJSRealmTypeClass() {
|
JSClassRef RJSRealmTypeClass() {
|
||||||
|
@ -228,7 +228,7 @@ json RPCServer::serialize_json_value(JSValueRef value) {
|
|||||||
return {
|
return {
|
||||||
{"type", RJSTypeGet(realm::PropertyTypeArray)},
|
{"type", RJSTypeGet(realm::PropertyTypeArray)},
|
||||||
{"id", store_object(js_object)},
|
{"id", store_object(js_object)},
|
||||||
{"size", list->link_view()->size()},
|
{"size", list->size()},
|
||||||
{"schema", serialize_object_schema(list->object_schema)}
|
{"schema", serialize_object_schema(list->object_schema)}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,20 @@
|
|||||||
/* Copyright 2015 Realm Inc - All Rights Reserved
|
////////////////////////////////////////////////////////////////////////////
|
||||||
* Proprietary and Confidential
|
//
|
||||||
*/
|
// Copyright 2015 Realm Inc.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
#include "list.hpp"
|
#include "list.hpp"
|
||||||
#import <stdexcept>
|
#import <stdexcept>
|
||||||
@ -8,22 +22,46 @@
|
|||||||
using namespace realm;
|
using namespace realm;
|
||||||
|
|
||||||
size_t List::size() {
|
size_t List::size() {
|
||||||
|
verify_attached();
|
||||||
return m_link_view->size();
|
return m_link_view->size();
|
||||||
}
|
}
|
||||||
|
|
||||||
Row List::get(std::size_t row_ndx) {
|
Row List::get(size_t row_ndx) {
|
||||||
|
verify_attached();
|
||||||
verify_valid_row(row_ndx);
|
verify_valid_row(row_ndx);
|
||||||
return m_link_view->get(row_ndx);
|
return m_link_view->get(row_ndx);
|
||||||
}
|
}
|
||||||
|
|
||||||
void List::set(std::size_t row_ndx, std::size_t target_row_ndx) {
|
void List::set(size_t row_ndx, size_t target_row_ndx) {
|
||||||
|
verify_attached();
|
||||||
|
verify_in_tranaction();
|
||||||
verify_valid_row(row_ndx);
|
verify_valid_row(row_ndx);
|
||||||
m_link_view->set(row_ndx, target_row_ndx);
|
m_link_view->set(row_ndx, target_row_ndx);
|
||||||
}
|
}
|
||||||
|
|
||||||
void List::verify_valid_row(std::size_t row_ndx) {
|
void List::add(size_t target_row_ndx) {
|
||||||
|
verify_attached();
|
||||||
|
verify_in_tranaction();
|
||||||
|
m_link_view->add(target_row_ndx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void List::insert(size_t row_ndx, size_t target_row_ndx) {
|
||||||
|
verify_attached();
|
||||||
|
verify_in_tranaction();
|
||||||
|
verify_valid_row(row_ndx, true);
|
||||||
|
m_link_view->insert(row_ndx, target_row_ndx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void List::remove(size_t row_ndx) {
|
||||||
|
verify_attached();
|
||||||
|
verify_in_tranaction();
|
||||||
|
verify_valid_row(row_ndx);
|
||||||
|
m_link_view->remove(row_ndx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void List::verify_valid_row(size_t row_ndx, bool insertion) {
|
||||||
size_t size = m_link_view->size();
|
size_t size = m_link_view->size();
|
||||||
if (row_ndx >= size) {
|
if (row_ndx > size || (!insertion && row_ndx == size)) {
|
||||||
throw std::out_of_range(std::string("Index ") + std::to_string(row_ndx) + " is outside of range 0..." + std::to_string(size) + ".");
|
throw std::out_of_range(std::string("Index ") + std::to_string(row_ndx) + " is outside of range 0..." + std::to_string(size) + ".");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -34,3 +72,9 @@ void List::verify_attached() {
|
|||||||
}
|
}
|
||||||
m_link_view->sync_if_needed();
|
m_link_view->sync_if_needed();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void List::verify_in_tranaction() {
|
||||||
|
if (!m_realm->is_in_transaction()) {
|
||||||
|
throw std::runtime_error("Can only mutate a list within a transaction.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,6 +1,20 @@
|
|||||||
/* Copyright 2015 Realm Inc - All Rights Reserved
|
////////////////////////////////////////////////////////////////////////////
|
||||||
* Proprietary and Confidential
|
//
|
||||||
*/
|
// Copyright 2015 Realm Inc.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
#ifndef REALM_LIST_HPP
|
#ifndef REALM_LIST_HPP
|
||||||
#define REALM_LIST_HPP
|
#define REALM_LIST_HPP
|
||||||
@ -15,14 +29,27 @@ namespace realm {
|
|||||||
|
|
||||||
const ObjectSchema &object_schema;
|
const ObjectSchema &object_schema;
|
||||||
SharedRealm realm() { return m_realm; }
|
SharedRealm realm() { return m_realm; }
|
||||||
LinkViewRef link_view() { return m_link_view; }
|
|
||||||
|
|
||||||
size_t size();
|
size_t size();
|
||||||
Row get(std::size_t row_ndx);
|
Row get(size_t row_ndx);
|
||||||
void set(std::size_t row_ndx, std::size_t target_row_ndx);
|
void set(size_t row_ndx, size_t target_row_ndx);
|
||||||
|
|
||||||
void verify_valid_row(std::size_t row_ndx);
|
void add(size_t target_row_ndx);
|
||||||
|
void remove(size_t list_ndx);
|
||||||
|
void insert(size_t list_ndx, size_t target_row_ndx);
|
||||||
|
|
||||||
|
template<typename ValueType, typename ContextType>
|
||||||
|
void add(ContextType ctx, ValueType value);
|
||||||
|
|
||||||
|
template<typename ValueType, typename ContextType>
|
||||||
|
void insert(ContextType ctx, ValueType value, size_t list_ndx);
|
||||||
|
|
||||||
|
template<typename ValueType, typename ContextType>
|
||||||
|
void set(ContextType ctx, ValueType value, size_t list_ndx);
|
||||||
|
|
||||||
|
void verify_valid_row(size_t row_ndx, bool insertion = false);
|
||||||
void verify_attached();
|
void verify_attached();
|
||||||
|
void verify_in_tranaction();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SharedRealm m_realm;
|
SharedRealm m_realm;
|
||||||
@ -30,5 +57,4 @@ namespace realm {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif /* REALM_LIST_HPP */
|
#endif /* REALM_LIST_HPP */
|
||||||
|
@ -297,6 +297,27 @@ namespace realm {
|
|||||||
}
|
}
|
||||||
return object;
|
return object;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// List implementation
|
||||||
|
//
|
||||||
|
template<typename ValueType, typename ContextType>
|
||||||
|
void List::add(ContextType ctx, ValueType value)
|
||||||
|
{
|
||||||
|
add(NativeAccessor<ValueType, ContextType>::to_object_index(ctx, m_realm, value, object_schema.name, false));
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename ValueType, typename ContextType>
|
||||||
|
void List::insert(ContextType ctx, ValueType value, size_t list_ndx)
|
||||||
|
{
|
||||||
|
insert(list_ndx, NativeAccessor<ValueType, ContextType>::to_object_index(ctx, m_realm, value, object_schema.name, false));
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename ValueType, typename ContextType>
|
||||||
|
void List::set(ContextType ctx, ValueType value, size_t list_ndx)
|
||||||
|
{
|
||||||
|
set(list_ndx, NativeAccessor<ValueType, ContextType>::to_object_index(ctx, m_realm, value, object_schema.name, false));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* defined(REALM_OBJECT_ACCESSOR_HPP) */
|
#endif /* defined(REALM_OBJECT_ACCESSOR_HPP) */
|
||||||
|
@ -382,10 +382,6 @@ void Realm::close()
|
|||||||
m_notifier->remove_realm(this);
|
m_notifier->remove_realm(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_group) {
|
|
||||||
m_shared_group->end_read();
|
|
||||||
}
|
|
||||||
|
|
||||||
m_group = nullptr;
|
m_group = nullptr;
|
||||||
m_shared_group = nullptr;
|
m_shared_group = nullptr;
|
||||||
m_history = nullptr;
|
m_history = nullptr;
|
||||||
|
@ -197,12 +197,6 @@ namespace realm {
|
|||||||
public:
|
public:
|
||||||
UnitializedRealmException(std::string message) : std::runtime_error(message) {}
|
UnitializedRealmException(std::string message) : std::runtime_error(message) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
class ClosedRealmException : public std::runtime_error
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
ClosedRealmException(std::string message) : std::runtime_error(message) {}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* defined(REALM_REALM_HPP) */
|
#endif /* defined(REALM_REALM_HPP) */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user