@fredlackey/devutils 0.0.17 → 0.0.19

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 (331) hide show
  1. package/README.md +32 -150
  2. package/package.json +5 -82
  3. package/bin/dev.js +0 -16
  4. package/files/README.md +0 -0
  5. package/files/claude/.claude/commands/setup-context.md +0 -3
  6. package/files/monorepos/_archive/README.md +0 -36
  7. package/files/monorepos/_legacy/README.md +0 -36
  8. package/files/monorepos/ai-docs/README.md +0 -33
  9. package/files/monorepos/apps/README.md +0 -24
  10. package/files/monorepos/docs/README.md +0 -40
  11. package/files/monorepos/packages/README.md +0 -25
  12. package/files/monorepos/research/README.md +0 -29
  13. package/files/monorepos/scripts/README.md +0 -24
  14. package/src/cli.js +0 -72
  15. package/src/commands/README.md +0 -41
  16. package/src/commands/configure.js +0 -199
  17. package/src/commands/identity.js +0 -1630
  18. package/src/commands/ignore.js +0 -247
  19. package/src/commands/install.js +0 -526
  20. package/src/commands/setup.js +0 -246
  21. package/src/commands/status.js +0 -223
  22. package/src/commands/update.js +0 -142
  23. package/src/commands/version.js +0 -100
  24. package/src/completion.js +0 -284
  25. package/src/constants.js +0 -45
  26. package/src/ignore/claude-code.txt +0 -10
  27. package/src/ignore/docker.txt +0 -18
  28. package/src/ignore/linux.txt +0 -23
  29. package/src/ignore/macos.txt +0 -36
  30. package/src/ignore/node.txt +0 -55
  31. package/src/ignore/terraform.txt +0 -37
  32. package/src/ignore/vscode.txt +0 -18
  33. package/src/ignore/windows.txt +0 -35
  34. package/src/index.js +0 -0
  35. package/src/installs/README.md +0 -399
  36. package/src/installs/adobe-creative-cloud.js +0 -546
  37. package/src/installs/adobe-creative-cloud.md +0 -605
  38. package/src/installs/appcleaner.js +0 -321
  39. package/src/installs/appcleaner.md +0 -699
  40. package/src/installs/apt-transport-https.js +0 -390
  41. package/src/installs/apt-transport-https.md +0 -678
  42. package/src/installs/atomicparsley.js +0 -642
  43. package/src/installs/atomicparsley.md +0 -795
  44. package/src/installs/aws-cli.js +0 -797
  45. package/src/installs/aws-cli.md +0 -727
  46. package/src/installs/balena-etcher.js +0 -710
  47. package/src/installs/balena-etcher.md +0 -761
  48. package/src/installs/bambu-studio.js +0 -1143
  49. package/src/installs/bambu-studio.md +0 -780
  50. package/src/installs/bash-completion.js +0 -575
  51. package/src/installs/bash-completion.md +0 -833
  52. package/src/installs/bash.js +0 -417
  53. package/src/installs/bash.md +0 -993
  54. package/src/installs/beyond-compare.js +0 -603
  55. package/src/installs/beyond-compare.md +0 -813
  56. package/src/installs/brave-browser.js +0 -968
  57. package/src/installs/brave-browser.md +0 -650
  58. package/src/installs/build-essential.js +0 -529
  59. package/src/installs/build-essential.md +0 -977
  60. package/src/installs/ca-certificates.js +0 -618
  61. package/src/installs/ca-certificates.md +0 -937
  62. package/src/installs/caffeine.js +0 -508
  63. package/src/installs/caffeine.md +0 -839
  64. package/src/installs/camtasia.js +0 -596
  65. package/src/installs/camtasia.md +0 -762
  66. package/src/installs/chatgpt.js +0 -476
  67. package/src/installs/chatgpt.md +0 -814
  68. package/src/installs/chocolatey.js +0 -456
  69. package/src/installs/chocolatey.md +0 -661
  70. package/src/installs/chrome-canary.js +0 -419
  71. package/src/installs/chrome-canary.md +0 -641
  72. package/src/installs/chromium.js +0 -667
  73. package/src/installs/chromium.md +0 -838
  74. package/src/installs/claude-code.js +0 -576
  75. package/src/installs/claude-code.md +0 -1173
  76. package/src/installs/cloudflare-warp.js +0 -900
  77. package/src/installs/cloudflare-warp.md +0 -1047
  78. package/src/installs/comet-browser.js +0 -588
  79. package/src/installs/comet-browser.md +0 -731
  80. package/src/installs/curl.js +0 -379
  81. package/src/installs/curl.md +0 -714
  82. package/src/installs/cursor.js +0 -579
  83. package/src/installs/cursor.md +0 -970
  84. package/src/installs/dbeaver.js +0 -924
  85. package/src/installs/dbeaver.md +0 -939
  86. package/src/installs/dbschema.js +0 -692
  87. package/src/installs/dbschema.md +0 -925
  88. package/src/installs/dependencies.md +0 -453
  89. package/src/installs/development-tools.js +0 -600
  90. package/src/installs/development-tools.md +0 -977
  91. package/src/installs/docker.js +0 -1029
  92. package/src/installs/docker.md +0 -1109
  93. package/src/installs/drawio.js +0 -1019
  94. package/src/installs/drawio.md +0 -795
  95. package/src/installs/elmedia-player.js +0 -347
  96. package/src/installs/elmedia-player.md +0 -556
  97. package/src/installs/ffmpeg.js +0 -889
  98. package/src/installs/ffmpeg.md +0 -852
  99. package/src/installs/file.js +0 -464
  100. package/src/installs/file.md +0 -987
  101. package/src/installs/gemini-cli.js +0 -811
  102. package/src/installs/gemini-cli.md +0 -1153
  103. package/src/installs/git.js +0 -400
  104. package/src/installs/git.md +0 -907
  105. package/src/installs/gitego.js +0 -949
  106. package/src/installs/gitego.md +0 -1172
  107. package/src/installs/go.js +0 -931
  108. package/src/installs/go.md +0 -958
  109. package/src/installs/google-antigravity.js +0 -913
  110. package/src/installs/google-antigravity.md +0 -1075
  111. package/src/installs/google-chrome.js +0 -833
  112. package/src/installs/google-chrome.md +0 -862
  113. package/src/installs/gpg.js +0 -480
  114. package/src/installs/gpg.md +0 -1056
  115. package/src/installs/homebrew.js +0 -1033
  116. package/src/installs/homebrew.md +0 -988
  117. package/src/installs/imageoptim.js +0 -968
  118. package/src/installs/imageoptim.md +0 -1119
  119. package/src/installs/installers.json +0 -4032
  120. package/src/installs/installers.json.tmp +0 -3953
  121. package/src/installs/jq.js +0 -400
  122. package/src/installs/jq.md +0 -809
  123. package/src/installs/keyboard-maestro.js +0 -719
  124. package/src/installs/keyboard-maestro.md +0 -825
  125. package/src/installs/kiro.js +0 -864
  126. package/src/installs/kiro.md +0 -1015
  127. package/src/installs/latex.js +0 -789
  128. package/src/installs/latex.md +0 -1095
  129. package/src/installs/lftp.js +0 -356
  130. package/src/installs/lftp.md +0 -907
  131. package/src/installs/lsb-release.js +0 -346
  132. package/src/installs/lsb-release.md +0 -814
  133. package/src/installs/messenger.js +0 -847
  134. package/src/installs/messenger.md +0 -900
  135. package/src/installs/microsoft-office.js +0 -568
  136. package/src/installs/microsoft-office.md +0 -760
  137. package/src/installs/microsoft-teams.js +0 -801
  138. package/src/installs/microsoft-teams.md +0 -886
  139. package/src/installs/moom.js +0 -326
  140. package/src/installs/moom.md +0 -570
  141. package/src/installs/node.js +0 -904
  142. package/src/installs/node.md +0 -1153
  143. package/src/installs/nordpass.js +0 -716
  144. package/src/installs/nordpass.md +0 -921
  145. package/src/installs/nordvpn.js +0 -892
  146. package/src/installs/nordvpn.md +0 -1052
  147. package/src/installs/nvm.js +0 -995
  148. package/src/installs/nvm.md +0 -1057
  149. package/src/installs/ohmyzsh.js +0 -529
  150. package/src/installs/ohmyzsh.md +0 -1094
  151. package/src/installs/openssh.js +0 -804
  152. package/src/installs/openssh.md +0 -1056
  153. package/src/installs/pandoc.js +0 -662
  154. package/src/installs/pandoc.md +0 -1036
  155. package/src/installs/parallels-desktop.js +0 -431
  156. package/src/installs/parallels-desktop.md +0 -446
  157. package/src/installs/pinentry.js +0 -510
  158. package/src/installs/pinentry.md +0 -1142
  159. package/src/installs/pngyu.js +0 -869
  160. package/src/installs/pngyu.md +0 -896
  161. package/src/installs/postman.js +0 -799
  162. package/src/installs/postman.md +0 -940
  163. package/src/installs/procps.js +0 -425
  164. package/src/installs/procps.md +0 -851
  165. package/src/installs/safari-tech-preview.js +0 -374
  166. package/src/installs/safari-tech-preview.md +0 -533
  167. package/src/installs/sfnt2woff.js +0 -658
  168. package/src/installs/sfnt2woff.md +0 -795
  169. package/src/installs/shellcheck.js +0 -481
  170. package/src/installs/shellcheck.md +0 -1005
  171. package/src/installs/slack.js +0 -741
  172. package/src/installs/slack.md +0 -865
  173. package/src/installs/snagit.js +0 -585
  174. package/src/installs/snagit.md +0 -844
  175. package/src/installs/software-properties-common.js +0 -372
  176. package/src/installs/software-properties-common.md +0 -805
  177. package/src/installs/spotify.js +0 -877
  178. package/src/installs/spotify.md +0 -901
  179. package/src/installs/studio-3t.js +0 -823
  180. package/src/installs/studio-3t.md +0 -918
  181. package/src/installs/sublime-text.js +0 -804
  182. package/src/installs/sublime-text.md +0 -914
  183. package/src/installs/superwhisper.js +0 -706
  184. package/src/installs/superwhisper.md +0 -630
  185. package/src/installs/tailscale.js +0 -745
  186. package/src/installs/tailscale.md +0 -1100
  187. package/src/installs/tar.js +0 -389
  188. package/src/installs/tar.md +0 -946
  189. package/src/installs/termius.js +0 -798
  190. package/src/installs/termius.md +0 -844
  191. package/src/installs/terraform.js +0 -779
  192. package/src/installs/terraform.md +0 -899
  193. package/src/installs/tfenv.js +0 -778
  194. package/src/installs/tfenv.md +0 -1091
  195. package/src/installs/tidal.js +0 -771
  196. package/src/installs/tidal.md +0 -864
  197. package/src/installs/tmux.js +0 -346
  198. package/src/installs/tmux.md +0 -1030
  199. package/src/installs/tree.js +0 -411
  200. package/src/installs/tree.md +0 -833
  201. package/src/installs/unzip.js +0 -460
  202. package/src/installs/unzip.md +0 -879
  203. package/src/installs/vim.js +0 -421
  204. package/src/installs/vim.md +0 -1040
  205. package/src/installs/vlc.js +0 -821
  206. package/src/installs/vlc.md +0 -927
  207. package/src/installs/vscode.js +0 -843
  208. package/src/installs/vscode.md +0 -1002
  209. package/src/installs/wget.js +0 -420
  210. package/src/installs/wget.md +0 -791
  211. package/src/installs/whatsapp.js +0 -729
  212. package/src/installs/whatsapp.md +0 -854
  213. package/src/installs/winpty.js +0 -352
  214. package/src/installs/winpty.md +0 -620
  215. package/src/installs/woff2.js +0 -553
  216. package/src/installs/woff2.md +0 -977
  217. package/src/installs/wsl.js +0 -572
  218. package/src/installs/wsl.md +0 -699
  219. package/src/installs/xcode-clt.js +0 -520
  220. package/src/installs/xcode-clt.md +0 -351
  221. package/src/installs/xcode.js +0 -560
  222. package/src/installs/xcode.md +0 -573
  223. package/src/installs/yarn.js +0 -824
  224. package/src/installs/yarn.md +0 -1074
  225. package/src/installs/yq.js +0 -654
  226. package/src/installs/yq.md +0 -944
  227. package/src/installs/yt-dlp.js +0 -701
  228. package/src/installs/yt-dlp.md +0 -946
  229. package/src/installs/yum-utils.js +0 -297
  230. package/src/installs/yum-utils.md +0 -648
  231. package/src/installs/zoom.js +0 -759
  232. package/src/installs/zoom.md +0 -884
  233. package/src/installs/zsh.js +0 -455
  234. package/src/installs/zsh.md +0 -1008
  235. package/src/scripts/README.md +0 -617
  236. package/src/scripts/STATUS.md +0 -208
  237. package/src/scripts/afk.js +0 -411
  238. package/src/scripts/backup-all.js +0 -746
  239. package/src/scripts/backup-source.js +0 -727
  240. package/src/scripts/brewd.js +0 -389
  241. package/src/scripts/brewi.js +0 -520
  242. package/src/scripts/brewr.js +0 -527
  243. package/src/scripts/brews.js +0 -477
  244. package/src/scripts/brewu.js +0 -504
  245. package/src/scripts/c.js +0 -201
  246. package/src/scripts/ccurl.js +0 -341
  247. package/src/scripts/certbot-crontab-init.js +0 -504
  248. package/src/scripts/certbot-init.js +0 -657
  249. package/src/scripts/ch.js +0 -355
  250. package/src/scripts/claude-danger.js +0 -268
  251. package/src/scripts/clean-dev.js +0 -435
  252. package/src/scripts/clear-dns-cache.js +0 -541
  253. package/src/scripts/clone.js +0 -435
  254. package/src/scripts/code-all.js +0 -437
  255. package/src/scripts/count-files.js +0 -211
  256. package/src/scripts/count-folders.js +0 -211
  257. package/src/scripts/count.js +0 -264
  258. package/src/scripts/d.js +0 -219
  259. package/src/scripts/datauri.js +0 -389
  260. package/src/scripts/delete-files.js +0 -380
  261. package/src/scripts/docker-clean.js +0 -426
  262. package/src/scripts/dp.js +0 -442
  263. package/src/scripts/e.js +0 -390
  264. package/src/scripts/empty-trash.js +0 -513
  265. package/src/scripts/evm.js +0 -444
  266. package/src/scripts/fetch-github-repos.js +0 -456
  267. package/src/scripts/get-channel.js +0 -345
  268. package/src/scripts/get-course.js +0 -399
  269. package/src/scripts/get-dependencies.js +0 -306
  270. package/src/scripts/get-folder.js +0 -799
  271. package/src/scripts/get-tunes.js +0 -426
  272. package/src/scripts/get-video.js +0 -367
  273. package/src/scripts/git-backup.js +0 -577
  274. package/src/scripts/git-clone.js +0 -493
  275. package/src/scripts/git-pup.js +0 -319
  276. package/src/scripts/git-push.js +0 -396
  277. package/src/scripts/h.js +0 -622
  278. package/src/scripts/hide-desktop-icons.js +0 -499
  279. package/src/scripts/hide-hidden-files.js +0 -538
  280. package/src/scripts/install-dependencies-from.js +0 -456
  281. package/src/scripts/ips.js +0 -663
  282. package/src/scripts/iso.js +0 -370
  283. package/src/scripts/killni.js +0 -577
  284. package/src/scripts/ll.js +0 -467
  285. package/src/scripts/local-ip.js +0 -325
  286. package/src/scripts/m.js +0 -524
  287. package/src/scripts/map.js +0 -309
  288. package/src/scripts/mkd.js +0 -351
  289. package/src/scripts/ncu-update-all.js +0 -457
  290. package/src/scripts/nginx-init.js +0 -718
  291. package/src/scripts/npmi.js +0 -382
  292. package/src/scripts/o.js +0 -511
  293. package/src/scripts/org-by-date.js +0 -338
  294. package/src/scripts/p.js +0 -224
  295. package/src/scripts/packages.js +0 -330
  296. package/src/scripts/path.js +0 -225
  297. package/src/scripts/ports.js +0 -597
  298. package/src/scripts/q.js +0 -305
  299. package/src/scripts/refresh-files.js +0 -394
  300. package/src/scripts/remove-smaller-files.js +0 -516
  301. package/src/scripts/rename-files-with-date.js +0 -533
  302. package/src/scripts/resize-image.js +0 -539
  303. package/src/scripts/rm-safe.js +0 -669
  304. package/src/scripts/s.js +0 -540
  305. package/src/scripts/set-git-public.js +0 -365
  306. package/src/scripts/show-desktop-icons.js +0 -475
  307. package/src/scripts/show-hidden-files.js +0 -472
  308. package/src/scripts/tpa.js +0 -280
  309. package/src/scripts/tpo.js +0 -280
  310. package/src/scripts/u.js +0 -505
  311. package/src/scripts/vpush.js +0 -437
  312. package/src/scripts/y.js +0 -283
  313. package/src/utils/README.md +0 -95
  314. package/src/utils/common/apps.js +0 -143
  315. package/src/utils/common/display.js +0 -157
  316. package/src/utils/common/network.js +0 -185
  317. package/src/utils/common/os.js +0 -294
  318. package/src/utils/common/package-manager.js +0 -301
  319. package/src/utils/common/privileges.js +0 -138
  320. package/src/utils/common/shell.js +0 -216
  321. package/src/utils/macos/apps.js +0 -228
  322. package/src/utils/macos/brew.js +0 -315
  323. package/src/utils/ubuntu/apt.js +0 -307
  324. package/src/utils/ubuntu/desktop.js +0 -292
  325. package/src/utils/ubuntu/snap.js +0 -344
  326. package/src/utils/ubuntu/systemd.js +0 -286
  327. package/src/utils/windows/choco.js +0 -465
  328. package/src/utils/windows/env.js +0 -246
  329. package/src/utils/windows/registry.js +0 -269
  330. package/src/utils/windows/shell.js +0 -240
  331. package/src/utils/windows/winget.js +0 -489
@@ -1,821 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * @fileoverview Install VLC Media Player.
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
28
- */
29
-
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
- }
349
-
350
- /**
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
769
- *
770
- * @returns {Promise<void>}
771
- */
772
- async function install() {
773
- const platform = os.detect();
774
-
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
- };
814
-
815
- // Allow direct execution: node vlc.js
816
- if (require.main === module) {
817
- install().catch(err => {
818
- console.error(err.message);
819
- process.exit(1);
820
- });
821
- }