X-Git-Url: https://git.josue.xyz/?a=blobdiff_plain;f=_webi%2Fnormalize.js;h=06c1ceec81e5f6043008698722a53cee60e344c0;hb=e2ade2382b346024c0f74092263230b488bf80e4;hp=df34ad2cd5aec75d469023ffb6243485be8b5fba;hpb=7f26649ebc86ec36da2d0e2de3517a92d1a71c4e;p=webi-installers%2F.git diff --git a/_webi/normalize.js b/_webi/normalize.js index df34ad2..06c1cee 100644 --- a/_webi/normalize.js +++ b/_webi/normalize.js @@ -38,13 +38,15 @@ var arches = [ 's390x' ]; var archMap = { - amd64: /(amd.?64|x64|[_\-]64)/i, - x86: /(86)(\b|_)/i, + //amd64: /(amd.?64|x64|[_\-]64)/i, + amd64: /(\b|_|amd|(dar)?win(dows)?|mac(os)?|linux|osx|x)64([_\-]?bit)?(\b|_)/i, + //x86: /(86)(\b|_)/i, + x86: /(\b|_|amd|(dar)?win(dows)?|mac(os)?|linux|osx|x)(86|32)([_\-]?bit)(\b|_)/i, ppc64le: /(\b|_)(ppc64le)/i, ppc64: /(\b|_)(ppc64)(\b|_)/i, - arm64: /(\b|_)(arm64|arm)/i, + arm64: /(\b|_)((aarch|arm)64|arm)/i, armv7l: /(\b|_)(armv?7l)/i, - armv6l: /(\b|_)(armv?6l)/i, + armv6l: /(\b|_)(aarch32|armv?6l)/i, s390x: /(\b|_)(s390x)/i }; arches.forEach(function (name) { @@ -86,8 +88,12 @@ function normalize(all) { // pkg-v1.0.tar.gz => ['gz', 'tar', '0', 'pkg-v1'] // pkg-v1.0.tar => ['tar', '0' ,'pkg-v1'] // pkg-v1.0.zip => ['zip', '0', 'pkg-v1'] - var exts = (rel.name || rel.download).split('.').reverse().slice(0, 2); - var ext; + var exts = (rel.name || rel.download).split('.'); + if (1 === exts.length) { + // for bare releases in the format of foo-linux-amd64 + rel.ext = 'exe'; + } + exts = exts.reverse().slice(0, 2); if ('tar' === exts[1]) { rel.ext = exts.reverse().join('.'); } else if ('tgz' == exts[0]) { @@ -95,6 +101,10 @@ function normalize(all) { } else { rel.ext = exts[0]; } + if (/\-|linux|mac|os[_\-]?x|arm|amd|86|64|mip/i.test(rel.ext)) { + // for bare releases in the format of foo.linux-amd64 + rel.ext = 'exe'; + } } supported.formats[rel.ext] = true;