From ec95ffd1b7554d2c5d731c48e9fbffb39db49a7b Mon Sep 17 00:00:00 2001 From: Gordon Williams Date: Wed, 4 Dec 2024 16:54:13 +0000 Subject: [PATCH] Adding code to make Bangle's connection device configurable --- js/comms.js | 26 ++++++++++++++------------ js/utils.js | 3 +++ 2 files changed, 17 insertions(+), 12 deletions(-) diff --git a/js/comms.js b/js/comms.js index 0485694..d87a7fe 100644 --- a/js/comms.js +++ b/js/comms.js @@ -124,7 +124,7 @@ const Comms = { } // Actually write the command with a 'print OK' at the end, and use responseHandler // to deal with the response. If OK we call uploadCmd to upload the next block - Puck.write(`${cmd};${Comms.getProgressCmd(currentBytes / maxBytes)}Bluetooth.println("OK")\n`,responseHandler, true /* wait for a newline*/); + Puck.write(`${cmd};${Comms.getProgressCmd(currentBytes / maxBytes)}${Const.CONNECTION_DEVICE}.println("OK")\n`,responseHandler, true /* wait for a newline*/); } uploadCmd() @@ -240,11 +240,12 @@ const Comms = { return; } - let cmd, finalJS = `JSON.stringify(require("Storage").getStats?require("Storage").getStats():{})+","+E.toJS([process.env.BOARD,process.env.VERSION,process.env.EXPTR,process.env.MODULES,0|getTime(),E.CRC32(getSerial()+NRF.getAddress())]).substr(1)`; + let cmd, finalJS = `JSON.stringify(require("Storage").getStats?require("Storage").getStats():{})+","+E.toJS([process.env.BOARD,process.env.VERSION,process.env.EXPTR,process.env.MODULES,0|getTime(),E.CRC32(getSerial()+(global.NRF?NRF.getAddress():0))]).substr(1)`; + let device = Const.CONNECTION_DEVICE; if (Const.SINGLE_APP_ONLY) // only one app on device, info file is in app.info - cmd = `\x10Bluetooth.println("["+(require("Storage").read("app.info")||"null")+","+${finalJS})\n`; + cmd = `\x10${device}.println("["+(require("Storage").read("app.info")||"null")+","+${finalJS})\n`; else - cmd = `\x10Bluetooth.print("[");require("Storage").list(/\\.info$/).forEach(f=>{var j=require("Storage").readJSON(f,1)||{};Bluetooth.print(JSON.stringify({id:f.slice(0,-5),version:j.version,files:j.files,data:j.data,type:j.type})+",")});Bluetooth.println(${finalJS})\n`; + cmd = `\x10${device}.print("[");require("Storage").list(/\\.info$/).forEach(f=>{var j=require("Storage").readJSON(f,1)||{};${device}.print(JSON.stringify({id:f.slice(0,-5),version:j.version,files:j.files,data:j.data,type:j.type})+",")});${device}.println(${finalJS})\n`; Puck.write(cmd, (appListStr,err) => { Progress.hide({sticky:true}); // we may have received more than one line - we're looking for an array (starting with '[') @@ -252,6 +253,7 @@ const Comms = { var appListJSON = lines.find(l => l[0]=="["); // check to see if we got our data if (!appListJSON) { + console.log("No JSON, just got: "+JSON.stringify(appListStr)); return reject("No response from device. Is 'Programmable' set to 'Off'?"); } // now try and parse @@ -285,7 +287,7 @@ const Comms = { }, // Get an app's info file from Bangle.js getAppInfo : app => { - return Comms.write(`\x10Bluetooth.println(require("Storage").read(${JSON.stringify(AppInfo.getAppInfoFilename(app))})||"null")\n`). + return Comms.write(`\x10${Const.CONNECTION_DEVICE}.println(require("Storage").read(${JSON.stringify(AppInfo.getAppInfoFilename(app))})||"null")\n`). then(appJSON=>{ let app; try { @@ -371,7 +373,7 @@ const Comms = { } } // Use write with newline here so we wait for it to finish - let cmd = '\x10E.showMessage("Erasing...");require("Storage").eraseAll();Bluetooth.println("OK");reset()\n'; + let cmd = `\x10E.showMessage("Erasing...");require("Storage").eraseAll();${Const.CONNECTION_DEVICE}.println("OK");reset()\n`; Puck.write(cmd, handleResult, true /* wait for newline */); }).then(() => new Promise(resolve => { console.log(" removeAllApps: Erase complete, waiting 500ms for 'reset()'"); @@ -489,9 +491,9 @@ const Comms = { return Comms.readTextBlock(`\x03\x10(function() { var s = require("Storage").read(${JSON.stringify(filename)}); if (s===undefined) s=""; -Bluetooth.println(((s.length+2)/3)<<2); -for (var i=0;i { return atobSafe(text); }); @@ -502,10 +504,10 @@ Bluetooth.print("\\xFF"); console.log(` readStorageFile ${JSON.stringify(filename)}`); return Comms.readTextBlock(`\x03\x10(function() { var f = require("Storage").open(${JSON.stringify(filename)},"r"); - Bluetooth.println(f.getLength()); + ${Const.CONNECTION_DEVICE}.println(f.getLength()); var l = f.readLine(); - while (l!==undefined) { Bluetooth.print(l); l = f.readLine(); } - Bluetooth.print("\\xFF"); + while (l!==undefined) { ${Const.CONNECTION_DEVICE}.print(l); l = f.readLine(); } + ${Const.CONNECTION_DEVICE}.print("\\xFF"); })()\n`); }, // Read a non-storagefile file diff --git a/js/utils.js b/js/utils.js index 400180a..3ccb2f9 100644 --- a/js/utils.js +++ b/js/utils.js @@ -23,6 +23,9 @@ const Const = { /* Message to display when an app has been loaded */ MESSAGE_RELOAD : 'Hold BTN3\nto reload', + /* What device are we connecting to Espruino with? */ + CONNECTION_DEVICE : 'Bluetooth', + /* The code to upload to the device show a progress bar on the screen (should define a fn. called 'p') */ CODE_PROGRESSBAR : "g.drawRect(10,g.getHeight()-16,g.getWidth()-10,g.getHeight()-8).flip();p=x=>g.fillRect(10,g.getHeight()-16,10+(g.getWidth()-20)*x/100,g.getHeight()-8).flip();",