1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 var createClassWrapper
= requireNative('utils').createClassWrapper
;
6 var schemaRegistry
= requireNative('schema_registry');
7 var CHECK
= requireNative('logging').CHECK
;
8 var WARNING
= requireNative('logging').WARNING
;
11 * An object forEach. Calls |f| with each (key, value) pair of |obj|, using
12 * |self| as the target.
13 * @param {Object} obj The object to iterate over.
14 * @param {function} f The function to call in each iteration.
15 * @param {Object} self The object to use as |this| in each function call.
17 function forEach(obj
, f
, self
) {
18 for (var key
in obj
) {
19 if ($Object
.hasOwnProperty(obj
, key
))
20 $Function
.call(f
, self
, key
, obj
[key
]);
25 * Assuming |array_of_dictionaries| is structured like this:
26 * [{id: 1, ... }, {id: 2, ...}, ...], you can use
27 * lookup(array_of_dictionaries, 'id', 2) to get the dictionary with id == 2.
28 * @param {Array.<Object.<string, ?>>} array_of_dictionaries
29 * @param {string} field
32 function lookup(array_of_dictionaries
, field
, value
) {
33 var filter = function (dict
) {return dict
[field
] == value
;};
34 var matches
= array_of_dictionaries
.filter(filter
);
35 if (matches
.length
== 0) {
37 } else if (matches
.length
== 1) {
40 throw new Error("Failed lookup of field '" + field
+ "' with value '" +
45 function loadTypeSchema(typeName
, defaultSchema
) {
46 var parts
= $String
.split(typeName
, '.');
47 if (parts
.length
== 1) {
48 if (defaultSchema
== null) {
49 WARNING('Trying to reference "' + typeName
+ '" ' +
50 'with neither namespace nor default schema.');
53 var types
= defaultSchema
.types
;
55 var schemaName
= $Array
.join($Array
.slice(parts
, 0, parts
.length
- 1), '.');
56 var types
= schemaRegistry
.GetSchema(schemaName
).types
;
58 for (var i
= 0; i
< types
.length
; ++i
) {
59 if (types
[i
].id
== typeName
)
66 * Takes a private class implementation |cls| and exposes a subset of its
67 * methods |functions| and properties |properties| and |readonly| in a public
68 * wrapper class that it returns. Within bindings code, you can access the
69 * implementation from an instance of the wrapper class using
70 * privates(instance).impl, and from the implementation class you can access
71 * the wrapper using this.wrapper (or implInstance.wrapper if you have another
72 * instance of the implementation class).
73 * @param {string} name The name of the exposed wrapper class.
74 * @param {Object} cls The class implementation.
75 * @param {{functions: ?Array.<string>,
76 * properties: ?Array.<string>,
77 * readonly: ?Array.<string>}} exposed The names of properties on the
78 * implementation class to be exposed. |functions| represents the names of
79 * functions which should be delegated to the implementation; |properties|
80 * are gettable/settable properties and |readonly| are read-only properties.
82 function expose(name
, cls
, exposed
) {
83 var publicClass
= createClassWrapper(name
, cls
);
85 if ('functions' in exposed
) {
86 $Array
.forEach(exposed
.functions
, function(func
) {
87 publicClass
.prototype[func
] = function() {
88 var impl
= privates(this).impl
;
89 return $Function
.apply(impl
[func
], impl
, arguments
);
94 if ('properties' in exposed
) {
95 $Array
.forEach(exposed
.properties
, function(prop
) {
96 $Object
.defineProperty(publicClass
.prototype, prop
, {
99 return privates(this).impl
[prop
];
101 set: function(value
) {
102 var impl
= privates(this).impl
;
110 if ('readonly' in exposed
) {
111 $Array
.forEach(exposed
.readonly
, function(readonly
) {
112 $Object
.defineProperty(publicClass
.prototype, readonly
, {
115 return privates(this).impl
[readonly
];
124 exports
.forEach
= forEach
;
125 exports
.loadTypeSchema
= loadTypeSchema
;
126 exports
.lookup
= lookup
;
127 exports
.expose
= expose
;