'use strict'; const isEq = require('@codefeathers/iseq/isEq'); const Deck = require('./deck'); const wrap = (f, ...x) => (...y) => f(...x, ...y); class Slider { constructor (options) { this.windowSize = options.size; this.prefer = options.prefer; this.accepting = options.accepting; } slide (master, compare) { const k = this.windowSize; const host = Deck.from(master); const guest = Deck.from(compare); const startSliding = (window, i) => { const firstMatch = host.findIndex(wrap(isEq, window[0])); if(firstMatch !== -1 && window.every((item, j) => host.findIndexAfter( firstMatch, wrap(isEq, window[j]) )) !== -1 ) return [ firstMatch, i ]; const newWindow = Deck.from(guest.slice(++i, k)); if(newWindow.length !== 0 && newWindow.length === k) return startSliding(newWindow, i); return [ -1, -1 ]; }; const window = Deck.from(guest.slice(0, k)); const index = startSliding(window, 0); return index; } }; module.exports = Slider;