-
Notifications
You must be signed in to change notification settings - Fork 74
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
chore: add typescript declarations to .gitignore #2665
base: master
Are you sure you want to change the base?
Conversation
(Yes, this change is basically just for me) |
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 have a lot of manually authored .d.ts
files so a blanket ignore of them is not ok. In general I wish we had a CI job to verify that any files in the repo are not currently excluded by the gitignore config, as it's a pain to manage files "force added"
I believe @kriskowal has some commands to verify no regression here that I'd like to see the output of before approving a merge. |
@mhofman I feel like the concern may be overblown.
We aren't really adding a ton of these on a regular basis. |
This should surface everything to be published: npm pack --workspaces --json --dry-run So we can diff the output of that |
One way forward is to have a consistent module name for hand-written types and make that an exclusion in gitignore. |
Some tests are failing because
UPDATE: |
@turadg Since I was touching the |
As @turadg mentioned, while we may not have a lot of these manual definition files currently, I would really like them to be excluded one way or another from being ignored. Force added files are a pain to deal with. |
0a6e879
to
de6eba7
Compare
@turadg @kriskowal @mhofman This is ready for re-review; please see the updated PR description |
de6eba7
to
7e39b49
Compare
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.
Looks like it will work to me.
When `npm`-`link`-ing Endo against external projects, the types are not resolvable without first building the declaration files (unlike how types are resolved within the project itself). This requires compiling declaration files in the appropriate Endo workspaces and re-running as needed. Previously, all generated declaration files (and their sourcemaps) were recognized as unstaged new files by Git, which is incredibly annoying when trying to see what changes have been made to Endo sources. **This change adds declaration files, their sourcemaps and any build cache files (`*.tsbuildinfo`) to Git's ignorelist.** ## Escape Hatch Sometimes it's helpful to keep declarations under version control. To that end, any _new_ declaration file that needs to be tracked should match `^.+\.types\.d\.[mc]?ts$`. Example: `foo.types.d.ts`. This will avoid the need to force-add the file to Git. ## Notes - To avoid the need to rename files (e.g., the various `types.js` files amongst the workspaces), the pattern `^types.*\.d\.[mc]?ts$` was **not** chosen. - If the need arises to track a directory full of declaration files, another convention can be established and appended to the ignorefile. - All `clean` scripts will need to be updated, since `git clean` needs another flag (`-X`) to delete _ignored_ files.
- Now that declaration files are ignored, `git` needs the `-X` flag to delete them - Normalized all `postpack` scripts: - Updated with new patterns matching newly-ignored declaration, declaration maps, and `.tsbuildinfo` files - If a workspace has a `clean` script which was essentially identical to `postpack`, `postpack` just invokes `yarn clean` - Replace single quotes `'` with escaped double quotes `\"` for the sake of portability (it is ugly, but Endo may want to support a Windows-based development environment one day) - `ses`, in particular, has a `clean` script which differs substantially from `postpack`, so I left `clean` as-is.
7e39b49
to
1169125
Compare
@mhofman please approve or otherwise withdraw the block |
When
npm
-link
-ing Endo against external projects, the types are not resolvable without first building the declaration files (unlike how types are resolved within the project itself). This requires compiling declaration files in the appropriate Endo workspaces and re-running as needed.Previously, all generated declaration files (and their sourcemaps) were recognized as unstaged new files by Git, which is incredibly annoying when trying to see what changes have been made to Endo sources.
This change adds declaration files, their sourcemaps and any build cache files (
*.tsbuildinfo
) to Git's ignorelist.Escape Hatch
Sometimes it's helpful to keep declarations under version control. To that end, any new declaration file that needs to be tracked should match:
/^.+\.types\.d\.[mc]?ts$/
Example:
foo.types.d.ts
. This will avoid the need to force-add the file to Git.Notes
types.js
files amongst the workspaces), this pattern was not chosen:/^types.*\.d\.[mc]?ts$/
clean
scripts will need to be updated, sincegit clean
needs another flag (-X
) to delete ignored files.What I'm Dealing With
An example of my workflow is something like this:
npm link -w @endo/compartment-mapper \ -w ses \ -w @endo/env-options \ -w @endo/cjs-module-analyzer \ -w @endo/static-module-record \ -w @endo/zip \ -w @endo/evasive-transform cd /path/to/lavamoat npm link @endo/compartment-mapper \ ses \ @endo/env-options \ @endo/cjs-module-analyzer \ @endo/static-module-record \ @endo/zip \ @endo/evasive-transform
At this point, my build will fail because the type declarations I need are missing. So I need to:
cd /path/to/endo npm run prepack -w @endo/compartment-mapper -w ses
This will generate the declarations I need, but
git status
results in:...which is annoying if I have actual changes in Endo!
Script changes
I updated
clean
andpostpack
scripts en masse:git
needs the-X
flag to delete thempostpack
scripts:.tsbuildinfo
filesclean
script which was essentially identical topostpack
,postpack
just invokesyarn clean
'
with escaped double quotes\"
for the sake of portability (it is ugly, but Endo may want to support a Windows-based development environment one day)ses
, in particular, has aclean
script which differs substantially frompostpack
, so I leftclean
as-is.No change to packed files
I used my preferred diff tool to compare
new-pack.json
, generated by this PR:npm pack -ws --json --dry-run > new-pack.json
...and
old-pack.json
, generated by themaster
branch:npm pack -ws --json --dry-run > old-pack.json
The only differences were the
package.json
files having different sizes and hashes due to the changes to theclean
andpostpack
scripts (as noted above)Description updated Jan 17 2025