gitx.do 0.0.3 → 0.1.1

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 (231) hide show
  1. package/README.md +319 -92
  2. package/dist/cli/commands/add.d.ts +176 -0
  3. package/dist/cli/commands/add.d.ts.map +1 -0
  4. package/dist/cli/commands/add.js +979 -0
  5. package/dist/cli/commands/add.js.map +1 -0
  6. package/dist/cli/commands/blame.d.ts +1 -1
  7. package/dist/cli/commands/blame.d.ts.map +1 -1
  8. package/dist/cli/commands/blame.js +1 -1
  9. package/dist/cli/commands/blame.js.map +1 -1
  10. package/dist/cli/commands/branch.d.ts +1 -1
  11. package/dist/cli/commands/branch.d.ts.map +1 -1
  12. package/dist/cli/commands/branch.js +2 -2
  13. package/dist/cli/commands/branch.js.map +1 -1
  14. package/dist/cli/commands/checkout.d.ts +73 -0
  15. package/dist/cli/commands/checkout.d.ts.map +1 -0
  16. package/dist/cli/commands/checkout.js +725 -0
  17. package/dist/cli/commands/checkout.js.map +1 -0
  18. package/dist/cli/commands/commit.d.ts.map +1 -1
  19. package/dist/cli/commands/commit.js +22 -2
  20. package/dist/cli/commands/commit.js.map +1 -1
  21. package/dist/cli/commands/diff.d.ts +4 -4
  22. package/dist/cli/commands/diff.d.ts.map +1 -1
  23. package/dist/cli/commands/diff.js +9 -8
  24. package/dist/cli/commands/diff.js.map +1 -1
  25. package/dist/cli/commands/log.d.ts +1 -1
  26. package/dist/cli/commands/log.d.ts.map +1 -1
  27. package/dist/cli/commands/log.js +1 -1
  28. package/dist/cli/commands/log.js.map +1 -1
  29. package/dist/cli/commands/merge.d.ts +106 -0
  30. package/dist/cli/commands/merge.d.ts.map +1 -0
  31. package/dist/cli/commands/merge.js +852 -0
  32. package/dist/cli/commands/merge.js.map +1 -0
  33. package/dist/cli/commands/review.d.ts +1 -1
  34. package/dist/cli/commands/review.d.ts.map +1 -1
  35. package/dist/cli/commands/review.js +26 -1
  36. package/dist/cli/commands/review.js.map +1 -1
  37. package/dist/cli/commands/stash.d.ts +157 -0
  38. package/dist/cli/commands/stash.d.ts.map +1 -0
  39. package/dist/cli/commands/stash.js +655 -0
  40. package/dist/cli/commands/stash.js.map +1 -0
  41. package/dist/cli/commands/status.d.ts.map +1 -1
  42. package/dist/cli/commands/status.js +1 -2
  43. package/dist/cli/commands/status.js.map +1 -1
  44. package/dist/cli/commands/web.d.ts.map +1 -1
  45. package/dist/cli/commands/web.js +3 -2
  46. package/dist/cli/commands/web.js.map +1 -1
  47. package/dist/cli/fs-adapter.d.ts.map +1 -1
  48. package/dist/cli/fs-adapter.js +3 -5
  49. package/dist/cli/fs-adapter.js.map +1 -1
  50. package/dist/cli/fsx-cli-adapter.d.ts +359 -0
  51. package/dist/cli/fsx-cli-adapter.d.ts.map +1 -0
  52. package/dist/cli/fsx-cli-adapter.js +619 -0
  53. package/dist/cli/fsx-cli-adapter.js.map +1 -0
  54. package/dist/cli/index.d.ts.map +1 -1
  55. package/dist/cli/index.js +68 -12
  56. package/dist/cli/index.js.map +1 -1
  57. package/dist/cli/ui/components/DiffView.d.ts +7 -2
  58. package/dist/cli/ui/components/DiffView.d.ts.map +1 -1
  59. package/dist/cli/ui/components/DiffView.js.map +1 -1
  60. package/dist/cli/ui/components/ErrorDisplay.d.ts +6 -2
  61. package/dist/cli/ui/components/ErrorDisplay.d.ts.map +1 -1
  62. package/dist/cli/ui/components/ErrorDisplay.js.map +1 -1
  63. package/dist/cli/ui/components/FuzzySearch.d.ts +8 -2
  64. package/dist/cli/ui/components/FuzzySearch.d.ts.map +1 -1
  65. package/dist/cli/ui/components/FuzzySearch.js.map +1 -1
  66. package/dist/cli/ui/components/LoadingSpinner.d.ts +6 -2
  67. package/dist/cli/ui/components/LoadingSpinner.d.ts.map +1 -1
  68. package/dist/cli/ui/components/LoadingSpinner.js.map +1 -1
  69. package/dist/cli/ui/components/NavigationList.d.ts +7 -2
  70. package/dist/cli/ui/components/NavigationList.d.ts.map +1 -1
  71. package/dist/cli/ui/components/NavigationList.js.map +1 -1
  72. package/dist/cli/ui/components/ScrollableContent.d.ts +7 -2
  73. package/dist/cli/ui/components/ScrollableContent.d.ts.map +1 -1
  74. package/dist/cli/ui/components/ScrollableContent.js.map +1 -1
  75. package/dist/cli/ui/terminal-ui.d.ts +42 -9
  76. package/dist/cli/ui/terminal-ui.d.ts.map +1 -1
  77. package/dist/cli/ui/terminal-ui.js.map +1 -1
  78. package/dist/do/BashModule.d.ts +871 -0
  79. package/dist/do/BashModule.d.ts.map +1 -0
  80. package/dist/do/BashModule.js +1143 -0
  81. package/dist/do/BashModule.js.map +1 -0
  82. package/dist/do/FsModule.d.ts +612 -0
  83. package/dist/do/FsModule.d.ts.map +1 -0
  84. package/dist/do/FsModule.js +1120 -0
  85. package/dist/do/FsModule.js.map +1 -0
  86. package/dist/do/GitModule.d.ts +635 -0
  87. package/dist/do/GitModule.d.ts.map +1 -0
  88. package/dist/do/GitModule.js +784 -0
  89. package/dist/do/GitModule.js.map +1 -0
  90. package/dist/do/GitRepoDO.d.ts +281 -0
  91. package/dist/do/GitRepoDO.d.ts.map +1 -0
  92. package/dist/do/GitRepoDO.js +479 -0
  93. package/dist/do/GitRepoDO.js.map +1 -0
  94. package/dist/do/bash-ast.d.ts +246 -0
  95. package/dist/do/bash-ast.d.ts.map +1 -0
  96. package/dist/do/bash-ast.js +888 -0
  97. package/dist/do/bash-ast.js.map +1 -0
  98. package/dist/do/container-executor.d.ts +491 -0
  99. package/dist/do/container-executor.d.ts.map +1 -0
  100. package/dist/do/container-executor.js +731 -0
  101. package/dist/do/container-executor.js.map +1 -0
  102. package/dist/do/index.d.ts +53 -0
  103. package/dist/do/index.d.ts.map +1 -0
  104. package/dist/do/index.js +91 -0
  105. package/dist/do/index.js.map +1 -0
  106. package/dist/do/tiered-storage.d.ts +403 -0
  107. package/dist/do/tiered-storage.d.ts.map +1 -0
  108. package/dist/do/tiered-storage.js +689 -0
  109. package/dist/do/tiered-storage.js.map +1 -0
  110. package/dist/do/withBash.d.ts +231 -0
  111. package/dist/do/withBash.d.ts.map +1 -0
  112. package/dist/do/withBash.js +244 -0
  113. package/dist/do/withBash.js.map +1 -0
  114. package/dist/do/withFs.d.ts +237 -0
  115. package/dist/do/withFs.d.ts.map +1 -0
  116. package/dist/do/withFs.js +387 -0
  117. package/dist/do/withFs.js.map +1 -0
  118. package/dist/do/withGit.d.ts +180 -0
  119. package/dist/do/withGit.d.ts.map +1 -0
  120. package/dist/do/withGit.js +271 -0
  121. package/dist/do/withGit.js.map +1 -0
  122. package/dist/durable-object/object-store.d.ts +157 -15
  123. package/dist/durable-object/object-store.d.ts.map +1 -1
  124. package/dist/durable-object/object-store.js +435 -47
  125. package/dist/durable-object/object-store.js.map +1 -1
  126. package/dist/durable-object/schema.d.ts +12 -1
  127. package/dist/durable-object/schema.d.ts.map +1 -1
  128. package/dist/durable-object/schema.js +87 -2
  129. package/dist/durable-object/schema.js.map +1 -1
  130. package/dist/index.d.ts +84 -1
  131. package/dist/index.d.ts.map +1 -1
  132. package/dist/index.js +34 -0
  133. package/dist/index.js.map +1 -1
  134. package/dist/mcp/sandbox/miniflare-evaluator.d.ts +22 -0
  135. package/dist/mcp/sandbox/miniflare-evaluator.d.ts.map +1 -0
  136. package/dist/mcp/sandbox/miniflare-evaluator.js +140 -0
  137. package/dist/mcp/sandbox/miniflare-evaluator.js.map +1 -0
  138. package/dist/mcp/sandbox/object-store-proxy.d.ts +32 -0
  139. package/dist/mcp/sandbox/object-store-proxy.d.ts.map +1 -0
  140. package/dist/mcp/sandbox/object-store-proxy.js +30 -0
  141. package/dist/mcp/sandbox/object-store-proxy.js.map +1 -0
  142. package/dist/mcp/sandbox/template.d.ts +17 -0
  143. package/dist/mcp/sandbox/template.d.ts.map +1 -0
  144. package/dist/mcp/sandbox/template.js +71 -0
  145. package/dist/mcp/sandbox/template.js.map +1 -0
  146. package/dist/mcp/sandbox.d.ts.map +1 -1
  147. package/dist/mcp/sandbox.js +16 -4
  148. package/dist/mcp/sandbox.js.map +1 -1
  149. package/dist/mcp/tools/do.d.ts +32 -0
  150. package/dist/mcp/tools/do.d.ts.map +1 -0
  151. package/dist/mcp/tools/do.js +117 -0
  152. package/dist/mcp/tools/do.js.map +1 -0
  153. package/dist/mcp/tools.d.ts.map +1 -1
  154. package/dist/mcp/tools.js +1258 -22
  155. package/dist/mcp/tools.js.map +1 -1
  156. package/dist/pack/delta.d.ts +8 -0
  157. package/dist/pack/delta.d.ts.map +1 -1
  158. package/dist/pack/delta.js +241 -30
  159. package/dist/pack/delta.js.map +1 -1
  160. package/dist/refs/branch.d.ts +38 -25
  161. package/dist/refs/branch.d.ts.map +1 -1
  162. package/dist/refs/branch.js +421 -94
  163. package/dist/refs/branch.js.map +1 -1
  164. package/dist/refs/storage.d.ts +77 -5
  165. package/dist/refs/storage.d.ts.map +1 -1
  166. package/dist/refs/storage.js +193 -43
  167. package/dist/refs/storage.js.map +1 -1
  168. package/dist/refs/tag.d.ts +44 -24
  169. package/dist/refs/tag.d.ts.map +1 -1
  170. package/dist/refs/tag.js +411 -70
  171. package/dist/refs/tag.js.map +1 -1
  172. package/dist/storage/backend.d.ts +425 -0
  173. package/dist/storage/backend.d.ts.map +1 -0
  174. package/dist/storage/backend.js +41 -0
  175. package/dist/storage/backend.js.map +1 -0
  176. package/dist/storage/fsx-adapter.d.ts +204 -0
  177. package/dist/storage/fsx-adapter.d.ts.map +1 -0
  178. package/dist/storage/fsx-adapter.js +518 -0
  179. package/dist/storage/fsx-adapter.js.map +1 -0
  180. package/dist/storage/r2-pack.d.ts.map +1 -1
  181. package/dist/storage/r2-pack.js +4 -1
  182. package/dist/storage/r2-pack.js.map +1 -1
  183. package/dist/tiered/cdc-pipeline.js +3 -3
  184. package/dist/tiered/cdc-pipeline.js.map +1 -1
  185. package/dist/tiered/migration.d.ts.map +1 -1
  186. package/dist/tiered/migration.js +4 -1
  187. package/dist/tiered/migration.js.map +1 -1
  188. package/dist/types/capability.d.ts +1385 -0
  189. package/dist/types/capability.d.ts.map +1 -0
  190. package/dist/types/capability.js +36 -0
  191. package/dist/types/capability.js.map +1 -0
  192. package/dist/types/index.d.ts +13 -0
  193. package/dist/types/index.d.ts.map +1 -0
  194. package/dist/types/index.js +18 -0
  195. package/dist/types/index.js.map +1 -0
  196. package/dist/types/interfaces.d.ts +673 -0
  197. package/dist/types/interfaces.d.ts.map +1 -0
  198. package/dist/types/interfaces.js +26 -0
  199. package/dist/types/interfaces.js.map +1 -0
  200. package/dist/types/objects.d.ts +182 -0
  201. package/dist/types/objects.d.ts.map +1 -1
  202. package/dist/types/objects.js +249 -4
  203. package/dist/types/objects.js.map +1 -1
  204. package/dist/types/storage.d.ts +114 -0
  205. package/dist/types/storage.d.ts.map +1 -1
  206. package/dist/types/storage.js +160 -1
  207. package/dist/types/storage.js.map +1 -1
  208. package/dist/types/worker-loader.d.ts +60 -0
  209. package/dist/types/worker-loader.d.ts.map +1 -0
  210. package/dist/types/worker-loader.js +62 -0
  211. package/dist/types/worker-loader.js.map +1 -0
  212. package/dist/utils/hash.d.ts +126 -80
  213. package/dist/utils/hash.d.ts.map +1 -1
  214. package/dist/utils/hash.js +191 -100
  215. package/dist/utils/hash.js.map +1 -1
  216. package/dist/utils/sha1.d.ts +206 -0
  217. package/dist/utils/sha1.d.ts.map +1 -1
  218. package/dist/utils/sha1.js +405 -0
  219. package/dist/utils/sha1.js.map +1 -1
  220. package/dist/wire/path-security.d.ts +157 -0
  221. package/dist/wire/path-security.d.ts.map +1 -0
  222. package/dist/wire/path-security.js +307 -0
  223. package/dist/wire/path-security.js.map +1 -0
  224. package/dist/wire/receive-pack.d.ts +7 -0
  225. package/dist/wire/receive-pack.d.ts.map +1 -1
  226. package/dist/wire/receive-pack.js +29 -1
  227. package/dist/wire/receive-pack.js.map +1 -1
  228. package/dist/wire/upload-pack.d.ts.map +1 -1
  229. package/dist/wire/upload-pack.js +4 -1
  230. package/dist/wire/upload-pack.js.map +1 -1
  231. package/package.json +10 -1
@@ -5,8 +5,8 @@
5
5
  * identification and verification. Git uses SHA-1 as its primary hash algorithm,
6
6
  * with SHA-256 available as an optional newer algorithm (Git v2.29+).
7
7
  *
8
- * The hash functions work with the Web Crypto API for broad compatibility
9
- * with browsers and edge runtimes like Cloudflare Workers.
8
+ * Core hash primitives are imported from fsx.do which uses the Web Crypto API.
9
+ * Sync primitives are kept local for pack operations that need streaming SHA1.
10
10
  *
11
11
  * @module utils/hash
12
12
  *
@@ -23,63 +23,14 @@
23
23
  * console.log(`blob ${blobSha}`)
24
24
  * ```
25
25
  */
26
- /**
27
- * Compute the SHA-1 hash of data.
28
- *
29
- * @description
30
- * Computes a SHA-1 digest of the input data using the Web Crypto API.
31
- * This is the standard hash algorithm used by Git for object identification.
32
- *
33
- * **Note**: SHA-1 is considered cryptographically weak. Git uses it for
34
- * content addressing, not security. For new security-sensitive applications,
35
- * use SHA-256.
36
- *
37
- * @param data - Input data as Uint8Array or string (UTF-8 encoded)
38
- * @returns 40-character lowercase hexadecimal hash string
39
- *
40
- * @example
41
- * ```typescript
42
- * // Hash a string
43
- * const hash1 = await sha1('Hello, World!')
44
- * console.log(hash1) // '0a0a9f2a6772942557ab5355d76af442f8f65e01'
45
- *
46
- * // Hash binary data
47
- * const data = new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f])
48
- * const hash2 = await sha1(data)
49
- * ```
50
- */
51
- export async function sha1(data) {
52
- const bytes = typeof data === 'string' ? new TextEncoder().encode(data) : data;
53
- const hashBuffer = await crypto.subtle.digest('SHA-1', bytes);
54
- return bytesToHex(new Uint8Array(hashBuffer));
55
- }
56
- /**
57
- * Compute the SHA-256 hash of data.
58
- *
59
- * @description
60
- * Computes a SHA-256 digest of the input data using the Web Crypto API.
61
- * SHA-256 is the newer, more secure hash algorithm supported by Git v2.29+
62
- * as an alternative to SHA-1.
63
- *
64
- * @param data - Input data as Uint8Array or string (UTF-8 encoded)
65
- * @returns 64-character lowercase hexadecimal hash string
66
- *
67
- * @example
68
- * ```typescript
69
- * // Hash a string
70
- * const hash = await sha256('Hello, World!')
71
- * console.log(hash) // 'dffd6021bb2bd5b0af676290809ec3a53191dd81c7f70a4b28688a362182986f'
72
- *
73
- * // Hash binary data
74
- * const data = new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f])
75
- * const hash2 = await sha256(data)
76
- * ```
77
- */
78
- export async function sha256(data) {
79
- const bytes = typeof data === 'string' ? new TextEncoder().encode(data) : data;
80
- const hashBuffer = await crypto.subtle.digest('SHA-256', bytes);
81
- return bytesToHex(new Uint8Array(hashBuffer));
82
- }
26
+ // Re-export hash functions from fsx.do - now works in Workers environment
27
+ export { sha1, sha256, bytesToHex, hexToBytes } from 'fsx.do';
28
+ // Keep local sync implementations for pack operations that need streaming SHA1
29
+ export { sha1Hex } from './sha1';
30
+ // Import local bytesToHex for cache key generation (synchronous)
31
+ import { bytesToHex as localBytesToHex } from './sha1';
32
+ // Import sha1 from fsx.do for the hashObject function
33
+ import { sha1 } from 'fsx.do';
83
34
  /**
84
35
  * Hash a Git object with its type header.
85
36
  *
@@ -114,68 +65,208 @@ export async function hashObject(type, data) {
114
65
  combined.set(data, headerBytes.length);
115
66
  return sha1(combined);
116
67
  }
68
+ // ============================================================================
69
+ // Hash Caching
70
+ // ============================================================================
117
71
  /**
118
- * Convert a hexadecimal string to a Uint8Array.
72
+ * LRU cache for storing computed hashes.
119
73
  *
120
74
  * @description
121
- * Parses a hexadecimal string and returns the corresponding bytes.
122
- * Each pair of hex characters becomes one byte.
75
+ * A Least Recently Used (LRU) cache implementation for caching SHA-1 hashes.
76
+ * This is useful when the same data is hashed multiple times, such as during
77
+ * pack file operations or object store lookups.
78
+ *
79
+ * **Key Strategy**: The cache key is derived from the first few bytes of the
80
+ * data combined with its length, which provides a fast key generation while
81
+ * avoiding collisions for different data.
123
82
  *
124
- * **Edge Cases**:
125
- * - Empty string returns empty Uint8Array
126
- * - Hex string should have even length (odd length may produce unexpected results)
83
+ * **Thread Safety**: This implementation is NOT thread-safe. In multi-threaded
84
+ * environments, external synchronization is required.
127
85
  *
128
- * @param hex - Hexadecimal string (case-insensitive)
129
- * @returns Binary data as Uint8Array
86
+ * @class HashCache
130
87
  *
131
88
  * @example
132
89
  * ```typescript
133
- * const bytes = hexToBytes('48656c6c6f')
134
- * console.log(new TextDecoder().decode(bytes)) // 'Hello'
90
+ * const cache = new HashCache(1000) // Cache up to 1000 hashes
135
91
  *
136
- * // Convert SHA back to bytes (useful for tree entries)
137
- * const sha = 'abc123def456...'
138
- * const sha20 = hexToBytes(sha) // 20 bytes for SHA-1
92
+ * // Use with getOrCompute for automatic caching
93
+ * const hash1 = await cache.getOrCompute(data, async () => sha1(data))
94
+ * const hash2 = await cache.getOrCompute(data, async () => sha1(data)) // Returns cached
95
+ *
96
+ * // Check stats
97
+ * console.log(`Hit rate: ${cache.hitRate}%`)
139
98
  * ```
140
99
  */
141
- export function hexToBytes(hex) {
142
- if (hex.length === 0)
143
- return new Uint8Array(0);
144
- const bytes = new Uint8Array(hex.length / 2);
145
- for (let i = 0; i < hex.length; i += 2) {
146
- bytes[i / 2] = parseInt(hex.slice(i, i + 2), 16);
100
+ export class HashCache {
101
+ cache;
102
+ maxSize;
103
+ hits = 0;
104
+ misses = 0;
105
+ /**
106
+ * Creates a new HashCache with the specified maximum size.
107
+ *
108
+ * @param {number} maxSize - Maximum number of hashes to cache (default: 10000)
109
+ */
110
+ constructor(maxSize = 10000) {
111
+ this.cache = new Map();
112
+ this.maxSize = maxSize;
113
+ }
114
+ /**
115
+ * Generates a cache key for the given data.
116
+ *
117
+ * @description Uses length + first 32 bytes (if available) to create a unique key.
118
+ * This is fast while providing good collision resistance.
119
+ *
120
+ * @param {Uint8Array} data - Data to generate key for
121
+ * @returns {string} Cache key
122
+ * @internal
123
+ */
124
+ generateKey(data) {
125
+ // Use length + first 32 bytes as key (fast and reasonably unique)
126
+ const prefix = data.length <= 32
127
+ ? localBytesToHex(data)
128
+ : localBytesToHex(data.subarray(0, 32));
129
+ return `${data.length}:${prefix}`;
130
+ }
131
+ /**
132
+ * Gets a cached hash if available.
133
+ *
134
+ * @param {Uint8Array} data - Data to look up
135
+ * @returns {string | undefined} Cached hash or undefined if not cached
136
+ */
137
+ get(data) {
138
+ const key = this.generateKey(data);
139
+ const value = this.cache.get(key);
140
+ if (value !== undefined) {
141
+ this.hits++;
142
+ // Move to end (most recently used)
143
+ this.cache.delete(key);
144
+ this.cache.set(key, value);
145
+ return value;
146
+ }
147
+ this.misses++;
148
+ return undefined;
149
+ }
150
+ /**
151
+ * Stores a hash in the cache.
152
+ *
153
+ * @param {Uint8Array} data - Original data
154
+ * @param {string} hash - Computed hash to cache
155
+ */
156
+ set(data, hash) {
157
+ const key = this.generateKey(data);
158
+ // Remove oldest entry if at capacity
159
+ if (this.cache.size >= this.maxSize && !this.cache.has(key)) {
160
+ const firstKey = this.cache.keys().next().value;
161
+ if (firstKey !== undefined) {
162
+ this.cache.delete(firstKey);
163
+ }
164
+ }
165
+ this.cache.set(key, hash);
166
+ }
167
+ /**
168
+ * Gets a hash from cache or computes and caches it.
169
+ *
170
+ * @description This is the recommended way to use the cache. It automatically
171
+ * handles cache lookup, computation, and storage.
172
+ *
173
+ * @param {Uint8Array} data - Data to hash
174
+ * @param {() => Promise<string> | string} compute - Function to compute hash if not cached
175
+ * @returns {Promise<string>} The hash (from cache or newly computed)
176
+ *
177
+ * @example
178
+ * ```typescript
179
+ * const hash = await cache.getOrCompute(data, () => sha1(data))
180
+ * ```
181
+ */
182
+ async getOrCompute(data, compute) {
183
+ const cached = this.get(data);
184
+ if (cached !== undefined) {
185
+ return cached;
186
+ }
187
+ const hash = await compute();
188
+ this.set(data, hash);
189
+ return hash;
190
+ }
191
+ /**
192
+ * Synchronous version of getOrCompute for use with synchronous hash functions.
193
+ *
194
+ * @param {Uint8Array} data - Data to hash
195
+ * @param {() => string} compute - Function to compute hash if not cached
196
+ * @returns {string} The hash (from cache or newly computed)
197
+ *
198
+ * @example
199
+ * ```typescript
200
+ * import { sha1Hex } from './sha1'
201
+ * const hash = cache.getOrComputeSync(data, () => sha1Hex(data))
202
+ * ```
203
+ */
204
+ getOrComputeSync(data, compute) {
205
+ const cached = this.get(data);
206
+ if (cached !== undefined) {
207
+ return cached;
208
+ }
209
+ const hash = compute();
210
+ this.set(data, hash);
211
+ return hash;
212
+ }
213
+ /**
214
+ * Clears all entries from the cache.
215
+ */
216
+ clear() {
217
+ this.cache.clear();
218
+ this.hits = 0;
219
+ this.misses = 0;
220
+ }
221
+ /**
222
+ * Gets the current number of cached entries.
223
+ */
224
+ get size() {
225
+ return this.cache.size;
226
+ }
227
+ /**
228
+ * Gets the cache hit rate as a percentage.
229
+ */
230
+ get hitRate() {
231
+ const total = this.hits + this.misses;
232
+ return total === 0 ? 0 : (this.hits / total) * 100;
233
+ }
234
+ /**
235
+ * Gets cache statistics.
236
+ *
237
+ * @returns {{ hits: number; misses: number; size: number; hitRate: number }}
238
+ */
239
+ getStats() {
240
+ return {
241
+ hits: this.hits,
242
+ misses: this.misses,
243
+ size: this.cache.size,
244
+ hitRate: this.hitRate
245
+ };
147
246
  }
148
- return bytes;
149
247
  }
150
248
  /**
151
- * Convert a Uint8Array to a hexadecimal string.
249
+ * Global hash cache instance for common use cases.
152
250
  *
153
251
  * @description
154
- * Converts binary data to a lowercase hexadecimal string representation.
155
- * Each byte becomes two hex characters (zero-padded).
156
- *
157
- * **Edge Cases**:
158
- * - Empty Uint8Array returns empty string
252
+ * A shared cache instance that can be used across the application for
253
+ * caching object hashes. This is particularly useful for pack file
254
+ * operations where the same objects are hashed multiple times.
159
255
  *
160
- * @param bytes - Binary data to convert
161
- * @returns Lowercase hexadecimal string
256
+ * **Memory Management**: The cache has a default limit of 10,000 entries.
257
+ * For applications with different requirements, create a custom HashCache
258
+ * instance with appropriate size.
162
259
  *
163
260
  * @example
164
261
  * ```typescript
165
- * const hello = new TextEncoder().encode('Hello')
166
- * const hex = bytesToHex(hello)
167
- * console.log(hex) // '48656c6c6f'
262
+ * import { globalHashCache, sha1 } from './utils/hash'
168
263
  *
169
- * // Convert SHA-1 bytes to string
170
- * const hashBytes = new Uint8Array(20) // ... from crypto
171
- * const sha = bytesToHex(hashBytes) // 40-char hex string
264
+ * // Use the global cache
265
+ * const hash = await globalHashCache.getOrCompute(data, () => sha1(data))
266
+ *
267
+ * // Check cache stats
268
+ * console.log(globalHashCache.getStats())
172
269
  * ```
173
270
  */
174
- export function bytesToHex(bytes) {
175
- if (bytes.length === 0)
176
- return '';
177
- return Array.from(bytes)
178
- .map(b => b.toString(16).padStart(2, '0'))
179
- .join('');
180
- }
271
+ export const globalHashCache = new HashCache();
181
272
  //# sourceMappingURL=hash.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"hash.js","sourceRoot":"","sources":["../../src/utils/hash.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAEH;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,CAAC,KAAK,UAAU,IAAI,CAAC,IAAyB;IAClD,MAAM,KAAK,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IAC9E,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAA;IAC7D,OAAO,UAAU,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAA;AAC/C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,IAAyB;IACpD,MAAM,KAAK,GAAG,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IAC9E,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;IAC/D,OAAO,UAAU,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAA;AAC/C,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,IAAY,EAAE,IAAgB;IAC7D,MAAM,MAAM,GAAG,GAAG,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,CAAA;IACzC,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACpD,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAA;IACjE,QAAQ,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC,CAAA;IAC5B,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,WAAW,CAAC,MAAM,CAAC,CAAA;IACtC,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAA;AACvB,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,UAAU,UAAU,CAAC,GAAW;IACpC,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,CAAA;IAC9C,MAAM,KAAK,GAAG,IAAI,UAAU,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IAC5C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;QACvC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;IAClD,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,UAAU,UAAU,CAAC,KAAiB;IAC1C,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAA;IACjC,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC;SACrB,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;SACzC,IAAI,CAAC,EAAE,CAAC,CAAA;AACb,CAAC"}
1
+ {"version":3,"file":"hash.js","sourceRoot":"","sources":["../../src/utils/hash.ts"],"names":[],"mappings":"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"}
@@ -116,4 +116,210 @@ export declare function sha1Hex(data: Uint8Array): string;
116
116
  * ```
117
117
  */
118
118
  export declare function sha1Verify(data: Uint8Array, expected: Uint8Array): boolean;
119
+ /**
120
+ * Convert bytes to hexadecimal string.
121
+ *
122
+ * @description Efficiently converts a Uint8Array to its hexadecimal
123
+ * representation. Each byte becomes two hex characters (00-ff).
124
+ *
125
+ * @param bytes - Input bytes to convert
126
+ * @returns Lowercase hexadecimal string (2 chars per byte)
127
+ *
128
+ * @example
129
+ * ```typescript
130
+ * const bytes = new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f])
131
+ * const hex = bytesToHex(bytes)
132
+ * console.log(hex) // '48656c6c6f'
133
+ * ```
134
+ */
135
+ export declare function bytesToHex(bytes: Uint8Array): string;
136
+ /**
137
+ * Convert hexadecimal string to bytes.
138
+ *
139
+ * @description Converts a hexadecimal string back to its binary representation.
140
+ * Each pair of hex characters becomes one byte.
141
+ *
142
+ * @param hex - Hexadecimal string (case-insensitive)
143
+ * @returns Uint8Array of bytes
144
+ * @throws {Error} If hex string has odd length
145
+ *
146
+ * @example
147
+ * ```typescript
148
+ * const hex = '48656c6c6f'
149
+ * const bytes = hexToBytes(hex)
150
+ * console.log(new TextDecoder().decode(bytes)) // 'Hello'
151
+ * ```
152
+ */
153
+ export declare function hexToBytes(hex: string): Uint8Array;
154
+ /**
155
+ * Streaming SHA-1 hasher for processing large data incrementally.
156
+ *
157
+ * @description
158
+ * This class allows hashing data in chunks, which is essential for:
159
+ * - Processing large files without loading everything into memory
160
+ * - Computing hashes of data streams
161
+ * - Pack file generation and verification
162
+ *
163
+ * The hasher maintains internal state and can accept data through the
164
+ * `update()` method before finalizing with `digest()` or `digestHex()`.
165
+ *
166
+ * **Performance Note**: For small data (< 64 bytes), the non-streaming
167
+ * `sha1()` function may be slightly faster due to lower overhead.
168
+ *
169
+ * @class StreamingSHA1
170
+ *
171
+ * @example
172
+ * ```typescript
173
+ * // Hash a large file in chunks
174
+ * const hasher = new StreamingSHA1()
175
+ *
176
+ * for await (const chunk of fileStream) {
177
+ * hasher.update(chunk)
178
+ * }
179
+ *
180
+ * const hash = hasher.digestHex()
181
+ * console.log(`File hash: ${hash}`)
182
+ * ```
183
+ *
184
+ * @example
185
+ * ```typescript
186
+ * // Hash Git object with header
187
+ * const hasher = new StreamingSHA1()
188
+ * hasher.update(new TextEncoder().encode(`blob ${size}\0`))
189
+ * hasher.update(content)
190
+ * const objectId = hasher.digestHex()
191
+ * ```
192
+ */
193
+ export declare class StreamingSHA1 {
194
+ /** Hash state */
195
+ private h;
196
+ /** Working array for chunk processing */
197
+ private w;
198
+ /** Buffer for incomplete chunks */
199
+ private buffer;
200
+ /** Current position in buffer */
201
+ private bufferLength;
202
+ /** Total bytes processed */
203
+ private totalLength;
204
+ /** Whether digest has been called */
205
+ private finalized;
206
+ /**
207
+ * Creates a new StreamingSHA1 hasher instance.
208
+ */
209
+ constructor();
210
+ /**
211
+ * Resets the hasher to its initial state.
212
+ *
213
+ * @description Allows reusing the same hasher instance for a new hash
214
+ * computation without creating a new object.
215
+ *
216
+ * @example
217
+ * ```typescript
218
+ * const hasher = new StreamingSHA1()
219
+ * hasher.update(data1)
220
+ * const hash1 = hasher.digestHex()
221
+ *
222
+ * hasher.reset()
223
+ * hasher.update(data2)
224
+ * const hash2 = hasher.digestHex()
225
+ * ```
226
+ */
227
+ reset(): void;
228
+ /**
229
+ * Updates the hash with additional data.
230
+ *
231
+ * @description Processes the input data, updating the internal hash state.
232
+ * Data is buffered internally until a complete 64-byte chunk is available,
233
+ * then processed immediately.
234
+ *
235
+ * This method can be called multiple times before finalizing with `digest()`.
236
+ *
237
+ * @param {Uint8Array} data - Data to add to the hash computation
238
+ * @returns {this} The hasher instance for method chaining
239
+ * @throws {Error} If called after digest() without reset()
240
+ *
241
+ * @example
242
+ * ```typescript
243
+ * const hasher = new StreamingSHA1()
244
+ * .update(header)
245
+ * .update(content)
246
+ * .update(footer)
247
+ * const hash = hasher.digestHex()
248
+ * ```
249
+ */
250
+ update(data: Uint8Array): this;
251
+ /**
252
+ * Finalizes the hash computation and returns the 20-byte digest.
253
+ *
254
+ * @description Applies SHA-1 padding to the remaining data and computes
255
+ * the final hash. After calling this method, the hasher cannot be updated
256
+ * unless `reset()` is called.
257
+ *
258
+ * @returns {Uint8Array} 20-byte SHA-1 hash
259
+ *
260
+ * @example
261
+ * ```typescript
262
+ * const hasher = new StreamingSHA1()
263
+ * hasher.update(data)
264
+ * const hashBytes = hasher.digest()
265
+ * console.log(hashBytes.length) // 20
266
+ * ```
267
+ */
268
+ digest(): Uint8Array;
269
+ /**
270
+ * Finalizes the hash computation and returns the hex string digest.
271
+ *
272
+ * @description Convenience method that calls `digest()` and converts
273
+ * the result to a 40-character lowercase hexadecimal string.
274
+ *
275
+ * @returns {string} 40-character lowercase hexadecimal hash string
276
+ *
277
+ * @example
278
+ * ```typescript
279
+ * const hasher = new StreamingSHA1()
280
+ * hasher.update(data)
281
+ * const hash = hasher.digestHex()
282
+ * console.log(hash) // 'aaf4c61ddcc5e8a2dabede0f3b482cd9aea9434d'
283
+ * ```
284
+ */
285
+ digestHex(): string;
286
+ }
287
+ /**
288
+ * Hash a Git object with streaming support for large objects.
289
+ *
290
+ * @description
291
+ * Uses the streaming hasher to compute the SHA-1 of a Git object with its header.
292
+ * This is more memory-efficient than `hashObject` in `hash.ts` for large objects
293
+ * as it doesn't require concatenating header and data.
294
+ *
295
+ * @param type - Object type ('blob', 'tree', 'commit', 'tag')
296
+ * @param data - Object content as binary data
297
+ * @returns 20-byte SHA-1 hash as Uint8Array
298
+ *
299
+ * @example
300
+ * ```typescript
301
+ * const content = new TextEncoder().encode('hello')
302
+ * const hashBytes = hashObjectStreaming('blob', content)
303
+ * ```
304
+ */
305
+ export declare function hashObjectStreaming(type: string, data: Uint8Array): Uint8Array;
306
+ /**
307
+ * Hash a Git object with streaming support, returning hex string.
308
+ *
309
+ * @description
310
+ * Convenience wrapper that returns the hash as a 40-character hex string
311
+ * instead of raw bytes.
312
+ *
313
+ * @param type - Object type ('blob', 'tree', 'commit', 'tag')
314
+ * @param data - Object content as binary data
315
+ * @returns 40-character lowercase hexadecimal SHA-1 hash
316
+ *
317
+ * @example
318
+ * ```typescript
319
+ * const content = new TextEncoder().encode('hello')
320
+ * const sha = hashObjectStreamingHex('blob', content)
321
+ * console.log(sha) // 'b6fc4c620b67d95f953a5c1c1230aaab5db5a1b0'
322
+ * ```
323
+ */
324
+ export declare function hashObjectStreamingHex(type: string, data: Uint8Array): string;
119
325
  //# sourceMappingURL=sha1.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"sha1.d.ts","sourceRoot":"","sources":["../../src/utils/sha1.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAEH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,wBAAgB,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,CAwGjD;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAOhD;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,GAAG,OAAO,CAgB1E"}
1
+ {"version":3,"file":"sha1.d.ts","sourceRoot":"","sources":["../../src/utils/sha1.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAEH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,wBAAgB,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,CAwGjD;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAOhD;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,GAAG,OAAO,CAgB1E;AAMD;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM,CAMpD;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,CASlD;AA4FD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCG;AACH,qBAAa,aAAa;IACxB,iBAAiB;IACjB,OAAO,CAAC,CAAC,CAAa;IACtB,yCAAyC;IACzC,OAAO,CAAC,CAAC,CAAa;IACtB,mCAAmC;IACnC,OAAO,CAAC,MAAM,CAAY;IAC1B,iCAAiC;IACjC,OAAO,CAAC,YAAY,CAAQ;IAC5B,4BAA4B;IAC5B,OAAO,CAAC,WAAW,CAAQ;IAC3B,qCAAqC;IACrC,OAAO,CAAC,SAAS,CAAS;IAE1B;;OAEG;;IAUH;;;;;;;;;;;;;;;;OAgBG;IACH,KAAK,IAAI,IAAI;IAWb;;;;;;;;;;;;;;;;;;;;;OAqBG;IACH,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;IAsC9B;;;;;;;;;;;;;;;;OAgBG;IACH,MAAM,IAAI,UAAU;IAmDpB;;;;;;;;;;;;;;;OAeG;IACH,SAAS,IAAI,MAAM;CAQpB;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,UAAU,CAM9E;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,MAAM,CAM7E"}