-
-
Notifications
You must be signed in to change notification settings - Fork 161
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Use modern JS features, ship TS defs #175
Conversation
New and removed dependencies detected. Learn more about Socket for GitHub ↗︎
🚮 Removed packages: npm/beautify-benchmark@0.2.4, npm/benchmark@2.1.4, npm/eslint-plugin-markdown@3.0.1, npm/eslint@8.53.0, npm/mocha@10.2.0, npm/nyc@15.1.0, npm/safe-buffer@5.2.1 |
bc34316
to
ac27522
Compare
src/index.ts
Outdated
str: string, | ||
options?: ParseOptions, | ||
): Record<string, string> { | ||
const obj: Record<string, string> = {}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great PR!
I just have one feedback
Since this object is a map/record and can have any key, it would be beneficial and good practice to make its prototype null
Either by doing const obj = Object.create(null)
or by using the more performant NullObject method (used in the Fastify router):
const NullObject = function () {}
NullObject.prototype = Object.create(null)
const obj = new NullObject();
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Awesome, thanks!
I had tried Object.create(null)
but found the perf impact was -10% or so, but NullObject
is comparable or better than {}
.
894787f
to
585e23d
Compare
src/index.ts
Outdated
const __hasOwnProperty = Object.prototype.hasOwnProperty; | ||
|
||
const NullObject: any = function () {}; | ||
NullObject.prototype = Object.create(null); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Small suggestion: This line is not treeshakable by esbuild playground
You might use something like this to make sure it is side-effect free.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed in the latest commit. I'm unsure how much it helps overall since it's used in 50% of the exposed API, am I correct in understanding it's mostly for bundle size?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The package is currently still CommonJS, so that might also waste these bytes as it won't tree shake?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
makes sense at least until being in CommonJS (not sure if it benefits rollup build with common js)
package-lock.json
Outdated
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a specific reason to add the lock file?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not particularly, I usually work with it checked it so the package versions are consistent and I can use npm ci
. I'm not strongly opinionated either way, I suppose it's possible a dependency could change their behavior and break CI for a PR 🤷
Would you prefer to keep it removed?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't have a strong opinion for every package but we don't use them at Fastify -- they mostly don't achieve much for consumable packages
Feel free to do as you prefer, I was just curious to see if it was intentional, sometimes people mistakenly commit it and don't realize
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should not use them without automation which runs without the lock before each publish. The chance of end users seeing a breaking issue because we were accidentally locked back is not worth catching stray bugs during development due to updated transitive deps.
6364cdd
to
e90f244
Compare
Refactored to modernize JS features used (
const
,let
, etc) and bump the min node.js in prep for v1. Using TypeScript to ship native.d.ts
files with the package moving forward. Removes some level of input validation relying on correct types (tiny perf win, less code checks).