mirror of https://github.com/espruino/BangleApps
ble_advert: debugging logs
parent
fc57f85eb4
commit
6a8d21980f
|
@ -1,4 +1,5 @@
|
||||||
declare let exports: any;
|
declare let exports: any;
|
||||||
|
declare let BLE_DEBUG: undefined | true;
|
||||||
|
|
||||||
type BleAdvert = { [key: string | number]: number[] };
|
type BleAdvert = { [key: string | number]: number[] };
|
||||||
type BangleWithAdvert = (typeof Bangle) & { bleAdvert?: BleAdvert | BleAdvert[]; };
|
type BangleWithAdvert = (typeof Bangle) & { bleAdvert?: BleAdvert | BleAdvert[]; };
|
||||||
|
@ -27,19 +28,31 @@ exports.set = (id: string | number, advert: number[], options?: SetAdvertisingOp
|
||||||
if(ad[id]){
|
if(ad[id]){
|
||||||
ad[id] = advert;
|
ad[id] = advert;
|
||||||
found = true;
|
found = true;
|
||||||
|
if(typeof BLE_DEBUG !== "undefined")
|
||||||
|
console.log(`bleAdvert is array, found existing entry for ${id}, replaced`)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!found)
|
if(!found){
|
||||||
bangle.bleAdvert.push({ [id]: advert });
|
bangle.bleAdvert.push({ [id]: advert });
|
||||||
|
if(typeof BLE_DEBUG !== "undefined")
|
||||||
|
console.log(`bleAdvert is array, no entry for ${id}, created`)
|
||||||
|
}
|
||||||
}else if(bangle.bleAdvert){
|
}else if(bangle.bleAdvert){
|
||||||
|
if(typeof BLE_DEBUG !== "undefined")
|
||||||
|
console.log(`bleAdvert is object, ${id} entry ${id in bangle.bleAdvert ? "replaced" : "created"}`);
|
||||||
bangle.bleAdvert[id] = advert;
|
bangle.bleAdvert[id] = advert;
|
||||||
}else{
|
}else{
|
||||||
|
if(typeof BLE_DEBUG !== "undefined")
|
||||||
|
console.log(`bleAdvert not present, created`);
|
||||||
bangle.bleAdvert = {
|
bangle.bleAdvert = {
|
||||||
[id]: advert,
|
[id]: advert,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(typeof BLE_DEBUG !== "undefined")
|
||||||
|
console.log(`NRF.setAdvertising({ ${Object.keys(bangle.bleAdvert).join(", ")} }, ${JSON.stringify(options)})`);
|
||||||
|
|
||||||
NRF.setAdvertising(clone(bangle.bleAdvert), options);
|
NRF.setAdvertising(clone(bangle.bleAdvert), options);
|
||||||
// clone the object, to avoid firmware behaving like so:
|
// clone the object, to avoid firmware behaving like so:
|
||||||
// bleAdvert = [Uint8Array, { [0x180f]: ... }]
|
// bleAdvert = [Uint8Array, { [0x180f]: ... }]
|
||||||
|
@ -59,6 +72,9 @@ exports.set = (id: string | number, advert: number[], options?: SetAdvertisingOp
|
||||||
exports.remove = (id: string | number, options?: SetAdvertisingOptions) => {
|
exports.remove = (id: string | number, options?: SetAdvertisingOptions) => {
|
||||||
const bangle = Bangle as BangleWithAdvert;
|
const bangle = Bangle as BangleWithAdvert;
|
||||||
|
|
||||||
|
if(typeof BLE_DEBUG !== "undefined")
|
||||||
|
console.log(`ble_advert.remove(${id}, ${JSON.stringify(options)})`);
|
||||||
|
|
||||||
if(Array.isArray(bangle.bleAdvert)){
|
if(Array.isArray(bangle.bleAdvert)){
|
||||||
let i = 0;
|
let i = 0;
|
||||||
for(const ad of bangle.bleAdvert){
|
for(const ad of bangle.bleAdvert){
|
||||||
|
|
Loading…
Reference in New Issue