|                                   |  | var root = require('./_root'),    toInteger = require('./toInteger'),    toNumber = require('./toNumber'),    toString = require('./toString');
/* Built-in method references for those with the same name as other `lodash` methods. */var nativeIsFinite = root.isFinite,    nativeMin = Math.min;
/** * Creates a function like `_.round`. * * @private * @param {string} methodName The name of the `Math` method to use when rounding. * @returns {Function} Returns the new round function. */function createRound(methodName) {  var func = Math[methodName];  return function(number, precision) {    number = toNumber(number);    precision = precision == null ? 0 : nativeMin(toInteger(precision), 292);    if (precision && nativeIsFinite(number)) {      // Shift with exponential notation to avoid floating-point issues.
      // See [MDN](https://mdn.io/round#Examples) for more details.
      var pair = (toString(number) + 'e').split('e'),          value = func(pair[0] + 'e' + (+pair[1] + precision));
      pair = (toString(value) + 'e').split('e');      return +(pair[0] + 'e' + (+pair[1] - precision));    }    return func(number);  };}
module.exports = createRound;
 |