It's just because I'm trying to do the bare minimum inside the IRQ. So the IRQ (first one) only allocates the data it needs - then outside of an IRQ it does more allocation.
In your case it works well, because you should be able to use the existing code in jswrap_bluetooth as-is?
setScan is defined as nrf.setScan. This is the way how all the descriptions are done. IMHO it would be a kind of confusing for users of other boards to use a nrf command. I could imagine to add one more wrapper which connects the same function to Bluetooth Object. Same for setServices etc.
Yes, I know. I think eventually I'd change NRF to be BLE or Bluetooth and would then make NRF==BLE on nRF5x devices to be compatible.
would this option add too much overhead
Not if done right - I wouldn't add 'shadow' functions though - that would use up a bit more memory for no real reason.
is there any other reason not to do it ?
Not really - but for the moment I'd leave it as NRF so as not to confuse your porting efforts - and then at some point soon I can change that in main Espruino branch.
If it really irks you, perhaps you could just execute the code var BLE=NRF at boot time on ESP32 for now?
BluetoothUtils holds a lot of helpful functions, which could be used for other boards as well. As far as I understand, there are also some nrf only functions in. could we split this into 2 files, BluetoothUtil and nrfUtil for example ? or ifdef the nrf relevant function ?
nrfUtil is basically what bluetooth.c should be? Board-specific bluetooth functions.
Currently bluetooth_utils.c does have some ifdefs, but they're in what should hopefully be quite generic functions like bleVarToUUID - hopefully you can just ifdef ESP32 in there as well for the small parts that are specific to each device.
Espruino is a JavaScript interpreter for low-power Microcontrollers. This site is both a support community for Espruino and a place to share what you are working on.
I'd maybe change the ifdef to be
BLUETOOTH
instead?You mean here: https://github.com/espruino/Espruino/blob/master/targets/nrf5x/bluetooth.c#L615
and then:
https://github.com/espruino/Espruino/blob/master/libs/bluetooth/jswrap_bluetooth.c#L1258
It's just because I'm trying to do the bare minimum inside the IRQ. So the IRQ (first one) only allocates the data it needs - then outside of an IRQ it does more allocation.
In your case it works well, because you should be able to use the existing code in jswrap_bluetooth as-is?
Yes, I know. I think eventually I'd change
NRF
to beBLE
orBluetooth
and would then makeNRF==BLE
on nRF5x devices to be compatible.Not if done right - I wouldn't add 'shadow' functions though - that would use up a bit more memory for no real reason.
Not really - but for the moment I'd leave it as
NRF
so as not to confuse your porting efforts - and then at some point soon I can change that in main Espruino branch.If it really irks you, perhaps you could just execute the code
var BLE=NRF
at boot time on ESP32 for now?Are you up to date with GitHub? I have now moved BluetoothUtils outside of the nrf5x directory: https://github.com/espruino/Espruino/tree/master/libs/bluetooth
nrfUtil
is basically whatbluetooth.c
should be? Board-specific bluetooth functions.Currently
bluetooth_utils.c
does have some ifdefs, but they're in what should hopefully be quite generic functions likebleVarToUUID
- hopefully you can justifdef ESP32
in there as well for the small parts that are specific to each device.