123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>JSDoc: Source: polyfill/Number.js</title>
- <script src="scripts/prettify/prettify.js"> </script>
- <script src="scripts/prettify/lang-css.js"> </script>
- <!--[if lt IE 9]>
- <script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
- <link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
- <link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
- </head>
- <body>
- <div id="main">
- <h1 class="page-title">Source: polyfill/Number.js</h1>
-
-
- <section>
- <article>
- <pre class="prettyprint source linenums"><code>// Licensed Materials - Property of IBM
- //
- // IBM Watson Analytics
- //
- // (C) Copyright IBM Corp. 2015
- //
- // US Government Users Restricted Rights - Use, duplication or
- // disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
- ( function( Number, ObjectPolyfill )
- {
- "use strict";
- /**
- * Polyfills for {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number Number}.
- * @class module:barejs/polyfill.Number
- */
- /** @lends module:barejs/polyfill.Number */
- var stat = {};
- /*istanbul ignore else: We test with __ES__ set to 3*/
- if ( __ES__ < 6 )
- {
- stat.parseInt = parseInt; // ES6 defines this global should be on Number
- stat.parseFloat = parseFloat; // ES6 defines this global should be on Number
- /**
- * The Number.MAX_SAFE_INTEGER constant represents the maximum safe integer in JavaScript (2<sup>53</sup> - 1).
- * @member {number}
- * @readonly
- */
- stat.MAX_SAFE_INTEGER = 9007199254740991 /*0x1fffffffffffff*/;
- /**
- * The Number.MIN_SAFE_INTEGER constant represents the minimum safe integer in JavaScript (-(2<sup>53</sup> - 1)).
- * @member {number}
- * @readonly
- */
- stat.MIN_SAFE_INTEGER = -stat.MAX_SAFE_INTEGER;
- /**
- * The Number.EPSILON property represents the difference between `1` and the smallest floating point number greater than `1`.
- * @member {number}
- * @readonly
- */
- stat.EPSILON = Math.pow( 2, -52 );
- // Closure to protect the isFinite name
- ( function( _isFinite )
- {
- /**
- * Check if a number is finite. Differs from global isFinite by not coercing types.
- * @param _value the value to check.
- * @returns {boolean} True if _value is a finite number
- */
- stat.isFinite = function isFinite( _value )
- {
- return typeof _value === "number" && _isFinite( _value );
- };
- }( isFinite /* Grab the global isFinite */ ) );
- /**
- * The Number.isInteger() method determines whether the passed value is an integer.
- * @param _value the value to check.
- * @returns {boolean} True if _value is an integer.
- */
- stat.isInteger = function isInteger( _value )
- {
- return Number.isFinite( _value ) && Math.floor( _value ) === _value;
- };
- /**
- * The Number.isSafeInteger() method determines whether the provided value is a number that is a safe integer.
- * A safe integer is an integer that
- * - can be exactly represented as an IEEE-754 double precision number, and
- * - whose IEEE-754 representation cannot be the result of rounding any other integer to fit the IEEE-754 representation.
- * For example, 2<sup>53</sup> - 1 is a safe integer: it can be exactly represented, and no other integer rounds to it under any IEEE-754 rounding mode.
- * In contrast, 2<sup>53</sup> is not a safe integer: it can be exactly represented in IEEE-754, but the integer 2<sup>53</sup> + 1 can't be directly represented in IEEE-754
- * but instead rounds to 2<sup>53</sup> under round-to-nearest and round-to-zero rounding.
- * The safe integers consist of all integers from -(2<sup>53</sup> - 1) inclusive to 2<sup>53</sup> - 1 inclusive.
- * @param {number} _value The value to test
- * @returns {boolean} True if _value is a Number and a safe integer value.
- */
- stat.isSafeInteger = function isSafeInteger( _value )
- {
- return Number.isInteger( _value ) && ( _value >= Number.MIN_SAFE_INTEGER ) && ( _value <= Number.MAX_SAFE_INTEGER );
- };
- // Closure to protect the isNaN name
- ( function( _isNaN )
- {
- /**
- * Check if _value is the special NaN value. Differs from global isNaN by not coercing types.
- * @param _value the value to check.
- * @returns {boolean} True if _value is the NaN value number
- */
- stat.isNaN = function isNaN( _value )
- {
- return typeof _value === "number" && _isNaN( _value );
- };
- }( isNaN /* Grab the global isNaN */ ) );
- // End of ES6 polyfill scope
- }
- ObjectPolyfill.polyfill( Number, stat, null, exports, "Number" );
- // End of module
- }( Number, require( "./Object" ) ) );
- </code></pre>
- </article>
- </section>
- </div>
- <nav>
- <h2><a href="index.html">Home</a></h2><h3>Modules</h3><ul><li><a href="module-barejs.html">barejs</a></li><li><a href="module-barejs_polyfill.html">barejs/polyfill</a></li><li><a href="module-barejs_polyfill_Intl.html">barejs/polyfill/Intl</a></li></ul><h3>Classes</h3><ul><li><a href="module-barejs.decl.html">decl</a></li><li><a href="module-barejs.decl-Enum.html">Enum</a></li><li><a href="module-barejs.decl-Interface.html">Interface</a></li><li><a href="module-barejs.decl-SpecialType.html">SpecialType</a></li><li><a href="module-barejs.Destroyable.html">Destroyable</a></li><li><a href="module-barejs.EventArgs.html">EventArgs</a></li><li><a href="module-barejs.Evented.html">Evented</a></li><li><a href="module-barejs.Evented-EventedHandle.html">EventedHandle</a></li><li><a href="module-barejs.Exception.html">Exception</a></li><li><a href="module-barejs_polyfill.Array.html">Array</a></li><li><a href="module-barejs_polyfill.Date.html">Date</a></li><li><a href="module-barejs_polyfill.EntryStore.html">EntryStore</a></li><li><a href="module-barejs_polyfill.EntryStore.Iterator.html">Iterator</a></li><li><a href="module-barejs_polyfill.Function.html">Function</a></li><li><a href="module-barejs_polyfill.Map.html">Map</a></li><li><a href="module-barejs_polyfill.Map-MapIterator.html">MapIterator</a></li><li><a href="module-barejs_polyfill.Math.html">Math</a></li><li><a href="module-barejs_polyfill.Number.html">Number</a></li><li><a href="module-barejs_polyfill.Object.html">Object</a></li><li><a href="module-barejs_polyfill.Promise.html">Promise</a></li><li><a href="module-barejs_polyfill.Set.html">Set</a></li><li><a href="module-barejs_polyfill.Set-SetIterator.html">SetIterator</a></li><li><a href="module-barejs_polyfill.String.html">String</a></li><li><a href="module-barejs_polyfill.Symbol.html">Symbol</a></li><li><a href="module-barejs_polyfill.WeakMap.html">WeakMap</a></li><li><a href="module-barejs_polyfill.WeakSet.html">WeakSet</a></li><li><a href="module-barejs_polyfill_Intl.DateTimeFormat.html">DateTimeFormat</a></li><li><a href="module-barejs_polyfill_Intl.DateTimeFormat-DateTimeFormatOptions.html">DateTimeFormatOptions</a></li><li><a href="module-barejs_polyfill_Intl.NumberFormat.html">NumberFormat</a></li><li><a href="module-barejs_polyfill_Intl.NumberFormat-NumberFormatOptions.html">NumberFormatOptions</a></li><li><a href="module-barejs_polyfill_Intl-Format.html">Format</a></li></ul>
- </nav>
- <br class="clear">
- <footer>
- Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.5.5</a> on Wed Oct 03 2018 15:59:34 GMT+0200 (W. Europe Daylight Time)
- </footer>
- <script> prettyPrint(); </script>
- <script src="scripts/linenumber.js"> </script>
- </body>
- </html>
|