parent
e6b8099d70
commit
2af5a73949
@ -1,241 +0,0 @@ |
|||||||
import { Crypto, load, _ } from './lib/cat.js'; |
|
||||||
|
|
||||||
let key = 'czzy'; |
|
||||||
let url = 'https://cz4k.com'; |
|
||||||
let siteKey = ''; |
|
||||||
let siteType = 0; |
|
||||||
|
|
||||||
const UA = 'Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1'; |
|
||||||
|
|
||||||
const cookie = {}; |
|
||||||
|
|
||||||
async function request(reqUrl, referer, mth, data, hd) { |
|
||||||
const headers = { |
|
||||||
'User-Agent': UA, |
|
||||||
Cookie: _.map(cookie, (value, key) => { |
|
||||||
return `${key}=${value}`; |
|
||||||
}).join(';'), |
|
||||||
}; |
|
||||||
if (referer) headers.referer = encodeURIComponent(referer); |
|
||||||
let res = await req(reqUrl, { |
|
||||||
method: mth || 'get', |
|
||||||
headers: headers, |
|
||||||
data: data, |
|
||||||
postType: mth === 'post' ? 'form' : '', |
|
||||||
}); |
|
||||||
if (res.headers['set-cookie']) { |
|
||||||
const set_cookie = _.isArray(res.headers['set-cookie']) ? res.headers['set-cookie'].join(';') : res.headers['set-cookie']; |
|
||||||
const cks = set_cookie.split(';'); |
|
||||||
for (const c of cks) { |
|
||||||
const tmp = c.trim(); |
|
||||||
if (tmp.startsWith('result=')) { |
|
||||||
cookie.result = tmp.substring(7); |
|
||||||
return await request(reqUrl, reqUrl, 'post', { |
|
||||||
result: cookie.result, |
|
||||||
}); |
|
||||||
} else if (tmp.startsWith('esc_search_captcha=1')) { |
|
||||||
cookie.esc_search_captcha = 1; |
|
||||||
delete cookie.result; |
|
||||||
return await request(reqUrl); |
|
||||||
} |
|
||||||
} |
|
||||||
// console.log(res.headers['set-cookie']);
|
|
||||||
} |
|
||||||
return res.content; |
|
||||||
} |
|
||||||
|
|
||||||
// cfg = {skey: siteKey, ext: extend}
|
|
||||||
async function init(cfg) { |
|
||||||
siteKey = cfg.skey; |
|
||||||
siteType = cfg.stype; |
|
||||||
} |
|
||||||
|
|
||||||
async function home(filter) { |
|
||||||
let filterObj = {}; |
|
||||||
const html = await request(url + '/movie_bt'); |
|
||||||
const $ = load(html); |
|
||||||
const series = $('div#beautiful-taxonomy-filters-tax-movie_bt_series > a[cat-url*=movie_bt_series]'); |
|
||||||
const tags = $('div#beautiful-taxonomy-filters-tax-movie_bt_tags > a'); |
|
||||||
let tag = { |
|
||||||
key: 'tag', |
|
||||||
name: '类型', |
|
||||||
value: _.map(tags, (n) => { |
|
||||||
let v = n.attribs['cat-url'] || ''; |
|
||||||
v = v.substring(v.lastIndexOf('/') + 1); |
|
||||||
return { n: n.children[0].data, v: v }; |
|
||||||
}), |
|
||||||
}; |
|
||||||
tag['init'] = tag.value[0].v; |
|
||||||
let classes = _.map(series, (s) => { |
|
||||||
let typeId = s.attribs['cat-url']; |
|
||||||
typeId = typeId.substring(typeId.lastIndexOf('/') + 1); |
|
||||||
filterObj[typeId] = [tag]; |
|
||||||
return { |
|
||||||
type_id: typeId, |
|
||||||
type_name: s.children[0].data, |
|
||||||
}; |
|
||||||
}); |
|
||||||
const sortName = ['电影', '电视剧', '国产剧', '美剧', '韩剧', '日剧', '海外剧(其他)', '华语电影', '印度电影', '日本电影', '欧美电影', '韩国电影', '动画', '俄罗斯电影', '加拿大电影']; |
|
||||||
classes = _.sortBy(classes, (c) => { |
|
||||||
const index = sortName.indexOf(c.type_name); |
|
||||||
return index === -1 ? sortName.length : index; |
|
||||||
}); |
|
||||||
return JSON.stringify({ |
|
||||||
class: classes, |
|
||||||
filters: filterObj, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
async function homeVod() { |
|
||||||
return '{}'; |
|
||||||
} |
|
||||||
|
|
||||||
async function category(tid, pg, filter, extend) { |
|
||||||
if (pg <= 0) pg = 1; |
|
||||||
const tag = extend.tag || ''; |
|
||||||
const link = url + '/movie_bt' + (tag.length > 0 ? `/movie_bt_tags/${tag}` : '') + '/movie_bt_series/' + tid + (pg > 1 ? `/page/${pg}` : ''); |
|
||||||
const html = await request(link); |
|
||||||
const $ = load(html); |
|
||||||
const items = $('div.mrb > ul > li'); |
|
||||||
let videos = _.map(items, (item) => { |
|
||||||
const img = $(item).find('img:first')[0]; |
|
||||||
const a = $(item).find('a:first')[0]; |
|
||||||
const hdinfo = $($(item).find('div.hdinfo')[0]).text().trim(); |
|
||||||
const jidi = $($(item).find('div.jidi')[0]).text().trim(); |
|
||||||
return { |
|
||||||
vod_id: a.attribs.href.replace(/.*?\/movie\/(.*).html/g, '$1'), |
|
||||||
vod_name: img.attribs.alt, |
|
||||||
vod_pic: img.attribs['data-original'], |
|
||||||
vod_remarks: jidi || hdinfo || '', |
|
||||||
}; |
|
||||||
}); |
|
||||||
const hasMore = $('div.mrb > div.pagenavi_txt > a:contains(>)').length > 0; |
|
||||||
const pgCount = hasMore ? parseInt(pg) + 1 : parseInt(pg); |
|
||||||
return JSON.stringify({ |
|
||||||
page: parseInt(pg), |
|
||||||
pagecount: pgCount, |
|
||||||
limit: 20, |
|
||||||
total: 20 * pgCount, |
|
||||||
list: videos, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
function stripHtmlTag(src) { |
|
||||||
return src |
|
||||||
.replace(/<\/?[^>]+(>|$)/g, '') |
|
||||||
.replace(/&.{1,5};/g, '') |
|
||||||
.replace(/\s{2,}/g, ' '); |
|
||||||
} |
|
||||||
|
|
||||||
async function detail(id) { |
|
||||||
const html = await request(url + '/movie/' + id + '.html'); |
|
||||||
const $ = load(html); |
|
||||||
const detail = $('ul.moviedteail_list > li'); |
|
||||||
let vod = { |
|
||||||
vod_id: id, |
|
||||||
vod_name: $('div.moviedteail_tt > h1').text().trim(), |
|
||||||
vod_pic: $('div.dyimg img:first').attr('src'), |
|
||||||
vod_remarks: '', |
|
||||||
vod_content: stripHtmlTag($('div.yp_context').html()).trim(), |
|
||||||
}; |
|
||||||
for (const info of detail) { |
|
||||||
const i = $(info).text().trim(); |
|
||||||
if (i.startsWith('地区:')) { |
|
||||||
vod.vod_area = i.substring(3); |
|
||||||
} else if (i.startsWith('年份:')) { |
|
||||||
vod.vod_year = i.substring(3); |
|
||||||
} else if (i.startsWith('导演:')) { |
|
||||||
vod.vod_director = _.map($(info).find('a'), (a) => { |
|
||||||
return a.children[0].data; |
|
||||||
}).join('/'); |
|
||||||
} else if (i.startsWith('主演:')) { |
|
||||||
vod.vod_actor = _.map($(info).find('a'), (a) => { |
|
||||||
return a.children[0].data; |
|
||||||
}).join('/'); |
|
||||||
} else if (i.startsWith('语言:')) { |
|
||||||
vod.vod_lang = i.substring(3); |
|
||||||
} |
|
||||||
} |
|
||||||
const playlist = _.map($('div.paly_list_btn > a'), (a) => { |
|
||||||
return a.children[0].data + '$' + a.attribs.href.replace(/.*?\/v_play\/(.*).html/g, '$1'); |
|
||||||
}); |
|
||||||
vod.vod_play_from = key; |
|
||||||
vod.vod_play_url = playlist.join('#'); |
|
||||||
return JSON.stringify({ |
|
||||||
list: [vod], |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
async function play(flag, id, flags) { |
|
||||||
const link = url + '/v_play/' + id + '.html'; |
|
||||||
const html = await request(link); |
|
||||||
const $ = load(html); |
|
||||||
const iframe = $('body iframe[src*=Cloud]'); |
|
||||||
if (iframe.length > 0) { |
|
||||||
const iframeHtml = ( |
|
||||||
await req(iframe[0].attribs.src, { |
|
||||||
headers: { |
|
||||||
Referer: link, |
|
||||||
'User-Agent': UA, |
|
||||||
}, |
|
||||||
}) |
|
||||||
).content; |
|
||||||
let code = iframeHtml |
|
||||||
.match(/var url = '(.*?)'/)[1] |
|
||||||
.split('') |
|
||||||
.reverse() |
|
||||||
.join(''); |
|
||||||
let temp = ''; |
|
||||||
for (let i = 0x0; i < code.length; i = i + 0x2) { |
|
||||||
temp += String.fromCharCode(parseInt(code[i] + code[i + 0x1], 0x10)); |
|
||||||
} |
|
||||||
const playUrl = temp.substring(0x0, (temp.length - 0x7) / 0x2) + temp.substring((temp.length - 0x7) / 0x2 + 0x7); |
|
||||||
return JSON.stringify({ |
|
||||||
parse: 0, |
|
||||||
url: playUrl, |
|
||||||
}); |
|
||||||
} else { |
|
||||||
const js = $('script:contains(window.wp_nonce)').html(); |
|
||||||
const group = js.match(/(var.*)eval\((\w*\(\w*\))\)/); |
|
||||||
const md5 = Crypto; |
|
||||||
const result = eval(group[1] + group[2]); |
|
||||||
const playUrl = result.match(/url:.*?['"](.*?)['"]/)[1]; |
|
||||||
return JSON.stringify({ |
|
||||||
parse: 0, |
|
||||||
url: playUrl, |
|
||||||
}); |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
async function search(wd, quick) { |
|
||||||
const html = await request(url + '/?s=' + wd); |
|
||||||
const $ = load(html); |
|
||||||
const items = $('div.search_list > ul > li'); |
|
||||||
let videos = _.map(items, (item) => { |
|
||||||
const img = $(item).find('img:first')[0]; |
|
||||||
const a = $(item).find('a:first')[0]; |
|
||||||
const hdinfo = $($(item).find('div.hdinfo')[0]).text().trim(); |
|
||||||
const jidi = $($(item).find('div.jidi')[0]).text().trim(); |
|
||||||
return { |
|
||||||
vod_id: a.attribs.href.replace(/.*?\/movie\/(.*).html/g, '$1'), |
|
||||||
vod_name: img.attribs.alt, |
|
||||||
vod_pic: img.attribs['data-original'], |
|
||||||
vod_remarks: jidi || hdinfo || '', |
|
||||||
}; |
|
||||||
}); |
|
||||||
return JSON.stringify({ |
|
||||||
list: videos, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
export function __jsEvalReturn() { |
|
||||||
return { |
|
||||||
init: init, |
|
||||||
home: home, |
|
||||||
homeVod: homeVod, |
|
||||||
category: category, |
|
||||||
detail: detail, |
|
||||||
play: play, |
|
||||||
search: search, |
|
||||||
}; |
|
||||||
} |
|
||||||
@ -1,203 +0,0 @@ |
|||||||
import { Crypto, load, _ } from './lib/cat.js'; |
|
||||||
|
|
||||||
let key = 'ikanbot'; |
|
||||||
let url = 'https://www.ikanbot.com'; |
|
||||||
let siteKey = ''; |
|
||||||
let siteType = 0; |
|
||||||
|
|
||||||
const UA = 'Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1'; |
|
||||||
|
|
||||||
async function request(reqUrl, agentSp) { |
|
||||||
let res = await req(reqUrl, { |
|
||||||
method: 'get', |
|
||||||
headers: { |
|
||||||
'User-Agent': agentSp || UA, |
|
||||||
}, |
|
||||||
}); |
|
||||||
return res.content; |
|
||||||
} |
|
||||||
|
|
||||||
// cfg = {skey: siteKey, ext: extend}
|
|
||||||
async function init(cfg) { |
|
||||||
siteKey = cfg.skey; |
|
||||||
siteType = cfg.stype; |
|
||||||
} |
|
||||||
|
|
||||||
function getClass($) { |
|
||||||
const nav = $('ul.nav-pills:eq(1) > li > a'); |
|
||||||
let tags = { |
|
||||||
key: 'tag', |
|
||||||
name: '标签', |
|
||||||
value: _.map(nav, (n) => { |
|
||||||
return { n: n.children[0].data, v: n.attribs.href }; |
|
||||||
}), |
|
||||||
}; |
|
||||||
tags['init'] = tags.value[0].v; |
|
||||||
const title = $('title:first').text().split('-')[0].substring(2); |
|
||||||
return { cls: { type_id: tags.value[0].v, type_name: title }, tags: [tags] }; |
|
||||||
} |
|
||||||
|
|
||||||
async function home(filter) { |
|
||||||
let classes = []; |
|
||||||
let filterObj = {}; |
|
||||||
for (const cate of ['/hot/index-movie-热门.html', '/hot/index-tv-热门.html']) { |
|
||||||
const html = await request(url + cate); |
|
||||||
const $ = load(html); |
|
||||||
const { cls, tags } = getClass($); |
|
||||||
classes.push(cls); |
|
||||||
filterObj[cls.type_id] = tags; |
|
||||||
} |
|
||||||
return JSON.stringify({ |
|
||||||
class: classes, |
|
||||||
filters: filterObj, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
async function homeVod() { |
|
||||||
return '{}'; |
|
||||||
} |
|
||||||
|
|
||||||
async function category(tid, pg, filter, extend) { |
|
||||||
if (pg <= 0) pg = 1; |
|
||||||
const link = url + (extend.tag || tid).replace('.html', pg > 1 ? `-p-${pg}.html` : '.html'); |
|
||||||
const html = await request(link); |
|
||||||
const $ = load(html); |
|
||||||
const items = $('div.v-list a.item'); |
|
||||||
var jsBase = await js2Proxy(true, siteType, siteKey, 'img/', {}); |
|
||||||
let videos = _.map(items, (item) => { |
|
||||||
const img = $(item).find('img:first')[0]; |
|
||||||
return { |
|
||||||
vod_id: item.attribs.href, |
|
||||||
vod_name: img.attribs.alt, |
|
||||||
vod_pic: jsBase + base64Encode(img.attribs['data-src']), |
|
||||||
vod_remarks: '', |
|
||||||
}; |
|
||||||
}); |
|
||||||
const hasMore = $('div.page-more > a:contains(下一页)').length > 0; |
|
||||||
const pgCount = hasMore ? parseInt(pg) + 1 : parseInt(pg); |
|
||||||
return JSON.stringify({ |
|
||||||
page: parseInt(pg), |
|
||||||
pagecount: pgCount, |
|
||||||
limit: 24, |
|
||||||
total: 24 * pgCount, |
|
||||||
list: videos, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
async function detail(id) { |
|
||||||
const html = await request(url + id); |
|
||||||
const $ = load(html); |
|
||||||
var jsBase = await js2Proxy(true, siteType, siteKey, 'img/', {}); |
|
||||||
const detail = $('div.detail > .meta'); |
|
||||||
let vod = { |
|
||||||
vod_id: id, |
|
||||||
vod_pic: jsBase + base64Encode($('div.item-root > img')[0].attribs['data-src']), |
|
||||||
vod_remarks: '', |
|
||||||
}; |
|
||||||
for (const info of detail) { |
|
||||||
if ($(info).hasClass('title')) { |
|
||||||
vod.vod_name = info.children[0].data; |
|
||||||
} else if ($(info).hasClass('year')) { |
|
||||||
vod.vod_area = info.children[0].data; |
|
||||||
} else if ($(info).hasClass('country')) { |
|
||||||
vod.vod_area = info.children[0].data; |
|
||||||
} else if ($(info).hasClass('celebrity')) { |
|
||||||
vod.vod_actor = info.children[0].data; |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
const res = await req(url + '/api/getResN?videoId=' + id.substring(id.lastIndexOf('/') + 1) + '&mtype=2', { |
|
||||||
headers: { |
|
||||||
Referer: url, |
|
||||||
'User-Agent': UA, |
|
||||||
}, |
|
||||||
}); |
|
||||||
const list = JSON.parse(res.content).data.list; |
|
||||||
let playlist = {}; |
|
||||||
for (const l of list) { |
|
||||||
const flagData = JSON.parse(l.resData); |
|
||||||
for (const f of flagData) { |
|
||||||
const from = f.flag; |
|
||||||
const urls = f.url; |
|
||||||
if (!from || !urls) continue; |
|
||||||
if (playlist[from]) continue; |
|
||||||
playlist[from] = urls; |
|
||||||
} |
|
||||||
} |
|
||||||
vod.vod_play_from = _.keys(playlist).join('$$$'); |
|
||||||
vod.vod_play_url = _.values(playlist).join('$$$'); |
|
||||||
return JSON.stringify({ |
|
||||||
list: [vod], |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
function base64Encode(text) { |
|
||||||
return Crypto.enc.Base64.stringify(Crypto.enc.Utf8.parse(text)); |
|
||||||
} |
|
||||||
|
|
||||||
function base64Decode(text) { |
|
||||||
return Crypto.enc.Utf8.stringify(Crypto.enc.Base64.parse(text)); |
|
||||||
} |
|
||||||
|
|
||||||
async function proxy(segments, headers) { |
|
||||||
let what = segments[0]; |
|
||||||
let url = base64Decode(segments[1]); |
|
||||||
if (what == 'img') { |
|
||||||
var resp = await req(url, { |
|
||||||
buffer: 2, |
|
||||||
headers: { |
|
||||||
Referer: url, |
|
||||||
'User-Agent': UA, |
|
||||||
}, |
|
||||||
}); |
|
||||||
return JSON.stringify({ |
|
||||||
code: resp.code, |
|
||||||
buffer: 2, |
|
||||||
content: resp.content, |
|
||||||
headers: resp.headers, |
|
||||||
}); |
|
||||||
} |
|
||||||
return JSON.stringify({ |
|
||||||
code: 500, |
|
||||||
content: '', |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
async function play(flag, id, flags) { |
|
||||||
return JSON.stringify({ |
|
||||||
parse: 0, |
|
||||||
url: id, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
async function search(wd, quick) { |
|
||||||
const html = await request(url + '/search?q=' + wd); |
|
||||||
const $ = load(html); |
|
||||||
const items = $('div.media > div.media-left > a'); |
|
||||||
var jsBase = await js2Proxy(true, siteType, siteKey, 'img/', {}); |
|
||||||
let videos = _.map(items, (item) => { |
|
||||||
const img = $(item).find('img:first')[0]; |
|
||||||
return { |
|
||||||
vod_id: item.attribs.href, |
|
||||||
vod_name: img.attribs.alt, |
|
||||||
vod_pic: jsBase + base64Encode(img.attribs['data-src']), |
|
||||||
vod_remarks: '', |
|
||||||
}; |
|
||||||
}); |
|
||||||
return JSON.stringify({ |
|
||||||
list: videos, |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
export function __jsEvalReturn() { |
|
||||||
return { |
|
||||||
init: init, |
|
||||||
home: home, |
|
||||||
homeVod: homeVod, |
|
||||||
category: category, |
|
||||||
detail: detail, |
|
||||||
play: play, |
|
||||||
proxy: proxy, |
|
||||||
search: search, |
|
||||||
}; |
|
||||||
} |
|
||||||
File diff suppressed because one or more lines are too long
@ -1,47 +0,0 @@ |
|||||||
function compareTwoStrings(first, second) { |
|
||||||
if ((first = first.replace(/\s+/g, '')) === (second = second.replace(/\s+/g, ''))) return 1; |
|
||||||
if (first.length < 2 || second.length < 2) return 0; |
|
||||||
var firstBigrams = new Map(); |
|
||||||
for (let i = 0; i < first.length - 1; i++) { |
|
||||||
var bigram = first.substring(i, i + 2), |
|
||||||
count = firstBigrams.has(bigram) ? firstBigrams.get(bigram) + 1 : 1; |
|
||||||
firstBigrams.set(bigram, count); |
|
||||||
} |
|
||||||
let intersectionSize = 0; |
|
||||||
for (let i = 0; i < second.length - 1; i++) { |
|
||||||
const bigram = second.substring(i, i + 2), |
|
||||||
count = firstBigrams.has(bigram) ? firstBigrams.get(bigram) : 0; |
|
||||||
0 < count && (firstBigrams.set(bigram, count - 1), intersectionSize++); |
|
||||||
} |
|
||||||
return (2 * intersectionSize) / (first.length + second.length - 2); |
|
||||||
} |
|
||||||
function findBestMatch(mainString, targetStrings) { |
|
||||||
var ratings = []; |
|
||||||
let bestMatchIndex = 0; |
|
||||||
for (let i = 0; i < targetStrings.length; i++) { |
|
||||||
var currentTargetString = targetStrings[i], |
|
||||||
currentRating = compareTwoStrings(mainString, currentTargetString); |
|
||||||
ratings.push({ target: currentTargetString, rating: currentRating }), currentRating > ratings[bestMatchIndex].rating && (bestMatchIndex = i); |
|
||||||
} |
|
||||||
return { ratings: ratings, bestMatch: ratings[bestMatchIndex], bestMatchIndex: bestMatchIndex }; |
|
||||||
} |
|
||||||
function lcs(str1, str2) { |
|
||||||
if (!str1 || !str2) return { length: 0, sequence: '', offset: 0 }; |
|
||||||
for (var sequence = '', str1Length = str1.length, str2Length = str2.length, num = new Array(str1Length), maxlen = 0, lastSubsBegin = 0, i = 0; i < str1Length; i++) { |
|
||||||
for (var subArray = new Array(str2Length), j = 0; j < str2Length; j++) subArray[j] = 0; |
|
||||||
num[i] = subArray; |
|
||||||
} |
|
||||||
for (var thisSubsBegin = null, i = 0; i < str1Length; i++) for (j = 0; j < str2Length; j++) str1[i] !== str2[j] ? (num[i][j] = 0) : ((num[i][j] = 0 === i || 0 === j ? 1 : 1 + num[i - 1][j - 1]), num[i][j] > maxlen && ((maxlen = num[i][j]), lastSubsBegin === (thisSubsBegin = i - num[i][j] + 1) ? (sequence += str1[i]) : ((lastSubsBegin = thisSubsBegin), (sequence = ''), (sequence += str1.substr(lastSubsBegin, i + 1 - lastSubsBegin))))); |
|
||||||
return { length: maxlen, sequence: sequence, offset: thisSubsBegin }; |
|
||||||
} |
|
||||||
function findBestLCS(mainString, targetStrings) { |
|
||||||
var results = []; |
|
||||||
let bestMatchIndex = 0; |
|
||||||
for (let i = 0; i < targetStrings.length; i++) { |
|
||||||
var currentTargetString = targetStrings[i], |
|
||||||
currentLCS = lcs(mainString, currentTargetString); |
|
||||||
results.push({ target: currentTargetString, lcs: currentLCS }), currentLCS.length > results[bestMatchIndex].lcs.length && (bestMatchIndex = i); |
|
||||||
} |
|
||||||
return { allLCS: results, bestMatch: results[bestMatchIndex], bestMatchIndex: bestMatchIndex }; |
|
||||||
} |
|
||||||
export { compareTwoStrings, findBestMatch, findBestLCS }; |
|
||||||
Loading…
Reference in new issue