@fredlackey/devutils 0.0.1 → 0.0.2

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 (257) 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
@@ -1,24 +1,435 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Remove node_modules and bower_components recursively.
4
+ * clean-dev - Remove node_modules and bower_components directories recursively
5
+ *
6
+ * Migrated from legacy dotfiles alias.
7
+ * Original:
8
+ * clean-dev() {
9
+ * sudo find . -name "node_modules" -exec rm -rf '{}' +
10
+ * find . -name "bower_components" -exec rm -rf '{}' +
11
+ * }
12
+ *
13
+ * This script recursively finds and removes all node_modules and bower_components
14
+ * directories to free up disk space. This is useful for:
15
+ * - Cleaning up old projects that are no longer being actively developed
16
+ * - Reducing disk space usage from accumulated dependencies
17
+ * - Preparing a directory for archival or backup
18
+ *
19
+ * Unlike the original bash version, this Node.js implementation:
20
+ * - Does NOT require sudo (handles permission errors gracefully)
21
+ * - Works identically across all platforms (macOS, Linux, Windows)
22
+ * - Shows progress as directories are found and removed
23
+ * - Provides a summary of space freed
24
+ *
5
25
  * @module scripts/clean-dev
6
26
  */
7
27
 
28
+ const os = require('../utils/common/os');
29
+ const fs = require('fs');
30
+ const path = require('path');
31
+
32
+ /**
33
+ * Directory names to search for and remove.
34
+ * These are common development artifact directories that can be safely deleted
35
+ * and recreated by running package manager install commands.
36
+ */
37
+ const TARGET_DIRECTORIES = ['node_modules', 'bower_components'];
38
+
39
+ /**
40
+ * Calculate the total size of a directory in bytes.
41
+ * This is used to show how much space was freed.
42
+ *
43
+ * @param {string} dirPath - Absolute path to the directory
44
+ * @returns {number} Total size in bytes, or 0 if directory cannot be read
45
+ */
46
+ function getDirectorySize(dirPath) {
47
+ let totalSize = 0;
48
+
49
+ try {
50
+ const entries = fs.readdirSync(dirPath, { withFileTypes: true });
51
+
52
+ for (const entry of entries) {
53
+ const fullPath = path.join(dirPath, entry.name);
54
+
55
+ try {
56
+ if (entry.isDirectory()) {
57
+ // Recursively calculate size of subdirectories
58
+ totalSize += getDirectorySize(fullPath);
59
+ } else if (entry.isFile()) {
60
+ // Add file size
61
+ const stats = fs.statSync(fullPath);
62
+ totalSize += stats.size;
63
+ }
64
+ } catch (err) {
65
+ // Skip files/directories we cannot access
66
+ // This handles permission errors and symlink issues
67
+ }
68
+ }
69
+ } catch (err) {
70
+ // Cannot read directory, return 0
71
+ }
72
+
73
+ return totalSize;
74
+ }
75
+
76
+ /**
77
+ * Format bytes into a human-readable string (KB, MB, GB).
78
+ *
79
+ * @param {number} bytes - Size in bytes
80
+ * @returns {string} Human-readable size string
81
+ */
82
+ function formatBytes(bytes) {
83
+ if (bytes === 0) return '0 B';
84
+
85
+ const units = ['B', 'KB', 'MB', 'GB', 'TB'];
86
+ const k = 1024;
87
+ const i = Math.floor(Math.log(bytes) / Math.log(k));
88
+ const size = (bytes / Math.pow(k, i)).toFixed(2);
89
+
90
+ return `${size} ${units[i]}`;
91
+ }
92
+
93
+ /**
94
+ * Recursively remove a directory and all its contents.
95
+ * This is the equivalent of 'rm -rf' in bash.
96
+ *
97
+ * @param {string} dirPath - Absolute path to the directory to remove
98
+ * @returns {boolean} True if successfully removed, false otherwise
99
+ */
100
+ function removeDirectory(dirPath) {
101
+ try {
102
+ // Node.js 14.14+ supports recursive removal with fs.rmSync
103
+ // We use this instead of shell commands for cross-platform compatibility
104
+ fs.rmSync(dirPath, { recursive: true, force: true });
105
+ return true;
106
+ } catch (err) {
107
+ // Permission denied or other error
108
+ return false;
109
+ }
110
+ }
111
+
112
+ /**
113
+ * Recursively find directories with a specific name.
114
+ * This walks the directory tree and collects paths to matching directories.
115
+ *
116
+ * IMPORTANT: When we find a target directory (like node_modules), we do NOT
117
+ * recurse into it. This is because:
118
+ * 1. node_modules can contain nested node_modules (from hoisting)
119
+ * 2. We want to delete the top-level directory, which will delete all contents
120
+ * 3. Recursing into these massive directories would be slow and wasteful
121
+ *
122
+ * @param {string} rootDir - Starting directory for the search
123
+ * @param {string[]} targetNames - Names of directories to find
124
+ * @returns {string[]} Array of absolute paths to found directories
125
+ */
126
+ function findDirectories(rootDir, targetNames) {
127
+ const results = [];
128
+
129
+ /**
130
+ * Inner recursive function to walk the directory tree.
131
+ * @param {string} currentDir - Current directory being examined
132
+ */
133
+ function walk(currentDir) {
134
+ let entries;
135
+
136
+ try {
137
+ entries = fs.readdirSync(currentDir, { withFileTypes: true });
138
+ } catch (err) {
139
+ // Cannot read directory (permission denied, etc.) - skip it
140
+ return;
141
+ }
142
+
143
+ for (const entry of entries) {
144
+ // Only process directories
145
+ if (!entry.isDirectory()) {
146
+ continue;
147
+ }
148
+
149
+ const fullPath = path.join(currentDir, entry.name);
150
+
151
+ // Check if this directory matches one of our target names
152
+ if (targetNames.includes(entry.name)) {
153
+ // Found a match! Add to results
154
+ results.push(fullPath);
155
+ // Do NOT recurse into this directory - we'll delete it entirely
156
+ // This also prevents us from finding nested node_modules inside
157
+ } else {
158
+ // Not a match, recurse into this directory to keep searching
159
+ walk(fullPath);
160
+ }
161
+ }
162
+ }
163
+
164
+ // Start the walk from the root directory
165
+ walk(rootDir);
166
+
167
+ return results;
168
+ }
169
+
170
+ /**
171
+ * Pure Node.js implementation that works on any platform.
172
+ *
173
+ * This implementation uses only Node.js fs module operations:
174
+ * - fs.readdirSync to walk directory trees
175
+ * - fs.rmSync to remove directories recursively
176
+ * - fs.statSync to calculate directory sizes
177
+ *
178
+ * No shell commands are needed because this is pure file system manipulation,
179
+ * which Node.js handles well across all platforms.
180
+ *
181
+ * @param {string[]} args - Command line arguments
182
+ * @param {string} [args[0]] - Optional path to clean (defaults to current directory)
183
+ * @returns {Promise<void>}
184
+ */
185
+ async function do_clean_dev_nodejs(args) {
186
+ // Determine the starting directory
187
+ // If a path is provided as an argument, use it; otherwise use current working directory
188
+ const startPath = args[0] ? path.resolve(args[0]) : process.cwd();
189
+
190
+ // Verify the starting path exists and is a directory
191
+ try {
192
+ const stats = fs.statSync(startPath);
193
+ if (!stats.isDirectory()) {
194
+ console.error(`Error: '${startPath}' is not a directory.`);
195
+ process.exit(1);
196
+ }
197
+ } catch (err) {
198
+ console.error(`Error: Cannot access '${startPath}'.`);
199
+ console.error(err.message);
200
+ process.exit(1);
201
+ }
202
+
203
+ console.log(`Scanning for development artifact directories in: ${startPath}`);
204
+ console.log(`Looking for: ${TARGET_DIRECTORIES.join(', ')}`);
205
+ console.log('');
206
+
207
+ // Find all target directories
208
+ const foundDirs = findDirectories(startPath, TARGET_DIRECTORIES);
209
+
210
+ if (foundDirs.length === 0) {
211
+ console.log('No node_modules or bower_components directories found.');
212
+ return;
213
+ }
214
+
215
+ console.log(`Found ${foundDirs.length} director${foundDirs.length === 1 ? 'y' : 'ies'} to remove:`);
216
+ console.log('');
217
+
218
+ let totalSize = 0;
219
+ let removedCount = 0;
220
+ let failedCount = 0;
221
+ const failedDirs = [];
222
+
223
+ // Process each found directory
224
+ for (const dirPath of foundDirs) {
225
+ // Calculate size before removal (for reporting)
226
+ const size = getDirectorySize(dirPath);
227
+
228
+ // Show which directory we're removing
229
+ const relativePath = path.relative(startPath, dirPath) || '.';
230
+ process.stdout.write(` Removing: ${relativePath} (${formatBytes(size)})... `);
231
+
232
+ // Attempt to remove the directory
233
+ const success = removeDirectory(dirPath);
234
+
235
+ if (success) {
236
+ console.log('done');
237
+ totalSize += size;
238
+ removedCount++;
239
+ } else {
240
+ console.log('FAILED (permission denied)');
241
+ failedCount++;
242
+ failedDirs.push(relativePath);
243
+ }
244
+ }
245
+
246
+ // Print summary
247
+ console.log('');
248
+ console.log('--- Summary ---');
249
+ console.log(`Directories removed: ${removedCount}`);
250
+ console.log(`Space freed: ${formatBytes(totalSize)}`);
251
+
252
+ if (failedCount > 0) {
253
+ console.log('');
254
+ console.log(`Failed to remove ${failedCount} director${failedCount === 1 ? 'y' : 'ies'}:`);
255
+ for (const dir of failedDirs) {
256
+ console.log(` - ${dir}`);
257
+ }
258
+ console.log('');
259
+ console.log('Tip: You may need to run with elevated privileges to remove these directories.');
260
+ console.log(' On macOS/Linux: sudo clean-dev');
261
+ console.log(' On Windows: Run as Administrator');
262
+ }
263
+ }
264
+
265
+ /**
266
+ * Remove node_modules and bower_components on macOS.
267
+ *
268
+ * Uses the pure Node.js implementation since file system operations
269
+ * work identically across platforms. The original bash version used sudo,
270
+ * but our Node.js version handles permission errors gracefully instead.
271
+ *
272
+ * @param {string[]} args - Command line arguments
273
+ * @returns {Promise<void>}
274
+ */
275
+ async function do_clean_dev_macos(args) {
276
+ // macOS uses the same Node.js file operations as all other platforms
277
+ return do_clean_dev_nodejs(args);
278
+ }
279
+
280
+ /**
281
+ * Remove node_modules and bower_components on Ubuntu.
282
+ *
283
+ * Uses the pure Node.js implementation since file system operations
284
+ * work identically across platforms.
285
+ *
286
+ * @param {string[]} args - Command line arguments
287
+ * @returns {Promise<void>}
288
+ */
289
+ async function do_clean_dev_ubuntu(args) {
290
+ // Ubuntu uses the same Node.js file operations as all other platforms
291
+ return do_clean_dev_nodejs(args);
292
+ }
293
+
294
+ /**
295
+ * Remove node_modules and bower_components on Raspberry Pi OS.
296
+ *
297
+ * Uses the pure Node.js implementation since file system operations
298
+ * work identically across platforms.
299
+ *
300
+ * @param {string[]} args - Command line arguments
301
+ * @returns {Promise<void>}
302
+ */
303
+ async function do_clean_dev_raspbian(args) {
304
+ // Raspbian uses the same Node.js file operations as all other platforms
305
+ return do_clean_dev_nodejs(args);
306
+ }
307
+
8
308
  /**
9
- * Recursively finds and removes all node_modules and bower_components
10
- * directories to free up disk space.
309
+ * Remove node_modules and bower_components on Amazon Linux.
310
+ *
311
+ * Uses the pure Node.js implementation since file system operations
312
+ * work identically across platforms.
11
313
  *
12
314
  * @param {string[]} args - Command line arguments
13
- * @param {string} [args.0] - Optional path to clean (defaults to current directory)
14
315
  * @returns {Promise<void>}
15
316
  */
16
- async function main(args) {
17
- // TODO: Implement recursive dev folder cleanup
317
+ async function do_clean_dev_amazon_linux(args) {
318
+ // Amazon Linux uses the same Node.js file operations as all other platforms
319
+ return do_clean_dev_nodejs(args);
320
+ }
321
+
322
+ /**
323
+ * Remove node_modules and bower_components on Windows Command Prompt.
324
+ *
325
+ * Uses the pure Node.js implementation since fs.rmSync with recursive: true
326
+ * works correctly on Windows for deep directory trees.
327
+ *
328
+ * @param {string[]} args - Command line arguments
329
+ * @returns {Promise<void>}
330
+ */
331
+ async function do_clean_dev_cmd(args) {
332
+ // Windows CMD uses the same Node.js file operations as all other platforms
333
+ return do_clean_dev_nodejs(args);
334
+ }
335
+
336
+ /**
337
+ * Remove node_modules and bower_components on Windows PowerShell.
338
+ *
339
+ * Uses the pure Node.js implementation since fs.rmSync with recursive: true
340
+ * works correctly on Windows for deep directory trees.
341
+ *
342
+ * @param {string[]} args - Command line arguments
343
+ * @returns {Promise<void>}
344
+ */
345
+ async function do_clean_dev_powershell(args) {
346
+ // Windows PowerShell uses the same Node.js file operations as all other platforms
347
+ return do_clean_dev_nodejs(args);
348
+ }
349
+
350
+ /**
351
+ * Remove node_modules and bower_components on Git Bash.
352
+ *
353
+ * Uses the pure Node.js implementation since fs.rmSync with recursive: true
354
+ * works correctly on Windows (which Git Bash runs on) for deep directory trees.
355
+ *
356
+ * @param {string[]} args - Command line arguments
357
+ * @returns {Promise<void>}
358
+ */
359
+ async function do_clean_dev_gitbash(args) {
360
+ // Git Bash uses the same Node.js file operations as all other platforms
361
+ return do_clean_dev_nodejs(args);
362
+ }
363
+
364
+ /**
365
+ * Main entry point - detects environment and executes appropriate implementation.
366
+ *
367
+ * Recursively finds and removes all node_modules and bower_components directories
368
+ * to free up disk space. This is a common cleanup operation for developers who
369
+ * work on many Node.js projects.
370
+ *
371
+ * Usage:
372
+ * clean-dev # Clean current directory
373
+ * clean-dev ~/projects # Clean a specific directory
374
+ *
375
+ * What gets removed:
376
+ * - node_modules/ # npm/yarn/pnpm dependencies
377
+ * - bower_components/ # Bower dependencies (legacy)
378
+ *
379
+ * This is safe because these directories can always be recreated by running
380
+ * 'npm install', 'yarn install', or 'bower install' in the project directory.
381
+ *
382
+ * @param {string[]} args - Command line arguments
383
+ * @returns {Promise<void>}
384
+ */
385
+ async function do_clean_dev(args) {
386
+ const platform = os.detect();
387
+
388
+ const handlers = {
389
+ 'macos': do_clean_dev_macos,
390
+ 'ubuntu': do_clean_dev_ubuntu,
391
+ 'debian': do_clean_dev_ubuntu,
392
+ 'raspbian': do_clean_dev_raspbian,
393
+ 'amazon_linux': do_clean_dev_amazon_linux,
394
+ 'rhel': do_clean_dev_amazon_linux,
395
+ 'fedora': do_clean_dev_ubuntu,
396
+ 'linux': do_clean_dev_ubuntu,
397
+ 'wsl': do_clean_dev_ubuntu,
398
+ 'cmd': do_clean_dev_cmd,
399
+ 'windows': do_clean_dev_cmd,
400
+ 'powershell': do_clean_dev_powershell,
401
+ 'gitbash': do_clean_dev_gitbash
402
+ };
403
+
404
+ const handler = handlers[platform.type];
405
+ if (!handler) {
406
+ console.error(`Platform '${platform.type}' is not supported for this command.`);
407
+ console.error('');
408
+ console.error('Supported platforms:');
409
+ console.error(' - macOS');
410
+ console.error(' - Ubuntu, Debian, and other Linux distributions');
411
+ console.error(' - Raspberry Pi OS');
412
+ console.error(' - Amazon Linux, RHEL, Fedora');
413
+ console.error(' - Windows (CMD, PowerShell, Git Bash)');
414
+ process.exit(1);
415
+ }
416
+
417
+ await handler(args);
18
418
  }
19
419
 
20
- module.exports = { main };
420
+ module.exports = {
421
+ main: do_clean_dev,
422
+ do_clean_dev,
423
+ do_clean_dev_nodejs,
424
+ do_clean_dev_macos,
425
+ do_clean_dev_ubuntu,
426
+ do_clean_dev_raspbian,
427
+ do_clean_dev_amazon_linux,
428
+ do_clean_dev_cmd,
429
+ do_clean_dev_powershell,
430
+ do_clean_dev_gitbash
431
+ };
21
432
 
22
433
  if (require.main === module) {
23
- main(process.argv.slice(2));
434
+ do_clean_dev(process.argv.slice(2));
24
435
  }