28 lines
		
	
	
		
			600 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			600 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
"use strict";
 | 
						|
 | 
						|
var toPosInt = require("../../number/to-pos-integer")
 | 
						|
  , callable = require("../../object/valid-callable")
 | 
						|
  , value    = require("../../object/valid-value")
 | 
						|
  , floor    = Math.floor;
 | 
						|
 | 
						|
module.exports = function (compareFn) {
 | 
						|
	var length, low, high, middle;
 | 
						|
 | 
						|
	value(this);
 | 
						|
	callable(compareFn);
 | 
						|
 | 
						|
	length = toPosInt(this.length);
 | 
						|
	low = 0;
 | 
						|
	high = length - 1;
 | 
						|
 | 
						|
	while (low <= high) {
 | 
						|
		middle = floor((low + high) / 2);
 | 
						|
		if (compareFn(this[middle]) < 0) high = middle - 1;
 | 
						|
		else low = middle + 1;
 | 
						|
	}
 | 
						|
 | 
						|
	if (high < 0) return 0;
 | 
						|
	if (high >= length) return length - 1;
 | 
						|
	return high;
 | 
						|
};
 |