File: repl.txt

package info (click to toggle)
node-stdlib 0.0.96%2Bds1%2B~cs0.0.429-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 421,476 kB
  • sloc: javascript: 1,562,831; ansic: 109,702; lisp: 49,823; cpp: 27,224; python: 7,871; sh: 6,807; makefile: 6,089; fortran: 3,102; awk: 387
file content (61 lines) | stat: -rw-r--r-- 1,926 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61

{{alias}}( value[, level] )
    Copy or deep clone a value to an arbitrary depth.

    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.

    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.

    The implementation supports custom error types which are `Error` instances
    (e.g., ES2015 subclasses).

    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.

    Parameters
    ----------
    value: any
        Value to test.

    level: integer (optional)
         Copy depth. Default: Infinity.

    Returns
    -------
    out: any
        Value copy.

    Examples
    --------
    > var value = [ { 'a': 1, 'b': true, 'c': [ 1, 2, 3 ] } ];
    > var out = {{alias}}( value )
    [ { 'a': 1, 'b': true, 'c': [ 1, 2, 3 ] } ]
    > var bool = ( value[ 0 ].c === out[ 0 ].c )
    false

    // Set the `level` option to limit the copy depth:
    > value = [ { 'a': 1, 'b': true, 'c': [ 1, 2, 3 ] } ];
    > out = {{alias}}( value, 1 );
    > bool = ( value[ 0 ] === out[ 0 ] )
    true
    > bool = ( value[ 0 ].c === out[ 0 ].c )
    true


    See Also
    --------