forked from alexyoung/ico
-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathes5.js
99 lines (85 loc) · 3.07 KB
/
es5.js
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
// ECMAScript 5 compatibility functions
//
// Copyright (c) 2011, Jean Vincent
//
// Licensed under the MIT license
//
Object.keys || ( Object.keys = function( o ) {
var keys = [];
for ( var property in o ) if ( o.hasOwnProperty( property ) ) keys.push( property );
return keys;
} );
Object.create || ( Object.create = function ( o ) {
if ( arguments.length > 1 ) {
throw new Error( 'Object.create implementation only accepts the first parameter.' );
}
function O() {}
O.prototype = o;
return new O();
} );
Function.prototype.bind || ( Function.prototype.bind = function( o ) {
if ( typeof this !== "function" ) {
throw new TypeError( "Function.prototype.bind - what is trying to be bound is not callable" )
}
var that = this
, slice = Array.prototype.slice
, a = slice.call( arguments, 1 )
, bound = function() {
return that.apply( o || {}, a.concat( slice.call( arguments ) ) );
}
;
bound.prototype = this.prototype;
return bound;
} );
Array.prototype.indexOf || ( Array.prototype.indexOf = function( v, i ) {
var l = this.length; if ( l === 0 ) return -1;
if ( i === undefined ) {
i = 0
} else if( i < 0 && ( i += l ) < 0 ) i = 0;
i -= 1; while( ++i < l ) if ( this[ i ] === v ) return i;
return -1;
} );
Array.prototype.lastIndexOf || ( Array.prototype.lastIndexOf = function( v, i ) {
var l = this.length; if ( l === 0 ) return -1;
if ( i === undefined ) {
i = l - 1
} else if( i < 0 && ( i += l ) < 0 ) {
return -1
} else if ( i >= l ) i = l - 1;
i += 1; while( --i >= 0 && this[ i ] !== v );
return i;
} );
Array.prototype.forEach || ( Array.prototype.forEach = function( c, t ) {
t || ( t = window );
var i = -1; while( ++i < this.length ) if ( i in this ) c.call( t, this[i], i, this );
} );
Array.prototype.every || ( Array.prototype.every = function( c, t ) {
t || ( t = window );
var i = -1; while( ++i < this.length ) if ( i in this && ! c.call( t, this[i], i, this ) ) return false;
return true;
} );
Array.prototype.some || ( Array.prototype.some = function( c, t ) {
t || ( t = window );
var i = -1; while( ++i < this.length ) if ( i in this && c.call( t, this[i], i, this ) ) return true;
return false;
} );
Array.prototype.map || ( Array.prototype.map = function( c, t ) {
t || ( t = window );
var a = [], i = -1; while( ++i < this.length ) if ( i in this ) a [i] = c.call( t, this[i], i, this );
return a;
} );
Array.prototype.filter || ( Array.prototype.filter = function( c, t ) {
t || ( t = window );
var a = [], v, l = this.length, i = -1; while( ++i < l ) if ( i in this ) c.call( t, v = this[i], i, this ) && a.push( v );
return a;
} );
Array.prototype.reduce || ( Array.prototype.reduce = function( c, v ) {
var i = -1; if ( v === undefined ) v = this[++i];
while( ++i < this.length ) if ( i in this ) v = c( v, this[i], i, this );
return v;
} );
Array.prototype.reduceRight || ( Array.prototype.reduceRight = function( c, v ) {
var i = this.length; if ( v === undefined ) v = this[--i];
while( --i >= 0 ) if ( i in this ) v = c( v, this[i], i, this );
return v;
} );