From 5eb1b96e4a2dd91e6befee82598ef34c869c94b0 Mon Sep 17 00:00:00 2001 From: rolux Date: Fri, 29 Nov 2013 21:13:04 +0100 Subject: [PATCH] add comment; fix Ox.extend if called with two arguments, add test --- source/Ox/js/Object.js | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/source/Ox/js/Object.js b/source/Ox/js/Object.js index df6305df..a1243c2c 100644 --- a/source/Ox/js/Object.js +++ b/source/Ox/js/Object.js @@ -6,14 +6,16 @@ Ox.extend Extends an object with one or more other objects {a: 1, b: 2, c: 3} > Ox.extend({a: 1}, 'b', 2) {a: 1, b: 2} + > Ox.extend({a: 1}, 'b') + {a: 1, b: void 0} @*/ Ox.extend = function(object) { var args = Ox.slice(arguments, 1); - if (args.length == 2 && !Ox.isObject(args[0])) { + if (!Ox.isObject(args[0])) { args = [Ox.makeObject(args)]; } - Ox.forEach(args, function(argument, i) { - Ox.forEach(argument, function(value, key) { + Ox.forEach(args, function(arg, i) { + Ox.forEach(arg, function(value, key) { object[key] = value; }); }); @@ -115,13 +117,14 @@ Ox.makeObject Takes an array and returns an object > (function() { return Ox.makeObject(arguments); }()) {} @*/ +// FIXME: rename to toObject Ox.makeObject = function(array) { var ret = {}; if (Ox.isObject(array[0])) { - // ({foo: 'bar'}) + // [{foo: 'bar'}] ret = array[0]; } else if (array.length) { - // ('foo', 'bar') + // ['foo', 'bar'] ret[array[0]] = array[1]; } return ret;