/* eslint-disable */  
 | 
var clone = (function() {  
 | 
  'use strict';  
 | 
  
 | 
  function _instanceof(obj, type) {  
 | 
    return type != null && obj instanceof type;  
 | 
  }  
 | 
  
 | 
  var nativeMap;  
 | 
  try {  
 | 
    nativeMap = Map;  
 | 
  } catch(_) {  
 | 
    // maybe a reference error because no `Map`. Give it a dummy value that no  
 | 
    // value will ever be an instanceof.  
 | 
    nativeMap = function() {};  
 | 
  }  
 | 
  
 | 
  var nativeSet;  
 | 
  try {  
 | 
    nativeSet = Set;  
 | 
  } catch(_) {  
 | 
    nativeSet = function() {};  
 | 
  }  
 | 
  
 | 
  var nativePromise;  
 | 
  try {  
 | 
    nativePromise = Promise;  
 | 
  } catch(_) {  
 | 
    nativePromise = function() {};  
 | 
  }  
 | 
  
 | 
  /**  
 | 
   * Clones (copies) an Object using deep copying.  
 | 
   *  
 | 
   * This function supports circular references by default, but if you are certain  
 | 
   * there are no circular references in your object, you can save some CPU time  
 | 
   * by calling clone(obj, false).  
 | 
   *  
 | 
   * Caution: if `circular` is false and `parent` contains circular references,  
 | 
   * your program may enter an infinite loop and crash.  
 | 
   *  
 | 
   * @param `parent` - the object to be cloned  
 | 
   * @param `circular` - set to true if the object to be cloned may contain  
 | 
   *    circular references. (optional - true by default)  
 | 
   * @param `depth` - set to a number if the object is only to be cloned to  
 | 
   *    a particular depth. (optional - defaults to Infinity)  
 | 
   * @param `prototype` - sets the prototype to be used when cloning an object.  
 | 
   *    (optional - defaults to parent prototype).  
 | 
   * @param `includeNonEnumerable` - set to true if the non-enumerable properties  
 | 
   *    should be cloned as well. Non-enumerable properties on the prototype  
 | 
   *    chain will be ignored. (optional - false by default)  
 | 
   */  
 | 
  function clone(parent, circular, depth, prototype, includeNonEnumerable) {  
 | 
    if (typeof circular === 'object') {  
 | 
      depth = circular.depth;  
 | 
      prototype = circular.prototype;  
 | 
      includeNonEnumerable = circular.includeNonEnumerable;  
 | 
      circular = circular.circular;  
 | 
    }  
 | 
    // maintain two arrays for circular references, where corresponding parents  
 | 
    // and children have the same index  
 | 
    var allParents = [];  
 | 
    var allChildren = [];  
 | 
  
 | 
    var useBuffer = typeof Buffer != 'undefined';  
 | 
  
 | 
    if (typeof circular == 'undefined')  
 | 
      circular = true;  
 | 
  
 | 
    if (typeof depth == 'undefined')  
 | 
      depth = Infinity;  
 | 
  
 | 
    // recurse this function so we don't reset allParents and allChildren  
 | 
    function _clone(parent, depth) {  
 | 
      // cloning null always returns null  
 | 
      if (parent === null)  
 | 
        return null;  
 | 
  
 | 
      if (depth === 0)  
 | 
        return parent;  
 | 
  
 | 
      var child;  
 | 
      var proto;  
 | 
      if (typeof parent != 'object') {  
 | 
        return parent;  
 | 
      }  
 | 
  
 | 
      if (_instanceof(parent, nativeMap)) {  
 | 
        child = new nativeMap();  
 | 
      } else if (_instanceof(parent, nativeSet)) {  
 | 
        child = new nativeSet();  
 | 
      } else if (_instanceof(parent, nativePromise)) {  
 | 
        child = new nativePromise(function (resolve, reject) {  
 | 
          parent.then(function(value) {  
 | 
            resolve(_clone(value, depth - 1));  
 | 
          }, function(err) {  
 | 
            reject(_clone(err, depth - 1));  
 | 
          });  
 | 
        });  
 | 
      } else if (clone.__isArray(parent)) {  
 | 
        child = [];  
 | 
      } else if (clone.__isRegExp(parent)) {  
 | 
        child = new RegExp(parent.source, __getRegExpFlags(parent));  
 | 
        if (parent.lastIndex) child.lastIndex = parent.lastIndex;  
 | 
      } else if (clone.__isDate(parent)) {  
 | 
        child = new Date(parent.getTime());  
 | 
      } else if (useBuffer && Buffer.isBuffer(parent)) {  
 | 
        if (Buffer.from) {  
 | 
          // Node.js >= 5.10.0  
 | 
          child = Buffer.from(parent);  
 | 
        } else {  
 | 
          // Older Node.js versions  
 | 
          child = new Buffer(parent.length);  
 | 
          parent.copy(child);  
 | 
        }  
 | 
        return child;  
 | 
      } else if (_instanceof(parent, Error)) {  
 | 
        child = Object.create(parent);  
 | 
      } else {  
 | 
        if (typeof prototype == 'undefined') {  
 | 
          proto = Object.getPrototypeOf(parent);  
 | 
          child = Object.create(proto);  
 | 
        }  
 | 
        else {  
 | 
          child = Object.create(prototype);  
 | 
          proto = prototype;  
 | 
        }  
 | 
      }  
 | 
  
 | 
      if (circular) {  
 | 
        var index = allParents.indexOf(parent);  
 | 
  
 | 
        if (index != -1) {  
 | 
          return allChildren[index];  
 | 
        }  
 | 
        allParents.push(parent);  
 | 
        allChildren.push(child);  
 | 
      }  
 | 
  
 | 
      if (_instanceof(parent, nativeMap)) {  
 | 
        parent.forEach(function(value, key) {  
 | 
          var keyChild = _clone(key, depth - 1);  
 | 
          var valueChild = _clone(value, depth - 1);  
 | 
          child.set(keyChild, valueChild);  
 | 
        });  
 | 
      }  
 | 
      if (_instanceof(parent, nativeSet)) {  
 | 
        parent.forEach(function(value) {  
 | 
          var entryChild = _clone(value, depth - 1);  
 | 
          child.add(entryChild);  
 | 
        });  
 | 
      }  
 | 
  
 | 
      for (var i in parent) {  
 | 
        var attrs = Object.getOwnPropertyDescriptor(parent, i);  
 | 
        if (attrs) {  
 | 
          child[i] = _clone(parent[i], depth - 1);  
 | 
        }  
 | 
  
 | 
        try {  
 | 
          var objProperty = Object.getOwnPropertyDescriptor(parent, i);  
 | 
          if (objProperty.set === 'undefined') {  
 | 
            // no setter defined. Skip cloning this property  
 | 
            continue;  
 | 
          }  
 | 
          child[i] = _clone(parent[i], depth - 1);  
 | 
        } catch(e){  
 | 
          if (e instanceof TypeError) {  
 | 
            // when in strict mode, TypeError will be thrown if child[i] property only has a getter  
 | 
            // we can't do anything about this, other than inform the user that this property cannot be set.  
 | 
            continue  
 | 
          } else if (e instanceof ReferenceError) {  
 | 
            //this may happen in non strict mode  
 | 
            continue  
 | 
          }  
 | 
        }  
 | 
  
 | 
      }  
 | 
  
 | 
      if (Object.getOwnPropertySymbols) {  
 | 
        var symbols = Object.getOwnPropertySymbols(parent);  
 | 
        for (var i = 0; i < symbols.length; i++) {  
 | 
          // Don't need to worry about cloning a symbol because it is a primitive,  
 | 
          // like a number or string.  
 | 
          var symbol = symbols[i];  
 | 
          var descriptor = Object.getOwnPropertyDescriptor(parent, symbol);  
 | 
          if (descriptor && !descriptor.enumerable && !includeNonEnumerable) {  
 | 
            continue;  
 | 
          }  
 | 
          child[symbol] = _clone(parent[symbol], depth - 1);  
 | 
          Object.defineProperty(child, symbol, descriptor);  
 | 
        }  
 | 
      }  
 | 
  
 | 
      if (includeNonEnumerable) {  
 | 
        var allPropertyNames = Object.getOwnPropertyNames(parent);  
 | 
        for (var i = 0; i < allPropertyNames.length; i++) {  
 | 
          var propertyName = allPropertyNames[i];  
 | 
          var descriptor = Object.getOwnPropertyDescriptor(parent, propertyName);  
 | 
          if (descriptor && descriptor.enumerable) {  
 | 
            continue;  
 | 
          }  
 | 
          child[propertyName] = _clone(parent[propertyName], depth - 1);  
 | 
          Object.defineProperty(child, propertyName, descriptor);  
 | 
        }  
 | 
      }  
 | 
  
 | 
      return child;  
 | 
    }  
 | 
  
 | 
    return _clone(parent, depth);  
 | 
  }  
 | 
  
 | 
  /**  
 | 
   * Simple flat clone using prototype, accepts only objects, usefull for property  
 | 
   * override on FLAT configuration object (no nested props).  
 | 
   *  
 | 
   * USE WITH CAUTION! This may not behave as you wish if you do not know how this  
 | 
   * works.  
 | 
   */  
 | 
  clone.clonePrototype = function clonePrototype(parent) {  
 | 
    if (parent === null)  
 | 
      return null;  
 | 
  
 | 
    var c = function () {};  
 | 
    c.prototype = parent;  
 | 
    return new c();  
 | 
  };  
 | 
  
 | 
// private utility functions  
 | 
  
 | 
  function __objToStr(o) {  
 | 
    return Object.prototype.toString.call(o);  
 | 
  }  
 | 
  clone.__objToStr = __objToStr;  
 | 
  
 | 
  function __isDate(o) {  
 | 
    return typeof o === 'object' && __objToStr(o) === '[object Date]';  
 | 
  }  
 | 
  clone.__isDate = __isDate;  
 | 
  
 | 
  function __isArray(o) {  
 | 
    return typeof o === 'object' && __objToStr(o) === '[object Array]';  
 | 
  }  
 | 
  clone.__isArray = __isArray;  
 | 
  
 | 
  function __isRegExp(o) {  
 | 
    return typeof o === 'object' && __objToStr(o) === '[object RegExp]';  
 | 
  }  
 | 
  clone.__isRegExp = __isRegExp;  
 | 
  
 | 
  function __getRegExpFlags(re) {  
 | 
    var flags = '';  
 | 
    if (re.global) flags += 'g';  
 | 
    if (re.ignoreCase) flags += 'i';  
 | 
    if (re.multiline) flags += 'm';  
 | 
    return flags;  
 | 
  }  
 | 
  clone.__getRegExpFlags = __getRegExpFlags;  
 | 
  
 | 
  return clone;  
 | 
})();  
 | 
  
 | 
export default clone  
 |