burn the logs and use 'install.bash'
[webi-installers/.git] / _common / normalize.js
index 6a0830f15405774672f4016b0bb3ebf3dcf90076..dac09020a7f4473ebfd917ecf3144bb3a0ac1791 100644 (file)
@@ -2,11 +2,12 @@
 
 // this may need customizations between packages
 const osMap = {
-  macos: /\b(apple|mac|darwin|iPhone|iOS|iPad)/i,
-  linux: /\b(linux)/i,
-  windows: /\b(win|microsoft|msft)/i,
-  sunos: /\b(sun)/i,
-  aix: /\b(aix)/i
+  macos: /(\b|_)(apple|mac|darwin|iPhone|iOS|iPad)/i,
+  linux: /(\b|_)(linux)/i,
+  freebsd: /(\b|_)(freebsd)/i,
+  windows: /(\b|_)(win|microsoft|msft)/i,
+  sunos: /(\b|_)(sun)/i,
+  aix: /(\b|_)(aix)/i
 };
 
 // evaluation order matters
@@ -23,29 +24,41 @@ var archArr = [
 ];
 var archMap = {
   amd64: /(amd.?64|x64|[_\-]64)/i,
-  x86: /(86)\b/i,
-  ppc64le: /\b(ppc64le)/i,
-  ppc64: /\b(ppc64)\b/i,
-  arm64: /\b(arm64|arm)/i,
-  armv7l: /\b(armv?7l)/i,
-  armv6l: /\b(armv?6l)/i,
-  s390x: /\b(s390x)/i
+  x86: /(86)(\b|_)/i,
+  ppc64le: /(\b|_)(ppc64le)/i,
+  ppc64: /(\b|_)(ppc64)(\b|_)/i,
+  arm64: /(\b|_)(arm64|arm)/i,
+  armv7l: /(\b|_)(armv?7l)/i,
+  armv6l: /(\b|_)(armv?6l)/i,
+  s390x: /(\b|_)(s390x)/i
 };
 
 function normalize(all) {
   all.releases.forEach(function (rel) {
+    rel.version = rel.version.replace(/^v/i, '');
+    if (!rel.name) {
+      rel.name = rel.download.replace(/.*\//, '');
+    }
     if (!rel.os) {
       rel.os =
         Object.keys(osMap).find(function (regKey) {
-          //console.log('release os:', rel.download, regKey, osMap[regKey]);
-          return osMap[regKey].test(rel.download);
+          /* console.log(
+            'release os:',
+            regKey,
+            osMap[regKey],
+            osMap[regKey].test(rel.name || rel.download),
+            rel.name,
+            rel.download
+          );
+          // */
+          return osMap[regKey].test(rel.name || rel.download);
         }) || 'unknown';
     }
 
     if (!rel.arch) {
       archArr.some(function (regKey) {
         //console.log('release arch:', rel.download, regKey, archMap[regKey]);
-        var arch = rel.download.match(archMap[regKey]) && regKey;
+        var arch = (rel.name || rel.download).match(archMap[regKey]) && regKey;
         if (arch) {
           rel.arch = arch;
           return true;
@@ -57,7 +70,7 @@ 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.download.split('.').reverse().slice(0, 2);
+      var exts = (rel.name || rel.download).split('.').reverse().slice(0, 2);
       var ext;
       if ('tar' === exts[1]) {
         rel.ext = exts.reverse().join('.');
@@ -69,7 +82,7 @@ function normalize(all) {
     }
 
     if (all.download) {
-       rel.download = all.download.replace(/{{ download }}/, rel.download);
+      rel.download = all.download.replace(/{{ download }}/, rel.download);
     }
   });
   return all;