/* Built-in method references for those with the same name as other `lodash` methods. */ var nativeMax = Math.max;

/**

* This function is like `composeArgs` except that the arguments composition
* is tailored for `_.partialRight`.
*
* @private
* @param {Array} args The provided arguments.
* @param {Array} partials The arguments to append to those provided.
* @param {Array} holders The `partials` placeholder indexes.
* @params {boolean} [isCurried] Specify composing for a curried function.
* @returns {Array} Returns the new array of composed arguments.
*/

function composeArgsRight(args, partials, holders, isCurried) {

var argsIndex = -1,
    argsLength = args.length,
    holdersIndex = -1,
    holdersLength = holders.length,
    rightIndex = -1,
    rightLength = partials.length,
    rangeLength = nativeMax(argsLength - holdersLength, 0),
    result = Array(rangeLength + rightLength),
    isUncurried = !isCurried;

while (++argsIndex < rangeLength) {
  result[argsIndex] = args[argsIndex];
}
var offset = argsIndex;
while (++rightIndex < rightLength) {
  result[offset + rightIndex] = partials[rightIndex];
}
while (++holdersIndex < holdersLength) {
  if (isUncurried || argsIndex < argsLength) {
    result[offset + holders[holdersIndex]] = args[argsIndex++];
  }
}
return result;

}

module.exports = composeArgsRight;