Преглед на файлове

Updated Finalize Script

Ayush Sharma преди 4 години
родител
ревизия
442b511a21
променени са 2 файла, в които са добавени 61 реда и са изтрити 55 реда
  1. 0 1
      src/webserial_webpage.h
  2. 61 54
      ui/finalize.js

Файловите разлики са ограничени, защото са твърде много
+ 0 - 1
src/webserial_webpage.h


+ 61 - 54
ui/finalize.js

@@ -1,66 +1,73 @@
-// Finalize Nodejs Script
-// 1 - Append JS in HTML Document
-// 2 - Gzip HTML
-// 3 - Covert to Raw Bytes
-// 4 - ( Save to File: webpage.h ) in dist Folder
+const { gzipAsync } = require('@gfx/zopfli');
+const FS = require('fs');
+const path = require('path');
 
-const fs = require('fs');
-const zlib = require('zlib');
-const { gzip } = require('@gfx/zopfli');
+const SAVE_PATH = '../src';
 
-function getByteArray(file){
-    let fileData = file.toString('hex');
-    let result = [];
-    for (let i = 0; i < fileData.length; i+=2)
-      result.push('0x'+fileData[i]+''+fileData[i+1]);
-    return result;
-}
-
-let js = fs.readFileSync(__dirname+'/dist/js/app.js');
-let html = `
-<!DOCTYPE html>
+const BUNDLE_JS = FS.readFileSync(path.resolve(__dirname, './dist/js/app.js'));
+const INDEX_HTML = 
+`<!DOCTYPE html>
 <html lang="en">
-  <head>
-    <meta charset="utf-8">
-    <meta http-equiv="X-UA-Compatible" content="IE=edge">
-    <meta name="viewport" content="width=device-width,initial-scale=1.0">
-    <title>WebSerial</title>
-    <script data-name="BMC-Widget" async src="https://cdnjs.buymeacoffee.com/1.0.0/widget.prod.min.js" data-id="6QGVpSj" data-description="Support me on Buy me a coffee!" data-message="You can always support my work by buying me a coffee!" data-color="#FF813F" data-position="right" data-x_margin="24" data-y_margin="24"></script>
-  </head>
-  <body>
-    <noscript>
-      <strong>We're sorry but WebSerial doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
-    </noscript>
-    <div id="app"></div>
-    <script>${js}</script>
-  </body>
+<head>
+	<meta charset='utf-8'>
+	<meta name='viewport' content='width=device-width,initial-scale=1'>
+	<title>WebSerial</title>
+  <script data-name="BMC-Widget" async src="https://cdnjs.buymeacoffee.com/1.0.0/widget.prod.min.js" data-id="6QGVpSj" data-description="Support me on Buy me a coffee!" data-message="You can always support my work by buying me a coffee!" data-color="#FF813F" data-position="right" data-x_margin="24" data-y_margin="24"></script>
+</head>
+<body>
+<div id="app"></div>
+<script>
+${BUNDLE_JS}
+</script>
+</body>
 </html>
-
 `;
-// Gzip the index.html file with JS Code.
-const gzippedIndex = zlib.gzipSync(html, {'level': zlib.constants.Z_BEST_COMPRESSION});
-let indexHTML = getByteArray(gzippedIndex);
 
-let source = 
-`
-const uint32_t WEBSERIAL_HTML_SIZE = ${indexHTML.length};
-const uint8_t WEBSERIAL_HTML[] PROGMEM = { ${indexHTML} };
-`;
+function chunkArray(myArray, chunk_size){
+  var index = 0;
+  var arrayLength = myArray.length;
+  var tempArray = [];
+  for (index = 0; index < arrayLength; index += chunk_size) {
+      myChunk = myArray.slice(index, index+chunk_size);
+      // Do something if you want with the group
+      tempArray.push(myChunk);
+  }
+  return tempArray;
+}
+
+function addLineBreaks(buffer){
+  let data = '';
+  let chunks = chunkArray(buffer, 30);
+  chunks.forEach((chunk, index) => {
+    data += chunk.join(',');
+    if(index+1 !== chunks.length){
+      data+=',\n';
+    }
+  });
+  return data;
+}
 
 
-fs.writeFileSync(__dirname+'/dist/webpage.h', source, 'utf8');
+(async function(){
+  try{
+    const GZIPPED_INDEX = await gzipAsync(INDEX_HTML, { numiterations: 15 });
 
-// Produce a second variant with zopfli
-// Zopfli is a improved zip algorithm by google
-// Takes much more time and maybe is not available on every machine
-const input =  html;
-gzip(input, {numiterations: 15}, (err, output) => {
-    indexHTML = output;
-    let source =
+    const FILE = 
 `
-const uint32_t WEBSERIAL_HTML_SIZE = ${indexHTML.length};
-const uint8_t WEBSERIAL_HTML[] PROGMEM = { ${indexHTML} };
+#ifndef _webserial_webapge_h
+#define _webserial_webpage_h
+
+const uint32_t WEBSERIAL_HTML_SIZE = ${GZIPPED_INDEX.length};
+const uint8_t WEBSERIAL_HTML[] PROGMEM = { 
+${ addLineBreaks(GZIPPED_INDEX) }
+};
+
+#endif
 `;
 
-  fs.writeFileSync(__dirname + '/dist/webpage_zopfli.h', source, 'utf8');
-});
+    FS.writeFileSync(path.resolve(__dirname, SAVE_PATH+'/webserial_webpage.h'), FILE);
+    console.log(`[COMPRESS.js] Compressed Bundle into webpage.h header file | Total Size: ${(GZIPPED_INDEX.length / 1024).toFixed(2) }KB`)
+  }catch(err){
+    return console.error(err);
+  }
+})();

Някои файлове не бяха показани, защото твърде много файлове са промени