@fredlackey/devutils 0.0.18 → 0.1.0

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