]> gerrit.simantics Code Review - simantics/district.git/blobdiff - org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/node-gyp/node_modules/path-array/node_modules/array-index/node_modules/es6-symbol/node_modules/es5-ext/object/mixin-prototypes.js
Adding integrated tile server
[simantics/district.git] / org.simantics.maps.server / node / node-v4.8.0-win-x64 / node_modules / npm / node_modules / node-gyp / node_modules / path-array / node_modules / array-index / node_modules / es6-symbol / node_modules / es5-ext / object / mixin-prototypes.js
diff --git a/org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/node-gyp/node_modules/path-array/node_modules/array-index/node_modules/es6-symbol/node_modules/es5-ext/object/mixin-prototypes.js b/org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/node-gyp/node_modules/path-array/node_modules/array-index/node_modules/es6-symbol/node_modules/es5-ext/object/mixin-prototypes.js
new file mode 100644 (file)
index 0000000..1ef5756
--- /dev/null
@@ -0,0 +1,34 @@
+'use strict';
+
+var value = require('./valid-value')
+  , mixin = require('./mixin')
+
+  , defineProperty = Object.defineProperty
+  , getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor
+  , getOwnPropertyNames = Object.getOwnPropertyNames
+  , getPrototypeOf = Object.getPrototypeOf
+  , hasOwnProperty = Object.prototype.hasOwnProperty;
+
+module.exports = function (target, source) {
+       var error, end, define;
+       target = Object(value(target));
+       source = Object(value(source));
+       end = getPrototypeOf(target);
+       if (source === end) return target;
+       try {
+               mixin(target, source);
+       } catch (e) { error = e; }
+       source = getPrototypeOf(source);
+       define = function (name) {
+               if (hasOwnProperty.call(target, name)) return;
+               try {
+                       defineProperty(target, name, getOwnPropertyDescriptor(source, name));
+               } catch (e) { error = e; }
+       };
+       while (source && (source !== end)) {
+               getOwnPropertyNames(source).forEach(define);
+               source = getPrototypeOf(source);
+       }
+       if (error) throw error;
+       return target;
+};