mirror of
https://github.com/status-im/realm-js.git
synced 2025-01-11 14:54:33 +00:00
Make List and Results inherit from Collection
This will allow for easier type checking, documentation, etc.
This commit is contained in:
parent
900f0dbd80
commit
b5ce02c0ce
@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
### Enhancements
|
### Enhancements
|
||||||
* Support for encryption
|
* Support for encryption
|
||||||
|
* List and Results now inherit from Realm.Collection
|
||||||
* Add common Array methods to List and Results
|
* Add common Array methods to List and Results
|
||||||
* Accept constructor in create() and objects() methods
|
* Accept constructor in create() and objects() methods
|
||||||
* Support relative paths when opening realms
|
* Support relative paths when opening realms
|
||||||
|
@ -76,6 +76,8 @@
|
|||||||
F6BCCFE21C8380A400FE31AE /* lib in Resources */ = {isa = PBXBuildFile; fileRef = F6BCCFDF1C83809A00FE31AE /* lib */; };
|
F6BCCFE21C8380A400FE31AE /* lib in Resources */ = {isa = PBXBuildFile; fileRef = F6BCCFDF1C83809A00FE31AE /* lib */; };
|
||||||
F6C74DF01C732CC500C9DDCD /* RealmAnalytics.h in Headers */ = {isa = PBXBuildFile; fileRef = F6C74DEE1C732CC500C9DDCD /* RealmAnalytics.h */; };
|
F6C74DF01C732CC500C9DDCD /* RealmAnalytics.h in Headers */ = {isa = PBXBuildFile; fileRef = F6C74DEE1C732CC500C9DDCD /* RealmAnalytics.h */; };
|
||||||
F6C74DF11C732CC500C9DDCD /* RealmAnalytics.mm in Sources */ = {isa = PBXBuildFile; fileRef = F6C74DEF1C732CC500C9DDCD /* RealmAnalytics.mm */; };
|
F6C74DF11C732CC500C9DDCD /* RealmAnalytics.mm in Sources */ = {isa = PBXBuildFile; fileRef = F6C74DEF1C732CC500C9DDCD /* RealmAnalytics.mm */; };
|
||||||
|
F6CB31001C8EDDAB0070EF3F /* js_collection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = F6CB30FC1C8EDD760070EF3F /* js_collection.cpp */; };
|
||||||
|
F6CB31011C8EDDBB0070EF3F /* js_collection.hpp in Headers */ = {isa = PBXBuildFile; fileRef = F6CB30FD1C8EDD760070EF3F /* js_collection.hpp */; };
|
||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXContainerItemProxy section */
|
/* Begin PBXContainerItemProxy section */
|
||||||
@ -247,6 +249,8 @@
|
|||||||
F6C3FBBC1BF680EC00E6FFD4 /* json.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = json.hpp; sourceTree = "<group>"; };
|
F6C3FBBC1BF680EC00E6FFD4 /* json.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = json.hpp; sourceTree = "<group>"; };
|
||||||
F6C74DEE1C732CC500C9DDCD /* RealmAnalytics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = RealmAnalytics.h; path = "react-native/RealmAnalytics.h"; sourceTree = "<group>"; };
|
F6C74DEE1C732CC500C9DDCD /* RealmAnalytics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = RealmAnalytics.h; path = "react-native/RealmAnalytics.h"; sourceTree = "<group>"; };
|
||||||
F6C74DEF1C732CC500C9DDCD /* RealmAnalytics.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = RealmAnalytics.mm; path = "react-native/RealmAnalytics.mm"; sourceTree = "<group>"; };
|
F6C74DEF1C732CC500C9DDCD /* RealmAnalytics.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = RealmAnalytics.mm; path = "react-native/RealmAnalytics.mm"; sourceTree = "<group>"; };
|
||||||
|
F6CB30FC1C8EDD760070EF3F /* js_collection.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = js_collection.cpp; sourceTree = "<group>"; };
|
||||||
|
F6CB30FD1C8EDD760070EF3F /* js_collection.hpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.h; path = js_collection.hpp; sourceTree = "<group>"; };
|
||||||
/* End PBXFileReference section */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
@ -309,6 +313,8 @@
|
|||||||
F62A35141C18E783004A917D /* Object Store */,
|
F62A35141C18E783004A917D /* Object Store */,
|
||||||
029048011C0428DF00ABDED4 /* js_init.cpp */,
|
029048011C0428DF00ABDED4 /* js_init.cpp */,
|
||||||
029048021C0428DF00ABDED4 /* js_init.h */,
|
029048021C0428DF00ABDED4 /* js_init.h */,
|
||||||
|
F6CB30FC1C8EDD760070EF3F /* js_collection.cpp */,
|
||||||
|
F6CB30FD1C8EDD760070EF3F /* js_collection.hpp */,
|
||||||
029048031C0428DF00ABDED4 /* js_list.cpp */,
|
029048031C0428DF00ABDED4 /* js_list.cpp */,
|
||||||
029048041C0428DF00ABDED4 /* js_list.hpp */,
|
029048041C0428DF00ABDED4 /* js_list.hpp */,
|
||||||
029048051C0428DF00ABDED4 /* js_object.cpp */,
|
029048051C0428DF00ABDED4 /* js_object.cpp */,
|
||||||
@ -535,6 +541,7 @@
|
|||||||
029048181C0428DF00ABDED4 /* js_realm.hpp in Headers */,
|
029048181C0428DF00ABDED4 /* js_realm.hpp in Headers */,
|
||||||
029048141C0428DF00ABDED4 /* js_list.hpp in Headers */,
|
029048141C0428DF00ABDED4 /* js_list.hpp in Headers */,
|
||||||
F6BB7DF21BF681BC00D0A69E /* base64.hpp in Headers */,
|
F6BB7DF21BF681BC00D0A69E /* base64.hpp in Headers */,
|
||||||
|
F6CB31011C8EDDBB0070EF3F /* js_collection.hpp in Headers */,
|
||||||
0290481C1C0428DF00ABDED4 /* js_schema.hpp in Headers */,
|
0290481C1C0428DF00ABDED4 /* js_schema.hpp in Headers */,
|
||||||
029048161C0428DF00ABDED4 /* js_object.hpp in Headers */,
|
029048161C0428DF00ABDED4 /* js_object.hpp in Headers */,
|
||||||
029048371C042A3C00ABDED4 /* platform.hpp in Headers */,
|
029048371C042A3C00ABDED4 /* platform.hpp in Headers */,
|
||||||
@ -787,6 +794,7 @@
|
|||||||
isa = PBXSourcesBuildPhase;
|
isa = PBXSourcesBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
|
F6CB31001C8EDDAB0070EF3F /* js_collection.cpp in Sources */,
|
||||||
02F59EE31C88F2BB007F774C /* transact_log_handler.cpp in Sources */,
|
02F59EE31C88F2BB007F774C /* transact_log_handler.cpp in Sources */,
|
||||||
F63FF2E81C159C4B00B3B8E0 /* platform.mm in Sources */,
|
F63FF2E81C159C4B00B3B8E0 /* platform.mm in Sources */,
|
||||||
02F59EC31C88F17D007F774C /* results.cpp in Sources */,
|
02F59EC31C88F17D007F774C /* results.cpp in Sources */,
|
||||||
|
125
lib/browser/collections.js
Normal file
125
lib/browser/collections.js
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Copyright 2016 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.
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
import { keys } from './constants';
|
||||||
|
import { getterForProperty, setterForProperty } from './util';
|
||||||
|
|
||||||
|
let mutationListeners = {};
|
||||||
|
|
||||||
|
export default class Collection {
|
||||||
|
constructor() {
|
||||||
|
throw new TypeError('Illegal constructor');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function addMutationListener(realmId, callback) {
|
||||||
|
let listeners = mutationListeners[realmId] || (mutationListeners[realmId] = new Set());
|
||||||
|
listeners.add(callback);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function removeMutationListener(realmId, callback) {
|
||||||
|
let listeners = mutationListeners[realmId];
|
||||||
|
if (listeners) {
|
||||||
|
listeners.delete(callback);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function clearMutationListeners() {
|
||||||
|
mutationListeners = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
export function fireMutationListeners(realmId) {
|
||||||
|
let listeners = mutationListeners[realmId];
|
||||||
|
if (listeners) {
|
||||||
|
listeners.forEach((cb) => cb());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function createCollection(prototype, realmId, info, mutable) {
|
||||||
|
let collection = Object.create(prototype);
|
||||||
|
let size = 0;
|
||||||
|
|
||||||
|
Object.defineProperties(collection, {
|
||||||
|
'length': {
|
||||||
|
get: getterForProperty('length'),
|
||||||
|
},
|
||||||
|
'-1': {
|
||||||
|
value: undefined,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
let resize = function(length) {
|
||||||
|
if (length == null) {
|
||||||
|
length = collection.length;
|
||||||
|
}
|
||||||
|
if (length == size) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let props = {};
|
||||||
|
|
||||||
|
if (length > size) {
|
||||||
|
for (let i = size; i < length; i++) {
|
||||||
|
props[i] = {
|
||||||
|
get: getterForProperty(i),
|
||||||
|
set: mutable ? setterForProperty(i) : undefined,
|
||||||
|
enumerable: true,
|
||||||
|
configurable: true,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (length < size) {
|
||||||
|
for (let i = size; i >= length; i--) {
|
||||||
|
delete collection[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helpfully throw an exception on attempts to set to one past the last index.
|
||||||
|
props[length] = {
|
||||||
|
value: undefined,
|
||||||
|
configurable: true,
|
||||||
|
};
|
||||||
|
|
||||||
|
Object.defineProperties(collection, props);
|
||||||
|
|
||||||
|
size = length;
|
||||||
|
};
|
||||||
|
|
||||||
|
collection[keys.realm] = realmId;
|
||||||
|
collection[keys.id] = info.id;
|
||||||
|
collection[keys.type] = info.type;
|
||||||
|
|
||||||
|
resize(info.size);
|
||||||
|
|
||||||
|
addMutationListener(realmId, function listener() {
|
||||||
|
try {
|
||||||
|
resize();
|
||||||
|
} catch (e) {
|
||||||
|
// If the error indicates the collection was deleted, then remove this listener.
|
||||||
|
if (e.message.indexOf('is not attached') > 0) {
|
||||||
|
removeMutationListener(realmId, listener);
|
||||||
|
} else {
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return collection;
|
||||||
|
}
|
@ -20,18 +20,19 @@
|
|||||||
|
|
||||||
import { NativeModules } from 'react-native';
|
import { NativeModules } from 'react-native';
|
||||||
import { keys, propTypes, objectTypes } from './constants';
|
import { keys, propTypes, objectTypes } from './constants';
|
||||||
import * as lists from './lists';
|
import Collection, * as collections from './collections';
|
||||||
|
import List, { createList } from './lists';
|
||||||
|
import Results, { createResults } from './results';
|
||||||
import * as objects from './objects';
|
import * as objects from './objects';
|
||||||
import * as results from './results';
|
|
||||||
import * as rpc from './rpc';
|
import * as rpc from './rpc';
|
||||||
import * as util from './util';
|
import * as util from './util';
|
||||||
|
|
||||||
const {debugHosts, debugPort} = NativeModules.Realm;
|
const {debugHosts, debugPort} = NativeModules.Realm;
|
||||||
const listenersKey = Symbol();
|
const listenersKey = Symbol();
|
||||||
|
|
||||||
rpc.registerTypeConverter(objectTypes.LIST, lists.create);
|
rpc.registerTypeConverter(objectTypes.LIST, createList);
|
||||||
|
rpc.registerTypeConverter(objectTypes.RESULTS, createResults);
|
||||||
rpc.registerTypeConverter(objectTypes.OBJECT, objects.create);
|
rpc.registerTypeConverter(objectTypes.OBJECT, objects.create);
|
||||||
rpc.registerTypeConverter(objectTypes.RESULTS, results.create);
|
|
||||||
|
|
||||||
export default class Realm {
|
export default class Realm {
|
||||||
constructor(config) {
|
constructor(config) {
|
||||||
@ -137,7 +138,7 @@ export default class Realm {
|
|||||||
callback();
|
callback();
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
rpc.cancelTransaction(realmId);
|
rpc.cancelTransaction(realmId);
|
||||||
util.fireMutationListeners(realmId);
|
collections.fireMutationListeners(realmId);
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,11 +160,14 @@ util.createMethods(Realm.prototype, objectTypes.REALM, [
|
|||||||
], true);
|
], true);
|
||||||
|
|
||||||
Object.defineProperties(Realm, {
|
Object.defineProperties(Realm, {
|
||||||
|
Collection: {
|
||||||
|
value: Collection,
|
||||||
|
},
|
||||||
List: {
|
List: {
|
||||||
value: lists.List,
|
value: List,
|
||||||
},
|
},
|
||||||
Results: {
|
Results: {
|
||||||
value: results.Results,
|
value: Results,
|
||||||
},
|
},
|
||||||
Types: {
|
Types: {
|
||||||
value: Object.freeze(propTypes),
|
value: Object.freeze(propTypes),
|
||||||
@ -174,7 +178,7 @@ Object.defineProperties(Realm, {
|
|||||||
},
|
},
|
||||||
clearTestState: {
|
clearTestState: {
|
||||||
value: function() {
|
value: function() {
|
||||||
util.clearMutationListeners();
|
collections.clearMutationListeners();
|
||||||
rpc.clearTestState();
|
rpc.clearTestState();
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -18,13 +18,11 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
import Collection, { createCollection } from './collections';
|
||||||
import { objectTypes } from './constants';
|
import { objectTypes } from './constants';
|
||||||
import { createCollection, createMethods } from './util';
|
import { createMethods } from './util';
|
||||||
|
|
||||||
export class List {
|
export default class List extends Collection {
|
||||||
constructor() {
|
|
||||||
throw new TypeError('Illegal constructor');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Non-mutating methods:
|
// Non-mutating methods:
|
||||||
@ -43,6 +41,6 @@ createMethods(List.prototype, objectTypes.LIST, [
|
|||||||
'splice',
|
'splice',
|
||||||
], true);
|
], true);
|
||||||
|
|
||||||
export function create(realmId, info) {
|
export function createList(realmId, info) {
|
||||||
return createCollection(List.prototype, realmId, info, true);
|
return createCollection(List.prototype, realmId, info, true);
|
||||||
}
|
}
|
||||||
|
@ -18,13 +18,11 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
import Collection, { createCollection } from './collections';
|
||||||
import { objectTypes } from './constants';
|
import { objectTypes } from './constants';
|
||||||
import { createCollection, createMethods } from './util';
|
import { createMethods } from './util';
|
||||||
|
|
||||||
export class Results {
|
export default class Results extends Collection {
|
||||||
constructor() {
|
|
||||||
throw new TypeError('Illegal constructor');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
createMethods(Results.prototype, objectTypes.RESULTS, [
|
createMethods(Results.prototype, objectTypes.RESULTS, [
|
||||||
@ -33,6 +31,6 @@ createMethods(Results.prototype, objectTypes.RESULTS, [
|
|||||||
'snapshot',
|
'snapshot',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
export function create(realmId, info) {
|
export function createResults(realmId, info) {
|
||||||
return createCollection(Results.prototype, realmId, info);
|
return createCollection(Results.prototype, realmId, info);
|
||||||
}
|
}
|
||||||
|
@ -18,106 +18,10 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
import { fireMutationListeners } from './collections';
|
||||||
import { keys } from './constants';
|
import { keys } from './constants';
|
||||||
import * as rpc from './rpc';
|
import * as rpc from './rpc';
|
||||||
|
|
||||||
let mutationListeners = {};
|
|
||||||
|
|
||||||
function addMutationListener(realmId, callback) {
|
|
||||||
let listeners = mutationListeners[realmId] || (mutationListeners[realmId] = new Set());
|
|
||||||
listeners.add(callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
function removeMutationListener(realmId, callback) {
|
|
||||||
let listeners = mutationListeners[realmId];
|
|
||||||
if (listeners) {
|
|
||||||
listeners.delete(callback);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export function clearMutationListeners() {
|
|
||||||
mutationListeners = {};
|
|
||||||
}
|
|
||||||
|
|
||||||
export function fireMutationListeners(realmId) {
|
|
||||||
let listeners = mutationListeners[realmId];
|
|
||||||
if (listeners) {
|
|
||||||
listeners.forEach((cb) => cb());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createCollection(prototype, realmId, info, mutable) {
|
|
||||||
let list = Object.create(prototype);
|
|
||||||
let size = 0;
|
|
||||||
|
|
||||||
Object.defineProperties(list, {
|
|
||||||
'length': {
|
|
||||||
get: getterForProperty('length'),
|
|
||||||
},
|
|
||||||
'-1': {
|
|
||||||
value: undefined,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
let resize = function(length) {
|
|
||||||
if (length == null) {
|
|
||||||
length = list.length;
|
|
||||||
}
|
|
||||||
if (length == size) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let props = {};
|
|
||||||
|
|
||||||
if (length > size) {
|
|
||||||
for (let i = size; i < length; i++) {
|
|
||||||
props[i] = {
|
|
||||||
get: getterForProperty(i),
|
|
||||||
set: mutable ? setterForProperty(i) : undefined,
|
|
||||||
enumerable: true,
|
|
||||||
configurable: true,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (length < size) {
|
|
||||||
for (let i = size; i >= length; i--) {
|
|
||||||
delete list[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helpfully throw an exception on attempts to set to list[list.length].
|
|
||||||
props[length] = {
|
|
||||||
value: undefined,
|
|
||||||
configurable: true,
|
|
||||||
};
|
|
||||||
|
|
||||||
Object.defineProperties(list, props);
|
|
||||||
|
|
||||||
size = length;
|
|
||||||
};
|
|
||||||
|
|
||||||
list[keys.realm] = realmId;
|
|
||||||
list[keys.id] = info.id;
|
|
||||||
list[keys.type] = info.type;
|
|
||||||
|
|
||||||
resize(info.size);
|
|
||||||
|
|
||||||
addMutationListener(realmId, function listener() {
|
|
||||||
try {
|
|
||||||
resize();
|
|
||||||
} catch (e) {
|
|
||||||
// If the error indicates the list was deleted, then remove this listener.
|
|
||||||
if (e.message.indexOf('is not attached') > 0) {
|
|
||||||
removeMutationListener(realmId, listener);
|
|
||||||
} else {
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createMethods(prototype, type, methodNames, mutates) {
|
export function createMethods(prototype, type, methodNames, mutates) {
|
||||||
let props = {};
|
let props = {};
|
||||||
|
|
||||||
|
@ -31,8 +31,7 @@ if (typeof Realm != 'undefined') {
|
|||||||
throw new Error('Missing Realm constructor - please ensure RealmReact framework is included!');
|
throw new Error('Missing Realm constructor - please ensure RealmReact framework is included!');
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add the specified Array methods to the prototype of List and Results.
|
// Add the specified Array methods to the Collection prototype.
|
||||||
Object.defineProperties(realmConstructor.List.prototype, arrayMethods);
|
Object.defineProperties(realmConstructor.Collection.prototype, arrayMethods);
|
||||||
Object.defineProperties(realmConstructor.Results.prototype, arrayMethods);
|
|
||||||
|
|
||||||
module.exports = realmConstructor;
|
module.exports = realmConstructor;
|
||||||
|
30
src/js_collection.cpp
Normal file
30
src/js_collection.cpp
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Copyright 2016 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 "js_collection.hpp"
|
||||||
|
|
||||||
|
static JSClassRef RJSCreateCollectionClass() {
|
||||||
|
JSClassDefinition classDefinition = kJSClassDefinitionEmpty;
|
||||||
|
classDefinition.className = "Collection";
|
||||||
|
return JSClassCreate(&classDefinition);
|
||||||
|
}
|
||||||
|
|
||||||
|
JSClassRef RJSCollectionClass() {
|
||||||
|
static JSClassRef s_collectionClass = RJSCreateCollectionClass();
|
||||||
|
return s_collectionClass;
|
||||||
|
}
|
23
src/js_collection.hpp
Normal file
23
src/js_collection.hpp
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Copyright 2016 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.
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "js_util.hpp"
|
||||||
|
|
||||||
|
JSClassRef RJSCollectionClass();
|
@ -19,6 +19,7 @@
|
|||||||
#include "js_init.h"
|
#include "js_init.h"
|
||||||
#include "js_realm.hpp"
|
#include "js_realm.hpp"
|
||||||
#include "js_object.hpp"
|
#include "js_object.hpp"
|
||||||
|
#include "js_collection.hpp"
|
||||||
#include "js_list.hpp"
|
#include "js_list.hpp"
|
||||||
#include "js_results.hpp"
|
#include "js_results.hpp"
|
||||||
#include "js_util.hpp"
|
#include "js_util.hpp"
|
||||||
@ -69,6 +70,7 @@ static JSValueRef ClearTestState(JSContextRef ctx, JSObjectRef function, JSObjec
|
|||||||
|
|
||||||
JSObjectRef RJSConstructorCreate(JSContextRef ctx) {
|
JSObjectRef RJSConstructorCreate(JSContextRef ctx) {
|
||||||
static JSStringRef clearTestStateString = JSStringCreateWithUTF8CString("clearTestState");
|
static JSStringRef clearTestStateString = JSStringCreateWithUTF8CString("clearTestState");
|
||||||
|
static JSStringRef collectionString = JSStringCreateWithUTF8CString("Collection");
|
||||||
static JSStringRef listString = JSStringCreateWithUTF8CString("List");
|
static JSStringRef listString = JSStringCreateWithUTF8CString("List");
|
||||||
static JSStringRef resultsString = JSStringCreateWithUTF8CString("Results");
|
static JSStringRef resultsString = JSStringCreateWithUTF8CString("Results");
|
||||||
static JSStringRef typeString = JSStringCreateWithUTF8CString("Types");
|
static JSStringRef typeString = JSStringCreateWithUTF8CString("Types");
|
||||||
@ -76,6 +78,9 @@ JSObjectRef RJSConstructorCreate(JSContextRef ctx) {
|
|||||||
JSObjectRef realmObject = JSObjectMake(ctx, RJSRealmConstructorClass(), NULL);
|
JSObjectRef realmObject = JSObjectMake(ctx, RJSRealmConstructorClass(), NULL);
|
||||||
JSPropertyAttributes attributes = kJSPropertyAttributeReadOnly | kJSPropertyAttributeDontEnum | kJSPropertyAttributeDontDelete;
|
JSPropertyAttributes attributes = kJSPropertyAttributeReadOnly | kJSPropertyAttributeDontEnum | kJSPropertyAttributeDontDelete;
|
||||||
|
|
||||||
|
JSObjectRef collectionConstructor = JSObjectMakeConstructor(ctx, RJSCollectionClass(), UncallableConstructor);
|
||||||
|
RJSValidatedSetProperty(ctx, realmObject, collectionString, collectionConstructor, attributes);
|
||||||
|
|
||||||
JSObjectRef listConstructor = JSObjectMakeConstructor(ctx, RJSListClass(), UncallableConstructor);
|
JSObjectRef listConstructor = JSObjectMakeConstructor(ctx, RJSListClass(), UncallableConstructor);
|
||||||
RJSValidatedSetProperty(ctx, realmObject, listString, listConstructor, attributes);
|
RJSValidatedSetProperty(ctx, realmObject, listString, listConstructor, attributes);
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
#include "js_list.hpp"
|
#include "js_list.hpp"
|
||||||
|
#include "js_collection.hpp"
|
||||||
#include "js_object.hpp"
|
#include "js_object.hpp"
|
||||||
#include "js_results.hpp"
|
#include "js_results.hpp"
|
||||||
#include "js_util.hpp"
|
#include "js_util.hpp"
|
||||||
@ -271,6 +272,6 @@ static const JSStaticFunction RJSListFuncs[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
JSClassRef RJSListClass() {
|
JSClassRef RJSListClass() {
|
||||||
static JSClassRef s_listClass = RJSCreateWrapperClass<List *>("RealmList", ListGetProperty, ListSetProperty, RJSListFuncs, ListPropertyNames);
|
static JSClassRef s_listClass = RJSCreateWrapperClass<List *>("List", ListGetProperty, ListSetProperty, RJSListFuncs, ListPropertyNames, RJSCollectionClass());
|
||||||
return s_listClass;
|
return s_listClass;
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
#include "js_results.hpp"
|
#include "js_results.hpp"
|
||||||
|
#include "js_collection.hpp"
|
||||||
#include "js_object.hpp"
|
#include "js_object.hpp"
|
||||||
#include "object_accessor.hpp"
|
#include "object_accessor.hpp"
|
||||||
#include "results.hpp"
|
#include "results.hpp"
|
||||||
@ -243,6 +244,6 @@ static const JSStaticFunction RJSResultsFuncs[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
JSClassRef RJSResultsClass() {
|
JSClassRef RJSResultsClass() {
|
||||||
static JSClassRef s_objectClass = RJSCreateWrapperClass<Results *>("Results", ResultsGetProperty, ResultsSetProperty, RJSResultsFuncs, ResultsPropertyNames);
|
static JSClassRef s_objectClass = RJSCreateWrapperClass<Results *>("Results", ResultsGetProperty, ResultsSetProperty, RJSResultsFuncs, ResultsPropertyNames, RJSCollectionClass());
|
||||||
return s_objectClass;
|
return s_objectClass;
|
||||||
}
|
}
|
||||||
|
@ -54,7 +54,7 @@ inline T RJSGetInternal(JSObjectRef jsObject) {
|
|||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
JSClassRef RJSCreateWrapperClass(const char * name, JSObjectGetPropertyCallback getter = NULL, JSObjectSetPropertyCallback setter = NULL, const JSStaticFunction *funcs = NULL,
|
JSClassRef RJSCreateWrapperClass(const char * name, JSObjectGetPropertyCallback getter = NULL, JSObjectSetPropertyCallback setter = NULL, const JSStaticFunction *funcs = NULL,
|
||||||
JSObjectGetPropertyNamesCallback propertyNames = NULL) {
|
JSObjectGetPropertyNamesCallback propertyNames = NULL, JSClassRef parentClass = NULL) {
|
||||||
JSClassDefinition classDefinition = kJSClassDefinitionEmpty;
|
JSClassDefinition classDefinition = kJSClassDefinitionEmpty;
|
||||||
classDefinition.className = name;
|
classDefinition.className = name;
|
||||||
classDefinition.finalize = RJSFinalize<T>;
|
classDefinition.finalize = RJSFinalize<T>;
|
||||||
@ -62,6 +62,7 @@ JSClassRef RJSCreateWrapperClass(const char * name, JSObjectGetPropertyCallback
|
|||||||
classDefinition.setProperty = setter;
|
classDefinition.setProperty = setter;
|
||||||
classDefinition.staticFunctions = funcs;
|
classDefinition.staticFunctions = funcs;
|
||||||
classDefinition.getPropertyNames = propertyNames;
|
classDefinition.getPropertyNames = propertyNames;
|
||||||
|
classDefinition.parentClass = parentClass;
|
||||||
return JSClassCreate(&classDefinition);
|
return JSClassCreate(&classDefinition);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,6 +30,7 @@ module.exports = BaseTest.extend({
|
|||||||
realm.write(function() {
|
realm.write(function() {
|
||||||
var obj = realm.create('PersonList', {list: []});
|
var obj = realm.create('PersonList', {list: []});
|
||||||
TestCase.assertTrue(obj.list instanceof Realm.List);
|
TestCase.assertTrue(obj.list instanceof Realm.List);
|
||||||
|
TestCase.assertTrue(obj.list instanceof Realm.Collection);
|
||||||
});
|
});
|
||||||
|
|
||||||
TestCase.assertThrows(function() {
|
TestCase.assertThrows(function() {
|
||||||
|
@ -29,6 +29,7 @@ module.exports = BaseTest.extend({
|
|||||||
var objects = realm.objects('TestObject');
|
var objects = realm.objects('TestObject');
|
||||||
|
|
||||||
TestCase.assertTrue(objects instanceof Realm.Results);
|
TestCase.assertTrue(objects instanceof Realm.Results);
|
||||||
|
TestCase.assertTrue(objects instanceof Realm.Collection);
|
||||||
|
|
||||||
TestCase.assertThrows(function() {
|
TestCase.assertThrows(function() {
|
||||||
new Realm.Results();
|
new Realm.Results();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user