Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: remove Node-specific APIs. #56

Open
wants to merge 13 commits into
base: master
Choose a base branch
from

Conversation

Symbitic
Copy link
Contributor

@Symbitic Symbitic commented Jun 4, 2023

This PR is intended to replace as many Node-specific APIs with their standardized equivalents. The number one thing it does is replace EventEmitter with EventTarget. I did my best to make sure nothing is a breaking change, but I'm putting this in as a draft because I'm not certain of it yet.

I'd hoped to only change the adapters for this PR and leave changing the types and Events stuff for a later PR, but that wasn't possible since EventDispatcher depended on EventEmitter. I'm really sorry for that; if there are any changes you want me to make, I'll do my best. For now, I'm leaving Deno for another PR.

I did add support for a SIMPLEBLE_ADAPTER environment variable for if a user has more than one Bluetooth adapter and wants to select a particular one.

Thanks again for your great work on this.

@Symbitic
Copy link
Contributor Author

Symbitic commented Jun 8, 2023

@thegecko I added an (also unfinished) AsyncIterableIterator method requestLEDevices (I wasn't sure what to call it). If you want me to rename it or save it for a separate PR, just LMK.

@Symbitic Symbitic marked this pull request as ready for review August 23, 2023 19:14
@thegecko
Copy link
Owner

I've enabled prebuilds on this PR which pass 👍
Locally, the full build fails for me while linting the TypeScript. Minor issues, but keen these are addressed:

/Users/robmor01/Projects/webbluetooth/src/adapter/adapter.ts
  25:37  error  Strings must use singlequote  quotes
  31:42  error  Strings must use singlequote  quotes

/Users/robmor01/Projects/webbluetooth/src/bluetooth.ts
  108:34  error    Strings must use singlequote                    quotes
  423:34  warning  Forbidden non-null assertion                    @typescript-eslint/no-non-null-assertion
  461:41  warning  Unexpected any. Specify a different type        @typescript-eslint/no-explicit-any
  462:1   error    Expected indentation of 16 spaces but found 14  indent
  462:26  error    A space is required after '{'                   object-curly-spacing
  462:34  error    A space is required before '}'                  object-curly-spacing

/Users/robmor01/Projects/webbluetooth/src/characteristic.ts
  30:45  error  Strings must use singlequote  quotes

/Users/robmor01/Projects/webbluetooth/src/device.ts
  53:15  error  Strings must use singlequote  quotes

/Users/robmor01/Projects/webbluetooth/src/events.ts
   96:23  error  Expected a `const` assertion instead of a literal type annotation  @typescript-eslint/prefer-as-const
  101:28  error  Expected a `const` assertion instead of a literal type annotation  @typescript-eslint/prefer-as-const
  106:29  error  Expected a `const` assertion instead of a literal type annotation  @typescript-eslint/prefer-as-const
  111:18  error  Expected a `const` assertion instead of a literal type annotation  @typescript-eslint/prefer-as-const

/Users/robmor01/Projects/webbluetooth/src/service.ts
  34:42  error  Strings must use singlequote  quotes

✖ 15 problems (13 errors, 2 warnings)
  9 errors and 0 warnings potentially fixable with the `--fix` option.

Running the test suite yarn test yields an error immediately:

TypeError: Class constructor EventTarget cannot be invoked without 'new'
    at new BluetoothAdapter (/Users/robmor01/Projects/webbluetooth/dist/adapter/adapter.js:96:47)
    at Object.<anonymous> (/Users/robmor01/Projects/webbluetooth/dist/adapter/adapter.js:521:19)
    at Module._compile (node:internal/modules/cjs/loader:1155:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1209:10)
    at Module.load (node:internal/modules/cjs/loader:1033:32)
    at Function.Module._load (node:internal/modules/cjs/loader:868:12)
    at Module.require (node:internal/modules/cjs/loader:1057:19)
    at require (node:internal/modules/cjs/helpers:103:18)
    at Object.<anonymous> (/Users/robmor01/Projects/webbluetooth/dist/bluetooth.js:118:17)
    at Module._compile (node:internal/modules/cjs/loader:1155:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1209:10)
    at Module.load (node:internal/modules/cjs/loader:1033:32)
    at Function.Module._load (node:internal/modules/cjs/loader:868:12)
    at Module.require (node:internal/modules/cjs/loader:1057:19)
    at require (node:internal/modules/cjs/helpers:103:18)
    at Object.<anonymous> (/Users/robmor01/Projects/webbluetooth/dist/index.js:42:19)
    at Module._compile (node:internal/modules/cjs/loader:1155:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1209:10)
    at Module.load (node:internal/modules/cjs/loader:1033:32)
    at Function.Module._load (node:internal/modules/cjs/loader:868:12)
    at Module.require (node:internal/modules/cjs/loader:1057:19)
    at require (node:internal/modules/cjs/helpers:103:18)
    at Object.<anonymous> (/Users/robmor01/Projects/webbluetooth/test/bluetooth.test.js:2:19)
    at Module._compile (node:internal/modules/cjs/loader:1155:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1209:10)
    at Module.load (node:internal/modules/cjs/loader:1033:32)
    at Function.Module._load (node:internal/modules/cjs/loader:868:12)
    at ModuleWrap.<anonymous> (node:internal/modules/esm/translators:169:29)
    at ModuleJob.run (node:internal/modules/esm/module_job:193:25)
    at async Promise.all (index 0)
    at async ESMLoader.import (node:internal/modules/esm/loader:526:24)
    at async importModuleDynamicallyWrapper (node:internal/vm/module:438:15)
    at async formattedImport (/Users/robmor01/Projects/webbluetooth/node_modules/mocha/lib/nodejs/esm-utils.js:9:14)
    at async Object.exports.requireOrImport (/Users/robmor01/Projects/webbluetooth/node_modules/mocha/lib/nodejs/esm-utils.js:42:28)
    at async Object.exports.loadFilesAsync (/Users/robmor01/Projects/webbluetooth/node_modules/mocha/lib/nodejs/esm-utils.js:100:20)
    at async singleRun (/Users/robmor01/Projects/webbluetooth/node_modules/mocha/lib/cli/run-helpers.js:125:3)
    at async Object.exports.handler (/Users/robmor01/Projects/webbluetooth/node_modules/mocha/lib/cli/run.js:370:5)

@Symbitic
Copy link
Contributor Author

Finally got around to fixing this. The ESLint errors were pretty easy. I eventually figured out the problem with the error was with the tsconfig target being set to es5. Changing it to es2016 did the trick. ES5 was actually removing the classes and compiling them down to old functions.

Some other changes:

  • Removed DOMEvent since that could interfere with e.g. instanceof Event. I just added a _handleDisconnect method to BluetoothDevice since that was the only time evt.target was set to anything but this.
  • Add bubbles to a lot of event initializers since that's what the spec says.
  • Add ValueEventInit used by availabilitychanged

@thegecko
Copy link
Owner

Thanks @Symbitic All the tests pass with physical hardware, I need to look through the code changes...

@Apollon77
Copy link
Contributor

@Symbitic I saw you now defined also the Advertisement data event ... did you also added code to "simulate" it being fired when someone calls watchAdvertisements on the device? Because they should be relatively straight forward, or? Most of teh data are present in the device ... and then it would be ,more standard conform here.

@Symbitic
Copy link
Contributor Author

Because they should be relatively straight forward, or? Most of teh data are present in the device ... and then it would be ,more standard conform here.

@Apollon77 I have a hard time understanding what you are asking for. watchAdvertisements is not yet stable in the webbluetooth spec, so it's difficult to implement at this time.

@Apollon77
Copy link
Contributor

Ok sorry, I wasn't aware that this is not stable (but Chrome already supports it behind a feature flag) ... Thoight might be an option too

@thegecko
Copy link
Owner

@Symbitic I've revisited this PR many times with a view to merge it but keep getting quite lost. I think it's because so much has changed (e.g. it looks like files have been renamed and the adapter abstraction has been removed). I can see this isn't an easy task but is there any way you can simplify this PR and reduce the churn?

@Symbitic
Copy link
Contributor Author

@Symbitic I've revisited this PR many times with a view to merge it but keep getting quite lost. I think it's because so much has changed (e.g. it looks like files have been renamed and the adapter abstraction has been removed). I can see this isn't an easy task but is there any way you can simplify this PR and reduce the churn?

I'll see what I can do. I may need to open a new PR and abandon this one. I'll definitely remove SIMPLEBLE_ADAPTER now that we have another PR for this.

@thegecko
Copy link
Owner

I'll see what I can do. I may need to open a new PR and abandon this one. I'll definitely remove SIMPLEBLE_ADAPTER now that we have another PR for this.

Thanks and sorry I'm not being very timely with supporting your merges

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants