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(@angular/build): use newer Node.js cp API for asset copying #29933

Merged
merged 1 commit into from
Mar 25, 2025

Conversation

clydin
Copy link
Member

@clydin clydin commented Mar 25, 2025

When using Node.js v22 (minimum of v22.11 for v22 with Angular v20), the application build system will now use the Node.js cp filesystem API instead of the copyFile API. This newer API provides equivalent functionality while also preserving timestamps for copied assets. Additionally, it supports potential future internal refactorings to support full direct directory copying. Projects built with Node.js v20 will continue to use the copyFile API.

@clydin clydin added the target: major This PR is targeted for the next major release label Mar 25, 2025
@alfaproject
Copy link

Node 20 won't be supported anymore for Angular 20? Thought only 18 was dropped

@clydin clydin force-pushed the application/assets-node-cp branch 2 times, most recently from 51e39d5 to 2e687bb Compare March 25, 2025 17:57
@clydin
Copy link
Member Author

clydin commented Mar 25, 2025

22.11 is the minimum version of Node.js v22 that can be used with Angular v20. The cp API was stabilized in Node.js 22.3.

@clydin clydin linked an issue Mar 25, 2025 that may be closed by this pull request
@clydin clydin marked this pull request as ready for review March 25, 2025 18:10
@clydin clydin requested a review from alan-agius4 March 25, 2025 18:10
When using Node.js v22 (minimum of v22.11 for v22 with Angular v20), the
application build system will now use the Node.js `cp` filesystem API
instead of the `copyFile` API. This newer API provides equivalent functionality
while also preserving timestamps for copied assets.  Additionally, it supports
potential future internal refactorings to support full direct directory
copying.
@clydin clydin force-pushed the application/assets-node-cp branch from 2e687bb to 56bdc71 Compare March 25, 2025 18:12
@alan-agius4 alan-agius4 added the action: merge The PR is ready for merge by the caretaker label Mar 25, 2025
@alan-agius4 alan-agius4 merged commit 5c9b371 into angular:main Mar 25, 2025
31 checks passed
@clydin clydin deleted the application/assets-node-cp branch March 25, 2025 18:56
@williamdes
Copy link

Thank you very much!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
action: merge The PR is ready for merge by the caretaker area: @angular/build target: major This PR is targeted for the next major release
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Support keeping the file stats while copying assets
4 participants