@fredlackey/devutils 0.0.18 → 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 -1028
  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 -261
  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,319 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * git-pup - Pull changes and update git submodules
5
- *
6
- * Migrated from legacy dotfiles alias.
7
- * Original:
8
- * git-pup(){
9
- * git pull && git submodule init && git submodule update && git submodule status
10
- * }
11
- *
12
- * This script performs a complete "pull and update" workflow for repositories
13
- * that use git submodules. It:
14
- * 1. Pulls the latest changes from the remote (git pull)
15
- * 2. Initializes any new submodules that were added (git submodule init)
16
- * 3. Updates all submodules to the committed versions (git submodule update)
17
- * 4. Shows the status of all submodules (git submodule status)
18
- *
19
- * This is useful when working with projects that have dependencies managed as
20
- * git submodules. Running "git pull" alone does not update submodules, so this
21
- * command ensures everything is in sync after pulling.
22
- *
23
- * @module scripts/git-pup
24
- */
25
-
26
- const os = require('../utils/common/os');
27
- const { execSync } = require('child_process');
28
-
29
- /**
30
- * Helper function to check if a command exists on the system.
31
- * Used to verify git is installed before running git commands.
32
- *
33
- * @param {string} cmd - The command name to check
34
- * @returns {boolean} True if the command exists, false otherwise
35
- */
36
- function isCommandAvailable(cmd) {
37
- try {
38
- // Use 'which' on Unix-like systems, 'where' on Windows
39
- const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
40
- execSync(checkCmd, { stdio: 'ignore' });
41
- return true;
42
- } catch {
43
- return false;
44
- }
45
- }
46
-
47
- /**
48
- * Helper function to check if the current directory is inside a git repository.
49
- * We use git's own detection mechanism rather than just looking for .git folder,
50
- * because the .git folder might be in a parent directory or be a gitdir file.
51
- *
52
- * @returns {boolean} True if inside a git repository, false otherwise
53
- */
54
- function isInsideGitRepo() {
55
- try {
56
- execSync('git rev-parse --is-inside-work-tree', { stdio: 'ignore' });
57
- return true;
58
- } catch {
59
- return false;
60
- }
61
- }
62
-
63
- /**
64
- * Pure Node.js implementation that uses git CLI commands.
65
- *
66
- * Since git is a native tool that provides:
67
- * - Battle-tested reliability for repository operations
68
- * - Consistent behavior across all platforms
69
- * - Complex functionality that would be error-prone to reimplement
70
- *
71
- * We use the git CLI rather than trying to reimplement git logic in Node.js.
72
- * Git works identically on macOS, Linux, and Windows, so all platform
73
- * functions delegate to this implementation.
74
- *
75
- * The function runs these commands in sequence:
76
- * 1. git pull - Fetches and merges changes from the remote
77
- * 2. git submodule init - Initializes local config for submodules
78
- * 3. git submodule update - Checks out the correct commit for each submodule
79
- * 4. git submodule status - Shows the current state of all submodules
80
- *
81
- * @param {string[]} args - Command line arguments (unused for this script)
82
- * @returns {Promise<void>}
83
- */
84
- async function do_git_pup_nodejs(args) {
85
- // Step 1: Verify git is installed
86
- // Git is not part of Node.js, so we must check for it
87
- if (!isCommandAvailable('git')) {
88
- console.error('Error: git is required but not installed.');
89
- console.error('');
90
- console.error('Install git for your platform:');
91
- console.error(' macOS: brew install git');
92
- console.error(' Ubuntu: sudo apt install git');
93
- console.error(' Windows: Download from https://git-scm.com/download/win');
94
- process.exit(1);
95
- }
96
-
97
- // Step 2: Verify we're in a git repository
98
- // Running git commands outside a repo gives confusing errors
99
- if (!isInsideGitRepo()) {
100
- console.error('Error: Not in a git repository.');
101
- console.error('');
102
- console.error('This command must be run from inside a git repository.');
103
- console.error('Navigate to a git repository and try again.');
104
- process.exit(1);
105
- }
106
-
107
- // Step 3: Pull changes from the remote
108
- // This fetches and merges changes from the tracked remote branch
109
- console.log('Pulling latest changes...');
110
- try {
111
- execSync('git pull', { stdio: 'inherit' });
112
- } catch (error) {
113
- console.error('');
114
- console.error('Error: git pull failed.');
115
- console.error('Check the error message above for details.');
116
- process.exit(1);
117
- }
118
-
119
- // Step 4: Initialize any new submodules
120
- // This sets up the local config for submodules that were added upstream
121
- // If no new submodules, this is a no-op (idempotent)
122
- console.log('');
123
- console.log('Initializing submodules...');
124
- try {
125
- execSync('git submodule init', { stdio: 'inherit' });
126
- } catch (error) {
127
- console.error('');
128
- console.error('Error: git submodule init failed.');
129
- console.error('Check the error message above for details.');
130
- process.exit(1);
131
- }
132
-
133
- // Step 5: Update submodules to the committed versions
134
- // This checks out the specific commit that the parent repo expects
135
- console.log('');
136
- console.log('Updating submodules...');
137
- try {
138
- execSync('git submodule update', { stdio: 'inherit' });
139
- } catch (error) {
140
- console.error('');
141
- console.error('Error: git submodule update failed.');
142
- console.error('Check the error message above for details.');
143
- process.exit(1);
144
- }
145
-
146
- // Step 6: Show submodule status
147
- // This helps the user see what submodules exist and their current state
148
- console.log('');
149
- console.log('Submodule status:');
150
- try {
151
- execSync('git submodule status', { stdio: 'inherit' });
152
- } catch (error) {
153
- // Status failing is not critical - the main work is done
154
- console.error('Warning: Could not retrieve submodule status.');
155
- }
156
-
157
- console.log('');
158
- console.log('Done! Repository and submodules are up to date.');
159
- }
160
-
161
- /**
162
- * Pull and update git submodules on macOS.
163
- *
164
- * Git works identically on macOS as other platforms, so this function
165
- * delegates to the shared Node.js implementation.
166
- *
167
- * @param {string[]} args - Command line arguments (unused)
168
- * @returns {Promise<void>}
169
- */
170
- async function do_git_pup_macos(args) {
171
- return do_git_pup_nodejs(args);
172
- }
173
-
174
- /**
175
- * Pull and update git submodules on Ubuntu.
176
- *
177
- * Git works identically on Ubuntu as other platforms, so this function
178
- * delegates to the shared Node.js implementation.
179
- *
180
- * @param {string[]} args - Command line arguments (unused)
181
- * @returns {Promise<void>}
182
- */
183
- async function do_git_pup_ubuntu(args) {
184
- return do_git_pup_nodejs(args);
185
- }
186
-
187
- /**
188
- * Pull and update git submodules on Raspberry Pi OS.
189
- *
190
- * Git works identically on Raspberry Pi OS as other platforms, so this
191
- * function delegates to the shared Node.js implementation.
192
- *
193
- * @param {string[]} args - Command line arguments (unused)
194
- * @returns {Promise<void>}
195
- */
196
- async function do_git_pup_raspbian(args) {
197
- return do_git_pup_nodejs(args);
198
- }
199
-
200
- /**
201
- * Pull and update git submodules on Amazon Linux.
202
- *
203
- * Git works identically on Amazon Linux as other platforms, so this
204
- * function delegates to the shared Node.js implementation.
205
- *
206
- * @param {string[]} args - Command line arguments (unused)
207
- * @returns {Promise<void>}
208
- */
209
- async function do_git_pup_amazon_linux(args) {
210
- return do_git_pup_nodejs(args);
211
- }
212
-
213
- /**
214
- * Pull and update git submodules on Windows Command Prompt.
215
- *
216
- * Git works identically on Windows as other platforms (when git is installed),
217
- * so this function delegates to the shared Node.js implementation.
218
- *
219
- * @param {string[]} args - Command line arguments (unused)
220
- * @returns {Promise<void>}
221
- */
222
- async function do_git_pup_cmd(args) {
223
- return do_git_pup_nodejs(args);
224
- }
225
-
226
- /**
227
- * Pull and update git submodules on Windows PowerShell.
228
- *
229
- * Git works identically on Windows as other platforms (when git is installed),
230
- * so this function delegates to the shared Node.js implementation.
231
- *
232
- * @param {string[]} args - Command line arguments (unused)
233
- * @returns {Promise<void>}
234
- */
235
- async function do_git_pup_powershell(args) {
236
- return do_git_pup_nodejs(args);
237
- }
238
-
239
- /**
240
- * Pull and update git submodules in Git Bash.
241
- *
242
- * Git Bash comes with git built-in, so this command will always work.
243
- * This function delegates to the shared Node.js implementation.
244
- *
245
- * @param {string[]} args - Command line arguments (unused)
246
- * @returns {Promise<void>}
247
- */
248
- async function do_git_pup_gitbash(args) {
249
- return do_git_pup_nodejs(args);
250
- }
251
-
252
- /**
253
- * Main entry point - detects environment and executes appropriate implementation.
254
- *
255
- * The "git-pup" (git Pull and UPdate) command is a convenience wrapper that
256
- * performs a complete pull and submodule update in one step. This is essential
257
- * for projects that use git submodules, because:
258
- *
259
- * 1. "git pull" alone does NOT update submodules
260
- * 2. After pulling, submodule references may point to new commits
261
- * 3. Running submodule init/update ensures your working tree matches the repo
262
- *
263
- * This command is idempotent - running it multiple times has no negative effects.
264
- * If there are no changes to pull or no submodules, it simply completes successfully.
265
- *
266
- * @param {string[]} args - Command line arguments (unused)
267
- * @returns {Promise<void>}
268
- */
269
- async function do_git_pup(args) {
270
- const platform = os.detect();
271
-
272
- const handlers = {
273
- 'macos': do_git_pup_macos,
274
- 'ubuntu': do_git_pup_ubuntu,
275
- 'debian': do_git_pup_ubuntu,
276
- 'raspbian': do_git_pup_raspbian,
277
- 'amazon_linux': do_git_pup_amazon_linux,
278
- 'rhel': do_git_pup_amazon_linux,
279
- 'fedora': do_git_pup_ubuntu,
280
- 'linux': do_git_pup_ubuntu,
281
- 'wsl': do_git_pup_ubuntu,
282
- 'cmd': do_git_pup_cmd,
283
- 'windows': do_git_pup_cmd,
284
- 'powershell': do_git_pup_powershell,
285
- 'gitbash': do_git_pup_gitbash
286
- };
287
-
288
- const handler = handlers[platform.type];
289
- if (!handler) {
290
- console.error(`Platform '${platform.type}' is not supported for this command.`);
291
- console.error('');
292
- console.error('Supported platforms:');
293
- console.error(' - macOS');
294
- console.error(' - Ubuntu, Debian, and other Linux distributions');
295
- console.error(' - Raspberry Pi OS');
296
- console.error(' - Amazon Linux, RHEL, Fedora');
297
- console.error(' - Windows (CMD, PowerShell, Git Bash)');
298
- process.exit(1);
299
- }
300
-
301
- await handler(args);
302
- }
303
-
304
- module.exports = {
305
- main: do_git_pup,
306
- do_git_pup,
307
- do_git_pup_nodejs,
308
- do_git_pup_macos,
309
- do_git_pup_ubuntu,
310
- do_git_pup_raspbian,
311
- do_git_pup_amazon_linux,
312
- do_git_pup_cmd,
313
- do_git_pup_powershell,
314
- do_git_pup_gitbash
315
- };
316
-
317
- if (require.main === module) {
318
- do_git_pup(process.argv.slice(2));
319
- }
@@ -1,396 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * git-push - Add, commit, and push in one command
5
- *
6
- * Migrated from legacy dotfiles alias.
7
- * Original:
8
- * git-push() {
9
- * local usage="git-push \"commit message\""
10
- * local message="$1"
11
- * local current_branch
12
- * local has_changes
13
- *
14
- * if [ -z "$message" ]; then
15
- * echo "Error: Commit message is required"
16
- * echo "Usage: $usage"
17
- * return 1
18
- * fi
19
- *
20
- * if ! git rev-parse --is-inside-work-tree > /dev/null 2>&1; then
21
- * echo "Error: Not in a git repository"
22
- * return 1
23
- * fi
24
- *
25
- * has_changes=$(git status --porcelain)
26
- * if [ -z "$has_changes" ]; then
27
- * echo "No changes detected in repository"
28
- * return 0
29
- * fi
30
- *
31
- * current_branch=$(git symbolic-ref --short HEAD 2>/dev/null)
32
- * if [ -z "$current_branch" ]; then
33
- * echo "Error: Could not determine current branch"
34
- * return 1
35
- * fi
36
- *
37
- * echo "Changes detected, proceeding with commit and push..."
38
- * git add -A && \
39
- * git commit -m "$message" && \
40
- * git push origin "$current_branch"
41
- * }
42
- *
43
- * This script stages all changes, commits them with the provided message,
44
- * and pushes to the current branch's remote. It provides a convenient
45
- * one-liner for the common "add, commit, push" workflow.
46
- *
47
- * @module scripts/git-push
48
- */
49
-
50
- const os = require('../utils/common/os');
51
- const { execSync } = require('child_process');
52
-
53
- /**
54
- * Helper function to check if a command exists on the system.
55
- * Used to verify git is installed before proceeding.
56
- *
57
- * @param {string} cmd - The command name to check
58
- * @returns {boolean} True if the command exists, false otherwise
59
- */
60
- function isCommandAvailable(cmd) {
61
- try {
62
- // Use 'which' on Unix-like systems, 'where' on Windows
63
- const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
64
- execSync(checkCmd, { stdio: 'ignore' });
65
- return true;
66
- } catch {
67
- return false;
68
- }
69
- }
70
-
71
- /**
72
- * Execute a git command and return stdout as a string.
73
- * Trims whitespace from the output for cleaner processing.
74
- *
75
- * @param {string} command - The git command to execute (without 'git' prefix)
76
- * @param {boolean} [ignoreErrors=false] - Whether to suppress error output
77
- * @returns {string} The command output, trimmed of whitespace
78
- * @throws {Error} If the command fails and ignoreErrors is false
79
- */
80
- function gitCommand(command, ignoreErrors = false) {
81
- try {
82
- const output = execSync(`git ${command}`, {
83
- encoding: 'utf8',
84
- stdio: ignoreErrors ? ['pipe', 'pipe', 'ignore'] : ['pipe', 'pipe', 'pipe']
85
- });
86
- return output.trim();
87
- } catch (error) {
88
- if (ignoreErrors) {
89
- return '';
90
- }
91
- throw error;
92
- }
93
- }
94
-
95
- /**
96
- * Check if the current directory is inside a git repository.
97
- * Uses 'git rev-parse --is-inside-work-tree' which returns 'true' if inside a repo.
98
- *
99
- * @returns {boolean} True if inside a git repository, false otherwise
100
- */
101
- function isInsideGitRepo() {
102
- try {
103
- const result = gitCommand('rev-parse --is-inside-work-tree', true);
104
- return result === 'true';
105
- } catch {
106
- return false;
107
- }
108
- }
109
-
110
- /**
111
- * Check if there are any changes in the repository.
112
- * Uses 'git status --porcelain' which outputs nothing if there are no changes.
113
- *
114
- * @returns {boolean} True if there are staged, unstaged, or untracked changes
115
- */
116
- function hasChanges() {
117
- try {
118
- const status = gitCommand('status --porcelain', true);
119
- return status.length > 0;
120
- } catch {
121
- return false;
122
- }
123
- }
124
-
125
- /**
126
- * Get the current git branch name.
127
- * Uses 'git symbolic-ref --short HEAD' to get the branch name without full ref path.
128
- *
129
- * @returns {string|null} The current branch name, or null if not on a branch (detached HEAD)
130
- */
131
- function getCurrentBranch() {
132
- try {
133
- const branch = gitCommand('symbolic-ref --short HEAD', true);
134
- return branch || null;
135
- } catch {
136
- return null;
137
- }
138
- }
139
-
140
- /**
141
- * Pure Node.js implementation for git-push.
142
- *
143
- * This function uses git commands which are available on all platforms.
144
- * Git is a cross-platform tool, so the same commands work identically
145
- * on macOS, Linux, and Windows.
146
- *
147
- * The workflow is:
148
- * 1. Validate commit message is provided
149
- * 2. Verify we're in a git repository
150
- * 3. Check for changes (skip if nothing to commit)
151
- * 4. Get current branch name
152
- * 5. Stage all changes (git add -A)
153
- * 6. Commit with the provided message
154
- * 7. Push to origin on the current branch
155
- *
156
- * @param {string[]} args - Command line arguments
157
- * @param {string} args.0 - The commit message (required)
158
- * @returns {Promise<void>}
159
- */
160
- async function do_git_push_nodejs(args) {
161
- const usage = 'git-push "commit message"';
162
-
163
- // Check if git is installed
164
- if (!isCommandAvailable('git')) {
165
- console.error('Error: git is required but not installed.');
166
- console.error('');
167
- console.error('Install git:');
168
- console.error(' macOS: brew install git');
169
- console.error(' Ubuntu: sudo apt install git');
170
- console.error(' Windows: winget install Git.Git');
171
- process.exit(1);
172
- }
173
-
174
- // Get commit message from arguments
175
- // Join all arguments to support messages without quotes
176
- const message = args.join(' ').trim();
177
-
178
- // Validate commit message is provided
179
- if (!message) {
180
- console.error('Error: Commit message is required');
181
- console.error(`Usage: ${usage}`);
182
- process.exit(1);
183
- }
184
-
185
- // Check if we're in a git repository
186
- if (!isInsideGitRepo()) {
187
- console.error('Error: Not in a git repository');
188
- process.exit(1);
189
- }
190
-
191
- // Check for any changes (staged, unstaged, or untracked files)
192
- if (!hasChanges()) {
193
- console.log('No changes detected in repository');
194
- return;
195
- }
196
-
197
- // Get current branch name
198
- const currentBranch = getCurrentBranch();
199
- if (!currentBranch) {
200
- console.error('Error: Could not determine current branch');
201
- console.error('You may be in a detached HEAD state.');
202
- console.error('Checkout a branch first: git checkout <branch-name>');
203
- process.exit(1);
204
- }
205
-
206
- // Proceed with add, commit, and push
207
- console.log('Changes detected, proceeding with commit and push...');
208
-
209
- try {
210
- // Stage all changes (including new files, modifications, and deletions)
211
- console.log('Staging all changes...');
212
- execSync('git add -A', { stdio: 'inherit' });
213
-
214
- // Commit with the provided message
215
- console.log(`Committing with message: "${message}"`);
216
- execSync(`git commit -m "${message.replace(/"/g, '\\"')}"`, { stdio: 'inherit' });
217
-
218
- // Push to origin on the current branch
219
- console.log(`Pushing to origin/${currentBranch}...`);
220
- execSync(`git push origin "${currentBranch}"`, { stdio: 'inherit' });
221
-
222
- console.log('Done!');
223
- } catch (error) {
224
- // Git commands will output their own error messages to stderr
225
- // Just exit with an error code
226
- process.exit(1);
227
- }
228
- }
229
-
230
- /**
231
- * Add, commit, and push on macOS.
232
- *
233
- * Git works identically on macOS as on other platforms, so this function
234
- * simply delegates to the pure Node.js implementation.
235
- *
236
- * @param {string[]} args - Command line arguments
237
- * @returns {Promise<void>}
238
- */
239
- async function do_git_push_macos(args) {
240
- return do_git_push_nodejs(args);
241
- }
242
-
243
- /**
244
- * Add, commit, and push on Ubuntu.
245
- *
246
- * Git works identically on Ubuntu as on other platforms, so this function
247
- * simply delegates to the pure Node.js implementation.
248
- *
249
- * @param {string[]} args - Command line arguments
250
- * @returns {Promise<void>}
251
- */
252
- async function do_git_push_ubuntu(args) {
253
- return do_git_push_nodejs(args);
254
- }
255
-
256
- /**
257
- * Add, commit, and push on Raspberry Pi OS.
258
- *
259
- * Git works identically on Raspberry Pi OS as on other platforms, so this
260
- * function simply delegates to the pure Node.js implementation.
261
- *
262
- * @param {string[]} args - Command line arguments
263
- * @returns {Promise<void>}
264
- */
265
- async function do_git_push_raspbian(args) {
266
- return do_git_push_nodejs(args);
267
- }
268
-
269
- /**
270
- * Add, commit, and push on Amazon Linux.
271
- *
272
- * Git works identically on Amazon Linux as on other platforms, so this
273
- * function simply delegates to the pure Node.js implementation.
274
- *
275
- * @param {string[]} args - Command line arguments
276
- * @returns {Promise<void>}
277
- */
278
- async function do_git_push_amazon_linux(args) {
279
- return do_git_push_nodejs(args);
280
- }
281
-
282
- /**
283
- * Add, commit, and push in Windows Command Prompt.
284
- *
285
- * Git works identically on Windows as on other platforms when installed
286
- * via Git for Windows, winget, or Chocolatey. This function simply
287
- * delegates to the pure Node.js implementation.
288
- *
289
- * @param {string[]} args - Command line arguments
290
- * @returns {Promise<void>}
291
- */
292
- async function do_git_push_cmd(args) {
293
- return do_git_push_nodejs(args);
294
- }
295
-
296
- /**
297
- * Add, commit, and push in Windows PowerShell.
298
- *
299
- * Git works identically in PowerShell as in other shells, so this function
300
- * simply delegates to the pure Node.js implementation.
301
- *
302
- * @param {string[]} args - Command line arguments
303
- * @returns {Promise<void>}
304
- */
305
- async function do_git_push_powershell(args) {
306
- return do_git_push_nodejs(args);
307
- }
308
-
309
- /**
310
- * Add, commit, and push in Git Bash on Windows.
311
- *
312
- * Git Bash is the native environment for Git on Windows, so git commands
313
- * work identically to other platforms. This function simply delegates
314
- * to the pure Node.js implementation.
315
- *
316
- * @param {string[]} args - Command line arguments
317
- * @returns {Promise<void>}
318
- */
319
- async function do_git_push_gitbash(args) {
320
- return do_git_push_nodejs(args);
321
- }
322
-
323
- /**
324
- * Main entry point - detects environment and executes appropriate implementation.
325
- *
326
- * The "git-push" command provides a convenient one-liner for the common
327
- * developer workflow of adding all changes, committing with a message,
328
- * and pushing to the remote repository.
329
- *
330
- * This is especially useful for:
331
- * - Quick commits during active development
332
- * - Saving work at the end of a coding session
333
- * - Simple single-change commits
334
- *
335
- * For more complex git workflows (multiple commits, selective staging,
336
- * rebasing, etc.), use the standard git commands directly.
337
- *
338
- * Usage:
339
- * git-push "Your commit message here"
340
- * git-push Fix typo in README
341
- *
342
- * @param {string[]} args - Command line arguments
343
- * @returns {Promise<void>}
344
- */
345
- async function do_git_push(args) {
346
- const platform = os.detect();
347
-
348
- const handlers = {
349
- 'macos': do_git_push_macos,
350
- 'ubuntu': do_git_push_ubuntu,
351
- 'debian': do_git_push_ubuntu,
352
- 'raspbian': do_git_push_raspbian,
353
- 'amazon_linux': do_git_push_amazon_linux,
354
- 'rhel': do_git_push_amazon_linux,
355
- 'fedora': do_git_push_ubuntu,
356
- 'linux': do_git_push_ubuntu,
357
- 'wsl': do_git_push_ubuntu,
358
- 'cmd': do_git_push_cmd,
359
- 'windows': do_git_push_cmd,
360
- 'powershell': do_git_push_powershell,
361
- 'gitbash': do_git_push_gitbash
362
- };
363
-
364
- const handler = handlers[platform.type];
365
- if (!handler) {
366
- console.error(`Platform '${platform.type}' is not supported for this command.`);
367
- console.error('');
368
- console.error('Supported platforms:');
369
- console.error(' - macOS');
370
- console.error(' - Ubuntu, Debian, and other Linux distributions');
371
- console.error(' - Raspberry Pi OS');
372
- console.error(' - Amazon Linux, RHEL, Fedora');
373
- console.error(' - Windows (CMD, PowerShell, Git Bash)');
374
- console.error(' - WSL (Windows Subsystem for Linux)');
375
- process.exit(1);
376
- }
377
-
378
- await handler(args);
379
- }
380
-
381
- module.exports = {
382
- main: do_git_push,
383
- do_git_push,
384
- do_git_push_nodejs,
385
- do_git_push_macos,
386
- do_git_push_ubuntu,
387
- do_git_push_raspbian,
388
- do_git_push_amazon_linux,
389
- do_git_push_cmd,
390
- do_git_push_powershell,
391
- do_git_push_gitbash
392
- };
393
-
394
- if (require.main === module) {
395
- do_git_push(process.argv.slice(2));
396
- }