just-git 1.1.3 → 1.1.4

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.
package/README.md CHANGED
@@ -50,7 +50,7 @@ await bash.exec("git add . && git commit -m 'initial commit'");
50
50
 
51
51
  ### Server
52
52
 
53
- Stand up a git server with SQLite-backed storage, branch protection, and push hooks:
53
+ Stand up a git server with built-in storage (SQLite or [PostgreSQL](SERVER.md#pgstorage)), branch protection, and push hooks:
54
54
 
55
55
  ```ts
56
56
  import { createGitServer, SqliteStorage } from "just-git/server";
@@ -248,6 +248,40 @@ interface StandardHooksConfig {
248
248
  */
249
249
  declare function createStandardHooks(config: StandardHooksConfig): ServerHooks;
250
250
 
251
+ /**
252
+ * Abstract storage backend for multi-repo git object and ref storage.
253
+ *
254
+ * Implemented by `SqliteStorage` and `PgStorage`.
255
+ */
256
+ interface Storage {
257
+ /** Get a `GitRepo` scoped to a specific repo. */
258
+ repo(repoId: string): GitRepo;
259
+ /** Delete all objects and refs for a repo. */
260
+ deleteRepo(repoId: string): Promise<void>;
261
+ }
262
+
263
+ /**
264
+ * In-memory git storage with multi-repo support.
265
+ *
266
+ * Useful for tests, ephemeral servers, and benchmarking.
267
+ * Data is lost when the process exits.
268
+ *
269
+ * ```ts
270
+ * const storage = new MemoryStorage();
271
+ * const server = createGitServer({
272
+ * resolveRepo: async (repoPath) => storage.repo(repoPath),
273
+ * });
274
+ * ```
275
+ */
276
+ declare class MemoryStorage implements Storage {
277
+ private objects;
278
+ private refs;
279
+ repo(repoId: string): GitRepo;
280
+ deleteRepo(repoId: string): Promise<void>;
281
+ private getObjects;
282
+ private getRefs;
283
+ }
284
+
251
285
  interface SqliteStatement {
252
286
  run(...params: any[]): void;
253
287
  get(...params: any[]): any;
@@ -272,7 +306,7 @@ interface SqliteDatabase {
272
306
  * });
273
307
  * ```
274
308
  */
275
- declare class SqliteStorage {
309
+ declare class SqliteStorage implements Storage {
276
310
  private db;
277
311
  private stmts;
278
312
  private ingestTx;
@@ -280,7 +314,64 @@ declare class SqliteStorage {
280
314
  /** Get a `GitRepo` scoped to a specific repo. */
281
315
  repo(repoId: string): GitRepo;
282
316
  /** Delete all objects and refs for a repo. */
283
- deleteRepo(repoId: string): void;
317
+ deleteRepo(repoId: string): Promise<void>;
318
+ }
319
+
320
+ interface PgDatabase {
321
+ query<T = any>(text: string, values?: any[]): Promise<{
322
+ rows: T[];
323
+ }>;
324
+ transaction<R>(fn: (tx: PgDatabase) => Promise<R>): Promise<R>;
325
+ }
326
+ interface PgPool {
327
+ query(text: string, values?: any[]): Promise<{
328
+ rows: any[];
329
+ }>;
330
+ connect(): Promise<PgPoolClient>;
331
+ }
332
+ interface PgPoolClient {
333
+ query(text: string, values?: any[]): Promise<{
334
+ rows: any[];
335
+ }>;
336
+ release(): void;
337
+ }
338
+ /**
339
+ * Wrap a `pg`-style pool into a `PgDatabase`.
340
+ *
341
+ * Handles `BEGIN`/`COMMIT`/`ROLLBACK` and client release automatically.
342
+ *
343
+ * ```ts
344
+ * import { Pool } from "pg";
345
+ * const pool = new Pool({ connectionString: "..." });
346
+ * const db = wrapPgPool(pool);
347
+ * ```
348
+ */
349
+ declare function wrapPgPool(pool: PgPool): PgDatabase;
350
+ /**
351
+ * PostgreSQL-backed git storage with multi-repo support.
352
+ *
353
+ * Creates and manages `git_objects` and `git_refs` tables in the
354
+ * provided database. Multiple repos are partitioned by `repo_id`.
355
+ *
356
+ * Use the static `create` factory (schema setup is async):
357
+ *
358
+ * ```ts
359
+ * import { Pool } from "pg";
360
+ * const pool = new Pool({ connectionString: "..." });
361
+ * const storage = await PgStorage.create(wrapPgPool(pool));
362
+ * const server = createGitServer({
363
+ * resolveRepo: async (repoPath) => storage.repo(repoPath),
364
+ * });
365
+ * ```
366
+ */
367
+ declare class PgStorage implements Storage {
368
+ private db;
369
+ private constructor();
370
+ static create(db: PgDatabase): Promise<PgStorage>;
371
+ /** Get a `GitRepo` scoped to a specific repo. */
372
+ repo(repoId: string): GitRepo;
373
+ /** Delete all objects and refs for a repo. */
374
+ deleteRepo(repoId: string): Promise<void>;
284
375
  }
285
376
 
286
- export { type AdvertiseRefsEvent, type GitServer, type GitServerConfig, PackCache, type PostReceiveEvent, type PreReceiveEvent, type ReceivePackResult, type RefAdvertisement, type RefUpdate, type RefsData, Rejection, type ServerHooks, type SqliteDatabase, type SqliteStatement, SqliteStorage, type StandardHooksConfig, type UpdateEvent, type UploadPackOptions, buildRefAdvertisementBytes, collectRefs, composeHooks, createGitServer, createStandardHooks, handleUploadPack, ingestReceivePack };
377
+ export { type AdvertiseRefsEvent, type GitServer, type GitServerConfig, MemoryStorage, PackCache, type PgDatabase, type PgPool, type PgPoolClient, PgStorage, type PostReceiveEvent, type PreReceiveEvent, type ReceivePackResult, type RefAdvertisement, type RefUpdate, type RefsData, Rejection, type ServerHooks, type SqliteDatabase, type SqliteStatement, SqliteStorage, type StandardHooksConfig, type Storage, type UpdateEvent, type UploadPackOptions, buildRefAdvertisementBytes, collectRefs, composeHooks, createGitServer, createStandardHooks, handleUploadPack, ingestReceivePack, wrapPgPool };
@@ -1,28 +1,28 @@
1
- var B=(n=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(n,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):n)(function(n){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+n+'" is not supported')});function S(n){return n!=null&&typeof n=="object"&&"reject"in n&&n.reject===!0}var K="0000000000000000000000000000000000000000",pe=(()=>{let n=new Array(256);for(let e=0;e<256;e++)n[e]=(e>>4).toString(16)+(e&15).toString(16);return n})();function N(n){let e="";for(let t=0;t<20;t++)e+=pe[n[t]];return e}function ue(n,e){let t="";for(let o=0;o<20;o++)t+=pe[n[e+o]];return t}function W(n){let e=new Uint8Array(20);for(let t=0;t<20;t++)e[t]=parseInt(n.slice(t*2,t*2+2),16);return e}var Ve=new TextEncoder;function Y(n){return typeof n=="string"?Ve.encode(n):n}function Xe(){if(typeof globalThis.Bun<"u")return()=>{let n=new Bun.CryptoHasher("sha1"),e={update(t){return n.update(Y(t)),e},hex:()=>Promise.resolve(n.digest("hex"))};return e};try{let n=B(["node","crypto"].join(":"));if(typeof n.createHash=="function")return()=>{let e=n.createHash("sha1"),t={update(o){return e.update(Y(o)),t},hex:()=>Promise.resolve(e.digest("hex"))};return t}}catch{}if(typeof globalThis.crypto?.subtle?.digest=="function")return()=>{let n=[],e={update(t){return n.push(Y(t)),e},async hex(){let t=0;for(let i of n)t+=i.byteLength;let o=new Uint8Array(t),r=0;for(let i of n)o.set(i,r),r+=i.byteLength;let a=await crypto.subtle.digest("SHA-1",o);return N(new Uint8Array(a))}};return e};throw new Error("No SHA-1 implementation available. Requires Bun, Node.js, Deno, or a browser with Web Crypto.")}var he=Xe(),$=he;async function be(n){return he().update(n).hex()}var Ze=new Set(["tree","commit","tag"]),_=class{map=new Map;currentBytes=0;maxBytes;constructor(e=16*1024*1024){this.maxBytes=e}get(e){return this.map.get(e)}set(e,t){if(!Ze.has(t.type))return;let o=t.content.byteLength;if(!(o>this.maxBytes/2)&&!this.map.has(e)){for(;this.currentBytes+o>this.maxBytes&&this.map.size>0;){let r=this.map.keys().next().value;this.currentBytes-=this.map.get(r).content.byteLength,this.map.delete(r)}this.map.set(e,t),this.currentBytes+=o}}get size(){return this.map.size}get bytes(){return this.currentBytes}clear(){this.map.clear(),this.currentBytes=0}};async function Je(){let n;try{n=B(["node","zlib"].join(":"))}catch{try{n=await import(["node","zlib"].join(":"))}catch{}}if(n&&typeof n.deflateSync=="function"&&typeof n.inflateSync=="function"){let e;try{let t=n.inflateSync(n.deflateSync(Buffer.from("x")),{info:!0});t?.engine&&typeof t.engine.bytesWritten=="number"&&(e=o=>{let r=n.inflateSync(o,{info:!0});return{result:new Uint8Array(r.buffer),bytesConsumed:r.engine.bytesWritten}})}catch{}return{deflateSync:t=>new Uint8Array(n.deflateSync(t)),inflateSync:t=>new Uint8Array(n.inflateSync(t)),inflateWithConsumed:e}}if(typeof globalThis.CompressionStream=="function"&&typeof globalThis.DecompressionStream=="function")return{async deflateSync(e){let t=new CompressionStream("deflate"),o=t.writable.getWriter();return o.write(e),o.close(),new Uint8Array(await new Response(t.readable).arrayBuffer())},async inflateSync(e){let t=new DecompressionStream("deflate"),o=t.writable.getWriter();return o.write(e),o.close(),new Uint8Array(await new Response(t.readable).arrayBuffer())}};throw new Error("No zlib implementation available. Requires Bun, Node.js, Deno, or a browser with CompressionStream.")}var Qe=null;function ye(){return Qe??=Je()}async function G(n){return await(await ye()).deflateSync(n)}async function xe(n,e){let t=await ye();if(t.inflateWithConsumed){let{result:i,bytesConsumed:s}=t.inflateWithConsumed(n);if(i.byteLength!==e)throw new Error(`Inflate size mismatch: got ${i.byteLength}, expected ${e}`);return{result:i,bytesConsumed:s}}let o=await t.inflateSync(n);if(o.byteLength!==e)throw new Error(`Inflate size mismatch: got ${o.byteLength}, expected ${e}`);let r=2,a=n.byteLength;for(;r<a;){let i=r+a>>>1;try{(await t.inflateSync(n.subarray(0,i))).byteLength===e?a=i:r=i+1}catch{r=i+1}}return{result:o,bytesConsumed:r}}var M=1346454347,Z=2,we=1,Re=2,ke=3,Pe=4,U=6,J=7,et={[we]:"commit",[Re]:"tree",[ke]:"blob",[Pe]:"tag"},Oe={commit:we,tree:Re,blob:ke,tag:Pe};async function je(n,e){let t=new DataView(n.buffer,n.byteOffset,n.byteLength),o=t.getUint32(0);if(o!==M)throw new Error(`Invalid pack signature: 0x${o.toString(16)} (expected 0x${M.toString(16)})`);let r=t.getUint32(4);if(r!==Z)throw new Error(`Unsupported pack version: ${r}`);let a=t.getUint32(8),i=[],s=12;for(let c=0;c<a;c++){let d=await tt(n,s);i.push(d),s=d.nextOffset}return(await nt(i,e)).map((c,d)=>({...c,offset:i[d].headerOffset,nextOffset:i[d].nextOffset}))}async function tt(n,e){let t=e,o=n[e++],r=o>>4&7,a=o&15,i=4;for(;o&128;)o=n[e++],a|=(o&127)<<i,i+=7;let s,f;if(r===U){let u=n[e++];for(s=u&127;u&128;)s+=1,u=n[e++],s=(s<<7)+(u&127);s=t-s}else r===J&&(f=ue(n,e),e+=20);let{result:c,bytesConsumed:d}=await xe(n.subarray(e),a);return{headerOffset:t,typeNum:r,inflated:c,baseOffset:s,baseHash:f,nextOffset:e+d}}async function nt(n,e){let t=new Map;for(let a=0;a<n.length;a++)t.set(n[a].headerOffset,a);let o=new Array(n.length).fill(null);async function r(a){let i=o[a];if(i)return i;let s=n[a];if(s.typeNum!==U&&s.typeNum!==J){let l=et[s.typeNum];if(!l)throw new Error(`Unknown object type: ${s.typeNum}`);let h={type:l,content:s.inflated,hash:await V(l,s.inflated)};return o[a]=h,h}if(s.typeNum===U){let l=t.get(s.baseOffset);if(l===void 0)throw new Error(`OFS_DELTA base not found at offset ${s.baseOffset}`);let h=await r(l),b=me(h.content,s.inflated),p={type:h.type,content:b,hash:await V(h.type,b)};return o[a]=p,p}let f=await rt(n,o,s.baseHash,r),c;if(f!==void 0)c=await r(f);else if(e){let l=await e(s.baseHash);l&&(c=l)}if(!c)throw new Error(`REF_DELTA base not found for hash ${s.baseHash}`);let d=me(c.content,s.inflated),u={type:c.type,content:d,hash:await V(c.type,d)};return o[a]=u,u}for(let a=0;a<n.length;a++)await r(a);return o}async function rt(n,e,t,o){for(let r=0;r<e.length;r++)if(e[r]?.hash===t)return r;for(let r=0;r<n.length;r++){let a=n[r];if(a.typeNum!==U&&a.typeNum!==J&&(await o(r)).hash===t)return r}}function me(n,e){let t=0,{value:o,newPos:r}=ge(e,t);if(t=r,o!==n.byteLength)throw new Error(`Delta base size mismatch: expected ${o}, got ${n.byteLength}`);let{value:a,newPos:i}=ge(e,t);t=i;let s=new Uint8Array(a),f=0;for(;t<e.byteLength;){let c=e[t++];if(c&128){let d=0,u=0;c&1&&(d=e[t++]),c&2&&(d|=e[t++]<<8),c&4&&(d|=e[t++]<<16),c&8&&(d|=e[t++]<<24),c&16&&(u=e[t++]),c&32&&(u|=e[t++]<<8),c&64&&(u|=e[t++]<<16),u===0&&(u=65536),s.set(n.subarray(d,d+u),f),f+=u}else if(c>0)s.set(e.subarray(t,t+c),f),f+=c,t+=c;else throw new Error("Unexpected delta opcode 0x00 (reserved)")}if(f!==a)throw new Error(`Delta produced ${f} bytes, expected ${a}`);return s}async function ve(n){let e=[],t=new Map,o=new Uint8Array(12),r=new DataView(o.buffer);r.setUint32(0,M),r.setUint32(4,Z),r.setUint32(8,n.length),e.push(o);let a=12,i=[];for(let s of n){let f=a;t.set(s.hash,a);let c=s.delta&&s.deltaBaseHash?t.get(s.deltaBaseHash):void 0;if(s.delta&&c!==void 0){let d=X(U,s.delta.byteLength),u=st(a-c),l=await G(s.delta);e.push(d,u,l),a+=d.byteLength+u.byteLength+l.byteLength}else{let d=Oe[s.type],u=X(d,s.content.byteLength),l=await G(s.content);e.push(u,l),a+=u.byteLength+l.byteLength}i.push({hash:s.hash,offset:f,nextOffset:a})}return{data:await ot(e),entries:i}}async function*Ie(n,e){let t=$(),o=new Uint8Array(12),r=new DataView(o.buffer);r.setUint32(0,M),r.setUint32(4,Z),r.setUint32(8,n),t.update(o),yield o;for await(let a of e){let i=Oe[a.type],s=X(i,a.content.byteLength),f=await G(a.content);t.update(s),t.update(f),yield at(s,f)}yield W(await t.hex())}async function ot(n){let e=0;for(let i of n)e+=i.byteLength;e+=20;let t=new Uint8Array(e),o=0;for(let i of n)t.set(i,o),o+=i.byteLength;let r=$();r.update(t.subarray(0,o));let a=await r.hex();return t.set(W(a),o),t}function st(n){let e=[];e.push(n&127);let t=n>>>7;for(;t>0;)e.unshift(128|--t&127),t>>>=7;return new Uint8Array(e)}function X(n,e){let t=[],o=n<<4|e&15;for(e>>=4;e>0;)t.push(o|128),o=e&127,e>>=7;return t.push(o),new Uint8Array(t)}function ge(n,e){let t=0,o=0,r;do r=n[e++],t|=(r&127)<<o,o+=7;while(r&128);return{value:t,newPos:e}}function at(n,e){let t=new Uint8Array(n.byteLength+e.byteLength);return t.set(n,0),t.set(e,n.byteLength),t}var it=new TextEncoder;async function V(n,e){let t=it.encode(`${n} ${e.byteLength}\0`),o=$();return o.update(t),o.update(e),o.hex()}var ct=new TextEncoder,Ft=new TextDecoder;function Ae(n,e){let t=ct.encode(`${n} ${e.byteLength}\0`),o=new Uint8Array(t.byteLength+e.byteLength);return o.set(t),o.set(e,t.byteLength),o}function T(n){let e=n.indexOf("<"),t=n.indexOf(">");if(e===-1||t===-1)throw new Error(`Malformed identity line: "${n}"`);let o=n.slice(0,e).trimEnd(),r=n.slice(e+1,t),a=n.slice(t+2),[i="0",s="+0000"]=a.split(" "),f=parseInt(i,10);return{name:o,email:r,timestamp:f,timezone:s}}var Yt=new TextEncoder,dt=new TextDecoder;function C(n){let e=dt.decode(n),t=e.indexOf(`
1
+ var M=(r=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(r,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):r)(function(r){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+r+'" is not supported')});function H(r){return r!=null&&typeof r=="object"&&"reject"in r&&r.reject===!0}var Z="0000000000000000000000000000000000000000",Oe=(()=>{let r=new Array(256);for(let e=0;e<256;e++)r[e]=(e>>4).toString(16)+(e&15).toString(16);return r})();function G(r){let e="";for(let t=0;t<20;t++)e+=Oe[r[t]];return e}function je(r,e){let t="";for(let s=0;s<20;s++)t+=Oe[r[e+s]];return t}function F(r){let e=new Uint8Array(20);for(let t=0;t<20;t++)e[t]=parseInt(r.slice(t*2,t*2+2),16);return e}var nt=new TextEncoder;function J(r){return typeof r=="string"?nt.encode(r):r}function st(){if(typeof globalThis.Bun<"u")return()=>{let r=new Bun.CryptoHasher("sha1"),e={update(t){return r.update(J(t)),e},hex:()=>Promise.resolve(r.digest("hex"))};return e};try{let r=M(["node","crypto"].join(":"));if(typeof r.createHash=="function")return()=>{let e=r.createHash("sha1"),t={update(s){return e.update(J(s)),t},hex:()=>Promise.resolve(e.digest("hex"))};return t}}catch{}if(typeof globalThis.crypto?.subtle?.digest=="function")return()=>{let r=[],e={update(t){return r.push(J(t)),e},async hex(){let t=0;for(let i of r)t+=i.byteLength;let s=new Uint8Array(t),n=0;for(let i of r)s.set(i,n),n+=i.byteLength;let a=await crypto.subtle.digest("SHA-1",s);return G(new Uint8Array(a))}};return e};throw new Error("No SHA-1 implementation available. Requires Bun, Node.js, Deno, or a browser with Web Crypto.")}var ke=st(),q=ke;async function v(r){return ke().update(r).hex()}var ot=new Set(["tree","commit","tag"]),I=class{map=new Map;currentBytes=0;maxBytes;constructor(e=16*1024*1024){this.maxBytes=e}get(e){return this.map.get(e)}set(e,t){if(!ot.has(t.type))return;let s=t.content.byteLength;if(!(s>this.maxBytes/2)&&!this.map.has(e)){for(;this.currentBytes+s>this.maxBytes&&this.map.size>0;){let n=this.map.keys().next().value;this.currentBytes-=this.map.get(n).content.byteLength,this.map.delete(n)}this.map.set(e,t),this.currentBytes+=s}}get size(){return this.map.size}get bytes(){return this.currentBytes}clear(){this.map.clear(),this.currentBytes=0}};async function at(){let r;try{r=M(["node","zlib"].join(":"))}catch{try{r=await import(["node","zlib"].join(":"))}catch{}}if(r&&typeof r.deflateSync=="function"&&typeof r.inflateSync=="function"){let e;try{let t=r.inflateSync(r.deflateSync(Buffer.from("x")),{info:!0});t?.engine&&typeof t.engine.bytesWritten=="number"&&(e=s=>{let n=r.inflateSync(s,{info:!0});return{result:new Uint8Array(n.buffer),bytesConsumed:n.engine.bytesWritten}})}catch{}return{deflateSync:t=>new Uint8Array(r.deflateSync(t)),inflateSync:t=>new Uint8Array(r.inflateSync(t)),inflateWithConsumed:e}}if(typeof globalThis.CompressionStream=="function"&&typeof globalThis.DecompressionStream=="function")return{async deflateSync(e){let t=new CompressionStream("deflate"),s=t.writable.getWriter();return s.write(e),s.close(),new Uint8Array(await new Response(t.readable).arrayBuffer())},async inflateSync(e){let t=new DecompressionStream("deflate"),s=t.writable.getWriter();return s.write(e),s.close(),new Uint8Array(await new Response(t.readable).arrayBuffer())}};throw new Error("No zlib implementation available. Requires Bun, Node.js, Deno, or a browser with CompressionStream.")}var it=null;function Ee(){return it??=at()}async function z(r){return await(await Ee()).deflateSync(r)}async function ve(r,e){let t=await Ee();if(t.inflateWithConsumed){let{result:i,bytesConsumed:o}=t.inflateWithConsumed(r);if(i.byteLength!==e)throw new Error(`Inflate size mismatch: got ${i.byteLength}, expected ${e}`);return{result:i,bytesConsumed:o}}let s=await t.inflateSync(r);if(s.byteLength!==e)throw new Error(`Inflate size mismatch: got ${s.byteLength}, expected ${e}`);let n=2,a=r.byteLength;for(;n<a;){let i=n+a>>>1;try{(await t.inflateSync(r.subarray(0,i))).byteLength===e?a=i:n=i+1}catch{n=i+1}}return{result:s,bytesConsumed:n}}var K=1346454347,te=2,Se=1,Te=2,Ue=3,Ce=4,D=6,re=7,ct={[Se]:"commit",[Te]:"tree",[Ue]:"blob",[Ce]:"tag"},Le={commit:Se,tree:Te,blob:Ue,tag:Ce};async function A(r,e){let t=new DataView(r.buffer,r.byteOffset,r.byteLength),s=t.getUint32(0);if(s!==K)throw new Error(`Invalid pack signature: 0x${s.toString(16)} (expected 0x${K.toString(16)})`);let n=t.getUint32(4);if(n!==te)throw new Error(`Unsupported pack version: ${n}`);let a=t.getUint32(8),i=[],o=12;for(let c=0;c<a;c++){let d=await ft(r,o);i.push(d),o=d.nextOffset}return(await dt(i,e)).map((c,d)=>({...c,offset:i[d].headerOffset,nextOffset:i[d].nextOffset}))}async function ft(r,e){let t=e,s=r[e++],n=s>>4&7,a=s&15,i=4;for(;s&128;)s=r[e++],a|=(s&127)<<i,i+=7;let o,f;if(n===D){let u=r[e++];for(o=u&127;u&128;)o+=1,u=r[e++],o=(o<<7)+(u&127);o=t-o}else n===re&&(f=je(r,e),e+=20);let{result:c,bytesConsumed:d}=await ve(r.subarray(e),a);return{headerOffset:t,typeNum:n,inflated:c,baseOffset:o,baseHash:f,nextOffset:e+d}}async function dt(r,e){let t=new Map;for(let a=0;a<r.length;a++)t.set(r[a].headerOffset,a);let s=new Array(r.length).fill(null);async function n(a){let i=s[a];if(i)return i;let o=r[a];if(o.typeNum!==D&&o.typeNum!==re){let l=ct[o.typeNum];if(!l)throw new Error(`Unknown object type: ${o.typeNum}`);let h={type:l,content:o.inflated,hash:await Q(l,o.inflated)};return s[a]=h,h}if(o.typeNum===D){let l=t.get(o.baseOffset);if(l===void 0)throw new Error(`OFS_DELTA base not found at offset ${o.baseOffset}`);let h=await n(l),y=Ie(h.content,o.inflated),p={type:h.type,content:y,hash:await Q(h.type,y)};return s[a]=p,p}let f=await lt(r,s,o.baseHash,n),c;if(f!==void 0)c=await n(f);else if(e){let l=await e(o.baseHash);l&&(c=l)}if(!c)throw new Error(`REF_DELTA base not found for hash ${o.baseHash}`);let d=Ie(c.content,o.inflated),u={type:c.type,content:d,hash:await Q(c.type,d)};return s[a]=u,u}for(let a=0;a<r.length;a++)await n(a);return s}async function lt(r,e,t,s){for(let n=0;n<e.length;n++)if(e[n]?.hash===t)return n;for(let n=0;n<r.length;n++){let a=r[n];if(a.typeNum!==D&&a.typeNum!==re&&(await s(n)).hash===t)return n}}function Ie(r,e){let t=0,{value:s,newPos:n}=Ae(e,t);if(t=n,s!==r.byteLength)throw new Error(`Delta base size mismatch: expected ${s}, got ${r.byteLength}`);let{value:a,newPos:i}=Ae(e,t);t=i;let o=new Uint8Array(a),f=0;for(;t<e.byteLength;){let c=e[t++];if(c&128){let d=0,u=0;c&1&&(d=e[t++]),c&2&&(d|=e[t++]<<8),c&4&&(d|=e[t++]<<16),c&8&&(d|=e[t++]<<24),c&16&&(u=e[t++]),c&32&&(u|=e[t++]<<8),c&64&&(u|=e[t++]<<16),u===0&&(u=65536),o.set(r.subarray(d,d+u),f),f+=u}else if(c>0)o.set(e.subarray(t,t+c),f),f+=c,t+=c;else throw new Error("Unexpected delta opcode 0x00 (reserved)")}if(f!==a)throw new Error(`Delta produced ${f} bytes, expected ${a}`);return o}async function He(r){let e=[],t=new Map,s=new Uint8Array(12),n=new DataView(s.buffer);n.setUint32(0,K),n.setUint32(4,te),n.setUint32(8,r.length),e.push(s);let a=12,i=[];for(let o of r){let f=a;t.set(o.hash,a);let c=o.delta&&o.deltaBaseHash?t.get(o.deltaBaseHash):void 0;if(o.delta&&c!==void 0){let d=ee(D,o.delta.byteLength),u=ut(a-c),l=await z(o.delta);e.push(d,u,l),a+=d.byteLength+u.byteLength+l.byteLength}else{let d=Le[o.type],u=ee(d,o.content.byteLength),l=await z(o.content);e.push(u,l),a+=u.byteLength+l.byteLength}i.push({hash:o.hash,offset:f,nextOffset:a})}return{data:await pt(e),entries:i}}async function*De(r,e){let t=q(),s=new Uint8Array(12),n=new DataView(s.buffer);n.setUint32(0,K),n.setUint32(4,te),n.setUint32(8,r),t.update(s),yield s;for await(let a of e){let i=Le[a.type],o=ee(i,a.content.byteLength),f=await z(a.content);t.update(o),t.update(f),yield ht(o,f)}yield F(await t.hex())}async function pt(r){let e=0;for(let i of r)e+=i.byteLength;e+=20;let t=new Uint8Array(e),s=0;for(let i of r)t.set(i,s),s+=i.byteLength;let n=q();n.update(t.subarray(0,s));let a=await n.hex();return t.set(F(a),s),t}function ut(r){let e=[];e.push(r&127);let t=r>>>7;for(;t>0;)e.unshift(128|--t&127),t>>>=7;return new Uint8Array(e)}function ee(r,e){let t=[],s=r<<4|e&15;for(e>>=4;e>0;)t.push(s|128),s=e&127,e>>=7;return t.push(s),new Uint8Array(t)}function Ae(r,e){let t=0,s=0,n;do n=r[e++],t|=(n&127)<<s,s+=7;while(n&128);return{value:t,newPos:e}}function ht(r,e){let t=new Uint8Array(r.byteLength+e.byteLength);return t.set(r,0),t.set(e,r.byteLength),t}var yt=new TextEncoder;async function Q(r,e){let t=yt.encode(`${r} ${e.byteLength}\0`),s=q();return s.update(t),s.update(e),s.hex()}var bt=new TextEncoder,er=new TextDecoder;function S(r,e){let t=bt.encode(`${r} ${e.byteLength}\0`),s=new Uint8Array(t.byteLength+e.byteLength);return s.set(t),s.set(e,t.byteLength),s}function N(r){let e=r.indexOf("<"),t=r.indexOf(">");if(e===-1||t===-1)throw new Error(`Malformed identity line: "${r}"`);let s=r.slice(0,e).trimEnd(),n=r.slice(e+1,t),a=r.slice(t+2),[i="0",o="+0000"]=a.split(" "),f=parseInt(i,10);return{name:s,email:n,timestamp:f,timezone:o}}var sr=new TextEncoder,xt=new TextDecoder;function B(r){let e=xt.decode(r),t=e.indexOf(`
2
2
 
3
- `),o=t===-1?e:e.slice(0,t),r=t===-1?"":e.slice(t+2),a="",i=[],s,f;for(let c of o.split(`
4
- `)){let d=c.indexOf(" ");if(d===-1)continue;let u=c.slice(0,d),l=c.slice(d+1);switch(u){case"tree":a=l;break;case"parent":i.push(l);break;case"author":s=T(l);break;case"committer":f=T(l);break}}if(!a)throw new Error("Commit missing tree field");if(!s)throw new Error("Commit missing author field");if(!f)throw new Error("Commit missing committer field");return{type:"commit",tree:a,parents:i,author:s,committer:f,message:r}}var Zt=new TextEncoder,lt=new TextDecoder;function P(n){let e=lt.decode(n),t=e.indexOf(`
3
+ `),s=t===-1?e:e.slice(0,t),n=t===-1?"":e.slice(t+2),a="",i=[],o,f;for(let c of s.split(`
4
+ `)){let d=c.indexOf(" ");if(d===-1)continue;let u=c.slice(0,d),l=c.slice(d+1);switch(u){case"tree":a=l;break;case"parent":i.push(l);break;case"author":o=N(l);break;case"committer":f=N(l);break}}if(!a)throw new Error("Commit missing tree field");if(!o)throw new Error("Commit missing author field");if(!f)throw new Error("Commit missing committer field");return{type:"commit",tree:a,parents:i,author:o,committer:f,message:n}}var ir=new TextEncoder,gt=new TextDecoder;function j(r){let e=gt.decode(r),t=e.indexOf(`
5
5
 
6
- `),o=t===-1?e:e.slice(0,t),r=t===-1?"":e.slice(t+2),a="",i="commit",s="",f;for(let c of o.split(`
7
- `)){let d=c.indexOf(" ");if(d===-1)continue;let u=c.slice(0,d),l=c.slice(d+1);switch(u){case"object":a=l;break;case"type":i=l;break;case"tag":s=l;break;case"tagger":f=T(l);break}}if(!a)throw new Error("Tag missing object field");if(!s)throw new Error("Tag missing tag name field");if(!f)throw new Error("Tag missing tagger field");return{type:"tag",object:a,objectType:i,name:s,tagger:f,message:r}}async function H(n,e){return n.objectStore.read(e)}async function Ee(n,e){return n.objectStore.exists(e)}var en=new TextDecoder;async function Se(n,e){let t=await H(n,e);if(t.type!=="commit")throw new Error(`Expected commit object for ${e}, got ${t.type}`);return C(t.content)}var rn=new TextEncoder,Ue=new TextDecoder;function Q(n){let e=[],t=0;for(;t<n.byteLength;){let o=n.indexOf(32,t);if(o===-1)break;let r=Ue.decode(n.subarray(t,o)),a=n.indexOf(0,o+1);if(a===-1)break;let i=Ue.decode(n.subarray(o+1,a)),s=n.subarray(a+1,a+21),f=N(s),c=r.padStart(6,"0");e.push({mode:c,name:i,hash:f}),t=a+21}return{type:"tree",entries:e}}async function Te(n,e,t){if(e===t)return!0;let o=new Set,r=[t],a=0;for(;a<r.length;){let i=r[a++];if(i===e)return!0;if(o.has(i))continue;o.add(i);let s=await Se(n,i);for(let f of s.parents)o.has(f)||r.push(f)}return!1}var q=new Uint32Array([0,2874782929,1454598562,4260027763,104818581,2909197124,1351355959,4225088230,209637162,2804382715,1523426952,4053013081,172075199,2702711918,1559413021,4155209164,419274324,3013880453,1313798134,3843506983,516094401,3046853904,1215402083,3811058866,344150398,3218793903,1110456540,3916008461,314324715,3118826042,1141858121,4015451032,838548648,2594343033,1732793610,3423723995,935615293,2627596268,1635201695,3392046670,1032188802,2531018579,1798740512,3228511985,1002083351,2430804166,1829371317,3327150436,688300796,2187269677,2142620510,3572268943,792315241,2220913080,2039131339,3537049626,628649430,2384582919,1942684788,3633492133,591858243,2283716242,1978950625,3735934768,1677097296,3366964609,893718770,2652677155,1707679429,3465587220,863663975,2552480694,1871230586,3302032043,960225240,2455923465,1773654511,3270403390,1057273933,2489126044,2064377604,3495056341,767069862,2262907511,2100592785,3597481024,730327347,2162056674,2004166702,3693911295,566641036,2325738845,1900695483,3658742634,670639641,2359333576,1376601592,4183093545,79572058,2951190667,1412571757,4285241020,42027983,2849570590,1584630482,4113186307,146858864,2744735649,1481436487,4078262678,251626725,2779131956,1257298860,3785977725,474198542,3071936223,1288682553,3885369576,444388763,2972016970,1183716486,3990331479,272465188,3143944693,1085371155,3957901250,369236657,3176902240,1823819377,3354194592,973483987,2438961922,1787437540,3251868981,1010387014,2539715735,1623951707,3415358858,913891577,2636207144,1727327950,3450690079,809994092,2602447805,1950930981,3742461172,586920327,2309096790,1920450480,3643673441,616879634,2409456323,2016810767,3547309022,780500653,2245839484,2114547866,3578840139,683284792,2212736489,1565424345,4128755208,201134971,2695145386,1534139724,4029196701,230847726,2795225151,1362146803,4201185570,126082129,2899994752,1460654694,4233520823,29146052,2867138325,1169417357,4008333404,318803247,3092855294,1133282072,3906287561,356510394,3194379883,1238182823,3801390966,528368133,3022517972,1341279282,3836475619,423699856,2987954497,256065313,2753203184,1508923011,4071219794,159144116,2720394341,1607414038,4103505351,54390795,2825143514,1435408809,4275514744,84055966,2925208399,1404173884,4175973101,398369141,3169260964,1091422423,3931405318,293717728,3134747185,1194504002,3966442387,465595999,2962872974,1299384317,3861558060,503253450,3064380699,1263296616,3759527097,1052246921,2514597720,1745578539,3276988154,948397084,2480853197,1848905150,3312302447,851889315,2577365106,1685431553,3475771856,888777526,2678071271,1649066644,3373495877,642096605,2367432972,1895232639,3685695662,544930376,2334346905,1992922090,3717211963,708530935,2170742310,2089302869,3620835204,738473314,2271052211,2058837184,3522095121]),pt=new Uint32Array([0,2125799437,1446245579,679924934,121527623,2039184714,1359849868,800622977,243055246,1892260483,1481592389,653946440,155379657,2012727236,1601245954,566506255,486110492,1649169681,1254785495,880779738,466036827,1701972054,1307892880,859962525,310759314,1815146399,1152793433,973282132,364614357,1796125400,1133012510,1027425811,972220984,1195887157,1874927347,292830974,1053603711,1081710450,1761559476,373973945,932073654,1228632251,1639818365,520651888,816844273,1308962300,1719925050,406247735,621518628,1539227433,1933077487,227363810,573948515,1551950446,1946564264,179508901,729228714,1438778791,2101662049,66187628,743012589,1392269536,2054851622,80718891,1944441968,223409277,634790075,1533214902,1960544567,175024442,585661948,1549622769,2107207422,53235443,732600885,1428142648,2057778105,68293556,747947890,1377953663,1864147308,296321377,959403431,1201305002,1747123243,379051046,1041303776,1084500205,1633688546,534068207,928247593,1239863076,1717454501,418080424,812495470,1322816099,1243037256,883039813,472173187,1653729934,1294557967,865878786,454727620,1706014665,1147897030,987669707,307785741,1827491840,1129699713,1038154124,359017802,1808993607,1458457428,677079897,14532511,2120785810,1372591635,795162142,132375256,2035729109,1486025178,640143831,245433617,1880368412,1605151901,555322512,161437782,1999272027,1284643889,841432124,446818554,1679083767,1269580150,890855803,497006013,1663735216,1122936511,1012631218,350048884,1785229945,1171323896,996531189,333647667,1834364734,1349216557,786319648,106470886,2028846571,1465201770,702551143,23511201,2144592044,1578619811,547550126,136587112,1989216101,1495895780,664579817,253393455,1907317282,1969288713,198563332,592642754,1575363279,1918806862,216763203,611147653,1524137864,2065452167,94989450,758102092,1402640449,2082607552,43463117,705815819,1420084486,1771668245,388801304,1068136414,1092573139,1856495186,269680223,949234329,1176570516,1743075739,424679830,836160848,1331948893,1624990940,510543057,921210903,1214099482,1064814657,1103292492,1766079626,401677447,944346374,1190966539,1853514189,282018240,822833871,1337873090,1731757572,428713481,909455240,1216352133,1611062083,515111758,596557149,1564187984,1975339414,185100699,615571482,1510326295,1921193169,204879068,770836435,1397172190,2076308248,91542293,718035604,1417247385,2097131103,38440530,109388409,2016412276,1354159794,772011711,29065022,2131648307,1468566517,691907576,150575351,1984739578,1590324284,545213489,264750512,1903355325,1509175675,658575734,444356453,1690924904,1280287662,855278499,490867234,1677142575,1265762025,902094564,335605227,1790299622,1110645024,1015429421,322875564,1837863073,1158497383,1001940074]),F=64,ut=4,ee=4096,Ce=65536,ht=127;function bt(n){let e=n.byteLength;if(e===0)return null;let t=(e-1)/16|0;if(t===0)return null;let o=t>>>2;o<16&&(o=16),o=xt(o);let r=o-1,a=new Uint32Array(o),i=[],s=-1>>>0;for(let l=t*16-16;l>=0;l-=16){let h=0;for(let b=1;b<=16;b++)h=(h<<8|n[l+b])^q[h>>>23];if(h=h>>>0,h===s)i[i.length-1].ptr=l+16;else{s=h;let b=h&r;i.push({ptr:l+16,val:h}),a[b]++}}let f=new Map;for(let l of i){let h=l.val&r,b=f.get(h);b||(b=[],f.set(h,b)),b.push(l)}for(let[l,h]of f){if(h.length<=F)continue;let b=[],p=h.length/F;for(let y=0;y<F;y++)b.push(h[Math.floor(y*p)]);f.set(l,b),a[l]=F}let c=new Uint32Array(o+1),d=[],u=0;for(let l=0;l<o;l++){c[l]=u;let h=f.get(l);if(h){for(let b of h)d.push(b);u+=h.length}}return c[o]=u,{src:n,hashMask:r,buckets:c,entries:d}}function yt(n,e,t){if(!n||e.byteLength===0)return null;let o=n.src.byteLength,r=e.byteLength,a=n.src,i=new Uint8Array(Math.max(r,1024)),s=0;function f(p){for(;s+p>i.length;){let y=new Uint8Array(i.length*2);y.set(i),i=y}}s=Le(i,s,o),s=Le(i,s,r),f(18),s++;let c=0,d=0,u=Math.min(16,r);for(let p=0;p<u;p++)i[s++]=e[p],c=(c<<8|e[p])^q[c>>>23],d++;c=c>>>0;let l=u,h=0,b=0;for(;l<r;){if(b<ee){c^=pt[e[l-16]],c=((c<<8|e[l])^q[c>>>23])>>>0;let p=c&n.hashMask,y=n.buckets[p],x=n.buckets[p+1];for(let R=y;R<x;R++){let m=n.entries[R];if(m.val!==c)continue;let g=m.ptr,k=a.byteLength-g,E=r-l;if(k>E&&(k=E),k<=b)break;let j=0;for(;j<k&&a[g+j]===e[l+j];)j++;if(j>b&&(b=j,h=g,b>=ee))break}}if(b<ut)f(2),d===0&&s++,i[s++]=e[l++],d++,d===ht&&(i[s-d-1]=d,d=0),b=0;else{if(d>0){for(;h>0&&a[h-1]===e[l-1];)if(b++,h--,l--,s--,!(--d>0)){s--,d=-1;break}d>0&&(i[s-d-1]=d),d=0}let p=b>Ce?b-Ce:0;b-=p,f(8);let y=s++,x=128;if(h&255&&(i[s++]=h&255,x|=1),h&65280&&(i[s++]=h>>>8&255,x|=2),h&16711680&&(i[s++]=h>>>16&255,x|=4),h&4278190080&&(i[s++]=h>>>24&255,x|=8),b&255&&(i[s++]=b&255,x|=16),b&65280&&(i[s++]=b>>>8&255,x|=32),i[y]=x,l+=b,h+=b,b=p,h>4294967295&&(b=0),b<ee){c=0;for(let R=-16;R<0;R++)c=(c<<8|e[l+R])^q[c>>>23];c=c>>>0}}if(t&&s>t)return null}return d>0&&(i[s-d-1]=d),t&&s>t?null:i.subarray(0,s)}var He={blob:0,tree:1,commit:2,tag:3};function De(n,e){let t=e?.window??10,o=e?.depth??50,r=n.slice().sort((c,d)=>{let u=He[c.type]??99,l=He[d.type]??99;return u!==l?u-l:d.content.byteLength-c.content.byteLength}),a=new Map,i=[],s=[],f=[];for(let c=0;c<r.length;c++){let d=r[c],u={hash:d.hash,type:d.type,content:d.content,depth:0},l=null,h=null,b=Math.max(0,c-t);for(let p=c-1;p>=b;p--){let y=r[p];if(y.type!==d.type||(a.get(y.hash)?.depth??0)>=o||d.content.byteLength<y.content.byteLength>>>5)continue;let m=s[p-b]??null;if(!m)continue;let g=l?l.byteLength:d.content.byteLength/2|0;if(g<16)continue;let k=yt(m,d.content,g);k&&(!l||k.byteLength<l.byteLength)&&(l=k,h=y.hash)}if(l&&h){u.delta=l,u.deltaBase=h;let p=a.get(h);u.depth=(p?.depth??0)+1}a.set(d.hash,u),i.push(u),s.length>=t&&(s.shift(),f.shift()),s.push(bt(d.content)),f.push(d.hash)}return i}function xt(n){let e=n;return e--,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,e|=e>>16,e++,e<16?16:e}function Le(n,e,t){let o=t;do{let r=o&127;o>>>=7,o>0&&(r|=128),n[e++]=r}while(o>0);return e}async function te(n,e,t){let o=new Set;for(let i of t)await L(n,i,o);let r=[],a=new Set;for(let i of e)await D(n,i,o,a,r);return{count:r.length,objects:mt(r)}}async function Be(n,e,t){let{count:o,objects:r}=await te(n,e,t);return{count:o,objects:gt(n,r)}}async function*mt(n){for(let e of n)yield e}async function*gt(n,e){for await(let t of e){let o=await H(n,t.hash);yield{hash:t.hash,type:t.type,content:o.content}}}async function Ne(n){let e=[];for await(let t of n.objects)e.push(t);return e}async function L(n,e,t){if(t.has(e)||(t.add(e),!await Ee(n,e)))return;let o=await H(n,e);switch(o.type){case"commit":{let r=C(o.content);await L(n,r.tree,t);for(let a of r.parents)await L(n,a,t);break}case"tree":{let r=Q(o.content);for(let a of r.entries)await L(n,a.hash,t);break}case"tag":{let r=P(o.content);await L(n,r.object,t);break}case"blob":break}}async function D(n,e,t,o,r){if(o.has(e)||t.has(e))return;o.add(e);let a=await H(n,e);switch(r.push({hash:e,type:a.type}),a.type){case"commit":{let i=C(a.content);await D(n,i.tree,t,o,r);for(let s of i.parents)await D(n,s,t,o,r);break}case"tree":{let i=Q(a.content);for(let s of i.entries)await D(n,s.hash,t,o,r);break}case"tag":{let i=P(a.content);await D(n,i.object,t,o,r);break}case"blob":break}}var wt=new TextEncoder,$e=new TextDecoder,We=65520,Rt=new Uint8Array([48,48,48,48]);function w(n){let e=typeof n=="string"?wt.encode(n):n,t=4+e.byteLength;if(t>We)throw new Error(`pkt-line too long: ${t} bytes (max ${We})`);let o=t.toString(16).padStart(4,"0"),r=new Uint8Array(t);return r[0]=o.charCodeAt(0),r[1]=o.charCodeAt(1),r[2]=o.charCodeAt(2),r[3]=o.charCodeAt(3),r.set(e,4),r}function O(){return Rt.slice()}function v(...n){let e=0;for(let r of n)e+=r.byteLength;let t=new Uint8Array(e),o=0;for(let r of n)t.set(r,o),o+=r.byteLength;return t}function _e(n){let e=[],t=0;for(;t<n.byteLength;){if(t+4>n.byteLength)throw new Error("Truncated pkt-line header");let o=$e.decode(n.subarray(t,t+4)),r=parseInt(o,16);if(Number.isNaN(r))throw new Error(`Invalid pkt-line length: ${o}`);if(r===0){e.push({type:"flush"}),t+=4;continue}if(r<4)throw new Error(`Invalid pkt-line length: ${r}`);if(t+r>n.byteLength)throw new Error(`Truncated pkt-line: need ${r} bytes at offset ${t}, have ${n.byteLength-t}`);e.push({type:"data",data:n.subarray(t+4,t+r)}),t+=r}return e}function Ge(n){if(n.type==="flush")return"";let e=$e.decode(n.data);return e.endsWith(`
8
- `)?e.slice(0,-1):e}var Me=65514;function Fe(n,e,t,o){let r=[];r.push(w(`# service=${e}
9
- `)),r.push(O());let a=[...t];o&&a.push(`symref=HEAD:${o}`),a.push("agent=just-git/1.0");let i=a.join(" ");if(n.length===0)r.push(w(`0000000000000000000000000000000000000000 capabilities^{}\0${i}
10
- `));else for(let s=0;s<n.length;s++){let f=n[s];s===0?r.push(w(`${f.hash} ${f.name}\0${i}
11
- `)):r.push(w(`${f.hash} ${f.name}
12
- `))}return r.push(O()),v(...r)}function qe(n){let e=_e(n),t=[],o=[],r=[];for(let a of e){if(a.type==="flush")continue;let i=Ge(a);if(i.startsWith("want ")){let s=i.slice(5);if(t.length===0){let f=s.indexOf(" ");f!==-1?(t.push(s.slice(0,f)),r=s.slice(f+1).split(" ").filter(Boolean)):t.push(s)}else t.push(s)}else i.startsWith("have ")&&o.push(i.slice(5))}return{wants:t,haves:o,capabilities:r}}function I(n,e,t){let o=[];if(t&&t.length>0){for(let a of t)o.push(w(`ACK ${a} common
13
- `));let r=t[t.length-1];o.push(w(`ACK ${r} ready
14
- `)),o.push(w(`ACK ${r}
15
- `))}else o.push(w(`NAK
16
- `));if(e){let r=0;for(;r<n.byteLength;){let a=Math.min(Me,n.byteLength-r);o.push(ne(1,n.subarray(r,r+a))),r+=a}o.push(O())}else{let r=new Uint8Array(n.byteLength);r.set(n),o.push(r)}return v(...o)}async function*ze(n,e,t){let o=[];if(t&&t.length>0){for(let a of t)o.push(w(`ACK ${a} common
17
- `));let r=t[t.length-1];o.push(w(`ACK ${r} ready
18
- `)),o.push(w(`ACK ${r}
19
- `))}else o.push(w(`NAK
20
- `));if(yield v(...o),e){for await(let r of n){let a=0;for(;a<r.byteLength;){let i=Math.min(Me,r.byteLength-a);yield ne(1,r.subarray(a,a+i)),a+=i}}yield O()}else for await(let r of n)yield r}function Ke(n){let e=new TextDecoder,t=[],o=[],r=0;for(;r<n.byteLength&&!(r+4>n.byteLength);){let i=e.decode(n.subarray(r,r+4)),s=parseInt(i,16);if(Number.isNaN(s))break;if(s===0){r+=4;break}if(s<4||r+s>n.byteLength)break;let f=n.subarray(r+4,r+s);r+=s;let c=f.indexOf(0),d;if(c!==-1)d=e.decode(f.subarray(0,c)),o=e.decode(f.subarray(c+1)).replace(/\n$/,"").split(" ").filter(Boolean);else{let l=e.decode(f);d=l.endsWith(`
21
- `)?l.slice(0,-1):l}let u=d.split(" ");u.length>=3&&t.push({oldHash:u[0],newHash:u[1],refName:u[2]})}let a=r<n.byteLength?n.subarray(r):new Uint8Array(0);return{commands:t,packData:a,capabilities:o}}function z(n,e,t){let o=[];o.push(w(n?`unpack ok
6
+ `),s=t===-1?e:e.slice(0,t),n=t===-1?"":e.slice(t+2),a="",i="commit",o="",f;for(let c of s.split(`
7
+ `)){let d=c.indexOf(" ");if(d===-1)continue;let u=c.slice(0,d),l=c.slice(d+1);switch(u){case"object":a=l;break;case"type":i=l;break;case"tag":o=l;break;case"tagger":f=N(l);break}}if(!a)throw new Error("Tag missing object field");if(!o)throw new Error("Tag missing tag name field");if(!f)throw new Error("Tag missing tagger field");return{type:"tag",object:a,objectType:i,name:o,tagger:f,message:n}}async function $(r,e){return r.objectStore.read(e)}async function Ne(r,e){return r.objectStore.exists(e)}var dr=new TextDecoder;async function Be(r,e){let t=await $(r,e);if(t.type!=="commit")throw new Error(`Expected commit object for ${e}, got ${t.type}`);return B(t.content)}var ur=new TextEncoder,$e=new TextDecoder;function ne(r){let e=[],t=0;for(;t<r.byteLength;){let s=r.indexOf(32,t);if(s===-1)break;let n=$e.decode(r.subarray(t,s)),a=r.indexOf(0,s+1);if(a===-1)break;let i=$e.decode(r.subarray(s+1,a)),o=r.subarray(a+1,a+21),f=G(o),c=n.padStart(6,"0");e.push({mode:c,name:i,hash:f}),t=a+21}return{type:"tree",entries:e}}async function _e(r,e,t){if(e===t)return!0;let s=new Set,n=[t],a=0;for(;a<n.length;){let i=n[a++];if(i===e)return!0;if(s.has(i))continue;s.add(i);let o=await Be(r,i);for(let f of o.parents)s.has(f)||n.push(f)}return!1}var Y=new Uint32Array([0,2874782929,1454598562,4260027763,104818581,2909197124,1351355959,4225088230,209637162,2804382715,1523426952,4053013081,172075199,2702711918,1559413021,4155209164,419274324,3013880453,1313798134,3843506983,516094401,3046853904,1215402083,3811058866,344150398,3218793903,1110456540,3916008461,314324715,3118826042,1141858121,4015451032,838548648,2594343033,1732793610,3423723995,935615293,2627596268,1635201695,3392046670,1032188802,2531018579,1798740512,3228511985,1002083351,2430804166,1829371317,3327150436,688300796,2187269677,2142620510,3572268943,792315241,2220913080,2039131339,3537049626,628649430,2384582919,1942684788,3633492133,591858243,2283716242,1978950625,3735934768,1677097296,3366964609,893718770,2652677155,1707679429,3465587220,863663975,2552480694,1871230586,3302032043,960225240,2455923465,1773654511,3270403390,1057273933,2489126044,2064377604,3495056341,767069862,2262907511,2100592785,3597481024,730327347,2162056674,2004166702,3693911295,566641036,2325738845,1900695483,3658742634,670639641,2359333576,1376601592,4183093545,79572058,2951190667,1412571757,4285241020,42027983,2849570590,1584630482,4113186307,146858864,2744735649,1481436487,4078262678,251626725,2779131956,1257298860,3785977725,474198542,3071936223,1288682553,3885369576,444388763,2972016970,1183716486,3990331479,272465188,3143944693,1085371155,3957901250,369236657,3176902240,1823819377,3354194592,973483987,2438961922,1787437540,3251868981,1010387014,2539715735,1623951707,3415358858,913891577,2636207144,1727327950,3450690079,809994092,2602447805,1950930981,3742461172,586920327,2309096790,1920450480,3643673441,616879634,2409456323,2016810767,3547309022,780500653,2245839484,2114547866,3578840139,683284792,2212736489,1565424345,4128755208,201134971,2695145386,1534139724,4029196701,230847726,2795225151,1362146803,4201185570,126082129,2899994752,1460654694,4233520823,29146052,2867138325,1169417357,4008333404,318803247,3092855294,1133282072,3906287561,356510394,3194379883,1238182823,3801390966,528368133,3022517972,1341279282,3836475619,423699856,2987954497,256065313,2753203184,1508923011,4071219794,159144116,2720394341,1607414038,4103505351,54390795,2825143514,1435408809,4275514744,84055966,2925208399,1404173884,4175973101,398369141,3169260964,1091422423,3931405318,293717728,3134747185,1194504002,3966442387,465595999,2962872974,1299384317,3861558060,503253450,3064380699,1263296616,3759527097,1052246921,2514597720,1745578539,3276988154,948397084,2480853197,1848905150,3312302447,851889315,2577365106,1685431553,3475771856,888777526,2678071271,1649066644,3373495877,642096605,2367432972,1895232639,3685695662,544930376,2334346905,1992922090,3717211963,708530935,2170742310,2089302869,3620835204,738473314,2271052211,2058837184,3522095121]),wt=new Uint32Array([0,2125799437,1446245579,679924934,121527623,2039184714,1359849868,800622977,243055246,1892260483,1481592389,653946440,155379657,2012727236,1601245954,566506255,486110492,1649169681,1254785495,880779738,466036827,1701972054,1307892880,859962525,310759314,1815146399,1152793433,973282132,364614357,1796125400,1133012510,1027425811,972220984,1195887157,1874927347,292830974,1053603711,1081710450,1761559476,373973945,932073654,1228632251,1639818365,520651888,816844273,1308962300,1719925050,406247735,621518628,1539227433,1933077487,227363810,573948515,1551950446,1946564264,179508901,729228714,1438778791,2101662049,66187628,743012589,1392269536,2054851622,80718891,1944441968,223409277,634790075,1533214902,1960544567,175024442,585661948,1549622769,2107207422,53235443,732600885,1428142648,2057778105,68293556,747947890,1377953663,1864147308,296321377,959403431,1201305002,1747123243,379051046,1041303776,1084500205,1633688546,534068207,928247593,1239863076,1717454501,418080424,812495470,1322816099,1243037256,883039813,472173187,1653729934,1294557967,865878786,454727620,1706014665,1147897030,987669707,307785741,1827491840,1129699713,1038154124,359017802,1808993607,1458457428,677079897,14532511,2120785810,1372591635,795162142,132375256,2035729109,1486025178,640143831,245433617,1880368412,1605151901,555322512,161437782,1999272027,1284643889,841432124,446818554,1679083767,1269580150,890855803,497006013,1663735216,1122936511,1012631218,350048884,1785229945,1171323896,996531189,333647667,1834364734,1349216557,786319648,106470886,2028846571,1465201770,702551143,23511201,2144592044,1578619811,547550126,136587112,1989216101,1495895780,664579817,253393455,1907317282,1969288713,198563332,592642754,1575363279,1918806862,216763203,611147653,1524137864,2065452167,94989450,758102092,1402640449,2082607552,43463117,705815819,1420084486,1771668245,388801304,1068136414,1092573139,1856495186,269680223,949234329,1176570516,1743075739,424679830,836160848,1331948893,1624990940,510543057,921210903,1214099482,1064814657,1103292492,1766079626,401677447,944346374,1190966539,1853514189,282018240,822833871,1337873090,1731757572,428713481,909455240,1216352133,1611062083,515111758,596557149,1564187984,1975339414,185100699,615571482,1510326295,1921193169,204879068,770836435,1397172190,2076308248,91542293,718035604,1417247385,2097131103,38440530,109388409,2016412276,1354159794,772011711,29065022,2131648307,1468566517,691907576,150575351,1984739578,1590324284,545213489,264750512,1903355325,1509175675,658575734,444356453,1690924904,1280287662,855278499,490867234,1677142575,1265762025,902094564,335605227,1790299622,1110645024,1015429421,322875564,1837863073,1158497383,1001940074]),X=64,Rt=4,se=4096,We=65536,Pt=127;function Ot(r){let e=r.byteLength;if(e===0)return null;let t=(e-1)/16|0;if(t===0)return null;let s=t>>>2;s<16&&(s=16),s=kt(s);let n=s-1,a=new Uint32Array(s),i=[],o=-1>>>0;for(let l=t*16-16;l>=0;l-=16){let h=0;for(let y=1;y<=16;y++)h=(h<<8|r[l+y])^Y[h>>>23];if(h=h>>>0,h===o)i[i.length-1].ptr=l+16;else{o=h;let y=h&n;i.push({ptr:l+16,val:h}),a[y]++}}let f=new Map;for(let l of i){let h=l.val&n,y=f.get(h);y||(y=[],f.set(h,y)),y.push(l)}for(let[l,h]of f){if(h.length<=X)continue;let y=[],p=h.length/X;for(let b=0;b<X;b++)y.push(h[Math.floor(b*p)]);f.set(l,y),a[l]=X}let c=new Uint32Array(s+1),d=[],u=0;for(let l=0;l<s;l++){c[l]=u;let h=f.get(l);if(h){for(let y of h)d.push(y);u+=h.length}}return c[s]=u,{src:r,hashMask:n,buckets:c,entries:d}}function jt(r,e,t){if(!r||e.byteLength===0)return null;let s=r.src.byteLength,n=e.byteLength,a=r.src,i=new Uint8Array(Math.max(n,1024)),o=0;function f(p){for(;o+p>i.length;){let b=new Uint8Array(i.length*2);b.set(i),i=b}}o=Ge(i,o,s),o=Ge(i,o,n),f(18),o++;let c=0,d=0,u=Math.min(16,n);for(let p=0;p<u;p++)i[o++]=e[p],c=(c<<8|e[p])^Y[c>>>23],d++;c=c>>>0;let l=u,h=0,y=0;for(;l<n;){if(y<se){c^=wt[e[l-16]],c=((c<<8|e[l])^Y[c>>>23])>>>0;let p=c&r.hashMask,b=r.buckets[p],m=r.buckets[p+1];for(let P=b;P<m;P++){let x=r.entries[P];if(x.val!==c)continue;let g=x.ptr,O=a.byteLength-g,L=n-l;if(O>L&&(O=L),O<=y)break;let E=0;for(;E<O&&a[g+E]===e[l+E];)E++;if(E>y&&(y=E,h=g,y>=se))break}}if(y<Rt)f(2),d===0&&o++,i[o++]=e[l++],d++,d===Pt&&(i[o-d-1]=d,d=0),y=0;else{if(d>0){for(;h>0&&a[h-1]===e[l-1];)if(y++,h--,l--,o--,!(--d>0)){o--,d=-1;break}d>0&&(i[o-d-1]=d),d=0}let p=y>We?y-We:0;y-=p,f(8);let b=o++,m=128;if(h&255&&(i[o++]=h&255,m|=1),h&65280&&(i[o++]=h>>>8&255,m|=2),h&16711680&&(i[o++]=h>>>16&255,m|=4),h&4278190080&&(i[o++]=h>>>24&255,m|=8),y&255&&(i[o++]=y&255,m|=16),y&65280&&(i[o++]=y>>>8&255,m|=32),i[b]=m,l+=y,h+=y,y=p,h>4294967295&&(y=0),y<se){c=0;for(let P=-16;P<0;P++)c=(c<<8|e[l+P])^Y[c>>>23];c=c>>>0}}if(t&&o>t)return null}return d>0&&(i[o-d-1]=d),t&&o>t?null:i.subarray(0,o)}var Me={blob:0,tree:1,commit:2,tag:3};function Fe(r,e){let t=e?.window??10,s=e?.depth??50,n=r.slice().sort((c,d)=>{let u=Me[c.type]??99,l=Me[d.type]??99;return u!==l?u-l:d.content.byteLength-c.content.byteLength}),a=new Map,i=[],o=[],f=[];for(let c=0;c<n.length;c++){let d=n[c],u={hash:d.hash,type:d.type,content:d.content,depth:0},l=null,h=null,y=Math.max(0,c-t);for(let p=c-1;p>=y;p--){let b=n[p];if(b.type!==d.type||(a.get(b.hash)?.depth??0)>=s||d.content.byteLength<b.content.byteLength>>>5)continue;let x=o[p-y]??null;if(!x)continue;let g=l?l.byteLength:d.content.byteLength/2|0;if(g<16)continue;let O=jt(x,d.content,g);O&&(!l||O.byteLength<l.byteLength)&&(l=O,h=b.hash)}if(l&&h){u.delta=l,u.deltaBase=h;let p=a.get(h);u.depth=(p?.depth??0)+1}a.set(d.hash,u),i.push(u),o.length>=t&&(o.shift(),f.shift()),o.push(Ot(d.content)),f.push(d.hash)}return i}function kt(r){let e=r;return e--,e|=e>>1,e|=e>>2,e|=e>>4,e|=e>>8,e|=e>>16,e++,e<16?16:e}function Ge(r,e,t){let s=t;do{let n=s&127;s>>>=7,s>0&&(n|=128),r[e++]=n}while(s>0);return e}async function oe(r,e,t){let s=new Set;for(let i of t)await _(r,i,s);let n=[],a=new Set;for(let i of e)await W(r,i,s,a,n);return{count:n.length,objects:Et(n)}}async function qe(r,e,t){let{count:s,objects:n}=await oe(r,e,t);return{count:s,objects:vt(r,n)}}async function*Et(r){for(let e of r)yield e}async function*vt(r,e){for await(let t of e){let s=await $(r,t.hash);yield{hash:t.hash,type:t.type,content:s.content}}}async function ze(r){let e=[];for await(let t of r.objects)e.push(t);return e}async function _(r,e,t){if(t.has(e)||(t.add(e),!await Ne(r,e)))return;let s=await $(r,e);switch(s.type){case"commit":{let n=B(s.content);await _(r,n.tree,t);for(let a of n.parents)await _(r,a,t);break}case"tree":{let n=ne(s.content);for(let a of n.entries)await _(r,a.hash,t);break}case"tag":{let n=j(s.content);await _(r,n.object,t);break}case"blob":break}}async function W(r,e,t,s,n){if(s.has(e)||t.has(e))return;s.add(e);let a=await $(r,e);switch(n.push({hash:e,type:a.type}),a.type){case"commit":{let i=B(a.content);await W(r,i.tree,t,s,n);for(let o of i.parents)await W(r,o,t,s,n);break}case"tree":{let i=ne(a.content);for(let o of i.entries)await W(r,o.hash,t,s,n);break}case"tag":{let i=j(a.content);await W(r,i.object,t,s,n);break}case"blob":break}}var It=new TextEncoder,Xe=new TextDecoder,Ke=65520,At=new Uint8Array([48,48,48,48]);function R(r){let e=typeof r=="string"?It.encode(r):r,t=4+e.byteLength;if(t>Ke)throw new Error(`pkt-line too long: ${t} bytes (max ${Ke})`);let s=t.toString(16).padStart(4,"0"),n=new Uint8Array(t);return n[0]=s.charCodeAt(0),n[1]=s.charCodeAt(1),n[2]=s.charCodeAt(2),n[3]=s.charCodeAt(3),n.set(e,4),n}function k(){return At.slice()}function T(...r){let e=0;for(let n of r)e+=n.byteLength;let t=new Uint8Array(e),s=0;for(let n of r)t.set(n,s),s+=n.byteLength;return t}function Ye(r){let e=[],t=0;for(;t<r.byteLength;){if(t+4>r.byteLength)throw new Error("Truncated pkt-line header");let s=Xe.decode(r.subarray(t,t+4)),n=parseInt(s,16);if(Number.isNaN(n))throw new Error(`Invalid pkt-line length: ${s}`);if(n===0){e.push({type:"flush"}),t+=4;continue}if(n<4)throw new Error(`Invalid pkt-line length: ${n}`);if(t+n>r.byteLength)throw new Error(`Truncated pkt-line: need ${n} bytes at offset ${t}, have ${r.byteLength-t}`);e.push({type:"data",data:r.subarray(t+4,t+n)}),t+=n}return e}function Ve(r){if(r.type==="flush")return"";let e=Xe.decode(r.data);return e.endsWith(`
8
+ `)?e.slice(0,-1):e}var Ze=65514;function Je(r,e,t,s){let n=[];n.push(R(`# service=${e}
9
+ `)),n.push(k());let a=[...t];s&&a.push(`symref=HEAD:${s}`),a.push("agent=just-git/1.0");let i=a.join(" ");if(r.length===0)n.push(R(`0000000000000000000000000000000000000000 capabilities^{}\0${i}
10
+ `));else for(let o=0;o<r.length;o++){let f=r[o];o===0?n.push(R(`${f.hash} ${f.name}\0${i}
11
+ `)):n.push(R(`${f.hash} ${f.name}
12
+ `))}return n.push(k()),T(...n)}function Qe(r){let e=Ye(r),t=[],s=[],n=[];for(let a of e){if(a.type==="flush")continue;let i=Ve(a);if(i.startsWith("want ")){let o=i.slice(5);if(t.length===0){let f=o.indexOf(" ");f!==-1?(t.push(o.slice(0,f)),n=o.slice(f+1).split(" ").filter(Boolean)):t.push(o)}else t.push(o)}else i.startsWith("have ")&&s.push(i.slice(5))}return{wants:t,haves:s,capabilities:n}}function U(r,e,t){let s=[];if(t&&t.length>0){for(let a of t)s.push(R(`ACK ${a} common
13
+ `));let n=t[t.length-1];s.push(R(`ACK ${n} ready
14
+ `)),s.push(R(`ACK ${n}
15
+ `))}else s.push(R(`NAK
16
+ `));if(e){let n=0;for(;n<r.byteLength;){let a=Math.min(Ze,r.byteLength-n);s.push(ae(1,r.subarray(n,n+a))),n+=a}s.push(k())}else{let n=new Uint8Array(r.byteLength);n.set(r),s.push(n)}return T(...s)}async function*et(r,e,t){let s=[];if(t&&t.length>0){for(let a of t)s.push(R(`ACK ${a} common
17
+ `));let n=t[t.length-1];s.push(R(`ACK ${n} ready
18
+ `)),s.push(R(`ACK ${n}
19
+ `))}else s.push(R(`NAK
20
+ `));if(yield T(...s),e){for await(let n of r){let a=0;for(;a<n.byteLength;){let i=Math.min(Ze,n.byteLength-a);yield ae(1,n.subarray(a,a+i)),a+=i}}yield k()}else for await(let n of r)yield n}function tt(r){let e=new TextDecoder,t=[],s=[],n=0;for(;n<r.byteLength&&!(n+4>r.byteLength);){let i=e.decode(r.subarray(n,n+4)),o=parseInt(i,16);if(Number.isNaN(o))break;if(o===0){n+=4;break}if(o<4||n+o>r.byteLength)break;let f=r.subarray(n+4,n+o);n+=o;let c=f.indexOf(0),d;if(c!==-1)d=e.decode(f.subarray(0,c)),s=e.decode(f.subarray(c+1)).replace(/\n$/,"").split(" ").filter(Boolean);else{let l=e.decode(f);d=l.endsWith(`
21
+ `)?l.slice(0,-1):l}let u=d.split(" ");u.length>=3&&t.push({oldHash:u[0],newHash:u[1],refName:u[2]})}let a=n<r.byteLength?r.subarray(n):new Uint8Array(0);return{commands:t,packData:a,capabilities:s}}function V(r,e,t){let s=[];s.push(R(r?`unpack ok
22
22
  `:`unpack error
23
- `));for(let a of e)a.ok?o.push(w(`ok ${a.name}
24
- `)):o.push(w(`ng ${a.name} ${a.error??"failed"}
25
- `));o.push(O());let r=v(...o);if(t){let a=[];return a.push(ne(1,r)),a.push(O()),v(...a)}return r}function ne(n,e){let t=new Uint8Array(1+e.byteLength);return t[0]=n,t.set(e,1),w(t)}var A=class{entries=new Map;currentBytes=0;maxBytes;hits=0;misses=0;constructor(e=256*1024*1024){this.maxBytes=e}static key(e,t,o){if(o.length>0)return null;let r=t.slice().sort();return`${e}\0${r.join(",")}`}get(e){let t=this.entries.get(e);return t?this.hits++:this.misses++,t}set(e,t){if(this.entries.has(e))return;let o=t.packData.byteLength;if(!(o>this.maxBytes)){for(;this.currentBytes+o>this.maxBytes&&this.entries.size>0;){let r=this.entries.keys().next().value;this.currentBytes-=this.entries.get(r).packData.byteLength,this.entries.delete(r)}this.entries.set(e,t),this.currentBytes+=o}}get stats(){return{entries:this.entries.size,bytes:this.currentBytes,hits:this.hits,misses:this.misses}}},kt=["multi_ack_detailed","no-done","side-band-64k","ofs-delta","include-tag"],Pt=["report-status","side-band-64k","ofs-delta","delete-refs"];async function re(n){let e=await n.refStore.listRefs("refs"),t=await n.refStore.readRef("HEAD"),o=[],r=null,a;if(t)if(t.type==="symbolic"){a=t.target;let i=await n.refStore.readRef(t.target);i?.type==="direct"&&(r=i.hash)}else r=t.hash;r&&o.push({name:"HEAD",hash:r});for(let i of e)if(o.push({name:i.name,hash:i.hash}),i.name.startsWith("refs/tags/"))try{let s=await n.objectStore.read(i.hash);if(s.type==="tag"){let f=P(s.content);o.push({name:`${i.name}^{}`,hash:f.object})}}catch{}return{refs:o,headTarget:a}}function oe(n,e,t){return Fe(n,e,e==="git-upload-pack"?kt:Pt,t)}async function se(n,e,t){let{wants:o,haves:r,capabilities:a}=qe(e);if(o.length===0)return I(new Uint8Array(0),!1);let i=a.includes("multi_ack_detailed"),s=a.includes("side-band-64k"),f;if(i&&r.length>0){f=[];for(let d of r)await n.objectStore.exists(d)&&f.push(d);f.length===0&&(f=void 0)}let c=t?.cache&&t.cacheKey?A.key(t.cacheKey,o,r):null;if(c&&t?.cache){let d=t.cache.get(c);if(d)return I(d.packData,s,f)}return t?.noDelta?Ot(n,o,r,a,s,f):jt(n,o,r,a,s,f,t,c)}async function Ot(n,e,t,o,r,a){let{count:i,objects:s}=await te(n,e,t);if(i===0){let p=I(new Uint8Array(0),r,a);return new ReadableStream({start(y){y.enqueue(p),y.close()}})}let f=[];for await(let p of s)f.push(p);let c=new Set(f.map(p=>p.hash)),d=[];if(o.includes("include-tag")){let p=await n.refStore.listRefs("refs/tags");for(let y of p)if(!c.has(y.hash))try{let x=await n.objectStore.read(y.hash);if(x.type==="tag"){let R=P(x.content);c.has(R.object)&&d.push({hash:y.hash,type:"tag",content:x.content})}}catch{}}let u=f.length+d.length;async function*l(){for(let p of f){let y=await n.objectStore.read(p.hash);yield{type:y.type,content:y.content}}for(let p of d)yield{type:p.type,content:p.content}}let h=Ie(u,l()),b=ze(h,r,a);return new ReadableStream({async pull(p){let{value:y,done:x}=await b.next();x?p.close():p.enqueue(y)}})}async function jt(n,e,t,o,r,a,i,s){let f=await Be(n,e,t);if(f.count===0)return I(new Uint8Array(0),r,a);let c=await Ne(f),d=new Set(c.map(p=>p.hash));if(o.includes("include-tag")){let p=await n.refStore.listRefs("refs/tags");for(let y of p)if(!d.has(y.hash))try{let x=await n.objectStore.read(y.hash);if(x.type==="tag"){let R=P(x.content);d.has(R.object)&&(c.push({hash:y.hash,type:"tag",content:x.content}),d.add(y.hash))}}catch{}}let u=i?.deltaWindow?{window:i.deltaWindow}:void 0,l=De(c,u),h=l.map(p=>({hash:p.hash,type:p.type,content:p.content,delta:p.delta,deltaBaseHash:p.deltaBase})),{data:b}=await ve(h);if(s&&i?.cache){let p=l.filter(y=>y.delta).length;i.cache.set(s,{packData:b,objectCount:c.length,deltaCount:p})}return I(b,r,a)}async function ae(n,e){let{commands:t,packData:o,capabilities:r}=Ke(e),a=!0;if(o.byteLength>0)try{await n.objectStore.ingestPack(o)}catch{a=!1}let i=[];for(let s of t){let f=s.oldHash===K,c=s.newHash===K,d=!1;if(!f&&!c&&a)try{d=await Te(n,s.oldHash,s.newHash)}catch{}i.push({ref:s.refName,oldHash:f?null:s.oldHash,newHash:s.newHash,isFF:d,isCreate:f,isDelete:c})}return{updates:i,unpackOk:a,capabilities:r}}function vt(n){let{resolveRepo:e,hooks:t,basePath:o}=n,r=n.packCache===!1?void 0:new A(n.packCache?.maxBytes);return{async fetch(a){try{let i=new URL(a.url),s=decodeURIComponent(i.pathname);if(o){let f=o.replace(/\/+$/,"");if(!s.startsWith(f))return new Response("Not Found",{status:404});s=s.slice(f.length)}if(s.startsWith("/")||(s=`/${s}`),s.endsWith("/info/refs")&&a.method==="GET"){let f=i.searchParams.get("service");if(f!=="git-upload-pack"&&f!=="git-receive-pack")return new Response("Unsupported service",{status:403});let c=ie(s,"/info/refs"),d=await e(c,a);if(d instanceof Response)return d;if(!d)return new Response("Not Found",{status:404});let u=d,{refs:l,headTarget:h}=await re(u),b=l;if(t?.advertiseRefs){let y=await t.advertiseRefs({repo:u,repoPath:c,refs:l,service:f,request:a});y&&(b=y)}let p=oe(b,f,h);return new Response(p,{headers:{"Content-Type":`application/x-${f}-advertisement`,"Cache-Control":"no-cache"}})}if(s.endsWith("/git-upload-pack")&&a.method==="POST"){let f=ie(s,"/git-upload-pack"),c=await e(f,a);if(c instanceof Response)return c;if(!c)return new Response("Not Found",{status:404});let d=c,u=await Ye(a),l=await se(d,u,{cache:r,cacheKey:f,noDelta:n.packOptions?.noDelta,deltaWindow:n.packOptions?.deltaWindow});return new Response(l,{headers:{"Content-Type":"application/x-git-upload-pack-result"}})}if(s.endsWith("/git-receive-pack")&&a.method==="POST"){let f=ie(s,"/git-receive-pack"),c=await e(f,a);if(c instanceof Response)return c;if(!c)return new Response("Not Found",{status:404});let d=c,u=await Ye(a),{updates:l,unpackOk:h,capabilities:b}=await ae(d,u),p=b.includes("side-band-64k"),y=b.includes("report-status");if(!h){if(y){let m=l.map(g=>({name:g.ref,ok:!1,error:"unpack failed"}));return new Response(z(!1,m,p),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response(new Uint8Array(0),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}if(t?.preReceive){let m=await t.preReceive({repo:d,repoPath:f,updates:l,request:a});if(S(m)){if(y){let g=m.message??"pre-receive hook declined",k=l.map(E=>({name:E.ref,ok:!1,error:g}));return new Response(z(!0,k,p),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response(new Uint8Array(0),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}}let x=[],R=[];for(let m of l){if(t?.update){let g=await t.update({repo:d,repoPath:f,update:m,request:a});if(S(g)){x.push({ref:m.ref,ok:!1,error:g.message??"update hook declined"});continue}}try{let g=m.isCreate?null:m.oldHash,k=m.isDelete?null:{type:"direct",hash:m.newHash};if(!await d.refStore.compareAndSwapRef(m.ref,g,k)){x.push({ref:m.ref,ok:!1,error:"failed to lock"});continue}x.push({ref:m.ref,ok:!0}),R.push(m)}catch(g){x.push({ref:m.ref,ok:!1,error:g instanceof Error?g.message:String(g)})}}if(t?.postReceive&&R.length>0)try{await t.postReceive({repo:d,repoPath:f,updates:R,request:a})}catch{}if(y){let m=x.map(g=>({name:g.ref,ok:g.ok,error:g.error}));return new Response(z(!0,m,p),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response(new Uint8Array(0),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response("Not Found",{status:404})}catch(i){return console.error(" [server] Internal error:",i),new Response("Internal Server Error",{status:500})}}}}function ie(n,e){let t=n.slice(0,-e.length);return t.startsWith("/")&&(t=t.slice(1)),t}async function Ye(n){let e=new Uint8Array(await n.arrayBuffer()),t=n.headers.get("content-encoding");if(t==="gzip"||t==="x-gzip"){let o=new DecompressionStream("gzip"),r=o.writable.getWriter();return r.write(e),r.close(),new Uint8Array(await new Response(o.readable).arrayBuffer())}return e}function It(...n){let e=n.filter(s=>s!=null);if(e.length===0)return{};if(e.length===1)return e[0];let t={},o=e.filter(s=>s.preReceive).map(s=>s.preReceive);o.length>0&&(t.preReceive=async s=>{for(let f of o){let c=await f(s);if(S(c))return c}});let r=e.filter(s=>s.update).map(s=>s.update);r.length>0&&(t.update=async s=>{for(let f of r){let c=await f(s);if(S(c))return c}});let a=e.filter(s=>s.postReceive).map(s=>s.postReceive);a.length>0&&(t.postReceive=async s=>{for(let f of a)try{await f(s)}catch{}});let i=e.filter(s=>s.advertiseRefs).map(s=>s.advertiseRefs);return i.length>0&&(t.advertiseRefs=async s=>{let f=s.refs;for(let c of i){let d=await c({...s,refs:f});d&&(f=d)}return f}),t}function At(n){let{protectedBranches:e=[],denyNonFastForward:t=!1,denyDeletes:o=!1,denyDeleteTags:r=!1,authorize:a,onPush:i}=n,s=new Set(e.map(c=>c.startsWith("refs/")?c:`refs/heads/${c}`)),f={};return(a||s.size>0)&&(f.preReceive=async c=>{if(a&&!await a(c.request))return{reject:!0,message:"unauthorized"};for(let d of c.updates)if(s.has(d.ref)){if(d.isDelete)return{reject:!0,message:`cannot delete protected branch ${d.ref}`};if(!d.isCreate&&!d.isFF)return{reject:!0,message:`non-fast-forward push to protected branch ${d.ref}`}}}),(t||o||r)&&(f.update=async c=>{if(o&&c.update.isDelete)return{reject:!0,message:"ref deletion denied"};if(r&&c.update.ref.startsWith("refs/tags/")){if(c.update.isDelete)return{reject:!0,message:"tag deletion denied"};if(!c.update.isCreate)return{reject:!0,message:"tag overwrite denied"}}if(t&&!c.update.isCreate&&!c.update.isDelete&&!c.update.isFF)return{reject:!0,message:"non-fast-forward"}}),i&&(f.postReceive=i),f}var Et=`
23
+ `));for(let a of e)a.ok?s.push(R(`ok ${a.name}
24
+ `)):s.push(R(`ng ${a.name} ${a.error??"failed"}
25
+ `));s.push(k());let n=T(...s);if(t){let a=[];return a.push(ae(1,n)),a.push(k()),T(...a)}return n}function ae(r,e){let t=new Uint8Array(1+e.byteLength);return t[0]=r,t.set(e,1),R(t)}var C=class{entries=new Map;currentBytes=0;maxBytes;hits=0;misses=0;constructor(e=256*1024*1024){this.maxBytes=e}static key(e,t,s){if(s.length>0)return null;let n=t.slice().sort();return`${e}\0${n.join(",")}`}get(e){let t=this.entries.get(e);return t?this.hits++:this.misses++,t}set(e,t){if(this.entries.has(e))return;let s=t.packData.byteLength;if(!(s>this.maxBytes)){for(;this.currentBytes+s>this.maxBytes&&this.entries.size>0;){let n=this.entries.keys().next().value;this.currentBytes-=this.entries.get(n).packData.byteLength,this.entries.delete(n)}this.entries.set(e,t),this.currentBytes+=s}}get stats(){return{entries:this.entries.size,bytes:this.currentBytes,hits:this.hits,misses:this.misses}}},St=["multi_ack_detailed","no-done","side-band-64k","ofs-delta","include-tag"],Tt=["report-status","side-band-64k","ofs-delta","delete-refs"];async function ie(r){let e=await r.refStore.listRefs("refs"),t=await r.refStore.readRef("HEAD"),s=[],n=null,a;if(t)if(t.type==="symbolic"){a=t.target;let i=await r.refStore.readRef(t.target);i?.type==="direct"&&(n=i.hash)}else n=t.hash;n&&s.push({name:"HEAD",hash:n});for(let i of e)if(s.push({name:i.name,hash:i.hash}),i.name.startsWith("refs/tags/"))try{let o=await r.objectStore.read(i.hash);if(o.type==="tag"){let f=j(o.content);s.push({name:`${i.name}^{}`,hash:f.object})}}catch{}return{refs:s,headTarget:a}}function ce(r,e,t){return Je(r,e,e==="git-upload-pack"?St:Tt,t)}async function fe(r,e,t){let{wants:s,haves:n,capabilities:a}=Qe(e);if(s.length===0)return U(new Uint8Array(0),!1);let i=a.includes("multi_ack_detailed"),o=a.includes("side-band-64k"),f;if(i&&n.length>0){f=[];for(let d of n)await r.objectStore.exists(d)&&f.push(d);f.length===0&&(f=void 0)}let c=t?.cache&&t.cacheKey?C.key(t.cacheKey,s,n):null;if(c&&t?.cache){let d=t.cache.get(c);if(d)return U(d.packData,o,f)}return t?.noDelta?Ut(r,s,n,a,o,f):Ct(r,s,n,a,o,f,t,c)}async function Ut(r,e,t,s,n,a){let{count:i,objects:o}=await oe(r,e,t);if(i===0){let p=U(new Uint8Array(0),n,a);return new ReadableStream({start(b){b.enqueue(p),b.close()}})}let f=[];for await(let p of o)f.push(p);let c=new Set(f.map(p=>p.hash)),d=[];if(s.includes("include-tag")){let p=await r.refStore.listRefs("refs/tags");for(let b of p)if(!c.has(b.hash))try{let m=await r.objectStore.read(b.hash);if(m.type==="tag"){let P=j(m.content);c.has(P.object)&&d.push({hash:b.hash,type:"tag",content:m.content})}}catch{}}let u=f.length+d.length;async function*l(){for(let p of f){let b=await r.objectStore.read(p.hash);yield{type:b.type,content:b.content}}for(let p of d)yield{type:p.type,content:p.content}}let h=De(u,l()),y=et(h,n,a);return new ReadableStream({async pull(p){let{value:b,done:m}=await y.next();m?p.close():p.enqueue(b)}})}async function Ct(r,e,t,s,n,a,i,o){let f=await qe(r,e,t);if(f.count===0)return U(new Uint8Array(0),n,a);let c=await ze(f),d=new Set(c.map(p=>p.hash));if(s.includes("include-tag")){let p=await r.refStore.listRefs("refs/tags");for(let b of p)if(!d.has(b.hash))try{let m=await r.objectStore.read(b.hash);if(m.type==="tag"){let P=j(m.content);d.has(P.object)&&(c.push({hash:b.hash,type:"tag",content:m.content}),d.add(b.hash))}}catch{}}let u=i?.deltaWindow?{window:i.deltaWindow}:void 0,l=Fe(c,u),h=l.map(p=>({hash:p.hash,type:p.type,content:p.content,delta:p.delta,deltaBaseHash:p.deltaBase})),{data:y}=await He(h);if(o&&i?.cache){let p=l.filter(b=>b.delta).length;i.cache.set(o,{packData:y,objectCount:c.length,deltaCount:p})}return U(y,n,a)}async function de(r,e){let{commands:t,packData:s,capabilities:n}=tt(e),a=!0;if(s.byteLength>0)try{await r.objectStore.ingestPack(s)}catch{a=!1}let i=[];for(let o of t){let f=o.oldHash===Z,c=o.newHash===Z,d=!1;if(!f&&!c&&a)try{d=await _e(r,o.oldHash,o.newHash)}catch{}i.push({ref:o.refName,oldHash:f?null:o.oldHash,newHash:o.newHash,isFF:d,isCreate:f,isDelete:c})}return{updates:i,unpackOk:a,capabilities:n}}function Lt(r){let{resolveRepo:e,hooks:t,basePath:s}=r,n=r.packCache===!1?void 0:new C(r.packCache?.maxBytes);return{async fetch(a){try{let i=new URL(a.url),o=decodeURIComponent(i.pathname);if(s){let f=s.replace(/\/+$/,"");if(!o.startsWith(f))return new Response("Not Found",{status:404});o=o.slice(f.length)}if(o.startsWith("/")||(o=`/${o}`),o.endsWith("/info/refs")&&a.method==="GET"){let f=i.searchParams.get("service");if(f!=="git-upload-pack"&&f!=="git-receive-pack")return new Response("Unsupported service",{status:403});let c=le(o,"/info/refs"),d=await e(c,a);if(d instanceof Response)return d;if(!d)return new Response("Not Found",{status:404});let u=d,{refs:l,headTarget:h}=await ie(u),y=l;if(t?.advertiseRefs){let b=await t.advertiseRefs({repo:u,repoPath:c,refs:l,service:f,request:a});b&&(y=b)}let p=ce(y,f,h);return new Response(p,{headers:{"Content-Type":`application/x-${f}-advertisement`,"Cache-Control":"no-cache"}})}if(o.endsWith("/git-upload-pack")&&a.method==="POST"){let f=le(o,"/git-upload-pack"),c=await e(f,a);if(c instanceof Response)return c;if(!c)return new Response("Not Found",{status:404});let d=c,u=await rt(a),l=await fe(d,u,{cache:n,cacheKey:f,noDelta:r.packOptions?.noDelta,deltaWindow:r.packOptions?.deltaWindow});return new Response(l,{headers:{"Content-Type":"application/x-git-upload-pack-result"}})}if(o.endsWith("/git-receive-pack")&&a.method==="POST"){let f=le(o,"/git-receive-pack"),c=await e(f,a);if(c instanceof Response)return c;if(!c)return new Response("Not Found",{status:404});let d=c,u=await rt(a),{updates:l,unpackOk:h,capabilities:y}=await de(d,u),p=y.includes("side-band-64k"),b=y.includes("report-status");if(!h){if(b){let x=l.map(g=>({name:g.ref,ok:!1,error:"unpack failed"}));return new Response(V(!1,x,p),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response(new Uint8Array(0),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}if(t?.preReceive){let x=await t.preReceive({repo:d,repoPath:f,updates:l,request:a});if(H(x)){if(b){let g=x.message??"pre-receive hook declined",O=l.map(L=>({name:L.ref,ok:!1,error:g}));return new Response(V(!0,O,p),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response(new Uint8Array(0),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}}let m=[],P=[];for(let x of l){if(t?.update){let g=await t.update({repo:d,repoPath:f,update:x,request:a});if(H(g)){m.push({ref:x.ref,ok:!1,error:g.message??"update hook declined"});continue}}try{let g=x.isCreate?null:x.oldHash,O=x.isDelete?null:{type:"direct",hash:x.newHash};if(!await d.refStore.compareAndSwapRef(x.ref,g,O)){m.push({ref:x.ref,ok:!1,error:"failed to lock"});continue}m.push({ref:x.ref,ok:!0}),P.push(x)}catch(g){m.push({ref:x.ref,ok:!1,error:g instanceof Error?g.message:String(g)})}}if(t?.postReceive&&P.length>0)try{await t.postReceive({repo:d,repoPath:f,updates:P,request:a})}catch{}if(b){let x=m.map(g=>({name:g.ref,ok:g.ok,error:g.error}));return new Response(V(!0,x,p),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response(new Uint8Array(0),{headers:{"Content-Type":"application/x-git-receive-pack-result"}})}return new Response("Not Found",{status:404})}catch(i){return console.error(" [server] Internal error:",i),new Response("Internal Server Error",{status:500})}}}}function le(r,e){let t=r.slice(0,-e.length);return t.startsWith("/")&&(t=t.slice(1)),t}async function rt(r){let e=new Uint8Array(await r.arrayBuffer()),t=r.headers.get("content-encoding");if(t==="gzip"||t==="x-gzip"){let s=new DecompressionStream("gzip"),n=s.writable.getWriter();return n.write(e),n.close(),new Uint8Array(await new Response(s.readable).arrayBuffer())}return e}function Ht(...r){let e=r.filter(o=>o!=null);if(e.length===0)return{};if(e.length===1)return e[0];let t={},s=e.filter(o=>o.preReceive).map(o=>o.preReceive);s.length>0&&(t.preReceive=async o=>{for(let f of s){let c=await f(o);if(H(c))return c}});let n=e.filter(o=>o.update).map(o=>o.update);n.length>0&&(t.update=async o=>{for(let f of n){let c=await f(o);if(H(c))return c}});let a=e.filter(o=>o.postReceive).map(o=>o.postReceive);a.length>0&&(t.postReceive=async o=>{for(let f of a)try{await f(o)}catch{}});let i=e.filter(o=>o.advertiseRefs).map(o=>o.advertiseRefs);return i.length>0&&(t.advertiseRefs=async o=>{let f=o.refs;for(let c of i){let d=await c({...o,refs:f});d&&(f=d)}return f}),t}function Dt(r){let{protectedBranches:e=[],denyNonFastForward:t=!1,denyDeletes:s=!1,denyDeleteTags:n=!1,authorize:a,onPush:i}=r,o=new Set(e.map(c=>c.startsWith("refs/")?c:`refs/heads/${c}`)),f={};return(a||o.size>0)&&(f.preReceive=async c=>{if(a&&!await a(c.request))return{reject:!0,message:"unauthorized"};for(let d of c.updates)if(o.has(d.ref)){if(d.isDelete)return{reject:!0,message:`cannot delete protected branch ${d.ref}`};if(!d.isCreate&&!d.isFF)return{reject:!0,message:`non-fast-forward push to protected branch ${d.ref}`}}}),(t||s||n)&&(f.update=async c=>{if(s&&c.update.isDelete)return{reject:!0,message:"ref deletion denied"};if(n&&c.update.ref.startsWith("refs/tags/")){if(c.update.isDelete)return{reject:!0,message:"tag deletion denied"};if(!c.update.isCreate)return{reject:!0,message:"tag overwrite denied"}}if(t&&!c.update.isCreate&&!c.update.isDelete&&!c.update.isFF)return{reject:!0,message:"non-fast-forward"}}),i&&(f.postReceive=i),f}var pe=class{objects=new Map;refs=new Map;repo(e){return{objectStore:new ue(this.getObjects(e)),refStore:new he(this.getRefs(e))}}async deleteRepo(e){this.objects.get(e)?.clear(),this.objects.delete(e),this.refs.get(e)?.clear(),this.refs.delete(e)}getObjects(e){let t=this.objects.get(e);return t||(t=new Map,this.objects.set(e,t)),t}getRefs(e){let t=this.refs.get(e);return t||(t=new Map,this.refs.set(e,t)),t}},ue=class{constructor(e){this.store=e}async write(e,t){let s=await v(S(e,t));return this.store.has(s)||this.store.set(s,{type:e,content:new Uint8Array(t)}),s}async read(e){let t=this.store.get(e);if(!t)throw new Error(`object ${e} not found`);return{type:t.type,content:new Uint8Array(t.content)}}async exists(e){return this.store.has(e)}async ingestPack(e){if(e.byteLength<32||new DataView(e.buffer,e.byteOffset,e.byteLength).getUint32(8)===0)return 0;let n=this.store,a=await A(e,async i=>{let o=n.get(i);return o?{type:o.type,content:new Uint8Array(o.content)}:null});for(let i of a)n.has(i.hash)||n.set(i.hash,{type:i.type,content:i.content});return a.length}async findByPrefix(e){if(e.length<4)return[];let t=[];for(let s of this.store.keys())s.startsWith(e)&&t.push(s);return t}},he=class{constructor(e){this.store=e}async readRef(e){return this.store.get(e)??null}async writeRef(e,t){this.store.set(e,t)}async deleteRef(e){this.store.delete(e)}async compareAndSwapRef(e,t,s){let n=this.store.get(e)??null,a=null;if(n&&(n.type==="direct"?a=n.hash:n.type==="symbolic"&&(a=this.resolveChain(n.target))),t===null){if(n!==null)return!1}else if(a!==t)return!1;return s===null?this.store.delete(e):this.store.set(e,s),!0}async listRefs(e){let t=[];for(let[s,n]of this.store)if(!(e&&!s.startsWith(e))){if(n.type==="direct")t.push({name:s,hash:n.hash});else if(n.type==="symbolic"){let a=this.resolveChain(n.target);a&&t.push({name:s,hash:a})}}return t}resolveChain(e,t=0){if(t>10)return null;let s=this.store.get(e);return s?s.type==="direct"?s.hash:s.type==="symbolic"?this.resolveChain(s.target,t+1):null:null}};var Nt=`
26
26
  CREATE TABLE IF NOT EXISTS git_objects (
27
27
  repo_id TEXT NOT NULL,
28
28
  hash TEXT NOT NULL,
@@ -39,4 +39,22 @@ CREATE TABLE IF NOT EXISTS git_refs (
39
39
  target TEXT,
40
40
  PRIMARY KEY (repo_id, name)
41
41
  ) WITHOUT ROWID;
42
- `;function St(n){return{objInsert:n.prepare("INSERT OR IGNORE INTO git_objects (repo_id, hash, type, content) VALUES (?, ?, ?, ?)"),objRead:n.prepare("SELECT type, content FROM git_objects WHERE repo_id = ? AND hash = ?"),objExists:n.prepare("SELECT 1 FROM git_objects WHERE repo_id = ? AND hash = ? LIMIT 1"),objPrefix:n.prepare("SELECT hash FROM git_objects WHERE repo_id = ? AND hash GLOB ?"),objDeleteAll:n.prepare("DELETE FROM git_objects WHERE repo_id = ?"),refRead:n.prepare("SELECT type, hash, target FROM git_refs WHERE repo_id = ? AND name = ?"),refWrite:n.prepare("INSERT OR REPLACE INTO git_refs (repo_id, name, type, hash, target) VALUES (?, ?, ?, ?, ?)"),refDelete:n.prepare("DELETE FROM git_refs WHERE repo_id = ? AND name = ?"),refList:n.prepare("SELECT name, type, hash, target FROM git_refs WHERE repo_id = ? AND name GLOB ?"),refListAll:n.prepare("SELECT name, type, hash, target FROM git_refs WHERE repo_id = ?"),refDeleteAll:n.prepare("DELETE FROM git_refs WHERE repo_id = ?")}}var ce=class{db;stmts;ingestTx;constructor(e){this.db=e,e.run(Et),this.stmts=St(e),this.ingestTx=e.transaction(t=>{for(let o of t)this.stmts.objInsert.run(o.repoId,o.hash,o.type,o.content)})}repo(e){return{objectStore:new fe(this.stmts,this.ingestTx,e),refStore:new de(this.stmts,this.db,e)}}deleteRepo(e){this.stmts.objDeleteAll.run(e),this.stmts.refDeleteAll.run(e)}},fe=class{constructor(e,t,o){this.stmts=e;this.ingestTx=t;this.repoId=o;this.cache=new _}cache;async write(e,t){let o=Ae(e,t),r=await be(o);return this.stmts.objInsert.run(this.repoId,r,e,t),r}async read(e){let t=this.cache.get(e);if(t)return t;let o=this.stmts.objRead.get(this.repoId,e);if(!o)throw new Error(`object ${e} not found`);let r={type:o.type,content:new Uint8Array(o.content)};return this.cache.set(e,r),r}async exists(e){return this.stmts.objExists.get(this.repoId,e)!==null}async ingestPack(e){if(e.byteLength<32||new DataView(e.buffer,e.byteOffset,e.byteLength).getUint32(8)===0)return 0;let r=await je(e,async i=>{let s=this.stmts.objRead.get(this.repoId,i);return s?{type:s.type,content:new Uint8Array(s.content)}:null}),a=r.map(i=>({repoId:this.repoId,hash:i.hash,type:i.type,content:i.content}));return this.ingestTx(a),r.length}async findByPrefix(e){return e.length<4?[]:this.stmts.objPrefix.all(this.repoId,`${e}*`).map(o=>o.hash)}},de=class{constructor(e,t,o){this.stmts=e;this.repoId=o;let r=e,a=o;this.casTx=t.transaction((i,s,f)=>{let c=r.refRead.get(a,i),d=null;if(c&&(c.type==="direct"?d=c.hash:c.type==="symbolic"&&c.target&&(d=le(r,a,c.target))),s===null){if(c!==null)return!1}else if(d!==s)return!1;return f===null?r.refDelete.run(a,i):f.type==="symbolic"?r.refWrite.run(a,i,"symbolic",null,f.target):r.refWrite.run(a,i,"direct",f.hash,null),!0})}casTx;async readRef(e){let t=this.stmts.refRead.get(this.repoId,e);return t?t.type==="symbolic"?{type:"symbolic",target:t.target}:{type:"direct",hash:t.hash}:null}async writeRef(e,t){t.type==="symbolic"?this.stmts.refWrite.run(this.repoId,e,"symbolic",null,t.target):this.stmts.refWrite.run(this.repoId,e,"direct",t.hash,null)}async deleteRef(e){this.stmts.refDelete.run(this.repoId,e)}async compareAndSwapRef(e,t,o){return this.casTx(e,t,o)}async listRefs(e){let t;e?t=this.stmts.refList.all(this.repoId,`${e}*`):t=this.stmts.refListAll.all(this.repoId);let o=[];for(let r of t)if(r.type==="direct"&&r.hash)o.push({name:r.name,hash:r.hash});else if(r.type==="symbolic"&&r.target){let a=le(this.stmts,this.repoId,r.target);a&&o.push({name:r.name,hash:a})}return o}};function le(n,e,t,o=0){if(o>10)return null;let r=n.refRead.get(e,t);return r?r.type==="direct"?r.hash:r.type==="symbolic"&&r.target?le(n,e,r.target,o+1):null:null}export{A as PackCache,ce as SqliteStorage,oe as buildRefAdvertisementBytes,re as collectRefs,It as composeHooks,vt as createGitServer,At as createStandardHooks,se as handleUploadPack,ae as ingestReceivePack};
42
+ `;function Bt(r){return{objInsert:r.prepare("INSERT OR IGNORE INTO git_objects (repo_id, hash, type, content) VALUES (?, ?, ?, ?)"),objRead:r.prepare("SELECT type, content FROM git_objects WHERE repo_id = ? AND hash = ?"),objExists:r.prepare("SELECT 1 FROM git_objects WHERE repo_id = ? AND hash = ? LIMIT 1"),objPrefix:r.prepare("SELECT hash FROM git_objects WHERE repo_id = ? AND hash GLOB ?"),objDeleteAll:r.prepare("DELETE FROM git_objects WHERE repo_id = ?"),refRead:r.prepare("SELECT type, hash, target FROM git_refs WHERE repo_id = ? AND name = ?"),refWrite:r.prepare("INSERT OR REPLACE INTO git_refs (repo_id, name, type, hash, target) VALUES (?, ?, ?, ?, ?)"),refDelete:r.prepare("DELETE FROM git_refs WHERE repo_id = ? AND name = ?"),refList:r.prepare("SELECT name, type, hash, target FROM git_refs WHERE repo_id = ? AND name GLOB ?"),refListAll:r.prepare("SELECT name, type, hash, target FROM git_refs WHERE repo_id = ?"),refDeleteAll:r.prepare("DELETE FROM git_refs WHERE repo_id = ?")}}var ye=class{db;stmts;ingestTx;constructor(e){this.db=e,e.run(Nt),this.stmts=Bt(e),this.ingestTx=e.transaction(t=>{for(let s of t)this.stmts.objInsert.run(s.repoId,s.hash,s.type,s.content)})}repo(e){return{objectStore:new be(this.stmts,this.ingestTx,e),refStore:new me(this.stmts,this.db,e)}}async deleteRepo(e){this.stmts.objDeleteAll.run(e),this.stmts.refDeleteAll.run(e)}},be=class{constructor(e,t,s){this.stmts=e;this.ingestTx=t;this.repoId=s;this.cache=new I}cache;async write(e,t){let s=S(e,t),n=await v(s);return this.stmts.objInsert.run(this.repoId,n,e,t),n}async read(e){let t=this.cache.get(e);if(t)return t;let s=this.stmts.objRead.get(this.repoId,e);if(!s)throw new Error(`object ${e} not found`);let n={type:s.type,content:new Uint8Array(s.content)};return this.cache.set(e,n),n}async exists(e){return this.stmts.objExists.get(this.repoId,e)!==null}async ingestPack(e){if(e.byteLength<32||new DataView(e.buffer,e.byteOffset,e.byteLength).getUint32(8)===0)return 0;let n=await A(e,async i=>{let o=this.stmts.objRead.get(this.repoId,i);return o?{type:o.type,content:new Uint8Array(o.content)}:null}),a=n.map(i=>({repoId:this.repoId,hash:i.hash,type:i.type,content:i.content}));return this.ingestTx(a),n.length}async findByPrefix(e){return e.length<4?[]:this.stmts.objPrefix.all(this.repoId,`${e}*`).map(s=>s.hash)}},me=class{constructor(e,t,s){this.stmts=e;this.repoId=s;let n=e,a=s;this.casTx=t.transaction((i,o,f)=>{let c=n.refRead.get(a,i),d=null;if(c&&(c.type==="direct"?d=c.hash:c.type==="symbolic"&&c.target&&(d=xe(n,a,c.target))),o===null){if(c!==null)return!1}else if(d!==o)return!1;return f===null?n.refDelete.run(a,i):f.type==="symbolic"?n.refWrite.run(a,i,"symbolic",null,f.target):n.refWrite.run(a,i,"direct",f.hash,null),!0})}casTx;async readRef(e){let t=this.stmts.refRead.get(this.repoId,e);return t?t.type==="symbolic"?{type:"symbolic",target:t.target}:{type:"direct",hash:t.hash}:null}async writeRef(e,t){t.type==="symbolic"?this.stmts.refWrite.run(this.repoId,e,"symbolic",null,t.target):this.stmts.refWrite.run(this.repoId,e,"direct",t.hash,null)}async deleteRef(e){this.stmts.refDelete.run(this.repoId,e)}async compareAndSwapRef(e,t,s){return this.casTx(e,t,s)}async listRefs(e){let t;e?t=this.stmts.refList.all(this.repoId,`${e}*`):t=this.stmts.refListAll.all(this.repoId);let s=[];for(let n of t)if(n.type==="direct"&&n.hash)s.push({name:n.name,hash:n.hash});else if(n.type==="symbolic"&&n.target){let a=xe(this.stmts,this.repoId,n.target);a&&s.push({name:n.name,hash:a})}return s}};function xe(r,e,t,s=0){if(s>10)return null;let n=r.refRead.get(e,t);return n?n.type==="direct"?n.hash:n.type==="symbolic"&&n.target?xe(r,e,n.target,s+1):null:null}function $t(r){return{query:(e,t)=>r.query(e,t),async transaction(e){let t=await r.connect();try{await t.query("BEGIN");let n=await e({query:(a,i)=>t.query(a,i),transaction:()=>{throw new Error("nested transactions not supported")}});return await t.query("COMMIT"),n}catch(s){throw await t.query("ROLLBACK"),s}finally{t.release()}}}}var _t=`
43
+ CREATE TABLE IF NOT EXISTS git_objects (
44
+ repo_id TEXT NOT NULL,
45
+ hash TEXT NOT NULL,
46
+ type TEXT NOT NULL,
47
+ content BYTEA NOT NULL,
48
+ PRIMARY KEY (repo_id, hash)
49
+ );
50
+
51
+ CREATE TABLE IF NOT EXISTS git_refs (
52
+ repo_id TEXT NOT NULL,
53
+ name TEXT NOT NULL,
54
+ type TEXT NOT NULL CHECK(type IN ('direct', 'symbolic')),
55
+ hash TEXT,
56
+ target TEXT,
57
+ PRIMARY KEY (repo_id, name)
58
+ );
59
+ `,w={objInsert:"INSERT INTO git_objects (repo_id, hash, type, content) VALUES ($1, $2, $3, $4) ON CONFLICT DO NOTHING",objRead:"SELECT type, content FROM git_objects WHERE repo_id = $1 AND hash = $2",objExists:"SELECT 1 FROM git_objects WHERE repo_id = $1 AND hash = $2 LIMIT 1",objPrefix:"SELECT hash FROM git_objects WHERE repo_id = $1 AND hash LIKE $2",objDeleteAll:"DELETE FROM git_objects WHERE repo_id = $1",refRead:"SELECT type, hash, target FROM git_refs WHERE repo_id = $1 AND name = $2",refReadForUpdate:"SELECT type, hash, target FROM git_refs WHERE repo_id = $1 AND name = $2 FOR UPDATE",refWrite:`INSERT INTO git_refs (repo_id, name, type, hash, target) VALUES ($1, $2, $3, $4, $5)
60
+ ON CONFLICT (repo_id, name) DO UPDATE SET type = EXCLUDED.type, hash = EXCLUDED.hash, target = EXCLUDED.target`,refDelete:"DELETE FROM git_refs WHERE repo_id = $1 AND name = $2",refList:"SELECT name, type, hash, target FROM git_refs WHERE repo_id = $1 AND name LIKE $2",refListAll:"SELECT name, type, hash, target FROM git_refs WHERE repo_id = $1",refDeleteAll:"DELETE FROM git_refs WHERE repo_id = $1"},ge=class r{constructor(e){this.db=e}static async create(e){return await e.query(_t),new r(e)}repo(e){return{objectStore:new we(this.db,e),refStore:new Re(this.db,e)}}async deleteRepo(e){await this.db.query(w.objDeleteAll,[e]),await this.db.query(w.refDeleteAll,[e])}},we=class{constructor(e,t){this.db=e;this.repoId=t;this.cache=new I}cache;async write(e,t){let s=S(e,t),n=await v(s);return await this.db.query(w.objInsert,[this.repoId,n,e,t]),n}async read(e){let t=this.cache.get(e);if(t)return t;let{rows:s}=await this.db.query(w.objRead,[this.repoId,e]),n=s[0];if(!n)throw new Error(`object ${e} not found`);let a={type:n.type,content:new Uint8Array(n.content)};return this.cache.set(e,a),a}async exists(e){let{rows:t}=await this.db.query(w.objExists,[this.repoId,e]);return t.length>0}async ingestPack(e){if(e.byteLength<32||new DataView(e.buffer,e.byteOffset,e.byteLength).getUint32(8)===0)return 0;let n=this.db,a=this.repoId,i=await A(e,async o=>{let{rows:f}=await n.query(w.objRead,[a,o]),c=f[0];return c?{type:c.type,content:new Uint8Array(c.content)}:null});return await n.transaction(async o=>{for(let f of i)await o.query(w.objInsert,[a,f.hash,f.type,f.content])}),i.length}async findByPrefix(e){if(e.length<4)return[];let{rows:t}=await this.db.query(w.objPrefix,[this.repoId,`${e}%`]);return t.map(s=>s.hash)}},Re=class{constructor(e,t){this.db=e;this.repoId=t}async readRef(e){let{rows:t}=await this.db.query(w.refRead,[this.repoId,e]),s=t[0];return s?s.type==="symbolic"?{type:"symbolic",target:s.target}:{type:"direct",hash:s.hash}:null}async writeRef(e,t){t.type==="symbolic"?await this.db.query(w.refWrite,[this.repoId,e,"symbolic",null,t.target]):await this.db.query(w.refWrite,[this.repoId,e,"direct",t.hash,null])}async deleteRef(e){await this.db.query(w.refDelete,[this.repoId,e])}async compareAndSwapRef(e,t,s){return this.db.transaction(async n=>{let{rows:a}=await n.query(w.refReadForUpdate,[this.repoId,e]),i=a[0]??null,o=null;if(i&&(i.type==="direct"?o=i.hash:i.type==="symbolic"&&i.target&&(o=await Pe(n,this.repoId,i.target))),t===null){if(i!==null)return!1}else if(o!==t)return!1;return s===null?await n.query(w.refDelete,[this.repoId,e]):s.type==="symbolic"?await n.query(w.refWrite,[this.repoId,e,"symbolic",null,s.target]):await n.query(w.refWrite,[this.repoId,e,"direct",s.hash,null]),!0})}async listRefs(e){let t;e?{rows:t}=await this.db.query(w.refList,[this.repoId,`${e}%`]):{rows:t}=await this.db.query(w.refListAll,[this.repoId]);let s=[];for(let n of t)if(n.type==="direct"&&n.hash)s.push({name:n.name,hash:n.hash});else if(n.type==="symbolic"&&n.target){let a=await Pe(this.db,this.repoId,n.target);a&&s.push({name:n.name,hash:a})}return s}};async function Pe(r,e,t,s=0){if(s>10)return null;let{rows:n}=await r.query(w.refRead,[e,t]),a=n[0];return a?a.type==="direct"?a.hash:a.type==="symbolic"&&a.target?Pe(r,e,a.target,s+1):null:null}export{pe as MemoryStorage,C as PackCache,ge as PgStorage,ye as SqliteStorage,ce as buildRefAdvertisementBytes,ie as collectRefs,Ht as composeHooks,Lt as createGitServer,Dt as createStandardHooks,fe as handleUploadPack,de as ingestReceivePack,$t as wrapPgPool};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "just-git",
3
- "version": "1.1.3",
3
+ "version": "1.1.4",
4
4
  "description": "Pure TypeScript git implementation: virtual filesystem client and embeddable server.",
5
5
  "keywords": [
6
6
  "agent",
@@ -52,10 +52,12 @@
52
52
  "devDependencies": {
53
53
  "@types/bun": "latest",
54
54
  "@types/node": "^25.4.0",
55
+ "@types/pg": "^8.18.0",
55
56
  "just-bash": "^2.9.7",
56
57
  "knip": "^5.86.0",
57
58
  "oxfmt": "^0.38.0",
58
59
  "oxlint": "^1.53.0",
60
+ "pg": "^8.20.0",
59
61
  "tsup": "^8.5.1",
60
62
  "typescript": "^5.9.3"
61
63
  }