@fredlackey/devutils 0.0.1 → 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. package/README.md +5 -5
  2. package/package.json +1 -1
  3. package/src/commands/install.js +374 -36
  4. package/src/installs/adobe-creative-cloud.js +527 -25
  5. package/src/installs/adobe-creative-cloud.md +605 -0
  6. package/src/installs/appcleaner.js +303 -26
  7. package/src/installs/appcleaner.md +699 -0
  8. package/src/installs/apt-transport-https.js +390 -0
  9. package/src/installs/apt-transport-https.md +678 -0
  10. package/src/installs/atomicparsley.js +624 -26
  11. package/src/installs/atomicparsley.md +795 -0
  12. package/src/installs/aws-cli.js +779 -26
  13. package/src/installs/aws-cli.md +727 -0
  14. package/src/installs/balena-etcher.js +688 -26
  15. package/src/installs/balena-etcher.md +761 -0
  16. package/src/installs/bambu-studio.js +912 -26
  17. package/src/installs/bambu-studio.md +780 -0
  18. package/src/installs/bash-completion.js +554 -23
  19. package/src/installs/bash-completion.md +833 -0
  20. package/src/installs/bash.js +399 -26
  21. package/src/installs/bash.md +993 -0
  22. package/src/installs/beyond-compare.js +585 -26
  23. package/src/installs/beyond-compare.md +813 -0
  24. package/src/installs/build-essential.js +511 -26
  25. package/src/installs/build-essential.md +977 -0
  26. package/src/installs/ca-certificates.js +618 -0
  27. package/src/installs/ca-certificates.md +937 -0
  28. package/src/installs/caffeine.js +490 -26
  29. package/src/installs/caffeine.md +839 -0
  30. package/src/installs/camtasia.js +577 -25
  31. package/src/installs/camtasia.md +762 -0
  32. package/src/installs/chatgpt.js +458 -26
  33. package/src/installs/chatgpt.md +814 -0
  34. package/src/installs/chocolatey.js +447 -0
  35. package/src/installs/chocolatey.md +661 -0
  36. package/src/installs/chrome-canary.js +472 -26
  37. package/src/installs/chrome-canary.md +641 -0
  38. package/src/installs/chromium.js +645 -26
  39. package/src/installs/chromium.md +838 -0
  40. package/src/installs/claude-code.js +558 -26
  41. package/src/installs/claude-code.md +1173 -0
  42. package/src/installs/curl.js +361 -26
  43. package/src/installs/curl.md +714 -0
  44. package/src/installs/cursor.js +561 -26
  45. package/src/installs/cursor.md +970 -0
  46. package/src/installs/dbschema.js +674 -26
  47. package/src/installs/dbschema.md +925 -0
  48. package/src/installs/dependencies.md +435 -0
  49. package/src/installs/development-tools.js +600 -0
  50. package/src/installs/development-tools.md +977 -0
  51. package/src/installs/docker.js +1010 -25
  52. package/src/installs/docker.md +1109 -0
  53. package/src/installs/drawio.js +1001 -26
  54. package/src/installs/drawio.md +795 -0
  55. package/src/installs/elmedia-player.js +328 -25
  56. package/src/installs/elmedia-player.md +556 -0
  57. package/src/installs/ffmpeg.js +870 -25
  58. package/src/installs/ffmpeg.md +852 -0
  59. package/src/installs/file.js +464 -0
  60. package/src/installs/file.md +987 -0
  61. package/src/installs/gemini-cli.js +793 -26
  62. package/src/installs/gemini-cli.md +1153 -0
  63. package/src/installs/git.js +382 -26
  64. package/src/installs/git.md +907 -0
  65. package/src/installs/gitego.js +931 -26
  66. package/src/installs/gitego.md +1172 -0
  67. package/src/installs/go.js +913 -26
  68. package/src/installs/go.md +958 -0
  69. package/src/installs/google-chrome.js +801 -25
  70. package/src/installs/google-chrome.md +862 -0
  71. package/src/installs/gpg.js +412 -73
  72. package/src/installs/gpg.md +1056 -0
  73. package/src/installs/homebrew.js +1015 -26
  74. package/src/installs/homebrew.md +988 -0
  75. package/src/installs/imageoptim.js +950 -26
  76. package/src/installs/imageoptim.md +1119 -0
  77. package/src/installs/installers.json +2297 -0
  78. package/src/installs/jq.js +382 -26
  79. package/src/installs/jq.md +809 -0
  80. package/src/installs/keyboard-maestro.js +701 -26
  81. package/src/installs/keyboard-maestro.md +825 -0
  82. package/src/installs/latex.js +771 -26
  83. package/src/installs/latex.md +1095 -0
  84. package/src/installs/lftp.js +338 -26
  85. package/src/installs/lftp.md +907 -0
  86. package/src/installs/lsb-release.js +346 -0
  87. package/src/installs/lsb-release.md +814 -0
  88. package/src/installs/messenger.js +829 -26
  89. package/src/installs/messenger.md +900 -0
  90. package/src/installs/microsoft-office.js +550 -26
  91. package/src/installs/microsoft-office.md +760 -0
  92. package/src/installs/microsoft-teams.js +782 -25
  93. package/src/installs/microsoft-teams.md +886 -0
  94. package/src/installs/node.js +886 -26
  95. package/src/installs/node.md +1153 -0
  96. package/src/installs/nordpass.js +698 -26
  97. package/src/installs/nordpass.md +921 -0
  98. package/src/installs/nvm.js +977 -26
  99. package/src/installs/nvm.md +1057 -0
  100. package/src/installs/openssh.js +734 -64
  101. package/src/installs/openssh.md +1056 -0
  102. package/src/installs/pandoc.js +644 -26
  103. package/src/installs/pandoc.md +1036 -0
  104. package/src/installs/pinentry.js +492 -26
  105. package/src/installs/pinentry.md +1142 -0
  106. package/src/installs/pngyu.js +851 -26
  107. package/src/installs/pngyu.md +896 -0
  108. package/src/installs/postman.js +781 -26
  109. package/src/installs/postman.md +940 -0
  110. package/src/installs/procps.js +425 -0
  111. package/src/installs/procps.md +851 -0
  112. package/src/installs/safari-tech-preview.js +355 -25
  113. package/src/installs/safari-tech-preview.md +533 -0
  114. package/src/installs/sfnt2woff.js +640 -26
  115. package/src/installs/sfnt2woff.md +795 -0
  116. package/src/installs/shellcheck.js +463 -26
  117. package/src/installs/shellcheck.md +1005 -0
  118. package/src/installs/slack.js +722 -25
  119. package/src/installs/slack.md +865 -0
  120. package/src/installs/snagit.js +566 -25
  121. package/src/installs/snagit.md +844 -0
  122. package/src/installs/software-properties-common.js +372 -0
  123. package/src/installs/software-properties-common.md +805 -0
  124. package/src/installs/spotify.js +858 -25
  125. package/src/installs/spotify.md +901 -0
  126. package/src/installs/studio-3t.js +803 -26
  127. package/src/installs/studio-3t.md +918 -0
  128. package/src/installs/sublime-text.js +780 -25
  129. package/src/installs/sublime-text.md +914 -0
  130. package/src/installs/superwhisper.js +687 -25
  131. package/src/installs/superwhisper.md +630 -0
  132. package/src/installs/tailscale.js +727 -26
  133. package/src/installs/tailscale.md +1100 -0
  134. package/src/installs/tar.js +389 -0
  135. package/src/installs/tar.md +946 -0
  136. package/src/installs/termius.js +780 -26
  137. package/src/installs/termius.md +844 -0
  138. package/src/installs/terraform.js +761 -26
  139. package/src/installs/terraform.md +899 -0
  140. package/src/installs/tidal.js +752 -25
  141. package/src/installs/tidal.md +864 -0
  142. package/src/installs/tmux.js +328 -26
  143. package/src/installs/tmux.md +1030 -0
  144. package/src/installs/tree.js +393 -26
  145. package/src/installs/tree.md +833 -0
  146. package/src/installs/unzip.js +460 -0
  147. package/src/installs/unzip.md +879 -0
  148. package/src/installs/vim.js +403 -26
  149. package/src/installs/vim.md +1040 -0
  150. package/src/installs/vlc.js +803 -26
  151. package/src/installs/vlc.md +927 -0
  152. package/src/installs/vscode.js +825 -26
  153. package/src/installs/vscode.md +1002 -0
  154. package/src/installs/wget.js +415 -0
  155. package/src/installs/wget.md +791 -0
  156. package/src/installs/whatsapp.js +710 -25
  157. package/src/installs/whatsapp.md +854 -0
  158. package/src/installs/winpty.js +352 -0
  159. package/src/installs/winpty.md +620 -0
  160. package/src/installs/woff2.js +535 -26
  161. package/src/installs/woff2.md +977 -0
  162. package/src/installs/wsl.js +572 -0
  163. package/src/installs/wsl.md +699 -0
  164. package/src/installs/xcode-clt.js +520 -0
  165. package/src/installs/xcode-clt.md +351 -0
  166. package/src/installs/xcode.js +542 -26
  167. package/src/installs/xcode.md +573 -0
  168. package/src/installs/yarn.js +806 -26
  169. package/src/installs/yarn.md +1074 -0
  170. package/src/installs/yq.js +636 -26
  171. package/src/installs/yq.md +944 -0
  172. package/src/installs/yt-dlp.js +683 -26
  173. package/src/installs/yt-dlp.md +946 -0
  174. package/src/installs/yum-utils.js +297 -0
  175. package/src/installs/yum-utils.md +648 -0
  176. package/src/installs/zoom.js +740 -25
  177. package/src/installs/zoom.md +884 -0
  178. package/src/scripts/README.md +567 -45
  179. package/src/scripts/STATUS.md +208 -0
  180. package/src/scripts/afk.js +395 -7
  181. package/src/scripts/backup-all.js +731 -9
  182. package/src/scripts/backup-source.js +711 -8
  183. package/src/scripts/brewd.js +373 -7
  184. package/src/scripts/brewi.js +505 -9
  185. package/src/scripts/brewr.js +512 -9
  186. package/src/scripts/brews.js +462 -9
  187. package/src/scripts/brewu.js +488 -7
  188. package/src/scripts/c.js +185 -7
  189. package/src/scripts/ccurl.js +325 -8
  190. package/src/scripts/certbot-crontab-init.js +488 -8
  191. package/src/scripts/certbot-init.js +641 -9
  192. package/src/scripts/ch.js +339 -7
  193. package/src/scripts/claude-danger.js +253 -8
  194. package/src/scripts/clean-dev.js +419 -8
  195. package/src/scripts/clear-dns-cache.js +525 -7
  196. package/src/scripts/clone.js +417 -7
  197. package/src/scripts/code-all.js +420 -7
  198. package/src/scripts/count-files.js +195 -8
  199. package/src/scripts/count-folders.js +195 -8
  200. package/src/scripts/count.js +248 -8
  201. package/src/scripts/d.js +203 -7
  202. package/src/scripts/datauri.js +373 -8
  203. package/src/scripts/delete-files.js +363 -7
  204. package/src/scripts/docker-clean.js +410 -8
  205. package/src/scripts/dp.js +426 -7
  206. package/src/scripts/e.js +375 -9
  207. package/src/scripts/empty-trash.js +497 -7
  208. package/src/scripts/evm.js +428 -9
  209. package/src/scripts/fetch-github-repos.js +441 -10
  210. package/src/scripts/get-channel.js +329 -8
  211. package/src/scripts/get-course.js +384 -11
  212. package/src/scripts/get-dependencies.js +290 -9
  213. package/src/scripts/get-folder.js +783 -10
  214. package/src/scripts/get-tunes.js +411 -10
  215. package/src/scripts/get-video.js +352 -9
  216. package/src/scripts/git-backup.js +561 -9
  217. package/src/scripts/git-clone.js +477 -9
  218. package/src/scripts/git-pup.js +303 -7
  219. package/src/scripts/git-push.js +380 -8
  220. package/src/scripts/h.js +607 -9
  221. package/src/scripts/hide-desktop-icons.js +483 -7
  222. package/src/scripts/hide-hidden-files.js +522 -7
  223. package/src/scripts/install-dependencies-from.js +440 -9
  224. package/src/scripts/ips.js +647 -10
  225. package/src/scripts/iso.js +354 -8
  226. package/src/scripts/killni.js +561 -7
  227. package/src/scripts/ll.js +451 -8
  228. package/src/scripts/local-ip.js +310 -8
  229. package/src/scripts/m.js +508 -8
  230. package/src/scripts/map.js +293 -8
  231. package/src/scripts/mkd.js +287 -7
  232. package/src/scripts/ncu-update-all.js +441 -8
  233. package/src/scripts/nginx-init.js +702 -12
  234. package/src/scripts/npmi.js +366 -7
  235. package/src/scripts/o.js +495 -8
  236. package/src/scripts/org-by-date.js +321 -7
  237. package/src/scripts/p.js +208 -7
  238. package/src/scripts/packages.js +313 -8
  239. package/src/scripts/path.js +209 -7
  240. package/src/scripts/ports.js +582 -8
  241. package/src/scripts/q.js +290 -8
  242. package/src/scripts/refresh-files.js +378 -10
  243. package/src/scripts/remove-smaller-files.js +500 -8
  244. package/src/scripts/rename-files-with-date.js +517 -9
  245. package/src/scripts/resize-image.js +523 -9
  246. package/src/scripts/rm-safe.js +653 -8
  247. package/src/scripts/s.js +525 -9
  248. package/src/scripts/set-git-public.js +349 -7
  249. package/src/scripts/show-desktop-icons.js +459 -7
  250. package/src/scripts/show-hidden-files.js +456 -7
  251. package/src/scripts/tpa.js +265 -8
  252. package/src/scripts/tpo.js +264 -7
  253. package/src/scripts/u.js +489 -7
  254. package/src/scripts/vpush.js +422 -8
  255. package/src/scripts/y.js +267 -7
  256. package/src/utils/common/os.js +94 -2
  257. package/src/utils/ubuntu/apt.js +13 -7
  258. package/src/utils/windows/choco.js +82 -26
  259. package/src/utils/windows/winget.js +89 -27
@@ -1,23 +1,389 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Run Homebrew doctor.
4
+ * brewd - Run Homebrew doctor to check for potential problems
5
+ *
6
+ * Migrated from legacy dotfiles alias.
7
+ * Original: alias brewd="brew doctor"
8
+ *
9
+ * This script runs `brew doctor` which checks your Homebrew installation
10
+ * for potential problems. It examines your system configuration, identifies
11
+ * common issues, and provides suggestions for fixing them.
12
+ *
13
+ * Common issues detected by brew doctor include:
14
+ * - Outdated Xcode Command Line Tools
15
+ * - Conflicting software or libraries
16
+ * - Permissions problems
17
+ * - Unlinked kegs (installed packages not properly symlinked)
18
+ * - Outdated formulae
19
+ *
5
20
  * @module scripts/brewd
6
21
  */
7
22
 
23
+ const os = require('../utils/common/os');
24
+ const shell = require('../utils/common/shell');
25
+
26
+ /**
27
+ * Check if Homebrew is installed and available in PATH.
28
+ *
29
+ * Uses the shell utility to search for the `brew` command in PATH.
30
+ * This works on both macOS and Linux where Linuxbrew may be installed.
31
+ *
32
+ * @returns {boolean} True if brew command is available, false otherwise
33
+ */
34
+ function isBrewInstalled() {
35
+ return shell.commandExists('brew');
36
+ }
37
+
38
+ /**
39
+ * Pure Node.js implementation - not applicable for this command.
40
+ *
41
+ * This function cannot be implemented in pure Node.js because `brew doctor`
42
+ * is a Homebrew-specific command that performs system-level checks that
43
+ * require Homebrew's internal knowledge of how it manages packages.
44
+ *
45
+ * Platform-specific functions should NOT call this function. They should
46
+ * either run `brew doctor` directly (on platforms with Homebrew support)
47
+ * or display guidance about equivalent commands for their platform.
48
+ *
49
+ * @param {string[]} args - Command line arguments (passed through to brew doctor)
50
+ * @returns {Promise<void>}
51
+ * @throws {Error} Always throws - this function should not be called directly
52
+ */
53
+ async function do_brewd_nodejs(args) {
54
+ throw new Error(
55
+ 'do_brewd_nodejs cannot be implemented in pure Node.js.\n' +
56
+ 'The `brew doctor` command requires Homebrew to be installed.\n' +
57
+ 'Use the platform-specific functions instead.'
58
+ );
59
+ }
60
+
61
+ /**
62
+ * Run brew doctor on macOS.
63
+ *
64
+ * macOS is the primary platform for Homebrew. This function checks if
65
+ * Homebrew is installed and runs `brew doctor` to diagnose potential
66
+ * problems with the Homebrew installation.
67
+ *
68
+ * @param {string[]} args - Command line arguments to pass to brew doctor
69
+ * @returns {Promise<void>}
70
+ */
71
+ async function do_brewd_macos(args) {
72
+ // Check if Homebrew is installed
73
+ if (!isBrewInstalled()) {
74
+ console.error('Error: Homebrew is not installed.');
75
+ console.error('');
76
+ console.error('To install Homebrew, run:');
77
+ console.error(' /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"');
78
+ console.error('');
79
+ console.error('Or use the devutils installer:');
80
+ console.error(' dev install homebrew');
81
+ process.exit(1);
82
+ }
83
+
84
+ // Build the command with any additional arguments
85
+ // Arguments could include things like --verbose or --debug
86
+ const command = args.length > 0
87
+ ? `brew doctor ${args.join(' ')}`
88
+ : 'brew doctor';
89
+
90
+ // Execute brew doctor and stream output directly to console
91
+ // We use spawnAsync with stdio inheritance to preserve colors and formatting
92
+ const { spawnSync } = require('child_process');
93
+
94
+ const result = spawnSync('brew', ['doctor', ...args], {
95
+ stdio: 'inherit', // Pass through stdin/stdout/stderr for real-time output
96
+ shell: false // Run brew directly without shell interpretation
97
+ });
98
+
99
+ // Exit with the same code as brew doctor
100
+ // brew doctor returns 0 if no problems found, non-zero otherwise
101
+ process.exit(result.status || 0);
102
+ }
103
+
104
+ /**
105
+ * Run brew doctor on Ubuntu.
106
+ *
107
+ * Homebrew (Linuxbrew) can be installed on Ubuntu and other Linux distributions.
108
+ * This function checks if Homebrew is installed and runs `brew doctor`.
109
+ * If Homebrew is not installed, it provides guidance for both installing
110
+ * Homebrew and using APT's built-in diagnostic tools.
111
+ *
112
+ * @param {string[]} args - Command line arguments to pass to brew doctor
113
+ * @returns {Promise<void>}
114
+ */
115
+ async function do_brewd_ubuntu(args) {
116
+ // Check if Homebrew is installed (Linuxbrew)
117
+ if (!isBrewInstalled()) {
118
+ console.error('Error: Homebrew (Linuxbrew) is not installed.');
119
+ console.error('');
120
+ console.error('On Ubuntu, you can either:');
121
+ console.error('');
122
+ console.error('1. Install Homebrew for Linux:');
123
+ console.error(' /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"');
124
+ console.error('');
125
+ console.error('2. Use APT diagnostic commands instead:');
126
+ console.error(' apt-get check # Verify package dependencies');
127
+ console.error(' dpkg --audit # Check for broken packages');
128
+ console.error(' apt-get -f install # Fix broken dependencies');
129
+ process.exit(1);
130
+ }
131
+
132
+ // Execute brew doctor with inherited stdio for real-time output
133
+ const { spawnSync } = require('child_process');
134
+
135
+ const result = spawnSync('brew', ['doctor', ...args], {
136
+ stdio: 'inherit',
137
+ shell: false
138
+ });
139
+
140
+ process.exit(result.status || 0);
141
+ }
142
+
143
+ /**
144
+ * Run brew doctor on Raspberry Pi OS.
145
+ *
146
+ * Homebrew can be installed on Raspberry Pi OS (64-bit ARM).
147
+ * This function checks if Homebrew is installed and runs `brew doctor`.
148
+ * If not available, it provides guidance for APT-based diagnostics.
149
+ *
150
+ * @param {string[]} args - Command line arguments to pass to brew doctor
151
+ * @returns {Promise<void>}
152
+ */
153
+ async function do_brewd_raspbian(args) {
154
+ // Check if Homebrew is installed
155
+ if (!isBrewInstalled()) {
156
+ console.error('Error: Homebrew is not installed.');
157
+ console.error('');
158
+ console.error('On Raspberry Pi OS, you can either:');
159
+ console.error('');
160
+ console.error('1. Install Homebrew (64-bit Raspberry Pi OS only):');
161
+ console.error(' /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"');
162
+ console.error('');
163
+ console.error('2. Use APT diagnostic commands instead:');
164
+ console.error(' apt-get check # Verify package dependencies');
165
+ console.error(' dpkg --audit # Check for broken packages');
166
+ console.error(' apt-get -f install # Fix broken dependencies');
167
+ process.exit(1);
168
+ }
169
+
170
+ // Execute brew doctor with inherited stdio
171
+ const { spawnSync } = require('child_process');
172
+
173
+ const result = spawnSync('brew', ['doctor', ...args], {
174
+ stdio: 'inherit',
175
+ shell: false
176
+ });
177
+
178
+ process.exit(result.status || 0);
179
+ }
180
+
181
+ /**
182
+ * Run brew doctor on Amazon Linux.
183
+ *
184
+ * Homebrew can be installed on Amazon Linux, though it's less common.
185
+ * This function checks if Homebrew is installed and provides guidance
186
+ * for DNF/YUM-based package manager diagnostics if not available.
187
+ *
188
+ * @param {string[]} args - Command line arguments to pass to brew doctor
189
+ * @returns {Promise<void>}
190
+ */
191
+ async function do_brewd_amazon_linux(args) {
192
+ // Check if Homebrew is installed
193
+ if (!isBrewInstalled()) {
194
+ console.error('Error: Homebrew is not installed.');
195
+ console.error('');
196
+ console.error('On Amazon Linux, Homebrew is not the standard package manager.');
197
+ console.error('');
198
+ console.error('Use DNF/YUM diagnostic commands instead:');
199
+ console.error(' dnf check # Check for package problems');
200
+ console.error(' dnf repolist # List configured repositories');
201
+ console.error(' rpm -Va # Verify all installed packages');
202
+ console.error('');
203
+ console.error('To install Homebrew anyway:');
204
+ console.error(' /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"');
205
+ process.exit(1);
206
+ }
207
+
208
+ // Execute brew doctor with inherited stdio
209
+ const { spawnSync } = require('child_process');
210
+
211
+ const result = spawnSync('brew', ['doctor', ...args], {
212
+ stdio: 'inherit',
213
+ shell: false
214
+ });
215
+
216
+ process.exit(result.status || 0);
217
+ }
218
+
219
+ /**
220
+ * Handle brewd command in Windows Command Prompt.
221
+ *
222
+ * Homebrew is not available on Windows. This function informs the user
223
+ * and provides guidance for equivalent package manager diagnostics using
224
+ * Chocolatey or winget.
225
+ *
226
+ * @param {string[]} args - Command line arguments (unused)
227
+ * @returns {Promise<void>}
228
+ */
229
+ async function do_brewd_cmd(args) {
230
+ console.error('Error: Homebrew is not available on Windows.');
231
+ console.error('');
232
+ console.error('Windows uses different package managers. Try these alternatives:');
233
+ console.error('');
234
+ console.error('For Chocolatey (if installed):');
235
+ console.error(' choco outdated # Check for outdated packages');
236
+ console.error(' choco list --local # List installed packages');
237
+ console.error('');
238
+ console.error('For winget (Windows Package Manager):');
239
+ console.error(' winget list # List installed packages');
240
+ console.error(' winget upgrade # Check for available upgrades');
241
+ console.error('');
242
+ console.error('For system health checks:');
243
+ console.error(' sfc /scannow # System File Checker (run as Admin)');
244
+ console.error(' DISM /Online /Cleanup-Image /CheckHealth');
245
+ process.exit(1);
246
+ }
247
+
248
+ /**
249
+ * Handle brewd command in Windows PowerShell.
250
+ *
251
+ * Homebrew is not available on Windows. This function informs the user
252
+ * and provides guidance for equivalent package manager diagnostics.
253
+ *
254
+ * @param {string[]} args - Command line arguments (unused)
255
+ * @returns {Promise<void>}
256
+ */
257
+ async function do_brewd_powershell(args) {
258
+ console.error('Error: Homebrew is not available on Windows.');
259
+ console.error('');
260
+ console.error('Windows uses different package managers. Try these alternatives:');
261
+ console.error('');
262
+ console.error('For Chocolatey (if installed):');
263
+ console.error(' choco outdated # Check for outdated packages');
264
+ console.error(' choco list --local # List installed packages');
265
+ console.error('');
266
+ console.error('For winget (Windows Package Manager):');
267
+ console.error(' winget list # List installed packages');
268
+ console.error(' winget upgrade # Check for available upgrades');
269
+ console.error('');
270
+ console.error('For system health checks:');
271
+ console.error(' sfc /scannow # System File Checker (run as Admin)');
272
+ console.error(' DISM /Online /Cleanup-Image /CheckHealth');
273
+ console.error('');
274
+ console.error('PowerShell modules check:');
275
+ console.error(' Get-Module -ListAvailable # List installed modules');
276
+ process.exit(1);
277
+ }
278
+
279
+ /**
280
+ * Run brew doctor from Git Bash on Windows.
281
+ *
282
+ * Git Bash runs on Windows where Homebrew is not natively available.
283
+ * However, if the user has installed Homebrew in WSL or another Linux
284
+ * environment, it may be accessible. This function checks for brew
285
+ * availability and provides appropriate guidance.
286
+ *
287
+ * @param {string[]} args - Command line arguments to pass to brew doctor
288
+ * @returns {Promise<void>}
289
+ */
290
+ async function do_brewd_gitbash(args) {
291
+ // Check if Homebrew is available (unlikely in Git Bash, but possible via WSL interop)
292
+ if (isBrewInstalled()) {
293
+ // Brew is somehow available, run it
294
+ const { spawnSync } = require('child_process');
295
+
296
+ const result = spawnSync('brew', ['doctor', ...args], {
297
+ stdio: 'inherit',
298
+ shell: false
299
+ });
300
+
301
+ process.exit(result.status || 0);
302
+ }
303
+
304
+ // Homebrew not available, provide guidance
305
+ console.error('Error: Homebrew is not available in Git Bash on Windows.');
306
+ console.error('');
307
+ console.error('Git Bash runs on Windows which uses different package managers.');
308
+ console.error('');
309
+ console.error('Options:');
310
+ console.error('');
311
+ console.error('1. Use Chocolatey (from PowerShell or CMD):');
312
+ console.error(' choco outdated # Check for outdated packages');
313
+ console.error('');
314
+ console.error('2. Use winget (Windows Package Manager):');
315
+ console.error(' winget upgrade # Check for available upgrades');
316
+ console.error('');
317
+ console.error('3. If you have WSL installed, you can run brew doctor there:');
318
+ console.error(' wsl brew doctor');
319
+ process.exit(1);
320
+ }
321
+
8
322
  /**
9
- * Executes `brew doctor` to check for potential problems
10
- * with the Homebrew installation.
323
+ * Main entry point - detects environment and executes appropriate implementation.
324
+ *
325
+ * Runs `brew doctor` to check for potential problems with your Homebrew
326
+ * installation. This command is essential for troubleshooting Homebrew
327
+ * issues and ensuring your package manager is functioning correctly.
328
+ *
329
+ * On platforms where Homebrew is not available, provides guidance for
330
+ * equivalent diagnostic commands using the native package manager.
11
331
  *
12
332
  * @param {string[]} args - Command line arguments to pass to brew doctor
13
333
  * @returns {Promise<void>}
14
334
  */
15
- async function main(args) {
16
- // TODO: Implement brew doctor
335
+ async function do_brewd(args) {
336
+ const platform = os.detect();
337
+
338
+ const handlers = {
339
+ 'macos': do_brewd_macos,
340
+ 'ubuntu': do_brewd_ubuntu,
341
+ 'raspbian': do_brewd_raspbian,
342
+ 'amazon_linux': do_brewd_amazon_linux,
343
+ 'cmd': do_brewd_cmd,
344
+ 'powershell': do_brewd_powershell,
345
+ 'gitbash': do_brewd_gitbash
346
+ };
347
+
348
+ const handler = handlers[platform.type];
349
+ if (!handler) {
350
+ // Handle other Linux distros that might have Homebrew
351
+ if (platform.type === 'debian' || platform.type === 'fedora' ||
352
+ platform.type === 'rhel' || platform.type === 'linux') {
353
+ // Try ubuntu handler as fallback for generic Linux
354
+ await do_brewd_ubuntu(args);
355
+ return;
356
+ }
357
+
358
+ // Handle Windows platform type
359
+ if (platform.type === 'windows') {
360
+ await do_brewd_cmd(args);
361
+ return;
362
+ }
363
+
364
+ console.error(`Platform '${platform.type}' is not supported for this command.`);
365
+ console.error('');
366
+ console.error('The brewd command is a shortcut for `brew doctor` which requires');
367
+ console.error('Homebrew to be installed. Homebrew is available on macOS and Linux.');
368
+ process.exit(1);
369
+ }
370
+
371
+ await handler(args);
17
372
  }
18
373
 
19
- module.exports = { main };
374
+ module.exports = {
375
+ main: do_brewd,
376
+ do_brewd,
377
+ do_brewd_nodejs,
378
+ do_brewd_macos,
379
+ do_brewd_ubuntu,
380
+ do_brewd_raspbian,
381
+ do_brewd_amazon_linux,
382
+ do_brewd_cmd,
383
+ do_brewd_powershell,
384
+ do_brewd_gitbash
385
+ };
20
386
 
21
387
  if (require.main === module) {
22
- main(process.argv.slice(2));
388
+ do_brewd(process.argv.slice(2));
23
389
  }