@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,44 +1,821 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Install VLC.
4
+ * @fileoverview Install VLC Media Player.
5
5
  * @module installs/vlc
6
+ *
7
+ * VLC is a free and open-source cross-platform multimedia player and framework
8
+ * developed by the VideoLAN project. It plays most multimedia files, DVDs,
9
+ * Audio CDs, VCDs, and various streaming protocols without requiring additional
10
+ * codec packs.
11
+ *
12
+ * This installer provides:
13
+ * - VLC via Homebrew cask for macOS
14
+ * - VLC via APT for Ubuntu/Debian and Raspberry Pi OS
15
+ * - VLC via DNF/YUM with RPM Fusion for Amazon Linux/RHEL
16
+ * - VLC via Chocolatey for Windows
17
+ * - VLC via APT for WSL (Ubuntu)
18
+ * - VLC via Windows installation (Chocolatey) for Git Bash
19
+ *
20
+ * IMPORTANT PLATFORM NOTES:
21
+ * - macOS: Installs VLC.app via Homebrew cask to /Applications
22
+ * - Ubuntu/Debian: Installs from official APT repositories
23
+ * - Raspberry Pi OS: Installs from official APT repositories (ARM compatible)
24
+ * - Amazon Linux/RHEL: Requires EPEL and RPM Fusion repositories
25
+ * - Windows: Installs via Chocolatey package manager
26
+ * - WSL: Installs via APT within WSL environment (requires WSLg for GUI)
27
+ * - Git Bash: Installs on Windows host via Chocolatey through PowerShell
6
28
  */
7
29
 
8
30
  const os = require('../utils/common/os');
31
+ const shell = require('../utils/common/shell');
32
+ const brew = require('../utils/macos/brew');
33
+ const macosApps = require('../utils/macos/apps');
34
+ const apt = require('../utils/ubuntu/apt');
35
+ const choco = require('../utils/windows/choco');
36
+
37
+ /**
38
+ * Indicates whether this installer requires a desktop environment.
39
+ * VLC is a GUI media player and requires a display.
40
+ * @type {boolean}
41
+ */
42
+ const REQUIRES_DESKTOP = true;
43
+
44
+ /**
45
+ * The Homebrew cask name for VLC on macOS.
46
+ * This installs the full VLC.app to /Applications.
47
+ */
48
+ const HOMEBREW_CASK_NAME = 'vlc';
49
+
50
+ /**
51
+ * The APT package name for VLC on Debian-based systems.
52
+ */
53
+ const APT_PACKAGE_NAME = 'vlc';
54
+
55
+ /**
56
+ * The Chocolatey package name for VLC on Windows.
57
+ */
58
+ const CHOCO_PACKAGE_NAME = 'vlc';
59
+
60
+ /**
61
+ * The macOS application name for VLC.
62
+ * Used to check if VLC is already installed in /Applications.
63
+ */
64
+ const MACOS_APP_NAME = 'VLC';
65
+
66
+ /**
67
+ * Check if VLC is installed by verifying the 'vlc' command exists.
68
+ *
69
+ * This check works on Linux and Windows where VLC adds itself to PATH.
70
+ * For macOS, use the macosApps utility to check for VLC.app instead.
71
+ *
72
+ * @returns {boolean} True if the vlc command is available, false otherwise
73
+ */
74
+ function isVLCCommandAvailable() {
75
+ return shell.commandExists('vlc');
76
+ }
77
+
78
+ /**
79
+ * Check if VLC is installed and get the version.
80
+ *
81
+ * Executes 'vlc --version' to verify VLC is properly installed
82
+ * and operational. Returns the version string if successful.
83
+ *
84
+ * @returns {Promise<string|null>} VLC version string, or null if not installed
85
+ */
86
+ async function getVLCVersion() {
87
+ // First check if the command exists to avoid unnecessary process spawning
88
+ if (!isVLCCommandAvailable()) {
89
+ return null;
90
+ }
91
+
92
+ // Execute vlc --version to get version information
93
+ // The output format is typically: "VLC media player X.Y.Z Vetinari..."
94
+ const result = await shell.exec('vlc --version');
95
+ if (result.code === 0 && result.stdout) {
96
+ // Parse version from output like: "VLC media player 3.0.21 Vetinari..."
97
+ const match = result.stdout.match(/VLC media player\s+([^\s]+)/);
98
+ return match ? match[1] : result.stdout.split('\n')[0].trim();
99
+ }
100
+ return null;
101
+ }
102
+
103
+ /**
104
+ * Install VLC on macOS using Homebrew cask.
105
+ *
106
+ * Prerequisites:
107
+ * - macOS 10.15 (Catalina) or later
108
+ * - Homebrew package manager installed
109
+ * - At least 200 MB free disk space
110
+ *
111
+ * Homebrew installs VLC.app to /Applications. On first launch, macOS may
112
+ * display a Gatekeeper warning that requires right-clicking the app and
113
+ * selecting "Open" to bypass.
114
+ *
115
+ * @returns {Promise<void>}
116
+ * @throws {Error} If Homebrew is not installed or installation fails
117
+ */
118
+ async function install_macos() {
119
+ console.log('Checking if VLC is already installed...');
120
+
121
+ // Check if VLC.app exists in /Applications
122
+ const isAppInstalled = macosApps.isAppInstalled(MACOS_APP_NAME);
123
+ if (isAppInstalled) {
124
+ const version = macosApps.getAppVersion(MACOS_APP_NAME);
125
+ if (version) {
126
+ console.log(`VLC ${version} is already installed, skipping installation.`);
127
+ } else {
128
+ console.log('VLC is already installed, skipping installation.');
129
+ }
130
+ return;
131
+ }
132
+
133
+ // Also check if the cask is installed via Homebrew
134
+ // (VLC may be installed but not detected in Applications for some reason)
135
+ const caskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
136
+ if (caskInstalled) {
137
+ console.log('VLC is already installed via Homebrew, skipping installation.');
138
+ console.log('');
139
+ console.log('NOTE: If VLC is not appearing in Applications, try:');
140
+ console.log(' brew reinstall --cask vlc');
141
+ return;
142
+ }
143
+
144
+ // Verify Homebrew is available
145
+ if (!brew.isInstalled()) {
146
+ throw new Error(
147
+ 'Homebrew is not installed. Please install Homebrew first using:\n' +
148
+ ' dev install homebrew\n' +
149
+ 'Then retry installing VLC.'
150
+ );
151
+ }
152
+
153
+ console.log('Installing VLC via Homebrew...');
154
+
155
+ // Install VLC cask with --quiet flag for cleaner output
156
+ const result = await shell.exec('brew install --quiet --cask vlc');
157
+
158
+ if (result.code !== 0) {
159
+ throw new Error(
160
+ `Failed to install VLC via Homebrew.\n` +
161
+ `Output: ${result.stderr || result.stdout}\n\n` +
162
+ `Troubleshooting:\n` +
163
+ ` 1. Run 'brew update && brew cleanup' and retry\n` +
164
+ ` 2. Check for Homebrew issues: brew doctor\n` +
165
+ ` 3. Try manual installation: brew install --cask vlc`
166
+ );
167
+ }
168
+
169
+ // Verify installation succeeded by checking for VLC.app
170
+ const verified = macosApps.isAppInstalled(MACOS_APP_NAME);
171
+ if (!verified) {
172
+ throw new Error(
173
+ 'Installation appeared to complete but VLC.app was not found.\n\n' +
174
+ 'Please try:\n' +
175
+ ' 1. Check /Applications/VLC.app exists\n' +
176
+ ' 2. Run: brew reinstall --cask vlc'
177
+ );
178
+ }
179
+
180
+ const installedVersion = macosApps.getAppVersion(MACOS_APP_NAME);
181
+ console.log(`VLC ${installedVersion || ''} installed successfully.`);
182
+ console.log('');
183
+ console.log('You can launch VLC from:');
184
+ console.log(' - Applications folder');
185
+ console.log(' - Spotlight (Cmd+Space, type "VLC")');
186
+ console.log(' - Terminal: open -a VLC');
187
+ console.log('');
188
+ console.log('NOTE: On first launch, you may see a Gatekeeper warning.');
189
+ console.log('Right-click VLC in Applications and select "Open" to bypass.');
190
+ }
191
+
192
+ /**
193
+ * Install VLC on Ubuntu/Debian using APT.
194
+ *
195
+ * Prerequisites:
196
+ * - Ubuntu 20.04 LTS or later, or Debian 11 (Bullseye) or later
197
+ * - sudo privileges
198
+ * - At least 500 MB free disk space (including dependencies)
199
+ *
200
+ * The version available in Ubuntu/Debian repositories may not be the absolute
201
+ * latest. For most use cases, the repository version is sufficient and receives
202
+ * security updates.
203
+ *
204
+ * @returns {Promise<void>}
205
+ * @throws {Error} If installation fails
206
+ */
207
+ async function install_ubuntu() {
208
+ console.log('Checking if VLC is already installed...');
209
+
210
+ // Check if VLC is already installed via dpkg
211
+ const isInstalled = await apt.isPackageInstalled(APT_PACKAGE_NAME);
212
+ if (isInstalled) {
213
+ const version = await apt.getPackageVersion(APT_PACKAGE_NAME);
214
+ if (version) {
215
+ console.log(`VLC ${version} is already installed, skipping installation.`);
216
+ } else {
217
+ console.log('VLC is already installed, skipping installation.');
218
+ }
219
+ return;
220
+ }
221
+
222
+ // Update package index before installing
223
+ console.log('Updating package index...');
224
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
225
+ if (updateResult.code !== 0) {
226
+ console.log('Warning: Could not update package index, continuing anyway...');
227
+ }
228
+
229
+ // Install VLC via APT
230
+ console.log('Installing VLC via APT...');
231
+ const installResult = await shell.exec(
232
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y vlc'
233
+ );
234
+
235
+ if (installResult.code !== 0) {
236
+ throw new Error(
237
+ `Failed to install VLC via APT.\n` +
238
+ `Output: ${installResult.stderr}\n\n` +
239
+ `Troubleshooting:\n` +
240
+ ` 1. Run 'sudo apt-get update' and retry\n` +
241
+ ` 2. Check available packages: apt-cache search vlc\n` +
242
+ ` 3. Try manual installation: sudo apt-get install vlc`
243
+ );
244
+ }
245
+
246
+ // Verify installation succeeded
247
+ const version = await getVLCVersion();
248
+ if (!version) {
249
+ throw new Error(
250
+ 'Installation appeared to complete but VLC was not found.\n\n' +
251
+ 'Please try:\n' +
252
+ ' 1. Restart your terminal session\n' +
253
+ ' 2. Run: vlc --version'
254
+ );
255
+ }
256
+
257
+ console.log(`VLC ${version} installed successfully.`);
258
+ console.log('');
259
+ console.log('You can launch VLC from:');
260
+ console.log(' - Applications menu');
261
+ console.log(' - Terminal: vlc');
262
+ console.log(' - Headless/CLI mode: cvlc');
263
+ console.log('');
264
+ console.log('NOTE: The repository version may not be the latest.');
265
+ console.log('For newer versions, consider the VideoLAN PPA.');
266
+ }
267
+
268
+ /**
269
+ * Install VLC on Raspberry Pi OS using APT.
270
+ *
271
+ * Prerequisites:
272
+ * - Raspberry Pi OS (Bookworm or Bullseye), 32-bit or 64-bit
273
+ * - Raspberry Pi 3 or later recommended (earlier models have limited performance)
274
+ * - sudo privileges
275
+ * - At least 500 MB free disk space
276
+ *
277
+ * NOTE: Raspberry Pi OS (full desktop version) typically comes with VLC
278
+ * pre-installed. This installer handles cases where VLC was removed or
279
+ * on Raspberry Pi OS Lite.
280
+ *
281
+ * The Raspberry Pi OS repositories contain VLC builds optimized for ARM
282
+ * processors with hardware acceleration patches for the Raspberry Pi's GPU.
283
+ *
284
+ * @returns {Promise<void>}
285
+ * @throws {Error} If installation fails
286
+ */
287
+ async function install_raspbian() {
288
+ console.log('Checking if VLC is already installed...');
289
+
290
+ // Check if VLC is already installed via dpkg
291
+ const isInstalled = await apt.isPackageInstalled(APT_PACKAGE_NAME);
292
+ if (isInstalled) {
293
+ const version = await apt.getPackageVersion(APT_PACKAGE_NAME);
294
+ if (version) {
295
+ console.log(`VLC ${version} is already installed, skipping installation.`);
296
+ } else {
297
+ console.log('VLC is already installed, skipping installation.');
298
+ }
299
+ return;
300
+ }
301
+
302
+ // Update package index before installing
303
+ console.log('Updating package index...');
304
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
305
+ if (updateResult.code !== 0) {
306
+ console.log('Warning: Could not update package index, continuing anyway...');
307
+ }
308
+
309
+ // Install VLC via APT
310
+ console.log('Installing VLC via APT...');
311
+ const installResult = await shell.exec(
312
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y vlc'
313
+ );
314
+
315
+ if (installResult.code !== 0) {
316
+ throw new Error(
317
+ `Failed to install VLC via APT.\n` +
318
+ `Output: ${installResult.stderr}\n\n` +
319
+ `Troubleshooting:\n` +
320
+ ` 1. Run 'sudo apt-get update' and retry\n` +
321
+ ` 2. Check available packages: apt-cache search vlc\n` +
322
+ ` 3. Try manual installation: sudo apt-get install vlc`
323
+ );
324
+ }
325
+
326
+ // Verify installation succeeded
327
+ const version = await getVLCVersion();
328
+ if (!version) {
329
+ throw new Error(
330
+ 'Installation appeared to complete but VLC was not found.\n\n' +
331
+ 'Please try:\n' +
332
+ ' 1. Restart your terminal session\n' +
333
+ ' 2. Run: vlc --version'
334
+ );
335
+ }
336
+
337
+ console.log(`VLC ${version} installed successfully.`);
338
+ console.log('');
339
+ console.log('You can launch VLC from:');
340
+ console.log(' - Desktop menu (under Sound & Video)');
341
+ console.log(' - Terminal: vlc');
342
+ console.log(' - Headless/CLI mode: cvlc');
343
+ console.log('');
344
+ console.log('RASPBERRY PI NOTES:');
345
+ console.log(' - Hardware acceleration is available for better performance');
346
+ console.log(' - Use MMAL codec for H.264: cvlc --codec=mmal_codec video.mp4');
347
+ console.log(' - For headless streaming, install vlc-nox: sudo apt install vlc-nox');
348
+ }
9
349
 
10
350
  /**
11
- * Install VLC across supported platforms.
351
+ * Install VLC on Amazon Linux/RHEL using DNF/YUM with RPM Fusion.
352
+ *
353
+ * Prerequisites:
354
+ * - Amazon Linux 2023 (AL2023), Amazon Linux 2 (AL2), or RHEL 8/9
355
+ * - sudo privileges
356
+ * - At least 500 MB free disk space
357
+ *
358
+ * IMPORTANT: VLC is not available in the standard Amazon Linux or RHEL
359
+ * repositories. This function enables the EPEL (Extra Packages for Enterprise
360
+ * Linux) and RPM Fusion repositories to install VLC.
361
+ *
362
+ * @returns {Promise<void>}
363
+ * @throws {Error} If installation fails
364
+ */
365
+ async function install_amazon_linux() {
366
+ console.log('Checking if VLC is already installed...');
367
+
368
+ // Check if VLC is already installed
369
+ const existingVersion = await getVLCVersion();
370
+ if (existingVersion) {
371
+ console.log(`VLC ${existingVersion} is already installed, skipping installation.`);
372
+ return;
373
+ }
374
+
375
+ // Detect package manager (dnf for AL2023/RHEL9, yum for AL2/RHEL8)
376
+ const hasDnf = shell.commandExists('dnf');
377
+ const hasYum = shell.commandExists('yum');
378
+ const packageManager = hasDnf ? 'dnf' : (hasYum ? 'yum' : null);
379
+
380
+ if (!packageManager) {
381
+ throw new Error(
382
+ 'Neither dnf nor yum package manager found.\n' +
383
+ 'This installer supports Amazon Linux 2023 (dnf), Amazon Linux 2 (yum), and RHEL 8/9.'
384
+ );
385
+ }
386
+
387
+ console.log(`Detected package manager: ${packageManager}`);
388
+
389
+ // Determine the RHEL version for repository URLs
390
+ // AL2023 is based on Fedora and compatible with RHEL 9 repos
391
+ // AL2 and RHEL 8 use version 8 repos
392
+ console.log('Detecting system version...');
393
+ const versionResult = await shell.exec('rpm -E %rhel');
394
+ let rhelVersion = versionResult.stdout.trim();
395
+
396
+ // If rpm -E %rhel returns empty or just "%rhel", try to detect from os-release
397
+ if (!rhelVersion || rhelVersion === '%rhel') {
398
+ if (hasDnf) {
399
+ // Amazon Linux 2023 is compatible with RHEL 9
400
+ rhelVersion = '9';
401
+ } else {
402
+ // Amazon Linux 2 is compatible with RHEL 8
403
+ rhelVersion = '8';
404
+ }
405
+ }
406
+
407
+ console.log(`Using RHEL ${rhelVersion} compatible repositories...`);
408
+
409
+ // Install EPEL repository (required dependency for RPM Fusion)
410
+ console.log('Installing EPEL repository...');
411
+ const epelUrl = `https://dl.fedoraproject.org/pub/epel/epel-release-latest-${rhelVersion}.noarch.rpm`;
412
+ const epelResult = await shell.exec(`sudo ${packageManager} install -y ${epelUrl}`);
413
+ if (epelResult.code !== 0) {
414
+ // EPEL might already be installed, continue anyway
415
+ console.log('Note: EPEL may already be installed, continuing...');
416
+ }
417
+
418
+ // Install RPM Fusion Free repository (contains VLC)
419
+ console.log('Installing RPM Fusion Free repository...');
420
+ const rpmfusionUrl = `https://download1.rpmfusion.org/free/el/rpmfusion-free-release-${rhelVersion}.noarch.rpm`;
421
+ const rpmfusionResult = await shell.exec(`sudo ${packageManager} install -y ${rpmfusionUrl}`);
422
+ if (rpmfusionResult.code !== 0) {
423
+ throw new Error(
424
+ `Failed to install RPM Fusion repository.\n` +
425
+ `Output: ${rpmfusionResult.stderr}\n\n` +
426
+ `Troubleshooting:\n` +
427
+ ` 1. Check your internet connection\n` +
428
+ ` 2. Verify the repository URL is accessible\n` +
429
+ ` 3. Try manually: sudo ${packageManager} install -y ${rpmfusionUrl}`
430
+ );
431
+ }
432
+
433
+ // Install VLC
434
+ console.log('Installing VLC...');
435
+ const installResult = await shell.exec(`sudo ${packageManager} install -y vlc`);
436
+
437
+ if (installResult.code !== 0) {
438
+ throw new Error(
439
+ `Failed to install VLC.\n` +
440
+ `Output: ${installResult.stderr}\n\n` +
441
+ `Troubleshooting:\n` +
442
+ ` 1. Verify RPM Fusion is enabled: ${packageManager} repolist\n` +
443
+ ` 2. Clean package cache: sudo ${packageManager} clean all\n` +
444
+ ` 3. Try manual installation: sudo ${packageManager} install vlc`
445
+ );
446
+ }
447
+
448
+ // Verify installation succeeded
449
+ const version = await getVLCVersion();
450
+ if (!version) {
451
+ throw new Error(
452
+ 'Installation appeared to complete but VLC was not found.\n\n' +
453
+ 'Please try:\n' +
454
+ ' 1. Restart your terminal session\n' +
455
+ ' 2. Run: vlc --version'
456
+ );
457
+ }
458
+
459
+ console.log(`VLC ${version} installed successfully.`);
460
+ console.log('');
461
+ console.log('You can launch VLC from:');
462
+ console.log(' - Terminal: vlc');
463
+ console.log(' - Headless/CLI mode: cvlc');
464
+ console.log('');
465
+ console.log('NOTE: VLC was installed from RPM Fusion repository.');
466
+ console.log('For headless server use (streaming/transcoding): cvlc --no-video');
467
+ }
468
+
469
+ /**
470
+ * Install VLC on Windows using Chocolatey.
471
+ *
472
+ * Prerequisites:
473
+ * - Windows 10 or later (32-bit or 64-bit), or Windows 11
474
+ * - Administrator PowerShell or Command Prompt
475
+ * - Chocolatey package manager installed
476
+ * - At least 200 MB free disk space
477
+ *
478
+ * Chocolatey downloads VLC from the official VideoLAN servers and handles
479
+ * the installation silently. VLC will be added to the system PATH.
480
+ *
481
+ * @returns {Promise<void>}
482
+ * @throws {Error} If Chocolatey is not installed or installation fails
483
+ */
484
+ async function install_windows() {
485
+ console.log('Checking if VLC is already installed...');
486
+
487
+ // Check if VLC is already installed
488
+ const existingVersion = await getVLCVersion();
489
+ if (existingVersion) {
490
+ console.log(`VLC ${existingVersion} is already installed, skipping installation.`);
491
+ return;
492
+ }
493
+
494
+ // Check if VLC package is installed via Chocolatey
495
+ const packageInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
496
+ if (packageInstalled) {
497
+ console.log('VLC is already installed via Chocolatey, skipping installation.');
498
+ console.log('');
499
+ console.log('NOTE: If VLC commands are not working, open a new terminal window');
500
+ console.log('to refresh your PATH, or run: refreshenv');
501
+ return;
502
+ }
503
+
504
+ // Verify Chocolatey is available
505
+ if (!choco.isInstalled()) {
506
+ throw new Error(
507
+ 'Chocolatey is not installed. Please install Chocolatey first:\n\n' +
508
+ 'Run the following in an Administrator PowerShell:\n' +
509
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
510
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
511
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
512
+ 'Then retry installing VLC.'
513
+ );
514
+ }
515
+
516
+ console.log('Installing VLC via Chocolatey...');
517
+ console.log('This may take a few minutes...');
518
+
519
+ // Install VLC using Chocolatey
520
+ const result = await choco.install(CHOCO_PACKAGE_NAME);
521
+
522
+ if (!result.success) {
523
+ throw new Error(
524
+ `Failed to install VLC via Chocolatey.\n` +
525
+ `Output: ${result.output}\n\n` +
526
+ `Troubleshooting:\n` +
527
+ ` 1. Ensure you are running as Administrator\n` +
528
+ ` 2. Try manual installation: choco install vlc -y\n` +
529
+ ` 3. Check Chocolatey logs for details`
530
+ );
531
+ }
532
+
533
+ console.log('VLC installed successfully.');
534
+ console.log('');
535
+ console.log('IMPORTANT: Open a new terminal window to refresh your PATH.');
536
+ console.log('Alternatively, run: refreshenv');
537
+ console.log('');
538
+ console.log('You can launch VLC from:');
539
+ console.log(' - Start Menu');
540
+ console.log(' - Command line: vlc');
541
+ console.log(' - File path: "C:\\Program Files\\VideoLAN\\VLC\\vlc.exe"');
542
+ console.log('');
543
+ console.log('Verify installation with: vlc --version');
544
+ }
545
+
546
+ /**
547
+ * Install VLC on Ubuntu running in WSL (Windows Subsystem for Linux).
548
+ *
549
+ * Prerequisites:
550
+ * - Windows 10 Build 19044 or higher, or Windows 11
551
+ * - WSL 2 enabled with Ubuntu distribution installed
552
+ * - WSLg enabled for GUI application support (Windows 11 or Windows 10 with updates)
553
+ * - sudo privileges within WSL
554
+ *
555
+ * IMPORTANT: VLC is a graphical application. Running VLC in WSL requires
556
+ * GUI support through WSLg (Windows Subsystem for Linux GUI). Windows 11
557
+ * includes WSLg by default. For headless operation, use cvlc or vlc-nox.
558
+ *
559
+ * @returns {Promise<void>}
560
+ * @throws {Error} If installation fails
561
+ */
562
+ async function install_ubuntu_wsl() {
563
+ console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
564
+ console.log('');
565
+ console.log('Installing VLC within WSL environment...');
566
+ console.log('');
567
+
568
+ // Check if VLC is already installed
569
+ const isInstalled = await apt.isPackageInstalled(APT_PACKAGE_NAME);
570
+ if (isInstalled) {
571
+ const version = await apt.getPackageVersion(APT_PACKAGE_NAME);
572
+ if (version) {
573
+ console.log(`VLC ${version} is already installed, skipping installation.`);
574
+ } else {
575
+ console.log('VLC is already installed, skipping installation.');
576
+ }
577
+ return;
578
+ }
579
+
580
+ // Update package index before installing
581
+ console.log('Updating package index...');
582
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
583
+ if (updateResult.code !== 0) {
584
+ console.log('Warning: Could not update package index, continuing anyway...');
585
+ }
586
+
587
+ // Install VLC via APT
588
+ console.log('Installing VLC via APT...');
589
+ const installResult = await shell.exec(
590
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y vlc'
591
+ );
592
+
593
+ if (installResult.code !== 0) {
594
+ throw new Error(
595
+ `Failed to install VLC via APT.\n` +
596
+ `Output: ${installResult.stderr}\n\n` +
597
+ `Troubleshooting:\n` +
598
+ ` 1. If you see DNS errors, try:\n` +
599
+ ` echo "nameserver 8.8.8.8" | sudo tee /etc/resolv.conf\n` +
600
+ ` 2. Run 'sudo apt-get update' and retry\n` +
601
+ ` 3. Try manual installation: sudo apt-get install vlc`
602
+ );
603
+ }
604
+
605
+ // Verify installation succeeded
606
+ const version = await getVLCVersion();
607
+ if (!version) {
608
+ throw new Error(
609
+ 'Installation appeared to complete but VLC was not found.\n\n' +
610
+ 'Please try:\n' +
611
+ ' 1. Restart your WSL session\n' +
612
+ ' 2. Run: vlc --version'
613
+ );
614
+ }
615
+
616
+ console.log(`VLC ${version} installed successfully.`);
617
+ console.log('');
618
+ console.log('WSL NOTES:');
619
+ console.log('');
620
+ console.log('1. GUI support requires WSLg:');
621
+ console.log(' - Windows 11: WSLg is included by default');
622
+ console.log(' - Windows 10: Requires specific builds and updates');
623
+ console.log(' - Test with: vlc &');
624
+ console.log('');
625
+ console.log('2. If you see "cannot open display" errors:');
626
+ console.log(' - Restart WSL: wsl --shutdown (from PowerShell)');
627
+ console.log(' - Then reopen your WSL terminal');
628
+ console.log('');
629
+ console.log('3. For headless operation (streaming/transcoding):');
630
+ console.log(' - Use cvlc: cvlc --no-video /path/to/media.mp4');
631
+ console.log('');
632
+ console.log('4. To access Windows files:');
633
+ console.log(' - cvlc /mnt/c/Users/YourName/Videos/movie.mp4');
634
+ }
635
+
636
+ /**
637
+ * Install VLC from Git Bash on Windows.
638
+ *
639
+ * Git Bash runs in a MinGW environment on Windows. This function installs
640
+ * VLC on the Windows host using Chocolatey via PowerShell interop.
641
+ * Once installed, VLC will be accessible from Git Bash through the Windows PATH.
642
+ *
643
+ * Prerequisites:
644
+ * - Windows 10 or later (64-bit)
645
+ * - Git Bash installed (comes with Git for Windows)
646
+ * - Chocolatey package manager installed on Windows
647
+ * - Administrator privileges
648
+ *
649
+ * @returns {Promise<void>}
650
+ * @throws {Error} If installation fails
651
+ */
652
+ async function install_gitbash() {
653
+ console.log('Detected Git Bash on Windows.');
654
+ console.log('Installing VLC on the Windows host...');
655
+ console.log('');
656
+
657
+ // Check if VLC is already available
658
+ const existingVersion = await getVLCVersion();
659
+ if (existingVersion) {
660
+ console.log(`VLC ${existingVersion} is already installed, skipping installation.`);
661
+ return;
662
+ }
663
+
664
+ // Check if VLC executable exists in common Windows location
665
+ const vlcExistsResult = await shell.exec('ls "/c/Program Files/VideoLAN/VLC/vlc.exe" 2>/dev/null');
666
+ if (vlcExistsResult.code === 0) {
667
+ console.log('VLC is already installed on Windows, skipping installation.');
668
+ console.log('');
669
+ console.log('If VLC is not in your PATH, add it with:');
670
+ console.log(' echo \'export PATH="$PATH:/c/Program Files/VideoLAN/VLC"\' >> ~/.bashrc');
671
+ console.log(' source ~/.bashrc');
672
+ return;
673
+ }
674
+
675
+ // Install via PowerShell using Chocolatey
676
+ console.log('Installing VLC via Chocolatey...');
677
+ console.log('This may take a few minutes...');
678
+
679
+ const installResult = await shell.exec(
680
+ 'powershell.exe -NoProfile -Command "choco install vlc -y"'
681
+ );
682
+
683
+ if (installResult.code !== 0) {
684
+ throw new Error(
685
+ `Failed to install VLC.\n` +
686
+ `Output: ${installResult.stdout || installResult.stderr}\n\n` +
687
+ `Troubleshooting:\n` +
688
+ ` 1. Ensure Chocolatey is installed on Windows\n` +
689
+ ` 2. Run Git Bash as Administrator and retry\n` +
690
+ ` 3. Try installing directly from PowerShell:\n` +
691
+ ` choco install vlc -y`
692
+ );
693
+ }
694
+
695
+ console.log('VLC installed successfully.');
696
+ console.log('');
697
+ console.log('Git Bash notes:');
698
+ console.log('');
699
+ console.log('1. Restart Git Bash or run: source ~/.bashrc');
700
+ console.log('');
701
+ console.log('2. If vlc is not found, add to PATH:');
702
+ console.log(' echo \'export PATH="$PATH:/c/Program Files/VideoLAN/VLC"\' >> ~/.bashrc');
703
+ console.log(' source ~/.bashrc');
704
+ console.log('');
705
+ console.log('3. To launch VLC:');
706
+ console.log(' vlc &');
707
+ console.log(' # or with full path:');
708
+ console.log(' "/c/Program Files/VideoLAN/VLC/vlc.exe" &');
709
+ console.log('');
710
+ console.log('4. When passing file paths, use Windows-style or double slashes:');
711
+ console.log(' vlc "C:/Users/YourName/Videos/movie.mp4"');
712
+ }
713
+
714
+ /**
715
+ * Check if VLC is installed on the current system.
716
+ * @returns {Promise<boolean>} True if VLC is installed
717
+ */
718
+ async function isInstalled() {
719
+ const platform = os.detect();
720
+ if (platform.type === 'macos') {
721
+ return brew.isCaskInstalled(HOMEBREW_CASK_NAME);
722
+ }
723
+ if (platform.type === 'windows') {
724
+ return choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
725
+ }
726
+ if (['ubuntu', 'debian', 'raspbian'].includes(platform.type)) {
727
+ return apt.isPackageInstalled(APT_PACKAGE_NAME);
728
+ }
729
+ return isVLCCommandAvailable();
730
+ }
731
+
732
+ /**
733
+ * Check if this installer is supported on the current platform.
734
+ * VLC is supported on all major platforms.
735
+ * @returns {boolean} True if installation is supported on this platform
736
+ */
737
+ function isEligible() {
738
+ const platform = os.detect();
739
+
740
+ // First check if the platform is supported
741
+ const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'rhel', 'fedora', 'windows', 'gitbash'];
742
+ if (!supportedPlatforms.includes(platform.type)) {
743
+ return false;
744
+ }
745
+
746
+ // This installer requires a desktop environment
747
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
748
+ return false;
749
+ }
750
+
751
+ return true;
752
+ }
753
+
754
+ /**
755
+ * Main installation entry point.
756
+ *
757
+ * Detects the current platform and runs the appropriate installer function.
758
+ * Handles platform-specific mappings to ensure all supported platforms
759
+ * have appropriate installation logic.
760
+ *
761
+ * Supported platforms:
762
+ * - macOS: VLC via Homebrew cask
763
+ * - Ubuntu/Debian: VLC via APT
764
+ * - Raspberry Pi OS: VLC via APT
765
+ * - Amazon Linux/RHEL: VLC via DNF/YUM with RPM Fusion
766
+ * - Windows: VLC via Chocolatey
767
+ * - WSL (Ubuntu): VLC via APT within WSL
768
+ * - Git Bash: VLC on Windows host via Chocolatey
12
769
  *
13
770
  * @returns {Promise<void>}
14
771
  */
15
772
  async function install() {
16
773
  const platform = os.detect();
17
774
 
18
- switch (platform.type) {
19
- case 'macos':
20
- // TODO: Implement macOS installation
21
- break;
22
- case 'debian':
23
- // TODO: Implement Debian/Ubuntu installation
24
- break;
25
- case 'rhel':
26
- // TODO: Implement RHEL/Amazon Linux installation
27
- break;
28
- case 'windows-wsl':
29
- // TODO: Implement WSL installation
30
- break;
31
- case 'windows':
32
- // TODO: Implement Windows installation
33
- break;
34
- default:
35
- console.error(`Unsupported platform: ${platform.type}`);
36
- process.exit(1);
37
- }
38
- }
39
-
40
- module.exports = { install };
775
+ // Map platform types to their installer functions
776
+ // This mapping handles aliases (e.g., debian maps to ubuntu installer)
777
+ const installers = {
778
+ 'macos': install_macos,
779
+ 'ubuntu': install_ubuntu,
780
+ 'debian': install_ubuntu,
781
+ 'wsl': install_ubuntu_wsl,
782
+ 'raspbian': install_raspbian,
783
+ 'amazon_linux': install_amazon_linux,
784
+ 'rhel': install_amazon_linux,
785
+ 'fedora': install_amazon_linux,
786
+ 'windows': install_windows,
787
+ 'gitbash': install_gitbash
788
+ };
789
+
790
+ const installer = installers[platform.type];
791
+
792
+ if (!installer) {
793
+ console.log(`VLC is not available for ${platform.type}.`);
794
+ return;
795
+ }
796
+
797
+ await installer();
798
+ }
799
+
800
+ // Export all functions for use as a module and for testing
801
+ module.exports = {
802
+ REQUIRES_DESKTOP,
803
+ install,
804
+ isInstalled,
805
+ isEligible,
806
+ install_macos,
807
+ install_ubuntu,
808
+ install_ubuntu_wsl,
809
+ install_raspbian,
810
+ install_amazon_linux,
811
+ install_windows,
812
+ install_gitbash
813
+ };
41
814
 
815
+ // Allow direct execution: node vlc.js
42
816
  if (require.main === module) {
43
- install();
817
+ install().catch(err => {
818
+ console.error(err.message);
819
+ process.exit(1);
820
+ });
44
821
  }