0byt3m1n1
Path:
/
data
/
applications
/
aps.bak
/
phprojekt
/
6.0.6-0
/
standard
/
htdocs
/
htdocs
/
dojo
/
dojox
/
lang
/
[
Home
]
File: utils.js
/* Copyright (c) 2004-2010, The Dojo Foundation All Rights Reserved. Available via Academic Free License >= 2.1 OR the modified BSD license. see: http://dojotoolkit.org/license for details */ if(!dojo._hasResource["dojox.lang.utils"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code. dojo._hasResource["dojox.lang.utils"] = true; dojo.provide("dojox.lang.utils"); (function(){ var empty = {}, du = dojox.lang.utils, opts = Object.prototype.toString; var clone = function(o){ if(o){ switch(opts.call(o)){ case "[object Array]": return o.slice(0); case "[object Object]": return dojo.delegate(o); } } return o; } dojo.mixin(du, { coerceType: function(target, source){ // summary: Coerces one object to the type of another. // target: Object: object, which typeof result is used to coerce "source" object. // source: Object: object, which will be forced to change type. switch(typeof target){ case "number": return Number(eval("(" + source + ")")); case "string": return String(source); case "boolean": return Boolean(eval("(" + source + ")")); } return eval("(" + source + ")"); }, updateWithObject: function(target, source, conv){ // summary: Updates an existing object in place with properties from an "source" object. // target: Object: the "target" object to be updated // source: Object: the "source" object, whose properties will be used to source the existed object. // conv: Boolean?: force conversion to the original type if(!source){ return target; } for(var x in target){ if(x in source && !(x in empty)){ var t = target[x]; if(t && typeof t == "object"){ du.updateWithObject(t, source[x], conv); }else{ target[x] = conv ? du.coerceType(t, source[x]) : clone(source[x]); } } } return target; // Object }, updateWithPattern: function(target, source, pattern, conv){ // summary: Updates an existing object in place with properties from an "source" object. // target: Object: the "target" object to be updated // source: Object: the "source" object, whose properties will be used to source the existed object. // pattern: Array: an array of properties to be copied // conv: Boolean?: force conversion to the original type if(!source || !pattern){ return target; } for(var x in pattern){ if(x in source && !(x in empty)){ target[x] = conv ? du.coerceType(pattern[x], source[x]) : clone(source[x]); } } return target; // Object }, merge: function(object, mixin){ // summary: Merge two objects structurally, mixin properties will override object's properties. // object: Object: original object. // mixin: Object: additional object, which properties will override object's properties. if(mixin){ var otype = opts.call(object), mtype = opts.call(mixin), t, i, l, m; switch(mtype){ case "[object Array]": if(mtype == otype){ t = new Array(Math.max(object.length, mixin.length)); for(i = 0, l = t.length; i < l; ++i){ t[i] = du.merge(object[i], mixin[i]); } return t; } return mixin.slice(0); case "[object Object]": if(mtype == otype && object){ t = dojo.delegate(object); for(i in mixin){ if(i in object){ l = object[i]; m = mixin[i]; if(m !== l){ t[i] = du.merge(l, m); } }else{ t[i] = dojo.clone(mixin[i]); } } return t; } return dojo.clone(mixin); } } return mixin; } }); })(); }