@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,23 +1,538 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Hide dotfiles in Finder.
4
+ * hide-hidden-files - Hide dotfiles in file manager
5
+ *
6
+ * Migrated from legacy dotfiles alias.
7
+ * Original: alias hide-hidden-files="defaults write com.apple.finder AppleShowAllFiles -bool false && killall Finder"
8
+ *
9
+ * This script configures the system's file manager to hide hidden files (dotfiles).
10
+ * Hidden files are files that start with a dot (.) on Unix-like systems, or have
11
+ * the "hidden" attribute on Windows.
12
+ *
13
+ * The behavior varies by platform:
14
+ * - macOS: Modifies Finder preferences to hide files starting with "."
15
+ * - Windows: Hidden files are hidden by default; this ensures they stay hidden
16
+ * - Linux: Configures file manager (Nautilus, Dolphin, etc.) to hide dotfiles
17
+ *
5
18
  * @module scripts/hide-hidden-files
6
19
  */
7
20
 
21
+ const os = require('../utils/common/os');
22
+ const { execSync } = require('child_process');
23
+
24
+ /**
25
+ * Helper function to check if a command exists on the system.
26
+ *
27
+ * @param {string} cmd - The command name to check
28
+ * @returns {boolean} True if the command exists, false otherwise
29
+ */
30
+ function isCommandAvailable(cmd) {
31
+ try {
32
+ const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
33
+ execSync(checkCmd, { stdio: 'ignore' });
34
+ return true;
35
+ } catch {
36
+ return false;
37
+ }
38
+ }
39
+
40
+ /**
41
+ * Pure Node.js implementation - NOT APPLICABLE for this script.
42
+ *
43
+ * Hiding hidden files in file managers requires OS-specific integration:
44
+ * - macOS uses the `defaults` command to modify Finder preferences
45
+ * - Windows uses registry or folder options
46
+ * - Linux uses gsettings, dconf, or file manager-specific configuration
47
+ *
48
+ * There is no cross-platform way to accomplish this in pure Node.js because
49
+ * each operating system's file manager stores its preferences differently.
50
+ *
51
+ * @param {string[]} args - Command line arguments (unused)
52
+ * @returns {Promise<void>}
53
+ * @throws {Error} Always throws - this function should not be called directly
54
+ */
55
+ async function do_hide_hidden_files_nodejs(args) {
56
+ throw new Error(
57
+ 'do_hide_hidden_files_nodejs should not be called directly. ' +
58
+ 'Hiding hidden files in file managers requires OS-specific commands.'
59
+ );
60
+ }
61
+
62
+ /**
63
+ * Hide hidden files in macOS Finder.
64
+ *
65
+ * Uses the `defaults` command to modify Finder's preference for showing hidden files.
66
+ * The AppleShowAllFiles key controls whether Finder displays files that start with
67
+ * a dot (.) character.
68
+ *
69
+ * After changing the preference, Finder must be restarted for the change to take effect.
70
+ * This is done by using `killall Finder`, which causes Finder to restart automatically.
71
+ *
72
+ * Original alias: defaults write com.apple.finder AppleShowAllFiles -bool false && killall Finder
73
+ *
74
+ * @param {string[]} args - Command line arguments (unused)
75
+ * @returns {Promise<void>}
76
+ */
77
+ async function do_hide_hidden_files_macos(args) {
78
+ try {
79
+ // Step 1: Check the current value to see if we even need to make a change
80
+ // This makes the function idempotent - running it multiple times has no side effects
81
+ let currentValue = 'false';
82
+ try {
83
+ currentValue = execSync('defaults read com.apple.finder AppleShowAllFiles', {
84
+ encoding: 'utf8',
85
+ stdio: ['pipe', 'pipe', 'ignore']
86
+ }).trim().toLowerCase();
87
+ } catch {
88
+ // If the key doesn't exist, the default is false (hidden files are hidden)
89
+ currentValue = 'false';
90
+ }
91
+
92
+ // Normalize various boolean representations to check current state
93
+ // defaults can return: true, false, 1, 0, YES, NO, yes, no
94
+ const isCurrentlyShowing = ['true', '1', 'yes'].includes(currentValue.toLowerCase());
95
+
96
+ if (!isCurrentlyShowing) {
97
+ console.log('Hidden files are already hidden in Finder.');
98
+ console.log('No changes needed.');
99
+ return;
100
+ }
101
+
102
+ // Step 2: Write the preference to hide hidden files
103
+ execSync('defaults write com.apple.finder AppleShowAllFiles -bool false', {
104
+ stdio: 'inherit'
105
+ });
106
+
107
+ // Step 3: Restart Finder for the change to take effect
108
+ // killall Finder causes Finder to quit and relaunch automatically
109
+ execSync('killall Finder', { stdio: 'inherit' });
110
+
111
+ console.log('Hidden files are now hidden in Finder.');
112
+ console.log('Finder has been restarted to apply the change.');
113
+ } catch (error) {
114
+ console.error('Error: Could not configure Finder to hide hidden files.');
115
+ console.error('Make sure you have the necessary permissions.');
116
+ console.error(`Details: ${error.message}`);
117
+ process.exit(1);
118
+ }
119
+ }
120
+
121
+ /**
122
+ * Hide hidden files in Ubuntu file managers.
123
+ *
124
+ * Ubuntu typically uses Nautilus (GNOME Files) as the default file manager.
125
+ * This function uses gsettings to modify the show-hidden preference.
126
+ *
127
+ * For other file managers (Dolphin, Thunar, etc.), the configuration method differs.
128
+ * This function attempts to detect and configure the most common file managers.
129
+ *
130
+ * Note: Users can also toggle hidden files with Ctrl+H in most file managers.
131
+ *
132
+ * @param {string[]} args - Command line arguments (unused)
133
+ * @returns {Promise<void>}
134
+ */
135
+ async function do_hide_hidden_files_ubuntu(args) {
136
+ // Check if we have a desktop environment
137
+ const hasDesktop = os.isDesktopAvailable();
138
+
139
+ if (!hasDesktop) {
140
+ console.log('No desktop environment detected.');
141
+ console.log('This command configures graphical file managers.');
142
+ console.log('');
143
+ console.log('On a headless server, hidden files (dotfiles) are not shown');
144
+ console.log('by default when using `ls`. Use `ls -a` to see them.');
145
+ return;
146
+ }
147
+
148
+ // Try to configure Nautilus (GNOME Files) using gsettings
149
+ if (isCommandAvailable('gsettings')) {
150
+ try {
151
+ // Check current value first for idempotency
152
+ const currentValue = execSync(
153
+ 'gsettings get org.gtk.Settings.FileChooser show-hidden',
154
+ { encoding: 'utf8', stdio: ['pipe', 'pipe', 'ignore'] }
155
+ ).trim();
156
+
157
+ if (currentValue === 'false') {
158
+ console.log('Hidden files are already hidden in file manager.');
159
+ console.log('No changes needed.');
160
+ return;
161
+ }
162
+
163
+ // Set the preference to hide hidden files in GTK file chooser dialogs
164
+ execSync('gsettings set org.gtk.Settings.FileChooser show-hidden false', {
165
+ stdio: 'inherit'
166
+ });
167
+
168
+ // Also try to set it for Nautilus specifically if the schema exists
169
+ try {
170
+ execSync('gsettings set org.gnome.nautilus.preferences show-hidden-files false', {
171
+ stdio: ['pipe', 'pipe', 'ignore']
172
+ });
173
+ } catch {
174
+ // This schema may not exist on all systems, which is fine
175
+ }
176
+
177
+ console.log('Hidden files are now hidden in file manager.');
178
+ console.log('');
179
+ console.log('Note: You can toggle hidden files with Ctrl+H in most file managers.');
180
+ return;
181
+ } catch (error) {
182
+ // gsettings command failed, try other methods
183
+ }
184
+ }
185
+
186
+ // Try dconf (alternative to gsettings)
187
+ if (isCommandAvailable('dconf')) {
188
+ try {
189
+ execSync('dconf write /org/gtk/settings/file-chooser/show-hidden false', {
190
+ stdio: 'inherit'
191
+ });
192
+ console.log('Hidden files are now hidden in file manager.');
193
+ console.log('');
194
+ console.log('Note: You can toggle hidden files with Ctrl+H in most file managers.');
195
+ return;
196
+ } catch {
197
+ // dconf command failed, continue
198
+ }
199
+ }
200
+
201
+ // Provide manual instructions if automatic configuration failed
202
+ console.log('Could not automatically configure your file manager.');
203
+ console.log('');
204
+ console.log('To hide hidden files manually:');
205
+ console.log('');
206
+ console.log(' Nautilus (GNOME Files):');
207
+ console.log(' Press Ctrl+H to toggle hidden files, or');
208
+ console.log(' Open hamburger menu > Show Hidden Files (uncheck)');
209
+ console.log('');
210
+ console.log(' Dolphin (KDE):');
211
+ console.log(' View menu > Show Hidden Files (uncheck), or');
212
+ console.log(' Press Alt+. to toggle');
213
+ console.log('');
214
+ console.log(' Thunar (XFCE):');
215
+ console.log(' View menu > Show Hidden Files (uncheck), or');
216
+ console.log(' Press Ctrl+H to toggle');
217
+ }
218
+
219
+ /**
220
+ * Hide hidden files on Raspberry Pi OS file managers.
221
+ *
222
+ * Raspberry Pi OS typically uses PCManFM (LXDE) or Nautilus (PIXEL) as file manager.
223
+ * Configuration is similar to Ubuntu.
224
+ *
225
+ * @param {string[]} args - Command line arguments (unused)
226
+ * @returns {Promise<void>}
227
+ */
228
+ async function do_hide_hidden_files_raspbian(args) {
229
+ const hasDesktop = os.isDesktopAvailable();
230
+
231
+ if (!hasDesktop) {
232
+ console.log('No desktop environment detected.');
233
+ console.log('This command configures graphical file managers.');
234
+ console.log('');
235
+ console.log('On a headless Raspberry Pi, hidden files are not shown');
236
+ console.log('by default when using `ls`. Use `ls -a` to see them.');
237
+ return;
238
+ }
239
+
240
+ // Try gsettings (works for PIXEL desktop which uses GTK apps)
241
+ if (isCommandAvailable('gsettings')) {
242
+ try {
243
+ const currentValue = execSync(
244
+ 'gsettings get org.gtk.Settings.FileChooser show-hidden',
245
+ { encoding: 'utf8', stdio: ['pipe', 'pipe', 'ignore'] }
246
+ ).trim();
247
+
248
+ if (currentValue === 'false') {
249
+ console.log('Hidden files are already hidden in file manager.');
250
+ console.log('No changes needed.');
251
+ return;
252
+ }
253
+
254
+ execSync('gsettings set org.gtk.Settings.FileChooser show-hidden false', {
255
+ stdio: 'inherit'
256
+ });
257
+
258
+ console.log('Hidden files are now hidden in file manager.');
259
+ console.log('');
260
+ console.log('Note: You can toggle hidden files with Ctrl+H in most file managers.');
261
+ return;
262
+ } catch {
263
+ // Continue to manual instructions
264
+ }
265
+ }
266
+
267
+ // PCManFM (LXDE file manager) uses a config file
268
+ // Check if PCManFM config exists and provide instructions
269
+ console.log('To hide hidden files in PCManFM (LXDE file manager):');
270
+ console.log('');
271
+ console.log(' 1. Open PCManFM');
272
+ console.log(' 2. Go to View menu');
273
+ console.log(' 3. Uncheck "Show Hidden Files"');
274
+ console.log(' 4. Or press Ctrl+H to toggle');
275
+ }
276
+
277
+ /**
278
+ * Hide hidden files on Amazon Linux.
279
+ *
280
+ * Amazon Linux is typically used in server environments without a graphical desktop.
281
+ * If a desktop is present, attempts to configure available file managers.
282
+ *
283
+ * @param {string[]} args - Command line arguments (unused)
284
+ * @returns {Promise<void>}
285
+ */
286
+ async function do_hide_hidden_files_amazon_linux(args) {
287
+ const hasDesktop = os.isDesktopAvailable();
288
+
289
+ if (!hasDesktop) {
290
+ console.log('No desktop environment detected.');
291
+ console.log('Amazon Linux is typically used in server environments.');
292
+ console.log('');
293
+ console.log('On a headless server, hidden files (dotfiles) are not shown');
294
+ console.log('by default when using `ls`. Use `ls -a` to see them.');
295
+ return;
296
+ }
297
+
298
+ // Try gsettings if a desktop is available
299
+ if (isCommandAvailable('gsettings')) {
300
+ try {
301
+ execSync('gsettings set org.gtk.Settings.FileChooser show-hidden false', {
302
+ stdio: 'inherit'
303
+ });
304
+ console.log('Hidden files are now hidden in file manager.');
305
+ return;
306
+ } catch {
307
+ // Continue to manual instructions
308
+ }
309
+ }
310
+
311
+ console.log('Could not automatically configure your file manager.');
312
+ console.log('');
313
+ console.log('To hide hidden files, use Ctrl+H in most file managers.');
314
+ }
315
+
8
316
  /**
9
- * Configures Finder to hide hidden files (dotfiles) and restarts Finder
10
- * to apply the change.
317
+ * Hide hidden files on Windows using Command Prompt.
318
+ *
319
+ * On Windows, files with the "hidden" attribute are hidden by default.
320
+ * This function ensures that File Explorer is configured to not show hidden files
321
+ * by modifying the registry.
322
+ *
323
+ * The relevant registry key is:
324
+ * HKCU\Software\Microsoft\Windows\CurrentVersion\Explorer\Advanced\Hidden
325
+ * - Value 1: Show hidden files
326
+ * - Value 2: Do not show hidden files
11
327
  *
12
328
  * @param {string[]} args - Command line arguments (unused)
13
329
  * @returns {Promise<void>}
14
330
  */
15
- async function main(args) {
16
- // TODO: Implement hidden file hiding
331
+ async function do_hide_hidden_files_cmd(args) {
332
+ try {
333
+ // Check current value first for idempotency
334
+ let currentValue = '2';
335
+ try {
336
+ const result = execSync(
337
+ 'reg query "HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" /v Hidden',
338
+ { encoding: 'utf8', stdio: ['pipe', 'pipe', 'ignore'] }
339
+ );
340
+ // Parse the REG_DWORD value from output
341
+ const match = result.match(/Hidden\s+REG_DWORD\s+0x(\d+)/);
342
+ if (match) {
343
+ currentValue = parseInt(match[1], 16).toString();
344
+ }
345
+ } catch {
346
+ // If we can't read the value, assume we need to set it
347
+ }
348
+
349
+ if (currentValue === '2') {
350
+ console.log('Hidden files are already hidden in File Explorer.');
351
+ console.log('No changes needed.');
352
+ return;
353
+ }
354
+
355
+ // Set the registry value to hide hidden files (2 = don't show)
356
+ execSync(
357
+ 'reg add "HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" /v Hidden /t REG_DWORD /d 2 /f',
358
+ { stdio: 'inherit' }
359
+ );
360
+
361
+ console.log('Hidden files are now hidden in File Explorer.');
362
+ console.log('');
363
+ console.log('You may need to refresh or restart File Explorer to see the change.');
364
+ console.log('');
365
+ console.log('Note: Windows hidden files have the "hidden" attribute set.');
366
+ console.log('Unix-style dotfiles (like .gitignore) are NOT automatically hidden');
367
+ console.log('on Windows unless you set the hidden attribute manually.');
368
+ } catch (error) {
369
+ console.error('Error: Could not configure File Explorer settings.');
370
+ console.error(`Details: ${error.message}`);
371
+ process.exit(1);
372
+ }
373
+ }
374
+
375
+ /**
376
+ * Hide hidden files on Windows using PowerShell.
377
+ *
378
+ * Uses the same registry modification as CMD, but can also use PowerShell cmdlets
379
+ * for a more native approach.
380
+ *
381
+ * @param {string[]} args - Command line arguments (unused)
382
+ * @returns {Promise<void>}
383
+ */
384
+ async function do_hide_hidden_files_powershell(args) {
385
+ try {
386
+ // Use PowerShell to check and set the registry value
387
+ const checkScript = `
388
+ $path = 'HKCU:\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced'
389
+ $value = Get-ItemPropertyValue -Path $path -Name 'Hidden' -ErrorAction SilentlyContinue
390
+ if ($value -eq $null) { $value = 2 }
391
+ Write-Output $value
392
+ `.replace(/\n\s*/g, ' ').trim();
393
+
394
+ let currentValue = '2';
395
+ try {
396
+ currentValue = execSync(`powershell -Command "${checkScript}"`, {
397
+ encoding: 'utf8',
398
+ stdio: ['pipe', 'pipe', 'ignore']
399
+ }).trim();
400
+ } catch {
401
+ // Assume we need to set it
402
+ }
403
+
404
+ if (currentValue === '2') {
405
+ console.log('Hidden files are already hidden in File Explorer.');
406
+ console.log('No changes needed.');
407
+ return;
408
+ }
409
+
410
+ // Set the registry value using PowerShell
411
+ const setScript = `
412
+ $path = 'HKCU:\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced'
413
+ Set-ItemProperty -Path $path -Name 'Hidden' -Value 2
414
+ `.replace(/\n\s*/g, ' ').trim();
415
+
416
+ execSync(`powershell -Command "${setScript}"`, { stdio: 'inherit' });
417
+
418
+ console.log('Hidden files are now hidden in File Explorer.');
419
+ console.log('');
420
+ console.log('You may need to refresh or restart File Explorer to see the change.');
421
+ } catch (error) {
422
+ console.error('Error: Could not configure File Explorer settings.');
423
+ console.error(`Details: ${error.message}`);
424
+ process.exit(1);
425
+ }
426
+ }
427
+
428
+ /**
429
+ * Hide hidden files from Git Bash on Windows.
430
+ *
431
+ * Git Bash runs on Windows, so this uses the Windows registry approach
432
+ * to configure File Explorer settings.
433
+ *
434
+ * @param {string[]} args - Command line arguments (unused)
435
+ * @returns {Promise<void>}
436
+ */
437
+ async function do_hide_hidden_files_gitbash(args) {
438
+ try {
439
+ // From Git Bash, we can use reg.exe to modify the registry
440
+ let currentValue = '2';
441
+ try {
442
+ const result = execSync(
443
+ 'reg query "HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" /v Hidden',
444
+ { encoding: 'utf8', stdio: ['pipe', 'pipe', 'ignore'] }
445
+ );
446
+ const match = result.match(/Hidden\s+REG_DWORD\s+0x(\d+)/);
447
+ if (match) {
448
+ currentValue = parseInt(match[1], 16).toString();
449
+ }
450
+ } catch {
451
+ // If we can't read, assume we need to set
452
+ }
453
+
454
+ if (currentValue === '2') {
455
+ console.log('Hidden files are already hidden in File Explorer.');
456
+ console.log('No changes needed.');
457
+ return;
458
+ }
459
+
460
+ execSync(
461
+ 'reg add "HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" /v Hidden /t REG_DWORD /d 2 /f',
462
+ { stdio: 'inherit' }
463
+ );
464
+
465
+ console.log('Hidden files are now hidden in File Explorer.');
466
+ console.log('');
467
+ console.log('You may need to refresh or restart File Explorer to see the change.');
468
+ } catch (error) {
469
+ console.error('Error: Could not configure File Explorer settings.');
470
+ console.error(`Details: ${error.message}`);
471
+ process.exit(1);
472
+ }
473
+ }
474
+
475
+ /**
476
+ * Main entry point - detects environment and executes appropriate implementation.
477
+ *
478
+ * Configures the system's file manager to hide hidden files (dotfiles).
479
+ * This is useful for keeping your file browser clean and focused on
480
+ * non-configuration files.
481
+ *
482
+ * Hidden files are:
483
+ * - Unix/macOS: Files starting with a dot (e.g., .gitignore, .bashrc)
484
+ * - Windows: Files with the "hidden" attribute set
485
+ *
486
+ * @param {string[]} args - Command line arguments (unused)
487
+ * @returns {Promise<void>}
488
+ */
489
+ async function do_hide_hidden_files(args) {
490
+ const platform = os.detect();
491
+
492
+ const handlers = {
493
+ 'macos': do_hide_hidden_files_macos,
494
+ 'ubuntu': do_hide_hidden_files_ubuntu,
495
+ 'debian': do_hide_hidden_files_ubuntu,
496
+ 'raspbian': do_hide_hidden_files_raspbian,
497
+ 'amazon_linux': do_hide_hidden_files_amazon_linux,
498
+ 'rhel': do_hide_hidden_files_amazon_linux,
499
+ 'fedora': do_hide_hidden_files_ubuntu,
500
+ 'linux': do_hide_hidden_files_ubuntu,
501
+ 'wsl': do_hide_hidden_files_ubuntu,
502
+ 'cmd': do_hide_hidden_files_cmd,
503
+ 'windows': do_hide_hidden_files_cmd,
504
+ 'powershell': do_hide_hidden_files_powershell,
505
+ 'gitbash': do_hide_hidden_files_gitbash
506
+ };
507
+
508
+ const handler = handlers[platform.type];
509
+ if (!handler) {
510
+ console.error(`Platform '${platform.type}' is not supported for this command.`);
511
+ console.error('');
512
+ console.error('Supported platforms:');
513
+ console.error(' - macOS (Finder)');
514
+ console.error(' - Ubuntu, Debian, and other Linux distributions');
515
+ console.error(' - Raspberry Pi OS');
516
+ console.error(' - Windows (File Explorer)');
517
+ process.exit(1);
518
+ }
519
+
520
+ await handler(args);
17
521
  }
18
522
 
19
- module.exports = { main };
523
+ module.exports = {
524
+ main: do_hide_hidden_files,
525
+ do_hide_hidden_files,
526
+ do_hide_hidden_files_nodejs,
527
+ do_hide_hidden_files_macos,
528
+ do_hide_hidden_files_ubuntu,
529
+ do_hide_hidden_files_raspbian,
530
+ do_hide_hidden_files_amazon_linux,
531
+ do_hide_hidden_files_cmd,
532
+ do_hide_hidden_files_powershell,
533
+ do_hide_hidden_files_gitbash
534
+ };
20
535
 
21
536
  if (require.main === module) {
22
- main(process.argv.slice(2));
537
+ do_hide_hidden_files(process.argv.slice(2));
23
538
  }