-
Notifications
You must be signed in to change notification settings - Fork 55
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
fix: Force colors to not be stripped off when piping child process stdout #677
Conversation
🦋 Changeset detectedLatest commit: bb7f2bd The changes in this PR will be included in the next version bump. This PR includes changesets to release 2 packages
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
// Piping the output by default strips off the color. This is a workaround to | ||
// preserve the color being piped to parent process. Later we reset it to whatever it was before. | ||
const oldForceColorValue = process.env['FORCE_COLOR']; | ||
process.env['FORCE_COLOR'] = '1'; |
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.
Can we clone process.env
, append this to a copy and pass to child process ?
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.
Good idea, only setting in the child process now.
@@ -184,6 +189,7 @@ export class CDKDeployer implements BackendDeployer { | |||
|
|||
try { | |||
await childProcess; | |||
process.env['FORCE_COLOR'] = oldForceColorValue; |
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.
this should be in finally block.
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.
no longer needed.
Description of changes: Piping the child process output by default strips off the color for consuming streams. This is a workaround to preserve the color being piped to parent process. See Marak/colors.js#127 (comment)
By submitting this pull request, I confirm that you can use, modify, copy, and redistribute this contribution, under the terms of your choice.