Skip to content

Commit 9b17b23

Browse files
Upgrade: Report errors when updating dependencies
1 parent 6164783 commit 9b17b23

File tree

2 files changed

+21
-3
lines changed

2 files changed

+21
-3
lines changed

CHANGELOG.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
1919
- Don’t replace `_` in suggested theme keys ([#16433](https://github.com/tailwindlabs/tailwindcss/pull/16433))
2020
- Ensure `--default-outline-width` can be used to change the `outline-width` value of the `outline` utility
2121
- Ensure drop shadow utilities don't inherit unexpectedly ([#16471](https://github.com/tailwindlabs/tailwindcss/pull/16471))
22+
- Upgrade: Report errors when updating dependencies
2223

2324
## [4.0.6] - 2025-02-10
2425

packages/@tailwindcss-upgrade/src/utils/packages.ts

Lines changed: 20 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@ import fs from 'node:fs/promises'
33
import { dirname, resolve } from 'node:path'
44
import { promisify } from 'node:util'
55
import { DefaultMap } from '../../../tailwindcss/src/utils/default-map'
6-
import { warn } from './renderer'
6+
import { error, warn } from './renderer'
77

88
const exec = promisify(execCb)
99

@@ -20,11 +20,28 @@ export function pkg(base: string) {
2020
if (location === 'devDependencies') {
2121
args.push(SAVE_DEV[packageManager] || SAVE_DEV.default)
2222
}
23-
return exec(`${packageManager} add ${args.join(' ')}`, { cwd: base })
23+
24+
let command = `${packageManager} add ${args.join(' ')}`
25+
try {
26+
return await exec(command, { cwd: base })
27+
} catch (e: any) {
28+
error(`An error occurred while running \`${command}\`\n\n${e.stdout}\n${e.stderr}`, {
29+
prefix: '↳ ',
30+
})
31+
throw e
32+
}
2433
},
2534
async remove(packages: string[]) {
2635
let packageManager = await packageManagerForBase.get(base)
27-
return exec(`${packageManager} remove ${packages.join(' ')}`, { cwd: base })
36+
let command = `${packageManager} remove ${packages.join(' ')}`
37+
try {
38+
return await exec(command, { cwd: base })
39+
} catch (e: any) {
40+
error(`An error occurred while running \`${command}\`\n\n${e.stdout}\n${e.stderr}`, {
41+
prefix: '↳ ',
42+
})
43+
throw e
44+
}
2845
},
2946
}
3047
}

0 commit comments

Comments
 (0)