@fredlackey/devutils 0.0.1 → 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. package/README.md +5 -5
  2. package/package.json +1 -1
  3. package/src/commands/install.js +374 -36
  4. package/src/installs/adobe-creative-cloud.js +527 -25
  5. package/src/installs/adobe-creative-cloud.md +605 -0
  6. package/src/installs/appcleaner.js +303 -26
  7. package/src/installs/appcleaner.md +699 -0
  8. package/src/installs/apt-transport-https.js +390 -0
  9. package/src/installs/apt-transport-https.md +678 -0
  10. package/src/installs/atomicparsley.js +624 -26
  11. package/src/installs/atomicparsley.md +795 -0
  12. package/src/installs/aws-cli.js +779 -26
  13. package/src/installs/aws-cli.md +727 -0
  14. package/src/installs/balena-etcher.js +688 -26
  15. package/src/installs/balena-etcher.md +761 -0
  16. package/src/installs/bambu-studio.js +912 -26
  17. package/src/installs/bambu-studio.md +780 -0
  18. package/src/installs/bash-completion.js +554 -23
  19. package/src/installs/bash-completion.md +833 -0
  20. package/src/installs/bash.js +399 -26
  21. package/src/installs/bash.md +993 -0
  22. package/src/installs/beyond-compare.js +585 -26
  23. package/src/installs/beyond-compare.md +813 -0
  24. package/src/installs/build-essential.js +511 -26
  25. package/src/installs/build-essential.md +977 -0
  26. package/src/installs/ca-certificates.js +618 -0
  27. package/src/installs/ca-certificates.md +937 -0
  28. package/src/installs/caffeine.js +490 -26
  29. package/src/installs/caffeine.md +839 -0
  30. package/src/installs/camtasia.js +577 -25
  31. package/src/installs/camtasia.md +762 -0
  32. package/src/installs/chatgpt.js +458 -26
  33. package/src/installs/chatgpt.md +814 -0
  34. package/src/installs/chocolatey.js +447 -0
  35. package/src/installs/chocolatey.md +661 -0
  36. package/src/installs/chrome-canary.js +472 -26
  37. package/src/installs/chrome-canary.md +641 -0
  38. package/src/installs/chromium.js +645 -26
  39. package/src/installs/chromium.md +838 -0
  40. package/src/installs/claude-code.js +558 -26
  41. package/src/installs/claude-code.md +1173 -0
  42. package/src/installs/curl.js +361 -26
  43. package/src/installs/curl.md +714 -0
  44. package/src/installs/cursor.js +561 -26
  45. package/src/installs/cursor.md +970 -0
  46. package/src/installs/dbschema.js +674 -26
  47. package/src/installs/dbschema.md +925 -0
  48. package/src/installs/dependencies.md +435 -0
  49. package/src/installs/development-tools.js +600 -0
  50. package/src/installs/development-tools.md +977 -0
  51. package/src/installs/docker.js +1010 -25
  52. package/src/installs/docker.md +1109 -0
  53. package/src/installs/drawio.js +1001 -26
  54. package/src/installs/drawio.md +795 -0
  55. package/src/installs/elmedia-player.js +328 -25
  56. package/src/installs/elmedia-player.md +556 -0
  57. package/src/installs/ffmpeg.js +870 -25
  58. package/src/installs/ffmpeg.md +852 -0
  59. package/src/installs/file.js +464 -0
  60. package/src/installs/file.md +987 -0
  61. package/src/installs/gemini-cli.js +793 -26
  62. package/src/installs/gemini-cli.md +1153 -0
  63. package/src/installs/git.js +382 -26
  64. package/src/installs/git.md +907 -0
  65. package/src/installs/gitego.js +931 -26
  66. package/src/installs/gitego.md +1172 -0
  67. package/src/installs/go.js +913 -26
  68. package/src/installs/go.md +958 -0
  69. package/src/installs/google-chrome.js +801 -25
  70. package/src/installs/google-chrome.md +862 -0
  71. package/src/installs/gpg.js +412 -73
  72. package/src/installs/gpg.md +1056 -0
  73. package/src/installs/homebrew.js +1015 -26
  74. package/src/installs/homebrew.md +988 -0
  75. package/src/installs/imageoptim.js +950 -26
  76. package/src/installs/imageoptim.md +1119 -0
  77. package/src/installs/installers.json +2297 -0
  78. package/src/installs/jq.js +382 -26
  79. package/src/installs/jq.md +809 -0
  80. package/src/installs/keyboard-maestro.js +701 -26
  81. package/src/installs/keyboard-maestro.md +825 -0
  82. package/src/installs/latex.js +771 -26
  83. package/src/installs/latex.md +1095 -0
  84. package/src/installs/lftp.js +338 -26
  85. package/src/installs/lftp.md +907 -0
  86. package/src/installs/lsb-release.js +346 -0
  87. package/src/installs/lsb-release.md +814 -0
  88. package/src/installs/messenger.js +829 -26
  89. package/src/installs/messenger.md +900 -0
  90. package/src/installs/microsoft-office.js +550 -26
  91. package/src/installs/microsoft-office.md +760 -0
  92. package/src/installs/microsoft-teams.js +782 -25
  93. package/src/installs/microsoft-teams.md +886 -0
  94. package/src/installs/node.js +886 -26
  95. package/src/installs/node.md +1153 -0
  96. package/src/installs/nordpass.js +698 -26
  97. package/src/installs/nordpass.md +921 -0
  98. package/src/installs/nvm.js +977 -26
  99. package/src/installs/nvm.md +1057 -0
  100. package/src/installs/openssh.js +734 -64
  101. package/src/installs/openssh.md +1056 -0
  102. package/src/installs/pandoc.js +644 -26
  103. package/src/installs/pandoc.md +1036 -0
  104. package/src/installs/pinentry.js +492 -26
  105. package/src/installs/pinentry.md +1142 -0
  106. package/src/installs/pngyu.js +851 -26
  107. package/src/installs/pngyu.md +896 -0
  108. package/src/installs/postman.js +781 -26
  109. package/src/installs/postman.md +940 -0
  110. package/src/installs/procps.js +425 -0
  111. package/src/installs/procps.md +851 -0
  112. package/src/installs/safari-tech-preview.js +355 -25
  113. package/src/installs/safari-tech-preview.md +533 -0
  114. package/src/installs/sfnt2woff.js +640 -26
  115. package/src/installs/sfnt2woff.md +795 -0
  116. package/src/installs/shellcheck.js +463 -26
  117. package/src/installs/shellcheck.md +1005 -0
  118. package/src/installs/slack.js +722 -25
  119. package/src/installs/slack.md +865 -0
  120. package/src/installs/snagit.js +566 -25
  121. package/src/installs/snagit.md +844 -0
  122. package/src/installs/software-properties-common.js +372 -0
  123. package/src/installs/software-properties-common.md +805 -0
  124. package/src/installs/spotify.js +858 -25
  125. package/src/installs/spotify.md +901 -0
  126. package/src/installs/studio-3t.js +803 -26
  127. package/src/installs/studio-3t.md +918 -0
  128. package/src/installs/sublime-text.js +780 -25
  129. package/src/installs/sublime-text.md +914 -0
  130. package/src/installs/superwhisper.js +687 -25
  131. package/src/installs/superwhisper.md +630 -0
  132. package/src/installs/tailscale.js +727 -26
  133. package/src/installs/tailscale.md +1100 -0
  134. package/src/installs/tar.js +389 -0
  135. package/src/installs/tar.md +946 -0
  136. package/src/installs/termius.js +780 -26
  137. package/src/installs/termius.md +844 -0
  138. package/src/installs/terraform.js +761 -26
  139. package/src/installs/terraform.md +899 -0
  140. package/src/installs/tidal.js +752 -25
  141. package/src/installs/tidal.md +864 -0
  142. package/src/installs/tmux.js +328 -26
  143. package/src/installs/tmux.md +1030 -0
  144. package/src/installs/tree.js +393 -26
  145. package/src/installs/tree.md +833 -0
  146. package/src/installs/unzip.js +460 -0
  147. package/src/installs/unzip.md +879 -0
  148. package/src/installs/vim.js +403 -26
  149. package/src/installs/vim.md +1040 -0
  150. package/src/installs/vlc.js +803 -26
  151. package/src/installs/vlc.md +927 -0
  152. package/src/installs/vscode.js +825 -26
  153. package/src/installs/vscode.md +1002 -0
  154. package/src/installs/wget.js +415 -0
  155. package/src/installs/wget.md +791 -0
  156. package/src/installs/whatsapp.js +710 -25
  157. package/src/installs/whatsapp.md +854 -0
  158. package/src/installs/winpty.js +352 -0
  159. package/src/installs/winpty.md +620 -0
  160. package/src/installs/woff2.js +535 -26
  161. package/src/installs/woff2.md +977 -0
  162. package/src/installs/wsl.js +572 -0
  163. package/src/installs/wsl.md +699 -0
  164. package/src/installs/xcode-clt.js +520 -0
  165. package/src/installs/xcode-clt.md +351 -0
  166. package/src/installs/xcode.js +542 -26
  167. package/src/installs/xcode.md +573 -0
  168. package/src/installs/yarn.js +806 -26
  169. package/src/installs/yarn.md +1074 -0
  170. package/src/installs/yq.js +636 -26
  171. package/src/installs/yq.md +944 -0
  172. package/src/installs/yt-dlp.js +683 -26
  173. package/src/installs/yt-dlp.md +946 -0
  174. package/src/installs/yum-utils.js +297 -0
  175. package/src/installs/yum-utils.md +648 -0
  176. package/src/installs/zoom.js +740 -25
  177. package/src/installs/zoom.md +884 -0
  178. package/src/scripts/README.md +567 -45
  179. package/src/scripts/STATUS.md +208 -0
  180. package/src/scripts/afk.js +395 -7
  181. package/src/scripts/backup-all.js +731 -9
  182. package/src/scripts/backup-source.js +711 -8
  183. package/src/scripts/brewd.js +373 -7
  184. package/src/scripts/brewi.js +505 -9
  185. package/src/scripts/brewr.js +512 -9
  186. package/src/scripts/brews.js +462 -9
  187. package/src/scripts/brewu.js +488 -7
  188. package/src/scripts/c.js +185 -7
  189. package/src/scripts/ccurl.js +325 -8
  190. package/src/scripts/certbot-crontab-init.js +488 -8
  191. package/src/scripts/certbot-init.js +641 -9
  192. package/src/scripts/ch.js +339 -7
  193. package/src/scripts/claude-danger.js +253 -8
  194. package/src/scripts/clean-dev.js +419 -8
  195. package/src/scripts/clear-dns-cache.js +525 -7
  196. package/src/scripts/clone.js +417 -7
  197. package/src/scripts/code-all.js +420 -7
  198. package/src/scripts/count-files.js +195 -8
  199. package/src/scripts/count-folders.js +195 -8
  200. package/src/scripts/count.js +248 -8
  201. package/src/scripts/d.js +203 -7
  202. package/src/scripts/datauri.js +373 -8
  203. package/src/scripts/delete-files.js +363 -7
  204. package/src/scripts/docker-clean.js +410 -8
  205. package/src/scripts/dp.js +426 -7
  206. package/src/scripts/e.js +375 -9
  207. package/src/scripts/empty-trash.js +497 -7
  208. package/src/scripts/evm.js +428 -9
  209. package/src/scripts/fetch-github-repos.js +441 -10
  210. package/src/scripts/get-channel.js +329 -8
  211. package/src/scripts/get-course.js +384 -11
  212. package/src/scripts/get-dependencies.js +290 -9
  213. package/src/scripts/get-folder.js +783 -10
  214. package/src/scripts/get-tunes.js +411 -10
  215. package/src/scripts/get-video.js +352 -9
  216. package/src/scripts/git-backup.js +561 -9
  217. package/src/scripts/git-clone.js +477 -9
  218. package/src/scripts/git-pup.js +303 -7
  219. package/src/scripts/git-push.js +380 -8
  220. package/src/scripts/h.js +607 -9
  221. package/src/scripts/hide-desktop-icons.js +483 -7
  222. package/src/scripts/hide-hidden-files.js +522 -7
  223. package/src/scripts/install-dependencies-from.js +440 -9
  224. package/src/scripts/ips.js +647 -10
  225. package/src/scripts/iso.js +354 -8
  226. package/src/scripts/killni.js +561 -7
  227. package/src/scripts/ll.js +451 -8
  228. package/src/scripts/local-ip.js +310 -8
  229. package/src/scripts/m.js +508 -8
  230. package/src/scripts/map.js +293 -8
  231. package/src/scripts/mkd.js +287 -7
  232. package/src/scripts/ncu-update-all.js +441 -8
  233. package/src/scripts/nginx-init.js +702 -12
  234. package/src/scripts/npmi.js +366 -7
  235. package/src/scripts/o.js +495 -8
  236. package/src/scripts/org-by-date.js +321 -7
  237. package/src/scripts/p.js +208 -7
  238. package/src/scripts/packages.js +313 -8
  239. package/src/scripts/path.js +209 -7
  240. package/src/scripts/ports.js +582 -8
  241. package/src/scripts/q.js +290 -8
  242. package/src/scripts/refresh-files.js +378 -10
  243. package/src/scripts/remove-smaller-files.js +500 -8
  244. package/src/scripts/rename-files-with-date.js +517 -9
  245. package/src/scripts/resize-image.js +523 -9
  246. package/src/scripts/rm-safe.js +653 -8
  247. package/src/scripts/s.js +525 -9
  248. package/src/scripts/set-git-public.js +349 -7
  249. package/src/scripts/show-desktop-icons.js +459 -7
  250. package/src/scripts/show-hidden-files.js +456 -7
  251. package/src/scripts/tpa.js +265 -8
  252. package/src/scripts/tpo.js +264 -7
  253. package/src/scripts/u.js +489 -7
  254. package/src/scripts/vpush.js +422 -8
  255. package/src/scripts/y.js +267 -7
  256. package/src/utils/common/os.js +94 -2
  257. package/src/utils/ubuntu/apt.js +13 -7
  258. package/src/utils/windows/choco.js +82 -26
  259. package/src/utils/windows/winget.js +89 -27
@@ -1,23 +1,437 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Commit with package.json version as message.
4
+ * vpush - Commit and push using package.json version as the commit message
5
+ *
6
+ * Migrated from legacy dotfiles alias.
7
+ * Original:
8
+ * vpush() {
9
+ * # Ensure JQ is installed
10
+ * if ! cmd_exists "jq"; then
11
+ * printf "jq is required, please install it!\n"
12
+ * exit 1
13
+ * fi
14
+ *
15
+ * pkg_ver=$(jq '.version' package.json)
16
+ * pkg_ver=${pkg_ver//\"/}
17
+ * git add -A
18
+ * git commit -a -S -m $pkg_ver
19
+ * git push origin master
20
+ * }
21
+ *
22
+ * This script reads the version from package.json, stages all changes,
23
+ * commits with the version as the commit message, and pushes to the
24
+ * current branch's remote. Unlike the original, this version:
25
+ * - Uses native Node.js JSON parsing (no jq dependency required)
26
+ * - Pushes to the current branch instead of hardcoding 'master'
27
+ * - Optionally supports GPG signing via --sign flag
28
+ *
5
29
  * @module scripts/vpush
6
30
  */
7
31
 
32
+ const os = require('../utils/common/os');
33
+ const fs = require('fs');
34
+ const path = require('path');
35
+ const { execSync } = require('child_process');
36
+
37
+ /**
38
+ * Helper function to check if a command exists on the system.
39
+ * Used to verify git is installed before proceeding.
40
+ *
41
+ * @param {string} cmd - The command name to check
42
+ * @returns {boolean} True if the command exists, false otherwise
43
+ */
44
+ function isCommandAvailable(cmd) {
45
+ try {
46
+ // Use 'which' on Unix-like systems, 'where' on Windows
47
+ const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
48
+ execSync(checkCmd, { stdio: 'ignore' });
49
+ return true;
50
+ } catch {
51
+ return false;
52
+ }
53
+ }
54
+
55
+ /**
56
+ * Execute a git command and return stdout as a string.
57
+ * Trims whitespace from the output for cleaner processing.
58
+ *
59
+ * @param {string} command - The git command to execute (without 'git' prefix)
60
+ * @param {boolean} [ignoreErrors=false] - Whether to suppress error output
61
+ * @returns {string} The command output, trimmed of whitespace
62
+ * @throws {Error} If the command fails and ignoreErrors is false
63
+ */
64
+ function gitCommand(command, ignoreErrors = false) {
65
+ try {
66
+ const output = execSync(`git ${command}`, {
67
+ encoding: 'utf8',
68
+ stdio: ignoreErrors ? ['pipe', 'pipe', 'ignore'] : ['pipe', 'pipe', 'pipe']
69
+ });
70
+ return output.trim();
71
+ } catch (error) {
72
+ if (ignoreErrors) {
73
+ return '';
74
+ }
75
+ throw error;
76
+ }
77
+ }
78
+
79
+ /**
80
+ * Check if the current directory is inside a git repository.
81
+ * Uses 'git rev-parse --is-inside-work-tree' which returns 'true' if inside a repo.
82
+ *
83
+ * @returns {boolean} True if inside a git repository, false otherwise
84
+ */
85
+ function isInsideGitRepo() {
86
+ try {
87
+ const result = gitCommand('rev-parse --is-inside-work-tree', true);
88
+ return result === 'true';
89
+ } catch {
90
+ return false;
91
+ }
92
+ }
93
+
94
+ /**
95
+ * Check if there are any changes in the repository.
96
+ * Uses 'git status --porcelain' which outputs nothing if there are no changes.
97
+ *
98
+ * @returns {boolean} True if there are staged, unstaged, or untracked changes
99
+ */
100
+ function hasChanges() {
101
+ try {
102
+ const status = gitCommand('status --porcelain', true);
103
+ return status.length > 0;
104
+ } catch {
105
+ return false;
106
+ }
107
+ }
108
+
109
+ /**
110
+ * Get the current git branch name.
111
+ * Uses 'git symbolic-ref --short HEAD' to get the branch name without full ref path.
112
+ *
113
+ * @returns {string|null} The current branch name, or null if not on a branch (detached HEAD)
114
+ */
115
+ function getCurrentBranch() {
116
+ try {
117
+ const branch = gitCommand('symbolic-ref --short HEAD', true);
118
+ return branch || null;
119
+ } catch {
120
+ return null;
121
+ }
122
+ }
123
+
8
124
  /**
9
- * Stages all changes, commits using the version from package.json
10
- * as the commit message, and pushes to the remote.
125
+ * Read and parse package.json from the current working directory.
126
+ * Returns the parsed JSON object or null if the file doesn't exist or is invalid.
127
+ *
128
+ * This function uses pure Node.js (fs and JSON.parse) instead of requiring
129
+ * external tools like jq, making it work on any platform with Node.js installed.
11
130
  *
12
- * @param {string[]} args - Command line arguments (unused)
131
+ * @returns {{ version: string } | null} The parsed package.json object, or null on error
132
+ */
133
+ function readPackageJson() {
134
+ const packageJsonPath = path.join(process.cwd(), 'package.json');
135
+
136
+ // Check if package.json exists in the current directory
137
+ if (!fs.existsSync(packageJsonPath)) {
138
+ return null;
139
+ }
140
+
141
+ try {
142
+ // Read and parse the file using Node.js native capabilities
143
+ const content = fs.readFileSync(packageJsonPath, 'utf8');
144
+ const packageJson = JSON.parse(content);
145
+ return packageJson;
146
+ } catch (error) {
147
+ // File exists but couldn't be read or parsed
148
+ return null;
149
+ }
150
+ }
151
+
152
+ /**
153
+ * Pure Node.js implementation for vpush.
154
+ *
155
+ * This function reads the version from package.json using native Node.js
156
+ * (no external dependencies like jq), then stages all changes, commits
157
+ * with the version as the message, and pushes to the current branch.
158
+ *
159
+ * The workflow is:
160
+ * 1. Verify git is installed
161
+ * 2. Verify we're in a git repository
162
+ * 3. Read and validate package.json exists and has a version field
163
+ * 4. Check for changes (skip if nothing to commit)
164
+ * 5. Get current branch name
165
+ * 6. Stage all changes (git add -A)
166
+ * 7. Commit with the version as the message
167
+ * 8. Push to origin on the current branch
168
+ *
169
+ * @param {string[]} args - Command line arguments
170
+ * @param {string} [args.0] - Optional '--sign' or '-S' flag to enable GPG signing
13
171
  * @returns {Promise<void>}
14
172
  */
15
- async function main(args) {
16
- // TODO: Implement version-based commit and push
173
+ async function do_vpush_nodejs(args) {
174
+ // Parse arguments for optional flags
175
+ const useSign = args.includes('--sign') || args.includes('-S');
176
+
177
+ // Check if git is installed
178
+ if (!isCommandAvailable('git')) {
179
+ console.error('Error: git is required but not installed.');
180
+ console.error('');
181
+ console.error('Install git:');
182
+ console.error(' macOS: brew install git');
183
+ console.error(' Ubuntu: sudo apt install git');
184
+ console.error(' Windows: winget install Git.Git');
185
+ process.exit(1);
186
+ }
187
+
188
+ // Check if we're in a git repository
189
+ if (!isInsideGitRepo()) {
190
+ console.error('Error: Not in a git repository');
191
+ process.exit(1);
192
+ }
193
+
194
+ // Read package.json from the current directory
195
+ // This uses native Node.js fs and JSON.parse - no jq needed!
196
+ const packageJson = readPackageJson();
197
+
198
+ if (!packageJson) {
199
+ console.error('Error: package.json not found in current directory');
200
+ console.error('');
201
+ console.error('This command must be run from a Node.js project directory');
202
+ console.error('containing a valid package.json file.');
203
+ process.exit(1);
204
+ }
205
+
206
+ // Validate that package.json has a version field
207
+ const version = packageJson.version;
208
+
209
+ if (!version) {
210
+ console.error('Error: package.json does not contain a "version" field');
211
+ console.error('');
212
+ console.error('Add a version to your package.json:');
213
+ console.error(' {');
214
+ console.error(' "name": "your-package",');
215
+ console.error(' "version": "1.0.0",');
216
+ console.error(' ...');
217
+ console.error(' }');
218
+ process.exit(1);
219
+ }
220
+
221
+ // Validate version format (should be a non-empty string)
222
+ if (typeof version !== 'string' || version.trim() === '') {
223
+ console.error('Error: package.json "version" field is empty or invalid');
224
+ process.exit(1);
225
+ }
226
+
227
+ // Check for any changes (staged, unstaged, or untracked files)
228
+ if (!hasChanges()) {
229
+ console.log('No changes detected in repository');
230
+ return;
231
+ }
232
+
233
+ // Get current branch name
234
+ const currentBranch = getCurrentBranch();
235
+ if (!currentBranch) {
236
+ console.error('Error: Could not determine current branch');
237
+ console.error('You may be in a detached HEAD state.');
238
+ console.error('Checkout a branch first: git checkout <branch-name>');
239
+ process.exit(1);
240
+ }
241
+
242
+ // Proceed with add, commit, and push
243
+ console.log(`Committing with version: ${version}`);
244
+ if (useSign) {
245
+ console.log('GPG signing enabled');
246
+ }
247
+
248
+ try {
249
+ // Stage all changes (including new files, modifications, and deletions)
250
+ console.log('Staging all changes...');
251
+ execSync('git add -A', { stdio: 'inherit' });
252
+
253
+ // Commit with the version as the message
254
+ // The original used -a -S, but -a is redundant after git add -A
255
+ // We support optional GPG signing via --sign flag
256
+ const signFlag = useSign ? '-S ' : '';
257
+ console.log(`Committing...`);
258
+ execSync(`git commit ${signFlag}-m "${version}"`, { stdio: 'inherit' });
259
+
260
+ // Push to origin on the current branch
261
+ console.log(`Pushing to origin/${currentBranch}...`);
262
+ execSync(`git push origin "${currentBranch}"`, { stdio: 'inherit' });
263
+
264
+ console.log('Done!');
265
+ } catch (error) {
266
+ // Git commands will output their own error messages to stderr
267
+ // Just exit with an error code
268
+ process.exit(1);
269
+ }
270
+ }
271
+
272
+ /**
273
+ * Commit and push with package version on macOS.
274
+ *
275
+ * Git and Node.js file operations work identically on macOS as on other
276
+ * platforms, so this function simply delegates to the pure Node.js implementation.
277
+ *
278
+ * @param {string[]} args - Command line arguments
279
+ * @returns {Promise<void>}
280
+ */
281
+ async function do_vpush_macos(args) {
282
+ return do_vpush_nodejs(args);
283
+ }
284
+
285
+ /**
286
+ * Commit and push with package version on Ubuntu.
287
+ *
288
+ * Git and Node.js file operations work identically on Ubuntu as on other
289
+ * platforms, so this function simply delegates to the pure Node.js implementation.
290
+ *
291
+ * @param {string[]} args - Command line arguments
292
+ * @returns {Promise<void>}
293
+ */
294
+ async function do_vpush_ubuntu(args) {
295
+ return do_vpush_nodejs(args);
296
+ }
297
+
298
+ /**
299
+ * Commit and push with package version on Raspberry Pi OS.
300
+ *
301
+ * Git and Node.js file operations work identically on Raspberry Pi OS as on
302
+ * other platforms, so this function simply delegates to the pure Node.js implementation.
303
+ *
304
+ * @param {string[]} args - Command line arguments
305
+ * @returns {Promise<void>}
306
+ */
307
+ async function do_vpush_raspbian(args) {
308
+ return do_vpush_nodejs(args);
309
+ }
310
+
311
+ /**
312
+ * Commit and push with package version on Amazon Linux.
313
+ *
314
+ * Git and Node.js file operations work identically on Amazon Linux as on
315
+ * other platforms, so this function simply delegates to the pure Node.js implementation.
316
+ *
317
+ * @param {string[]} args - Command line arguments
318
+ * @returns {Promise<void>}
319
+ */
320
+ async function do_vpush_amazon_linux(args) {
321
+ return do_vpush_nodejs(args);
322
+ }
323
+
324
+ /**
325
+ * Commit and push with package version in Windows Command Prompt.
326
+ *
327
+ * Git and Node.js file operations work identically on Windows as on other
328
+ * platforms when installed via Git for Windows, winget, or Chocolatey.
329
+ * This function simply delegates to the pure Node.js implementation.
330
+ *
331
+ * @param {string[]} args - Command line arguments
332
+ * @returns {Promise<void>}
333
+ */
334
+ async function do_vpush_cmd(args) {
335
+ return do_vpush_nodejs(args);
336
+ }
337
+
338
+ /**
339
+ * Commit and push with package version in Windows PowerShell.
340
+ *
341
+ * Git and Node.js file operations work identically in PowerShell as in
342
+ * other shells, so this function simply delegates to the pure Node.js implementation.
343
+ *
344
+ * @param {string[]} args - Command line arguments
345
+ * @returns {Promise<void>}
346
+ */
347
+ async function do_vpush_powershell(args) {
348
+ return do_vpush_nodejs(args);
349
+ }
350
+
351
+ /**
352
+ * Commit and push with package version in Git Bash on Windows.
353
+ *
354
+ * Git Bash is the native environment for Git on Windows, so git commands
355
+ * work identically to other platforms. This function simply delegates
356
+ * to the pure Node.js implementation.
357
+ *
358
+ * @param {string[]} args - Command line arguments
359
+ * @returns {Promise<void>}
360
+ */
361
+ async function do_vpush_gitbash(args) {
362
+ return do_vpush_nodejs(args);
363
+ }
364
+
365
+ /**
366
+ * Main entry point - detects environment and executes appropriate implementation.
367
+ *
368
+ * The "vpush" command provides a convenient way to commit and push a
369
+ * Node.js package using its version number as the commit message.
370
+ * This is especially useful when releasing new versions, ensuring the
371
+ * commit message matches the package version.
372
+ *
373
+ * Unlike the original bash version, this implementation:
374
+ * - Uses native Node.js to read package.json (no jq dependency)
375
+ * - Pushes to the current branch instead of hardcoding 'master'
376
+ * - Supports optional GPG signing via --sign or -S flag
377
+ *
378
+ * Usage:
379
+ * vpush # Commit with version, no GPG signing
380
+ * vpush --sign # Commit with version, GPG signing enabled
381
+ * vpush -S # Same as --sign
382
+ *
383
+ * @param {string[]} args - Command line arguments
384
+ * @returns {Promise<void>}
385
+ */
386
+ async function do_vpush(args) {
387
+ const platform = os.detect();
388
+
389
+ const handlers = {
390
+ 'macos': do_vpush_macos,
391
+ 'ubuntu': do_vpush_ubuntu,
392
+ 'debian': do_vpush_ubuntu,
393
+ 'raspbian': do_vpush_raspbian,
394
+ 'amazon_linux': do_vpush_amazon_linux,
395
+ 'rhel': do_vpush_amazon_linux,
396
+ 'fedora': do_vpush_ubuntu,
397
+ 'linux': do_vpush_ubuntu,
398
+ 'wsl': do_vpush_ubuntu,
399
+ 'cmd': do_vpush_cmd,
400
+ 'windows': do_vpush_cmd,
401
+ 'powershell': do_vpush_powershell,
402
+ 'gitbash': do_vpush_gitbash
403
+ };
404
+
405
+ const handler = handlers[platform.type];
406
+ if (!handler) {
407
+ console.error(`Platform '${platform.type}' is not supported for this command.`);
408
+ console.error('');
409
+ console.error('Supported platforms:');
410
+ console.error(' - macOS');
411
+ console.error(' - Ubuntu, Debian, and other Linux distributions');
412
+ console.error(' - Raspberry Pi OS');
413
+ console.error(' - Amazon Linux, RHEL, Fedora');
414
+ console.error(' - Windows (CMD, PowerShell, Git Bash)');
415
+ console.error(' - WSL (Windows Subsystem for Linux)');
416
+ process.exit(1);
417
+ }
418
+
419
+ await handler(args);
17
420
  }
18
421
 
19
- module.exports = { main };
422
+ module.exports = {
423
+ main: do_vpush,
424
+ do_vpush,
425
+ do_vpush_nodejs,
426
+ do_vpush_macos,
427
+ do_vpush_ubuntu,
428
+ do_vpush_raspbian,
429
+ do_vpush_amazon_linux,
430
+ do_vpush_cmd,
431
+ do_vpush_powershell,
432
+ do_vpush_gitbash
433
+ };
20
434
 
21
435
  if (require.main === module) {
22
- main(process.argv.slice(2));
436
+ do_vpush(process.argv.slice(2));
23
437
  }