@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.
- package/README.md +5 -5
- package/package.json +1 -1
- package/src/commands/install.js +374 -36
- package/src/installs/adobe-creative-cloud.js +527 -25
- package/src/installs/adobe-creative-cloud.md +605 -0
- package/src/installs/appcleaner.js +303 -26
- package/src/installs/appcleaner.md +699 -0
- package/src/installs/apt-transport-https.js +390 -0
- package/src/installs/apt-transport-https.md +678 -0
- package/src/installs/atomicparsley.js +624 -26
- package/src/installs/atomicparsley.md +795 -0
- package/src/installs/aws-cli.js +779 -26
- package/src/installs/aws-cli.md +727 -0
- package/src/installs/balena-etcher.js +688 -26
- package/src/installs/balena-etcher.md +761 -0
- package/src/installs/bambu-studio.js +912 -26
- package/src/installs/bambu-studio.md +780 -0
- package/src/installs/bash-completion.js +554 -23
- package/src/installs/bash-completion.md +833 -0
- package/src/installs/bash.js +399 -26
- package/src/installs/bash.md +993 -0
- package/src/installs/beyond-compare.js +585 -26
- package/src/installs/beyond-compare.md +813 -0
- package/src/installs/build-essential.js +511 -26
- package/src/installs/build-essential.md +977 -0
- package/src/installs/ca-certificates.js +618 -0
- package/src/installs/ca-certificates.md +937 -0
- package/src/installs/caffeine.js +490 -26
- package/src/installs/caffeine.md +839 -0
- package/src/installs/camtasia.js +577 -25
- package/src/installs/camtasia.md +762 -0
- package/src/installs/chatgpt.js +458 -26
- package/src/installs/chatgpt.md +814 -0
- package/src/installs/chocolatey.js +447 -0
- package/src/installs/chocolatey.md +661 -0
- package/src/installs/chrome-canary.js +472 -26
- package/src/installs/chrome-canary.md +641 -0
- package/src/installs/chromium.js +645 -26
- package/src/installs/chromium.md +838 -0
- package/src/installs/claude-code.js +558 -26
- package/src/installs/claude-code.md +1173 -0
- package/src/installs/curl.js +361 -26
- package/src/installs/curl.md +714 -0
- package/src/installs/cursor.js +561 -26
- package/src/installs/cursor.md +970 -0
- package/src/installs/dbschema.js +674 -26
- package/src/installs/dbschema.md +925 -0
- package/src/installs/dependencies.md +435 -0
- package/src/installs/development-tools.js +600 -0
- package/src/installs/development-tools.md +977 -0
- package/src/installs/docker.js +1010 -25
- package/src/installs/docker.md +1109 -0
- package/src/installs/drawio.js +1001 -26
- package/src/installs/drawio.md +795 -0
- package/src/installs/elmedia-player.js +328 -25
- package/src/installs/elmedia-player.md +556 -0
- package/src/installs/ffmpeg.js +870 -25
- package/src/installs/ffmpeg.md +852 -0
- package/src/installs/file.js +464 -0
- package/src/installs/file.md +987 -0
- package/src/installs/gemini-cli.js +793 -26
- package/src/installs/gemini-cli.md +1153 -0
- package/src/installs/git.js +382 -26
- package/src/installs/git.md +907 -0
- package/src/installs/gitego.js +931 -26
- package/src/installs/gitego.md +1172 -0
- package/src/installs/go.js +913 -26
- package/src/installs/go.md +958 -0
- package/src/installs/google-chrome.js +801 -25
- package/src/installs/google-chrome.md +862 -0
- package/src/installs/gpg.js +412 -73
- package/src/installs/gpg.md +1056 -0
- package/src/installs/homebrew.js +1015 -26
- package/src/installs/homebrew.md +988 -0
- package/src/installs/imageoptim.js +950 -26
- package/src/installs/imageoptim.md +1119 -0
- package/src/installs/installers.json +2297 -0
- package/src/installs/jq.js +382 -26
- package/src/installs/jq.md +809 -0
- package/src/installs/keyboard-maestro.js +701 -26
- package/src/installs/keyboard-maestro.md +825 -0
- package/src/installs/latex.js +771 -26
- package/src/installs/latex.md +1095 -0
- package/src/installs/lftp.js +338 -26
- package/src/installs/lftp.md +907 -0
- package/src/installs/lsb-release.js +346 -0
- package/src/installs/lsb-release.md +814 -0
- package/src/installs/messenger.js +829 -26
- package/src/installs/messenger.md +900 -0
- package/src/installs/microsoft-office.js +550 -26
- package/src/installs/microsoft-office.md +760 -0
- package/src/installs/microsoft-teams.js +782 -25
- package/src/installs/microsoft-teams.md +886 -0
- package/src/installs/node.js +886 -26
- package/src/installs/node.md +1153 -0
- package/src/installs/nordpass.js +698 -26
- package/src/installs/nordpass.md +921 -0
- package/src/installs/nvm.js +977 -26
- package/src/installs/nvm.md +1057 -0
- package/src/installs/openssh.js +734 -64
- package/src/installs/openssh.md +1056 -0
- package/src/installs/pandoc.js +644 -26
- package/src/installs/pandoc.md +1036 -0
- package/src/installs/pinentry.js +492 -26
- package/src/installs/pinentry.md +1142 -0
- package/src/installs/pngyu.js +851 -26
- package/src/installs/pngyu.md +896 -0
- package/src/installs/postman.js +781 -26
- package/src/installs/postman.md +940 -0
- package/src/installs/procps.js +425 -0
- package/src/installs/procps.md +851 -0
- package/src/installs/safari-tech-preview.js +355 -25
- package/src/installs/safari-tech-preview.md +533 -0
- package/src/installs/sfnt2woff.js +640 -26
- package/src/installs/sfnt2woff.md +795 -0
- package/src/installs/shellcheck.js +463 -26
- package/src/installs/shellcheck.md +1005 -0
- package/src/installs/slack.js +722 -25
- package/src/installs/slack.md +865 -0
- package/src/installs/snagit.js +566 -25
- package/src/installs/snagit.md +844 -0
- package/src/installs/software-properties-common.js +372 -0
- package/src/installs/software-properties-common.md +805 -0
- package/src/installs/spotify.js +858 -25
- package/src/installs/spotify.md +901 -0
- package/src/installs/studio-3t.js +803 -26
- package/src/installs/studio-3t.md +918 -0
- package/src/installs/sublime-text.js +780 -25
- package/src/installs/sublime-text.md +914 -0
- package/src/installs/superwhisper.js +687 -25
- package/src/installs/superwhisper.md +630 -0
- package/src/installs/tailscale.js +727 -26
- package/src/installs/tailscale.md +1100 -0
- package/src/installs/tar.js +389 -0
- package/src/installs/tar.md +946 -0
- package/src/installs/termius.js +780 -26
- package/src/installs/termius.md +844 -0
- package/src/installs/terraform.js +761 -26
- package/src/installs/terraform.md +899 -0
- package/src/installs/tidal.js +752 -25
- package/src/installs/tidal.md +864 -0
- package/src/installs/tmux.js +328 -26
- package/src/installs/tmux.md +1030 -0
- package/src/installs/tree.js +393 -26
- package/src/installs/tree.md +833 -0
- package/src/installs/unzip.js +460 -0
- package/src/installs/unzip.md +879 -0
- package/src/installs/vim.js +403 -26
- package/src/installs/vim.md +1040 -0
- package/src/installs/vlc.js +803 -26
- package/src/installs/vlc.md +927 -0
- package/src/installs/vscode.js +825 -26
- package/src/installs/vscode.md +1002 -0
- package/src/installs/wget.js +415 -0
- package/src/installs/wget.md +791 -0
- package/src/installs/whatsapp.js +710 -25
- package/src/installs/whatsapp.md +854 -0
- package/src/installs/winpty.js +352 -0
- package/src/installs/winpty.md +620 -0
- package/src/installs/woff2.js +535 -26
- package/src/installs/woff2.md +977 -0
- package/src/installs/wsl.js +572 -0
- package/src/installs/wsl.md +699 -0
- package/src/installs/xcode-clt.js +520 -0
- package/src/installs/xcode-clt.md +351 -0
- package/src/installs/xcode.js +542 -26
- package/src/installs/xcode.md +573 -0
- package/src/installs/yarn.js +806 -26
- package/src/installs/yarn.md +1074 -0
- package/src/installs/yq.js +636 -26
- package/src/installs/yq.md +944 -0
- package/src/installs/yt-dlp.js +683 -26
- package/src/installs/yt-dlp.md +946 -0
- package/src/installs/yum-utils.js +297 -0
- package/src/installs/yum-utils.md +648 -0
- package/src/installs/zoom.js +740 -25
- package/src/installs/zoom.md +884 -0
- package/src/scripts/README.md +567 -45
- package/src/scripts/STATUS.md +208 -0
- package/src/scripts/afk.js +395 -7
- package/src/scripts/backup-all.js +731 -9
- package/src/scripts/backup-source.js +711 -8
- package/src/scripts/brewd.js +373 -7
- package/src/scripts/brewi.js +505 -9
- package/src/scripts/brewr.js +512 -9
- package/src/scripts/brews.js +462 -9
- package/src/scripts/brewu.js +488 -7
- package/src/scripts/c.js +185 -7
- package/src/scripts/ccurl.js +325 -8
- package/src/scripts/certbot-crontab-init.js +488 -8
- package/src/scripts/certbot-init.js +641 -9
- package/src/scripts/ch.js +339 -7
- package/src/scripts/claude-danger.js +253 -8
- package/src/scripts/clean-dev.js +419 -8
- package/src/scripts/clear-dns-cache.js +525 -7
- package/src/scripts/clone.js +417 -7
- package/src/scripts/code-all.js +420 -7
- package/src/scripts/count-files.js +195 -8
- package/src/scripts/count-folders.js +195 -8
- package/src/scripts/count.js +248 -8
- package/src/scripts/d.js +203 -7
- package/src/scripts/datauri.js +373 -8
- package/src/scripts/delete-files.js +363 -7
- package/src/scripts/docker-clean.js +410 -8
- package/src/scripts/dp.js +426 -7
- package/src/scripts/e.js +375 -9
- package/src/scripts/empty-trash.js +497 -7
- package/src/scripts/evm.js +428 -9
- package/src/scripts/fetch-github-repos.js +441 -10
- package/src/scripts/get-channel.js +329 -8
- package/src/scripts/get-course.js +384 -11
- package/src/scripts/get-dependencies.js +290 -9
- package/src/scripts/get-folder.js +783 -10
- package/src/scripts/get-tunes.js +411 -10
- package/src/scripts/get-video.js +352 -9
- package/src/scripts/git-backup.js +561 -9
- package/src/scripts/git-clone.js +477 -9
- package/src/scripts/git-pup.js +303 -7
- package/src/scripts/git-push.js +380 -8
- package/src/scripts/h.js +607 -9
- package/src/scripts/hide-desktop-icons.js +483 -7
- package/src/scripts/hide-hidden-files.js +522 -7
- package/src/scripts/install-dependencies-from.js +440 -9
- package/src/scripts/ips.js +647 -10
- package/src/scripts/iso.js +354 -8
- package/src/scripts/killni.js +561 -7
- package/src/scripts/ll.js +451 -8
- package/src/scripts/local-ip.js +310 -8
- package/src/scripts/m.js +508 -8
- package/src/scripts/map.js +293 -8
- package/src/scripts/mkd.js +287 -7
- package/src/scripts/ncu-update-all.js +441 -8
- package/src/scripts/nginx-init.js +702 -12
- package/src/scripts/npmi.js +366 -7
- package/src/scripts/o.js +495 -8
- package/src/scripts/org-by-date.js +321 -7
- package/src/scripts/p.js +208 -7
- package/src/scripts/packages.js +313 -8
- package/src/scripts/path.js +209 -7
- package/src/scripts/ports.js +582 -8
- package/src/scripts/q.js +290 -8
- package/src/scripts/refresh-files.js +378 -10
- package/src/scripts/remove-smaller-files.js +500 -8
- package/src/scripts/rename-files-with-date.js +517 -9
- package/src/scripts/resize-image.js +523 -9
- package/src/scripts/rm-safe.js +653 -8
- package/src/scripts/s.js +525 -9
- package/src/scripts/set-git-public.js +349 -7
- package/src/scripts/show-desktop-icons.js +459 -7
- package/src/scripts/show-hidden-files.js +456 -7
- package/src/scripts/tpa.js +265 -8
- package/src/scripts/tpo.js +264 -7
- package/src/scripts/u.js +489 -7
- package/src/scripts/vpush.js +422 -8
- package/src/scripts/y.js +267 -7
- package/src/utils/common/os.js +94 -2
- package/src/utils/ubuntu/apt.js +13 -7
package/src/scripts/clean-dev.js
CHANGED
|
@@ -1,24 +1,435 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
|
-
*
|
|
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
|
-
*
|
|
10
|
-
*
|
|
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
|
|
17
|
-
//
|
|
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 = {
|
|
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
|
-
|
|
434
|
+
do_clean_dev(process.argv.slice(2));
|
|
24
435
|
}
|