A suite to track Project Diva score statistics and ratings / D4DJ event data.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
projectdivar/server/node_modules/utils-copy/README.md

274 lines
6.5 KiB

Copy
===
[![NPM version][npm-image]][npm-url] [![Build Status][build-image]][build-url] [![Coverage Status][coverage-image]][coverage-url] [![Dependencies][dependencies-image]][dependencies-url]
> Copy or deep clone a value to an arbitrary depth.
## Installation
``` bash
$ npm install utils-copy
```
## Usage
``` javascript
var cp = require( 'utils-copy' );
```
#### cp( value[, level] )
Copy or deep clone a `value` to an arbitrary depth. The `function` accepts both `objects` and `primitives`.
``` javascript
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.
``` javascript
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
```
## Notes
* 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][node-buffer])
* 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.
``` javascript
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
```
## Examples
``` javascript
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,
``` bash
$ node ./examples/index.js
```
---
## Tests
### Unit
This repository uses [tape][tape] for unit tests. To run the tests, execute the following command in the top-level application directory:
``` bash
$ make test
```
All new feature development should have corresponding unit tests to validate correct functionality.
### Test Coverage
This repository uses [Istanbul][istanbul] as its code coverage tool. To generate a test coverage report, execute the following command in the top-level application directory:
``` bash
$ make test-cov
```
Istanbul creates a `./reports/coverage` directory. To access an HTML version of the report,
``` bash
$ make view-cov
```
### Browser Support
This repository uses [Testling][testling] for browser testing. To run the tests in a (headless) local web browser, execute the following command in the top-level application directory:
``` bash
$ make test-browsers
```
To view the tests in a local web browser,
``` bash
$ make view-browser-tests
```
<!-- [![browser support][browsers-image]][browsers-url] -->
---
## License
[MIT license](http://opensource.org/licenses/MIT).
## Copyright
Copyright &copy; 2015-2016. Athan Reines.
[npm-image]: http://img.shields.io/npm/v/utils-copy.svg
[npm-url]: https://npmjs.org/package/utils-copy
[build-image]: http://img.shields.io/travis/kgryte/utils-copy/master.svg
[build-url]: https://travis-ci.org/kgryte/utils-copy
[coverage-image]: https://img.shields.io/codecov/c/github/kgryte/utils-copy/master.svg
[coverage-url]: https://codecov.io/github/kgryte/utils-copy?branch=master
[dependencies-image]: http://img.shields.io/david/kgryte/utils-copy.svg
[dependencies-url]: https://david-dm.org/kgryte/utils-copy
[dev-dependencies-image]: http://img.shields.io/david/dev/kgryte/utils-copy.svg
[dev-dependencies-url]: https://david-dm.org/dev/kgryte/utils-copy
[github-issues-image]: http://img.shields.io/github/issues/kgryte/utils-copy.svg
[github-issues-url]: https://github.com/kgryte/utils-copy/issues
[browsers-image]: https://ci.testling.com/kgryte/utils-copy.png
[browsers-url]: https://ci.testling.com/kgryte/utils-copy
[tape]: https://github.com/substack/tape
[istanbul]: https://github.com/gotwarlost/istanbul
[testling]: https://ci.testling.com
[node-buffer]: http://nodejs.org/api/buffer.html