Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Copy or deep clone a value to an arbitrary depth.
$ npm install utils-copy
var cp = require( 'utils-copy' );
Copy or deep clone a value
to an arbitrary depth. The function
accepts both objects
and primitives
.
var value, copy;
// Primitives...
value = 'beep';
copy = cp( value );
// returns 'beep'
// Objects...
value = [{'a':1,'b':true,'c':[1,2,3]}];
copy = cp( value );
// returns [{'a':1,'b':true,'c':[1,2,3]}]
console.log( value[0].c === copy[0].c );
// returns false
The default behavior returns a full deep copy of any object
. To limit the copy depth, set the level
option.
var value, copy;
value = [{'a':1,'b':true,'c':[1,2,3]}];
// Trivial case => return the same reference
copy = cp( value, 0 );
// returns [{'a':1,'b':true,'c':[1,2,3]}]
console.log( value[0] === copy[0] );
// returns true
// Shallow copy:
copy = cp( value, 1 );
console.log( value[0] === copy[0] );
// returns false
console.log( value[0].c === copy[0].c );
// returns true
// Deep copy:
copy = cp( value, 2 );
console.log( value[0].c === copy[0].c );
// returns false
List of supported values/types:
undefined
null
boolean
/Boolean
string
/String
number
/Number
function
Object
Date
RegExp
Set
Map
Error
URIError
ReferenceError
SyntaxError
RangeError
EvalError
TypeError
Array
Int8Array
Uint8Array
Uint8ClampedArray
Init16Array
Uint16Array
Int32Array
Uint32Array
Float32Array
Float64Array
Buffer
(Node.js)List of unsupported values/types:
DOMElement
: to copy DOM elements, use element.cloneNode()
.Symbol
WeakMap
WeakSet
Blob
File
FileList
ImageData
ImageBitmap
ArrayBuffer
The implementation can handle circular references.
If a Number
, String
, or Boolean
object is encountered, the value is cloned as a primitive. This behavior is intentional. The implementation is opinionated in wanting to avoid creating numbers
, strings
, and booleans
via the new
operator and a constructor.
For objects
, the implementation only copies enumerable
keys and their associated property descriptors.
The implementation only checks whether basic Objects
, Arrays
, and class instances are extensible
, sealed
, and/or frozen
.
functions
are not cloned; their reference is copied.
Support for copying class instances is inherently fragile. Any instances with privileged access to variables (e.g., within closures) cannot be cloned. This stated, basic copying of class instances is supported. Provided an environment which supports ES5, the implementation is greedy and performs a deep clone of any arbitrary class instance and its properties. The implementation assumes that the concept of level
applies only to the class instance reference, but not to its internal state.
function Foo() {
this._data = [ 1, 2, 3, 4 ];
this._name = 'bar';
return this;
}
var foo = new Foo();
var fooey = cp( foo );
console.log( foo._name === fooey._name );
// returns true
console.log( foo._data === fooey._data );
// returns false
console.log( foo._data[0] === fooey._data[0] );
// returns true
var cp = require( 'utils-copy' );
var arr = [
{
'x': new Date(),
'y': [Math.random(),Math.random()],
'z': new Int32Array([1,2,3,4]),
'label': 'Beep'
},
{
'x': new Date(),
'y': [Math.random(),Math.random()],
'z': new Int32Array([3,1,2,4]),
'label': 'Boop'
}
];
var copy = cp( arr );
console.log( arr[ 0 ] === copy[ 0 ] );
// returns false
console.log( arr[ 1 ].y === copy[ 1 ].y );
// returns false
copy = cp( arr, 1 );
console.log( arr[ 0 ] === copy[ 0 ] );
// returns true
console.log( arr[ 1 ].z === copy[ 1 ].z );
// returns true
To run the example code from the top-level application directory,
$ node ./examples/index.js
This repository uses tape for unit tests. To run the tests, execute the following command in the top-level application directory:
$ make test
All new feature development should have corresponding unit tests to validate correct functionality.
This repository uses Istanbul as its code coverage tool. To generate a test coverage report, execute the following command in the top-level application directory:
$ make test-cov
Istanbul creates a ./reports/coverage
directory. To access an HTML version of the report,
$ make view-cov
This repository uses Testling for browser testing. To run the tests in a (headless) local web browser, execute the following command in the top-level application directory:
$ make test-browsers
To view the tests in a local web browser,
$ make view-browser-tests
Copyright © 2015-2016. Athan Reines.
FAQs
Copy or deep clone a value to an arbitrary depth.
The npm package utils-copy receives a total of 26,580 weekly downloads. As such, utils-copy popularity was classified as popular.
We found that utils-copy demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.