pup-recorder 0.3.0 → 0.3.2

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/dist/app.cjs CHANGED
@@ -1,4 +1,4 @@
1
- 'use strict';require('source-map-support/register.js');var assert=require('assert'),electron=require('electron'),promises=require('fs/promises'),path=require('path'),module$1=require('module'),nodeAv=require('node-av'),constants=require('node-av/constants'),commander=require('commander'),C=require('zod'),net=require('net'),api=require('node-av/api'),crypto=require('crypto'),os=require('os'),promises$1=require('timers/promises'),url=require('url');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var C__default=/*#__PURE__*/_interopDefault(C);var pr=Object.create;var Ae=Object.defineProperty;var mr=Object.getOwnPropertyDescriptor;var ae=(r,e)=>(e=Symbol[r])?e:Symbol.for("Symbol."+r),T=r=>{throw TypeError(r)};var nt=(r,e,t)=>e in r?Ae(r,e,{enumerable:true,configurable:true,writable:true,value:t}):r[e]=t;var at=r=>[,,,pr(null)],st=["class","method","getter","setter","accessor","field","value","get","set"],Z=r=>r!==void 0&&typeof r!="function"?T("Function expected"):r,lr=(r,e,t,o,i)=>({kind:st[r],name:e,metadata:o,addInitializer:n=>t._?T("Already initialized"):i.push(Z(n||null))}),ke=(r,e)=>nt(e,ae("metadata"),r[3]),ct=(r,e,t,o)=>{for(var i=0,n=r[e>>1],c=n&&n.length;i<c;i++)n[i].call(t);return o},U=(r,e,t,o,i,n)=>{var s,a,u,p,d=e&7,m=false,l=false,g=2,b=st[d+5],E=r[g]||(r[g]=[]),x=((i=i.prototype),mr(i,t));for(var y=o.length-1;y>=0;y--)u=lr(d,t,a={},r[3],E),(u.static=m,u.private=l,p=u.access={has:h=>t in h},(p.get=h=>h[t]),d>2),s=(0, o[y])(x[b],u),a._=1,Z(s)&&(x[b]=s);return x&&Ae(i,t,x),i},ut=(r,e,t)=>nt(r,e+"",t);var v=(r,e,t)=>{if(e!=null){typeof e!="object"&&typeof e!="function"&&T("Object expected");var o,i;t&&(o=e[ae("asyncDispose")]),o===void 0&&(o=e[ae("dispose")],t&&(i=o)),typeof o!="function"&&T("Object not disposable"),i&&(o=function(){try{i.call(this);}catch(n){return Promise.reject(n)}}),r.push([t,o,e]);}else t&&r.push([t]);return e},F=(r,e,t)=>{var o=typeof SuppressedError=="function"?SuppressedError:function(c,s,a,u){return u=Error(a),u.name="SuppressedError",u.error=c,u.suppressed=s,u},i=c=>e=t?new o(c,e,"An error was suppressed during disposal"):(t=true,c),n=c=>{for(;c=r.pop();)try{var s=c[1]&&c[1].call(c[2]);if(c[0])return Promise.resolve(s).then(n,a=>(i(a),n()))}catch(a){i(a);}if(t)throw e};return n()};var wr=()=>typeof document>"u"?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.tagName.toUpperCase()==="SCRIPT"?document.currentScript.src:new URL("main.js",document.baseURI).href,f=wr();function dt(r,e,t){try{return e(process.env[r])}catch{return t}}function B(r){if(typeof r=="number")return r;let e=Number(r);if(Number.isNaN(e))throw new Error(`Value ${r} is not a valid number`);return e}var xr=module$1.createRequire(f),ee=process.env,pt=dt("PUP_LOG_LEVEL",B,2),mt=ee.PUP_USE_INNER_PROXY==="1",lt=ee.PUP_DISABLE_GPU==="1",ft=ee.PUP_DETERMINISTIC==="1",yr=path.dirname(xr.resolve("pup-recorder/package.json"));path.join(yr,"dist","app.cjs");var Te=ee.PUP_IPC_SOCKET;ee.PUP_EXPERIMENTAL_PUPPETEER==="1";var Be="<pup@debug>",Oe="<pup@info>",Me="<pup@warn>",Ne="<pup@error>",De="<pup@fatal>";function te(r,e){return function(...t){let o=t.map(i=>i instanceof Error?i.stack??String(i):i);return r.call(this,...o)}}var ht,wt,_t,gt,bt,O;bt=[te],gt=[te],_t=[te],wt=[te],ht=[te];var k=class{constructor(e=pt){this._level=e;ct(O,5,this);ut(this,"_impl");this.impl=console;}_level;get level(){return this._level}set level(e){this._level=e,this.impl=this._impl??console;}get impl(){return this._impl}set impl(e){let t=e.debug??console.debug,o=e.info??console.info,i=e.warn??console.warn,n=e.error??console.error,c=this._level;this._impl={debug:c>=3?t:void 0,info:c>=2?o:void 0,warn:c>=1?i:void 0,error:c>=0?n:void 0};}debug(...e){this.impl?.debug?.(Be,...e);}info(...e){this.impl?.info?.(Oe,...e);}warn(...e){this.impl?.warn?.(Me,...e);}error(...e){this.impl?.error?.(Ne,...e);}fatal(...e){this.impl?.error?.(De,...e),process.exit(1);}dispatch(e){let t=e.trimEnd();t.startsWith(Be)?this.debug(t.slice(Be.length+1)):t.startsWith(Oe)?this.info(t.slice(Oe.length+1)):t.startsWith(Me)?this.warn(t.slice(Me.length+1)):t.startsWith(Ne)?this.error(t.slice(Ne.length+1)):this.info(t);}attach(e,t){return new Promise((o,i)=>{this.debug(`${t}.attach`);let n="",c=s=>{let a=s.toString();a.startsWith(De)?n+=a.slice(De.length+1):this.dispatch(a);};e.stderr?.on("data",c),e.stdout?.on("data",c),e.on("message",c).on("error",s=>{n+=s.message,e.kill();}).once("close",(s,a)=>{s||a||n?(n||=`command failed: ${e.spawnargs.join(" ")}`,this.debug(`${t}.close`,{code:s,signal:a,fatal:n}),i(new Error(n))):(this.debug(`${t}.close`),o());}).on("unhandledRejection",s=>{this.error(`${t}.unhandled`,s);}).on("uncaughtExceptionMonitor",s=>{this.error(`${t}.unhandled`,s);});})}};O=at(),U(O,1,"debug",bt,k),U(O,1,"info",gt,k),U(O,1,"warn",_t,k),U(O,1,"error",wt,k),U(O,1,"fatal",ht,k),ke(O,k);var _=new k;nodeAv.Log.setCallback((r,e)=>{let t=e.trimEnd();t&&(r<=constants.AV_LOG_ERROR?_.error(t):r<=constants.AV_LOG_WARNING&&_.warn(t));});function re(r,e){return (...t)=>{try{let o=r(...t);return o instanceof Promise?o.catch(()=>e):o}catch{return e}}}var Pr="--pup-priv-args";function xt(){let r=process.argv,e=r.find(o=>o.startsWith(Pr));if(!e)return _.debug("procargv",r),process.argv;let t=["exec",...r.slice(-1)];return e=Buffer.from(e.split("=")[1],"base64").toString(),t.push(...JSON.parse(e)),_.debug("pupargs",t),t}var Sr=1920,Cr=1080,Ir=30,Ar=5,kr="output.mp4",yt=C__default.default.object({duration:C__default.default.number().describe("Duration in seconds"),width:C__default.default.number().describe("Video width"),height:C__default.default.number().describe("Video height"),fps:C__default.default.number().describe("Frames per second"),withAudio:C__default.default.boolean().describe("Capture and encode audio"),outFile:C__default.default.string().describe("Output mp4 file path"),useInnerProxy:C__default.default.boolean().describe("Use bilibili inner proxy for resource access"),deterministic:C__default.default.boolean().describe("Render by frame rather than recording"),disableGpu:C__default.default.boolean().describe("Disable GPU rendering, may reduce performance but increase stability")}),Et={width:Sr,height:Cr,fps:Ir,duration:Ar,outFile:kr,withAudio:false,useInnerProxy:mt,deterministic:ft,disableGpu:lt};async function Ft(r){let e=yt.shape,t=r.defaults;commander.program.name(r.name).argument("<source>","file://, http(s)://, or data: URI").option("-W, --width <number>",e.width.description,`${t.width}`).option("-H, --height <number>",e.height.description,`${t.height}`).option("-f, --fps <number>",e.fps.description,`${t.fps}`).option("-t, --duration <number>",e.duration.description,`${t.duration}`).option("-o, --out-file <path>",e.outFile.description,t.outFile).option("-a, --with-audio",e.withAudio.description,t.withAudio).option("-d, --deterministic",e.deterministic.description,t.deterministic).option("--use-inner-proxy",e.useInnerProxy.description,t.useInnerProxy).option("--disable-gpu",e.disableGpu.description,t.disableGpu).action(async(o,i)=>{try{await r.run(o,{width:re(B,t.width)(i.width),height:re(B,t.height)(i.height),fps:re(B,t.fps)(i.fps),duration:re(B,t.duration)(i.duration),outFile:i.outFile??t.outFile,withAudio:i.withAudio??t.withAudio,useInnerProxy:i.useInnerProxy??t.useInnerProxy,deterministic:i.deterministic??t.deterministic,disableGpu:i.disableGpu??t.disableGpu});}catch(n){_.fatal(n);}}),await commander.program.parseAsync(xt());}var Tr=8;var Le=class{constructor(e){this._socket=e;}_socket;writeProgress(e){this.write(1,Buffer.from(`${e}`));}writeError(e){this.write(3,Buffer.from(e)),this._socket.end();}writeDone(e){this.write(2,Buffer.from(JSON.stringify(e))),this._socket.end();}write(e,t){let o=Buffer.alloc(Tr);o.writeUInt32LE(e,0),o.writeUInt32LE(t.byteLength,4),this._socket.write(o),this._socket.write(t);}};function Pt(r){return new Promise((e,t)=>{let o=net.createConnection(r);o.once("connect",()=>e(new Le(o))),o.once("error",t);})}function St(r,e){let{width:t,height:o}=e;return `<!DOCTYPE html>
1
+ 'use strict';require('source-map-support/register.js');var assert=require('assert'),electron=require('electron'),promises=require('fs/promises'),path=require('path'),module$1=require('module'),nodeAv=require('node-av'),constants=require('node-av/constants'),commander=require('commander');require('tree-kill');var P=require('zod'),net=require('net'),api=require('node-av/api'),crypto=require('crypto'),os=require('os'),promises$1=require('timers/promises'),url=require('url');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var P__default=/*#__PURE__*/_interopDefault(P);var gr=Object.create;var Re=Object.defineProperty;var _r=Object.getOwnPropertyDescriptor;var se=(r,e)=>(e=Symbol[r])?e:Symbol.for("Symbol."+r),T=r=>{throw TypeError(r)};var st=(r,e,t)=>e in r?Re(r,e,{enumerable:true,configurable:true,writable:true,value:t}):r[e]=t;var ct=r=>[,,,gr(null)],ut=["class","method","getter","setter","accessor","field","value","get","set"],te=r=>r!==void 0&&typeof r!="function"?T("Function expected"):r,br=(r,e,t,o,i)=>({kind:ut[r],name:e,metadata:o,addInitializer:n=>t._?T("Already initialized"):i.push(te(n||null))}),Be=(r,e)=>st(e,se("metadata"),r[3]),dt=(r,e,t,o)=>{for(var i=0,n=r[e>>1],s=n&&n.length;i<s;i++)n[i].call(t);return o},U=(r,e,t,o,i,n)=>{var c,a,u,d,p=e&7,h=false,l=false,w=2,x=ut[p+5],E=r[w]||(r[w]=[]),_=((i=i.prototype),_r(i,t));for(var C=o.length-1;C>=0;C--)u=br(p,t,a={},r[3],E),(u.static=h,u.private=l,d=u.access={has:g=>t in g},(d.get=g=>g[t]),p>2),c=(0, o[C])(_[x],u),a._=1,te(c)&&(_[x]=c);return _&&Re(i,t,_),i},pt=(r,e,t)=>st(r,e+"",t);var y=(r,e,t)=>{if(e!=null){typeof e!="object"&&typeof e!="function"&&T("Object expected");var o,i;t&&(o=e[se("asyncDispose")]),o===void 0&&(o=e[se("dispose")],t&&(i=o)),typeof o!="function"&&T("Object not disposable"),i&&(o=function(){try{i.call(this);}catch(n){return Promise.reject(n)}}),r.push([t,o,e]);}else t&&r.push([t]);return e},v=(r,e,t)=>{var o=typeof SuppressedError=="function"?SuppressedError:function(s,c,a,u){return u=Error(a),u.name="SuppressedError",u.error=s,u.suppressed=c,u},i=s=>e=t?new o(s,e,"An error was suppressed during disposal"):(t=true,s),n=s=>{for(;s=r.pop();)try{var c=s[1]&&s[1].call(s[2]);if(s[0])return Promise.resolve(c).then(n,a=>(i(a),n()))}catch(a){i(a);}if(t)throw e};return n()};var Er=()=>typeof document>"u"?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.tagName.toUpperCase()==="SCRIPT"?document.currentScript.src:new URL("main.js",document.baseURI).href,m=Er();function mt(r,e,t){try{return e(process.env[r])}catch{return t}}function R(r){if(typeof r=="number")return r;let e=Number(r);if(Number.isNaN(e))throw new Error(`Value ${r} is not a valid number`);return e}var Fr=module$1.createRequire(m),H=process.env,lt=mt("PUP_LOG_LEVEL",R,2),ft=H.PUP_USE_INNER_PROXY==="1",ht=H.PUP_DISABLE_GPU==="1",wt=H.PUP_DISABLE_HW_CODEC==="1",gt=H.PUP_DETERMINISTIC==="1",Sr=path.dirname(Fr.resolve("pup-recorder/package.json"));path.join(Sr,"dist","app.cjs");var Oe=H.PUP_IPC_SOCKET,_t=H.PUP_WINDOW_TOLERANT==="1";var Ne="<pup@debug>",De="<pup@info>",Le="<pup@warn>",Ve="<pup@error>",Ue="<pup@fatal>";function re(r,e){return function(...t){let o=t.map(i=>i instanceof Error?i.stack??String(i):i);return r.call(this,...o)}}var bt,xt,yt,Et,vt,B;vt=[re],Et=[re],yt=[re],xt=[re],bt=[re];var k=class{constructor(e=lt){this._level=e;dt(B,5,this);pt(this,"_impl");this.impl=console;}_level;get level(){return this._level}set level(e){this._level=e,this.impl=this._impl??console;}get impl(){return this._impl}set impl(e){let t=e.debug??console.debug,o=e.info??console.info,i=e.warn??console.warn,n=e.error??console.error,s=this._level;this._impl={debug:s>=3?t:void 0,info:s>=2?o:void 0,warn:s>=1?i:void 0,error:s>=0?n:void 0};}debug(...e){this.impl?.debug?.(Ne,...e);}info(...e){this.impl?.info?.(De,...e);}warn(...e){this.impl?.warn?.(Le,...e);}error(...e){this.impl?.error?.(Ve,...e);}fatal(...e){this.impl?.error?.(Ue,...e),process.exit(1);}dispatch(e){let t=e.trimEnd();t.startsWith(Ne)?this.debug(t.slice(Ne.length+1)):t.startsWith(De)?this.info(t.slice(De.length+1)):t.startsWith(Le)?this.warn(t.slice(Le.length+1)):t.startsWith(Ve)?this.error(t.slice(Ve.length+1)):this.info(t);}attach(e,t){return new Promise((o,i)=>{this.debug(`${t}.attach`);let n="",s=c=>{let a=c.toString();a.startsWith(Ue)?n+=a.slice(Ue.length+1):this.dispatch(a);};e.stderr?.on("data",s),e.stdout?.on("data",s),e.on("message",s).on("error",c=>{n+=c.message,e.kill();}).once("close",(c,a)=>{c||a||n?(n||=`command failed: ${e.spawnargs.join(" ")}`,this.debug(`${t}.close`,{code:c,signal:a,fatal:n}),i(new Error(n))):(this.debug(`${t}.close`),o());}).on("unhandledRejection",c=>{this.error(`${t}.unhandled`,c);}).on("uncaughtExceptionMonitor",c=>{this.error(`${t}.unhandled`,c);});})}};B=ct(),U(B,1,"debug",vt,k),U(B,1,"info",Et,k),U(B,1,"warn",yt,k),U(B,1,"error",xt,k),U(B,1,"fatal",bt,k),Be(B,k);var f=new k;nodeAv.Log.setCallback((r,e)=>{let t=e.trimEnd();t&&(r<=constants.AV_LOG_ERROR?f.error(t):r<=constants.AV_LOG_WARNING&&f.warn(t));});function oe(r,e){return (...t)=>{try{let o=r(...t);return o instanceof Promise?o.catch(()=>e):o}catch{return e}}}var Tr="--pup-priv-args";function Pt(){let r=process.argv,e=r.find(o=>o.startsWith(Tr));if(!e)return f.debug("procargv",r),process.argv;let t=["exec",...r.slice(-1)];return e=Buffer.from(e.split("=")[1],"base64").toString(),t.push(...JSON.parse(e)),f.debug("pupargs",t),t}var Rr=1920,Br=1080,Mr=30,Or=5,Nr="output.mp4",Ct=P__default.default.object({duration:P__default.default.number().describe("Duration in seconds"),width:P__default.default.number().describe("Video width"),height:P__default.default.number().describe("Video height"),fps:P__default.default.number().describe("Frames per second"),withAudio:P__default.default.boolean().describe("Capture and encode audio"),outFile:P__default.default.string().describe("Output mp4 file path"),useInnerProxy:P__default.default.boolean().describe("Use bilibili inner proxy for resource access"),deterministic:P__default.default.boolean().describe("Render by frame rather than recording"),disableGpu:P__default.default.boolean().describe("Disable GPU rendering, may reduce performance but increase stability"),disableHwCodec:P__default.default.boolean().describe("Disable hardware video encoder (NVENC/VideoToolbox), use software x265"),windowTolerant:P__default.default.boolean().describe("Fall back to dom-ready if warmup load times out")}),Ft={width:Rr,height:Br,fps:Mr,duration:Or,outFile:Nr,withAudio:false,useInnerProxy:ft,deterministic:gt,disableGpu:ht,disableHwCodec:wt,windowTolerant:_t};async function At(r){let e=Ct.shape,t=r.defaults;commander.program.name(r.name).argument("<source>","file://, http(s)://, or data: URI").option("-W, --width <number>",e.width.description,`${t.width}`).option("-H, --height <number>",e.height.description,`${t.height}`).option("-f, --fps <number>",e.fps.description,`${t.fps}`).option("-t, --duration <number>",e.duration.description,`${t.duration}`).option("-o, --out-file <path>",e.outFile.description,t.outFile).option("-a, --with-audio",e.withAudio.description,t.withAudio).option("-d, --deterministic",e.deterministic.description,t.deterministic).option("--use-inner-proxy",e.useInnerProxy.description,t.useInnerProxy).option("--disable-gpu",e.disableGpu.description,t.disableGpu).option("--disable-hw-codec",e.disableHwCodec.description,t.disableHwCodec).option("--window-tolerant",e.windowTolerant.description,t.windowTolerant).action(async(o,i)=>{try{await r.run(o,{width:oe(R,t.width)(i.width),height:oe(R,t.height)(i.height),fps:oe(R,t.fps)(i.fps),duration:oe(R,t.duration)(i.duration),outFile:i.outFile??t.outFile,withAudio:i.withAudio??t.withAudio,useInnerProxy:i.useInnerProxy??t.useInnerProxy,deterministic:i.deterministic??t.deterministic,disableGpu:i.disableGpu??t.disableGpu,disableHwCodec:i.disableHwCodec??t.disableHwCodec,windowTolerant:i.windowTolerant??t.windowTolerant});}catch(n){f.fatal(n);}}),await commander.program.parseAsync(Pt());}var Lr=8;var He=class{constructor(e){this._socket=e;}_socket;writeProgress(e){this.write(1,Buffer.from(`${e}`));}writeError(e){this.write(3,Buffer.from(e)),this._socket.end();}writeDone(e){this.write(2,Buffer.from(JSON.stringify(e))),this._socket.end();}write(e,t){let o=Buffer.alloc(Lr);o.writeUInt32LE(e,0),o.writeUInt32LE(t.byteLength,4),this._socket.write(o),this._socket.write(t);}};function It(r){return new Promise((e,t)=>{let o=net.createConnection(r);o.once("connect",()=>e(new He(o))),o.once("error",t);})}var ce="stego-tick";function kt(r,e){let{width:t,height:o}=e;return `<!DOCTYPE html>
2
2
  <html>
3
3
  <head>
4
4
  <meta charset="UTF-8">
@@ -30,6 +30,7 @@
30
30
  <canvas id="stego" width="${t}" height="1"></canvas>
31
31
  <script>
32
32
  (function() {
33
+ const { ipcRenderer } = require('electron');
33
34
  const WIDTH = ${t};
34
35
  const MARKER_WIDTH = 32;
35
36
  const canvas = document.getElementById('stego');
@@ -62,6 +63,7 @@
62
63
  }
63
64
 
64
65
  ctx.putImageData(imageData, 0, 0);
66
+ ipcRenderer.send("${ce}", timestampMs);
65
67
  }
66
68
 
67
69
  function updateLoop() {
@@ -77,6 +79,10 @@
77
79
  requestAnimationFrame(updateLoop);
78
80
  };
79
81
 
82
+ window.__pup_tick_stego__ = (ms) => {
83
+ requestAnimationFrame(() => encodeTimestamp(ms));
84
+ };
85
+
80
86
  window.__pup_stop_stego__ = () => {
81
87
  if (rafId !== null) {
82
88
  cancelAnimationFrame(rafId);
@@ -86,7 +92,7 @@
86
92
  })();
87
93
  </script>
88
94
  </body>
89
- </html>`}function se(r,e){let{width:t,height:o}=e;if(t<32||o<2)return;let i=o-1,n=0;for(let c=0;c<32;c++){let s=(i*t+c)*4,u=(r[s]??0)>127?1:0;n=n<<1|u;}if(n=n>>>0,!(!Number.isFinite(n)||n<0||n>1e7))return n}function ce(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_start_stego__()"})}function ue(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_stop_stego__()"})}var Ve="pup";electron.protocol.registerSchemesAsPrivileged([{scheme:Ve,privileges:{standard:true,secure:true,bypassCSP:true,allowServiceWorkers:true,supportFetchAPI:true,corsEnabled:true,stream:true,codeCache:true}}]);function It(){electron.protocol.handle(Ve,r=>{let e=new URL(r.url),t=e.searchParams.get("src")??"",o=parseInt(e.searchParams.get("w")??"0",10),i=parseInt(e.searchParams.get("h")??"0",10),n=St(t,{width:o,height:i});return new Response(n,{headers:{"content-type":"text/html"}})});}function At(r,e){let t=new URL(`${Ve}://stego`);return t.searchParams.set("src",r),t.searchParams.set("w",String(e.width)),t.searchParams.set("h",String(e.height)),t.toString()}var G=class{constructor(e){this.maxConcurrency=e;}maxConcurrency;_active=0;_queue=[];_signals=new WeakSet;_resolve;get active(){return this._active}get pending(){return this._queue.length}get stats(){return `active: ${this.active}, pending: ${this.pending}`}async schedule(e,t){return t?.throwIfAborted(),t&&!this._signals.has(t)&&(this._signals.add(t),t.addEventListener("abort",()=>this.flush(t),{once:true})),new Promise((o,i)=>{this._queue.push({run:()=>{if(t?.aborted){i(t.reason),this.next();return}this._active++,e().then(n=>{this._active--,o(n),this.next();}).catch(n=>{this._active--,i(n),this.next();});},reject:i,signal:t}),this.next();})}async drain(){if(!(this._active===0&&this.pending===0))return new Promise(e=>this._resolve=e)}flush(e){let t=[];for(let o of this._queue)o.signal===e?o.reject(e.reason):t.push(o);this._queue=t,this.next();}next(){if(this._active===0&&this.pending===0){this._resolve?.(),this._resolve=void 0;return}this._active<this.maxConcurrency&&this._queue.shift()?.run();}};function M(r,e,t){let o=new nodeAv.Frame;return o.alloc(),o.format=t,o.width=r,o.height=e,nodeAv.FFmpegError.throwIfError(o.getBuffer(0),"frame.getBuffer"),o}function S(){let r=new nodeAv.Packet;return r.alloc(),r}async function H(r,e,t,o){for(;;){let i=await r.receivePacket(e);if(i===constants.AVERROR_EAGAIN||i===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(i,"receivePacket"),e.streamIndex=t.index,e.duration===0n&&(e.duration=1n),e.rescaleTs(r.timeBase,t.timeBase),await o.writePacket(e),e.unref();}}var jr={[constants.AV_SAMPLE_FMT_FLT]:"flt",[constants.AV_SAMPLE_FMT_FLTP]:"fltp"},de=class r{_ctx;_stream;_pkt;_outRate;_outFmt;_frameSize;_filterFrame;_graph;_bufSrc;_bufSink;_inRate;_pts=0n;constructor(e,t,o){this._ctx=e,this._stream=t,this._outRate=e.sampleRate,this._outFmt=o,this._frameSize=e.frameSize,this._pkt=S(),this._filterFrame=new nodeAv.Frame,this._filterFrame.alloc();}static async create(e){let t=nodeAv.Codec.findEncoderByName(e.codecName);if(!t)throw new Error(`Audio encoder not found: ${e.codecName}`);let o=new nodeAv.CodecContext;o.allocContext3(t),o.codecId=t.id,o.sampleFormat=e.outSampleFmt,o.sampleRate=e.outSampleRate,o.channelLayout=constants.AV_CHANNEL_LAYOUT_STEREO,o.timeBase=new nodeAv.Rational(1,e.outSampleRate),o.bitRate=BigInt(e.bitrate),e.globalHeader&&o.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER),nodeAv.FFmpegError.throwIfError(await o.open2(t,null),"audioCtx.open2");let i=e.muxer.addStream(o);return new r(o,i,e.outSampleFmt)}setInputRate(e){this._graph?.[Symbol.dispose](),this._inRate=e;let t=new nodeAv.FilterGraph;t.alloc();let o=nodeAv.Filter.getByName("abuffer"),i=t.createFilter(o,"src",`sample_rate=${e}:sample_fmt=flt:channel_layout=stereo:time_base=1/${e}`);if(!i)throw new Error("Failed to create abuffer");let n=nodeAv.Filter.getByName("abuffersink"),c=t.createFilter(n,"sink");if(!c)throw new Error("Failed to create abuffersink");let a=`aformat=sample_fmts=${jr[this._outFmt]??"flt"}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`,u=nodeAv.FilterInOut.createList([{name:"in",filterCtx:i,padIdx:0}]),p=nodeAv.FilterInOut.createList([{name:"out",filterCtx:c,padIdx:0}]);nodeAv.FFmpegError.throwIfError(t.parsePtr(a,p,u),"graph.parsePtr"),nodeAv.FFmpegError.throwIfError(t.configSync(),"graph.config"),this._graph=t,this._bufSrc=i,this._bufSink=c;}async encode(e,t){var c=[];try{if(!this._bufSrc||!this._inRate)return;let o=new Float32Array(e.buffer,e.byteOffset,e.byteLength/4);for(let p=0;p<o.length;p++)isFinite(o[p])||(o[p]=0);let i=o.length>>1;let n=v(c,nodeAv.Frame.fromAudioBuffer(Buffer.from(o.buffer,o.byteOffset,o.byteLength),{nbSamples:i,format:constants.AV_SAMPLE_FMT_FLT,sampleRate:this._inRate,channelLayout:constants.AV_CHANNEL_LAYOUT_STEREO,pts:this._pts,timeBase:{num:1,den:this._inRate}}));this._pts+=BigInt(i);nodeAv.FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(n),"buffersrcAddFrame");await this.drain(t);}catch(s){var a=s,u=true;}finally{F(c,a,u);}}async flush(e){this._bufSrc&&(await this._bufSrc.buffersrcAddFrame(null),await this.drain(e)),await this._ctx.sendFrame(null),await this.drainCodec(e);}[Symbol.dispose](){this._pkt.free(),this._filterFrame.free(),this._graph?.[Symbol.dispose](),this._ctx.freeContext();}async drain(e){for(;;){let t=await this._bufSink.buffersinkGetFrame(this._filterFrame);if(t===constants.AVERROR_EAGAIN||t===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(t,"buffersinkGetFrame"),nodeAv.FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame),"audioCtx.sendFrame"),this._filterFrame.unref(),await this.drainCodec(e);}}drainCodec(e){return H(this._ctx,this._pkt,this._stream,e)}};var $=class r{src;dst;pkt;_sws;_png;static async create(e,t){let o=nodeAv.Codec.findDecoderByName(nodeAv.FF_DECODER_PNG);return assert.ok(o,"png decoder unavailable"),new r(e,t,o)}constructor(e,t,o){this._png=o,this.src=M(e,t,nodeAv.AV_PIX_FMT_BGRA),this.dst=M(e,t,nodeAv.AV_PIX_FMT_YUVA420P),this.pkt=S();}async png(){let e=new nodeAv.CodecContext;return e.allocContext3(this._png),nodeAv.FFmpegError.throwIfError(await e.open2(this._png),"pngDecoder.open2"),e}async decodePNG(e){var o=[];try{let t=v(o,await this.png());this.pkt.data=e;nodeAv.FFmpegError.throwIfError(await t.sendPacket(this.pkt),"pngDecoder.sendPacket");this.pkt.unref();nodeAv.FFmpegError.throwIfError(await t.receiveFrame(this.src),"pngDecoder.receiveFrame");return this.src}catch(i){var n=i,c=true;}finally{F(o,n,c);}}get sws(){if(!this._sws){let e=new nodeAv.SoftwareScaleContext,t=this.src.format;e.getContext(this.src.width,this.src.height,t,this.src.width,this.src.height,nodeAv.AV_PIX_FMT_YUVA420P,nodeAv.SWS_BILINEAR),this._sws=e;}return this._sws}[Symbol.dispose](){this.src[Symbol.dispose](),this.dst[Symbol.dispose](),this.pkt[Symbol.dispose](),this._sws?.[Symbol.dispose]();}};var j=Buffer.from([0,0,0,1]);function Dt(r,e){let t=r>>1&63,o=(r&1)<<5|e>>3&31,i=e&7;return {type:t,layerId:o,temporalId:i}}function Ge(r,e,t){let o=(r&63)<<1|e>>5&1,i=(e&31)<<3|t&7;return [o,i]}function He(r){let e=Buffer.alloc(r.length>>3);for(let t=0;t<e.length;t++){let o=0;for(let i=0;i<8;i++)o=o<<1|r[t*8+i];e[t]=o;}return e}function z(r){let e=[],t=0;for(;t<r.length;){let o=0;if(t+3<r.length&&r[t]===0&&r[t+1]===0&&r[t+2]===1)o=3;else if(t+4<r.length&&r[t]===0&&r[t+1]===0&&r[t+2]===0&&r[t+3]===1)o=4;else {t++;continue}let i=t+o;if(i+2>r.length)break;let n=r.length;for(let a=i+2;a<r.length-2;a++)if(r[a]===0&&r[a+1]===0&&(r[a+2]===1||a+3<r.length&&r[a+2]===0&&r[a+3]===1)){n=a;break}let{type:c,layerId:s}=Dt(r[i],r[i+1]);e.push({type:c,layerId:s,data:r.subarray(i,n)}),t=n;}return e}function We(r,e){let t=Buffer.from(r),{type:o,temporalId:i}=Dt(t[0],t[1]),[n,c]=Ge(o,e,i);return t[0]=n,t[1]=c,t}var Zr=39;function Vt(r,e){let t=z(r),o=z(e),i=new Map;for(let s of o){if(s.type===32)continue;let a=i.get(s.type)??[];a.push(s),i.set(s.type,a);}let n=[],c=new Set;for(let s of t){let a=s.type===32?eo(s.data):s.data;if(n.push(j,a),!c.has(s.type)){c.add(s.type);for(let u of i.get(s.type)??[])n.push(j,We(u.data,1));}}return n.push($e()),Buffer.concat(n)}function eo(r){let e=r.subarray(2),t=0,o=p=>{let d=0;for(let m=0;m<p;m++){let l=t+m>>3,g=7-(t+m&7);d=d<<1|e[l]>>g&1;}return t+=p,d};o(4);let i=o(1);o(1);let n=t;if(o(6)>0)return r;let s=[];for(let p=0;p<r.length;p++)for(let d=7;d>=0;d--)s.push(r[p]>>d&1);let a=n+16;for(let p=0;p<6;p++)s[a+p]=0;s[a+5]=1;let u=s.length-1;for(;u>0&&s[u]===0;)u--;if(u<=1)throw new Error("Invalid VPS: no RBSP stop bit");for(s[u-1]=1,s.length=u;s.length%8!==0;)s.push(1);if(i)for(let p=0;p<8;p++)s.push(0);s.push(0);for(let p=0;p<16;p++)s.push(p===3?1:0);for(s.push(0,0,0),s.push(0),s.push(1),s.push(1);s.length%8!==0;)s.push(0);return He(s)}function $e(){let[t,o]=Ge(Zr,0,1),i=[],n=(c,s)=>{for(let a=s-1;a>=0;a--)i.push(c>>a&1);};for(n(0,1),n(0,3),n(0,3),n(0,9),n(255,9),n(0,1),n(0,1),n(1,1);i.length%8!==0;)n(0,1);return Buffer.concat([j,Buffer.from([t,o]),Buffer.from([165,4]),He(i),Buffer.from([128])])}function Ut(r,e){let t=[];for(let o of r)t.push(j,o.data);for(let o of e)o.type<32&&t.push(j,We(o.data,1));return Buffer.concat(t)}var me=class r{_s;_seiBuffer;_pts=0n;_seiInjected=false;_alphaBuf;_alphaFrame;constructor(e){this._s=e,this._seiBuffer=$e();}static async create(e){let{width:t,height:o,fps:i,bitrate:n,hw:c,muxer:s}=e,a=nodeAv.Codec.findEncoderByName(constants.FF_ENCODER_HEVC_NVENC);if(!a)throw new Error("hevc_nvenc encoder not found");let u=new nodeAv.HardwareFramesContext;u.alloc(c.deviceContext),u.format=constants.AV_PIX_FMT_CUDA,u.swFormat=constants.AV_PIX_FMT_YUV420P,u.width=t,u.height=o,u.initialPoolSize=20,nodeAv.FFmpegError.throwIfError(u.init(),"hwFramesCtx.init");let p=async y=>{let h=new nodeAv.CodecContext;return h.allocContext3(a),h.codecId=a.id,h.width=t,h.height=o,h.pixelFormat=constants.AV_PIX_FMT_CUDA,y.fullRange&&(h.colorRange=constants.AVCOL_RANGE_JPEG),h.timeBase=new nodeAv.Rational(1,i),h.framerate=new nodeAv.Rational(i,1),h.gopSize=i*2,h.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER),h.setOption("preset","p4"),h.setOption("bf","0"),y.cqp!==void 0?(h.setOption("rc","constqp"),h.setOption("qp",String(y.cqp))):h.bitRate=BigInt(y.br),h.hwFramesCtx=u,nodeAv.FFmpegError.throwIfError(await h.open2(a,null),"nvenc.open2"),h},d=await p({br:n}),m=await p({br:n,fullRange:true,cqp:1}),l=S(),g=S(),b=s.addStream(d,"hvc1"),w=d.extraData,E=m.extraData;w&&E&&(b.codecpar.extradata=Vt(w,E));let x=new nodeAv.SoftwareScaleContext;return x.getContext(t,o,constants.AV_PIX_FMT_BGRA,t,o,constants.AV_PIX_FMT_YUV420P,nodeAv.SWS_BILINEAR),new r({baseCtx:d,alphaCtx:m,basePkt:l,alphaPkt:g,stream:b,baseSws:x,yuvFrame:M(t,o,constants.AV_PIX_FMT_YUV420P),hwFramesCtx:u})}async encode(e,t){let{baseCtx:o,alphaCtx:i,baseSws:n,yuvFrame:c,hwFramesCtx:s}=this._s,a=this._pts++;nodeAv.FFmpegError.throwIfError(c.makeWritable(),"yuv.makeWritable"),nodeAv.FFmpegError.throwIfError(await n.scaleFrame(c,e),"sws.base");let u=e.data?.[0],p=e.linesize?.[0];if(!u||!p)throw new Error("encode: missing BGRA data");let d=e.width,m=e.height,l=d*m,g=(d>>1)*(m>>1);this._alphaBuf||(this._alphaBuf=Buffer.alloc(l+g*2));let b=this._alphaBuf;for(let x=0;x<m;x++)for(let y=0;y<d;y++)b[x*d+y]=u[x*p+y*4+3];b.fill(128,l,l+g*2),this._alphaFrame?.free(),this._alphaFrame=nodeAv.Frame.fromVideoBuffer(b,{format:constants.AV_PIX_FMT_YUV420P,width:d,height:m});let w=new nodeAv.Frame;w.alloc(),nodeAv.FFmpegError.throwIfError(s.getBuffer(w,0),"base.getBuffer"),nodeAv.FFmpegError.throwIfError(await s.transferData(w,c,0),"base.transfer"),w.pts=a,w.duration=1n;let E=new nodeAv.Frame;E.alloc(),nodeAv.FFmpegError.throwIfError(s.getBuffer(E,0),"alpha.getBuffer"),nodeAv.FFmpegError.throwIfError(await s.transferData(E,this._alphaFrame,0),"alpha.transfer"),E.pts=a,E.duration=1n,nodeAv.FFmpegError.throwIfError(await o.sendFrame(w),"base.sendFrame"),nodeAv.FFmpegError.throwIfError(await i.sendFrame(E),"alpha.sendFrame"),await this.drainInterleaved(t),w.free(),E.free();}async flush(e){await this._s.baseCtx.sendFrame(null),await this._s.alphaCtx.sendFrame(null),await this.drainInterleaved(e);}[Symbol.dispose](){let{basePkt:e,alphaPkt:t,yuvFrame:o,baseSws:i,hwFramesCtx:n,baseCtx:c,alphaCtx:s}=this._s;e.free(),t.free(),o[Symbol.dispose](),this._alphaFrame?.free(),i[Symbol.dispose](),n.free(),c.freeContext(),s.freeContext();}async drainInterleaved(e){let{baseCtx:t,alphaCtx:o,basePkt:i,alphaPkt:n,stream:c}=this._s;for(;;){let s=await t.receivePacket(i),a=await o.receivePacket(n),u=s>=0,p=a>=0;if(!u&&!p)break;if(u!==p)throw new Error(`NVENC desync: base=${u}, alpha=${p}`);let d=z(i.data),m=z(n.data),l=[];this._seiInjected||(l.push(this._seiBuffer),this._seiInjected=true),l.push(Ut(d,m));let g=i.pts,b=i.dts,w=i.duration;i.data=Buffer.concat(l),i.pts=g,i.dts=b,i.duration=w===0n?1n:w,i.streamIndex=c.index,i.rescaleTs(t.timeBase,c.timeBase),await e.writePacket(i),i.unref(),n.unref();}}};var le=class r{_ctx;_pkt;_stream;_pts=0n;constructor(e,t,o){this._ctx=e,this._pkt=t,this._stream=o;}static async create(e){let{width:t,height:o,fps:i,codecName:n,codecTag:c,globalHeader:s,codecOpts:a,bitrate:u,muxer:p}=e,d=nodeAv.Codec.findEncoderByName(n);if(!d)throw new Error(`Video encoder not found: ${n}`);let m=new nodeAv.CodecContext;m.allocContext3(d),m.codecId=d.id,m.width=t,m.height=o,m.pixelFormat=e.pixelFormat,m.timeBase=new nodeAv.Rational(1,i),m.framerate=new nodeAv.Rational(i,1),m.gopSize=i*2,m.bitRate=BigInt(u),s&&m.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER);for(let[g,b]of Object.entries(a))m.setOption(g,b);c&&(m.codecTag=c),nodeAv.FFmpegError.throwIfError(await m.open2(d,null),"videoCtx.open2");let l=p.addStream(m,c);return new r(m,S(),l)}async encode(e,t){e.pts=this._pts++,e.duration=1n,nodeAv.FFmpegError.throwIfError(await this._ctx.sendFrame(e),"videoCtx.sendFrame"),await this.drain(t);}async flush(e){await this._ctx.sendFrame(null),await this.drain(e);}[Symbol.dispose](){this._pkt.free(),this._ctx.freeContext();}drain(e){return H(this._ctx,this._pkt,this._stream,e)}};var fe=class r{_ctx;_pkt;_stream;_pts=0n;constructor(e,t,o){this._ctx=e,this._pkt=t,this._stream=o;}static async create(e){let{width:t,height:o,fps:i,hw:n,bitrate:c,muxer:s}=e,a=n.getEncoderCodec("hevc");if(!a)throw new Error("hevc_videotoolbox encoder not found");let u=new nodeAv.CodecContext;u.allocContext3(a),u.codecId=a.id,u.width=t,u.height=o,u.pixelFormat=constants.AV_PIX_FMT_BGRA,u.colorRange=constants.AVCOL_RANGE_JPEG,u.timeBase=new nodeAv.Rational(1,i),u.framerate=new nodeAv.Rational(i,1),u.gopSize=i*2,u.bitRate=BigInt(c),u.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER),u.setOption("alpha_quality","1"),u.codecTag="hvc1",nodeAv.FFmpegError.throwIfError(await u.open2(a,null),"vtEnc.open2");let p=s.addStream(u,"hvc1");return new r(u,S(),p)}async encode(e,t){e.pts=this._pts++,e.duration=1n,nodeAv.FFmpegError.throwIfError(await this._ctx.sendFrame(e),"vtEnc.sendFrame"),await this.drain(t);}async flush(e){await this._ctx.sendFrame(null),await this.drain(e);}[Symbol.dispose](){this._pkt.free(),this._ctx.freeContext();}drain(e){return H(this._ctx,this._pkt,this._stream,e)}};var ze="[Encoder]";async function qt(r,e){let{width:t,height:o,fps:i,bitrate:n=8e6,disableGpu:c=false}=r,s=c?void 0:api.HardwareContext.auto()??void 0;return s?.deviceTypeName===constants.FF_HWDEVICE_TYPE_VIDEOTOOLBOX&&s.getEncoderCodec("hevc")?(_.debug(ze,"using VideoToolbox HEVC alpha encoder"),{hwVideo:await fe.create({width:t,height:o,fps:i,hw:s,bitrate:n,muxer:e}),hw:s}):s?.deviceTypeName===constants.FF_HWDEVICE_TYPE_CUDA&&s.getEncoderCodec("hevc")?(_.debug(ze,"using NVENC dual-layer HEVC alpha encoder"),{hwVideo:await me.create({width:t,height:o,fps:i,hw:s,bitrate:n,muxer:e}),hw:s}):(_.debug(ze,"using software libx265 HEVC alpha encoder"),s?.dispose(),{video:await le.create({width:t,height:o,fps:i,codecName:constants.FF_ENCODER_LIBX265,codecTag:"hvc1",globalHeader:true,codecOpts:{preset:"medium","x265-params":"log-level=1:bframes=3:pools=+:frame-threads=0"},bitrate:n,pixelFormat:constants.AV_PIX_FMT_YUVA420P,muxer:e}),codec:await $.create(t,o)})}var he=class{_ctx;_opened=false;constructor(e,t){this._ctx=new nodeAv.FormatContext,nodeAv.FFmpegError.throwIfError(this._ctx.allocOutputContext2(null,t??null,e),"allocOutputContext2");}addStream(e,t){let o=this._ctx.newStream(null);return o.timeBase=e.timeBase,nodeAv.FFmpegError.throwIfError(o.codecpar.fromContext(e),"codecpar.fromContext"),t&&(o.codecpar.codecTag=t),o}async open(){this._opened||(nodeAv.FFmpegError.throwIfError(await this._ctx.openOutput(),"openOutput"),nodeAv.FFmpegError.throwIfError(await this._ctx.writeHeader(null),"writeHeader"),this._opened=true);}async writePacket(e){nodeAv.FFmpegError.throwIfError(await this._ctx.interleavedWriteFrame(e),"interleavedWriteFrame");}async[Symbol.asyncDispose](){this._opened&&(await this._ctx.writeTrailer(),await this._ctx.closeOutput(),await this._ctx[Symbol.asyncDispose](),this._opened=false);}};var q=class r{_s;_disposed=false;constructor(e){this._s=e;}static async create(e){let{width:t,height:o,outFile:i,withAudio:n=false}=e,c=new he(i),{video:s,hwVideo:a,codec:u,hw:p}=await qt(e,c),d;return n&&(d=await de.create({outSampleRate:44100,outSampleFmt:constants.AV_SAMPLE_FMT_FLTP,codecName:constants.FF_ENCODER_AAC,globalHeader:true,bitrate:128e3,muxer:c})),await c.open(),new r({video:s,hwVideo:a,audio:d,muxer:c,limiter:new G(1),outFile:i,codec:u,hw:p,width:t,height:o})}setupAudio(e){this._s.audio?.setInputRate(e);}async encodeBGRA(e){await this._s.limiter.schedule(async()=>{let{hwVideo:t,video:o,codec:i,muxer:n}=this._s;if(t){var u=[];try{let l=v(u,this.bgraFrame(e));await t.encode(l,n);return}catch(p){var d=p,m=true;}finally{F(u,d,m);}}let{src:c,dst:s,sws:a}=i;return assert.ok(a,"sws not initialized"),nodeAv.FFmpegError.throwIfError(c.makeWritable(),"bgraSrc.makeWritable"),nodeAv.FFmpegError.throwIfError(c.fromBuffer(e),"bgraSrc.fromBuffer"),nodeAv.FFmpegError.throwIfError(s.makeWritable(),"bgraDst.makeWritable"),nodeAv.FFmpegError.throwIfError(await a.scaleFrame(s,c),"bgraSws.scaleFrame"),o.encode(s,n)});}async encodePNG(e){await this._s.limiter.schedule(async()=>{let{hwVideo:t,video:o,codec:i,muxer:n,width:c,height:s}=this._s,a=i??await $.create(c,s);try{let u=await a.decodePNG(e);t?await t.encode(u,n):(nodeAv.FFmpegError.throwIfError(a.dst.makeWritable(),"pngDst.makeWritable"),nodeAv.FFmpegError.throwIfError(await a.sws.scaleFrame(a.dst,u),"pngSws.scaleFrame"),await o.encode(a.dst,n));}finally{i||a[Symbol.dispose]();}});}async encodeAudio(e){let{audio:t,limiter:o,muxer:i}=this._s;t&&await o.schedule(()=>t.encode(e,i));}async finish(){let{video:e,hwVideo:t,audio:o,muxer:i,limiter:n}=this._s;try{var c=[];try{let d=v(c,i,!0);let m=v(c,e);let l=v(c,t);let g=v(c,o);await n.drain();await o?.flush(i);t?await t.flush(i):await e.flush(i);}catch(s){var a=s,u=!0;}finally{var p=F(c,a,u);p&&await p;}}finally{this.free();}return this._s.outFile}async[Symbol.asyncDispose](){if(this._disposed)return;let{video:e,hwVideo:t,audio:o,muxer:i,limiter:n}=this._s;await n.drain(),e?.[Symbol.dispose](),t?.[Symbol.dispose](),o?.[Symbol.dispose](),await i[Symbol.asyncDispose](),this.free();}free(){var t=[];try{if(this._disposed)return;this._disposed=!0;let e=v(t,this._s.codec);this._s.hw?.dispose();}catch(o){var i=o,n=true;}finally{F(t,i,n);}}bgraFrame(e){let t=M(this._s.width,this._s.height,constants.AV_PIX_FMT_BGRA);return nodeAv.FFmpegError.throwIfError(t.fromBuffer(e),"bgraFrame.fromBuffer"),t}};var we=class{_fps;_actual=0;_currentBurst=0;_bursts=[];constructor(e){this._fps=e;}wrote(e=1){this._currentBurst>0&&(this._bursts.push(this._currentBurst),this._currentBurst=0),this._actual+=e;}dropped(e=1){this._currentBurst+=e;}finalize(){this._currentBurst>0&&(this._bursts.push(this._currentBurst),this._currentBurst=0);let e=0,t=0,o=0;for(let a of this._bursts){e+=a,o=Math.max(o,a);let u=Math.max(0,a-1);t+=(u/this._fps)**2;}let i=this._actual+e,n=i>0?e/i:0,c=Math.min(1,t),s=1-(1-n)*(1-c);return {global:n,local:c,jank:s,expected:i,actual:this._actual,maxBurst:o}}};function _e(r){let e=r.getSize();return e.width===0||e.height===0?true:r.isEmpty()}var Bo=`
95
+ </html>`}function ue(r,e){let{width:t,height:o}=e;if(t<32||o<2)return;let i=o-1,n=0;for(let s=0;s<32;s++){let c=(i*t+s)*4,u=(r[c]??0)>127?1:0;n=n<<1|u;}if(n=n>>>0,!(!Number.isFinite(n)||n<0||n>1e7))return n}function Tt(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_start_stego__()"})}function Rt(r,e){return r.sendCommand("Runtime.evaluate",{expression:`window.__pup_tick_stego__(${e})`})}function Bt(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_stop_stego__()"})}var We="pup";electron.protocol.registerSchemesAsPrivileged([{scheme:We,privileges:{standard:true,secure:true,bypassCSP:true,allowServiceWorkers:true,supportFetchAPI:true,corsEnabled:true,stream:true,codeCache:true}}]);function Ot(){electron.protocol.handle(We,r=>{let e=new URL(r.url),t=e.searchParams.get("src")??"",o=parseInt(e.searchParams.get("w")??"0",10),i=parseInt(e.searchParams.get("h")??"0",10),n=kt(t,{width:o,height:i});return new Response(n,{headers:{"content-type":"text/html"}})});}function Nt(r,e){let t=new URL(`${We}://stego`);return t.searchParams.set("src",r),t.searchParams.set("w",String(e.width)),t.searchParams.set("h",String(e.height)),t.toString()}var W=class{constructor(e){this.maxConcurrency=e;}maxConcurrency;_active=0;_queue=[];_signals=new WeakSet;_resolve;get active(){return this._active}get pending(){return this._queue.length}get stats(){return `active: ${this.active}, pending: ${this.pending}`}async schedule(e,t){return t?.throwIfAborted(),t&&!this._signals.has(t)&&(this._signals.add(t),t.addEventListener("abort",()=>this.flush(t),{once:true})),new Promise((o,i)=>{this._queue.push({run:()=>{if(t?.aborted){i(t.reason),this.next();return}this._active++,e().then(n=>{this._active--,o(n),this.next();}).catch(n=>{this._active--,i(n),this.next();});},reject:i,signal:t}),this.next();})}async drain(){if(!(this._active===0&&this.pending===0))return new Promise(e=>this._resolve=e)}flush(e){let t=[];for(let o of this._queue)o.signal===e?o.reject(e.reason):t.push(o);this._queue=t,this.next();}next(){if(this._active===0&&this.pending===0){this._resolve?.(),this._resolve=void 0;return}this._active<this.maxConcurrency&&this._queue.shift()?.run();}};async function M(r,e){let t=new nodeAv.CodecContext;t.allocContext3(r.codec),t.codecId=r.codec.id,t.width=r.width,t.height=r.height,t.pixelFormat=r.pixelFormat,t.timeBase=new nodeAv.Rational(1,r.fps),t.framerate=new nodeAv.Rational(r.fps,1),t.gopSize=r.fps*2,t.bitRate=BigInt(r.bitrate),t.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER),r.codecTag&&(t.codecTag=r.codecTag),r.colorRange!==void 0&&(t.colorRange=r.colorRange);for(let[o,i]of Object.entries(r.options??{}))t.setOption(o,i);return nodeAv.FFmpegError.throwIfError(await t.open2(r.codec,null),e),t}function ie(r,e,t){let o=new nodeAv.Frame;return o.alloc(),o.format=t,o.width=r,o.height=e,nodeAv.FFmpegError.throwIfError(o.getBuffer(0),"frame.getBuffer"),o}function F(){let r=new nodeAv.Packet;return r.alloc(),r}async function $(r,e,t,o){for(;;){let i=await r.receivePacket(e);if(i===constants.AVERROR_EAGAIN||i===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(i,"receivePacket"),e.streamIndex=t.index,e.duration===0n&&(e.duration=1n),e.rescaleTs(r.timeBase,t.timeBase),await o.writePacket(e),e.unref();}}var Zr={[constants.AV_SAMPLE_FMT_FLT]:"flt",[constants.AV_SAMPLE_FMT_FLTP]:"fltp"},de=class r{_ctx;_stream;_pkt;_outRate;_outFmt;_frameSize;_filterFrame;_graph;_bufSrc;_bufSink;_inRate;_pts=0n;constructor(e,t,o){this._ctx=e,this._stream=t,this._outRate=e.sampleRate,this._outFmt=o,this._frameSize=e.frameSize,this._pkt=F(),this._filterFrame=new nodeAv.Frame,this._filterFrame.alloc();}static async create(e){let t=nodeAv.Codec.findEncoderByName(e.codecName);if(!t)throw new Error(`Audio encoder not found: ${e.codecName}`);let o=new nodeAv.CodecContext;o.allocContext3(t),o.codecId=t.id,o.sampleFormat=e.outSampleFmt,o.sampleRate=e.outSampleRate,o.channelLayout=constants.AV_CHANNEL_LAYOUT_STEREO,o.timeBase=new nodeAv.Rational(1,e.outSampleRate),o.bitRate=BigInt(e.bitrate),e.globalHeader&&o.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER),nodeAv.FFmpegError.throwIfError(await o.open2(t,null),"audioCtx.open2");let i=e.muxer.addStream(o);return new r(o,i,e.outSampleFmt)}setInputRate(e){this._graph?.[Symbol.dispose](),this._inRate=e;let t=new nodeAv.FilterGraph;t.alloc();let o=nodeAv.Filter.getByName("abuffer"),i=t.createFilter(o,"src",`sample_rate=${e}:sample_fmt=flt:channel_layout=stereo:time_base=1/${e}`);if(!i)throw new Error("Failed to create abuffer");let n=nodeAv.Filter.getByName("abuffersink"),s=t.createFilter(n,"sink");if(!s)throw new Error("Failed to create abuffersink");let a=`aformat=sample_fmts=${Zr[this._outFmt]??"flt"}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`,u=nodeAv.FilterInOut.createList([{name:"in",filterCtx:i,padIdx:0}]),d=nodeAv.FilterInOut.createList([{name:"out",filterCtx:s,padIdx:0}]);nodeAv.FFmpegError.throwIfError(t.parsePtr(a,d,u),"graph.parsePtr"),nodeAv.FFmpegError.throwIfError(t.configSync(),"graph.config"),this._graph=t,this._bufSrc=i,this._bufSink=s;}async encode(e,t){var s=[];try{if(!this._bufSrc||!this._inRate)return;let o=new Float32Array(e.buffer,e.byteOffset,e.byteLength/4);for(let d=0;d<o.length;d++)isFinite(o[d])||(o[d]=0);let i=o.length>>1;let n=y(s,nodeAv.Frame.fromAudioBuffer(Buffer.from(o.buffer,o.byteOffset,o.byteLength),{nbSamples:i,format:constants.AV_SAMPLE_FMT_FLT,sampleRate:this._inRate,channelLayout:constants.AV_CHANNEL_LAYOUT_STEREO,pts:this._pts,timeBase:{num:1,den:this._inRate}}));this._pts+=BigInt(i);nodeAv.FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(n),"buffersrcAddFrame");await this.drain(t);}catch(c){var a=c,u=true;}finally{v(s,a,u);}}async flush(e){this._bufSrc&&(await this._bufSrc.buffersrcAddFrame(null),await this.drain(e)),await this._ctx.sendFrame(null),await this.drainCodec(e);}[Symbol.dispose](){this._pkt.free(),this._filterFrame.free(),this._graph?.[Symbol.dispose](),this._ctx.freeContext();}async drain(e){for(;;){let t=await this._bufSink.buffersinkGetFrame(this._filterFrame);if(t===constants.AVERROR_EAGAIN||t===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(t,"buffersinkGetFrame"),nodeAv.FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame),"audioCtx.sendFrame"),this._filterFrame.unref(),await this.drainCodec(e);}}drainCodec(e){return $(this._ctx,this._pkt,this._stream,e)}};var j=class r{src;dst;pkt;_sws;_png;static async create(e,t){let o=nodeAv.Codec.findDecoderByName(nodeAv.FF_DECODER_PNG);return assert.ok(o,"png decoder unavailable"),new r(e,t,o)}constructor(e,t,o){this._png=o,this.src=ie(e,t,nodeAv.AV_PIX_FMT_BGRA),this.dst=ie(e,t,nodeAv.AV_PIX_FMT_YUVA420P),this.pkt=F();}async png(){let e=new nodeAv.CodecContext;return e.allocContext3(this._png),nodeAv.FFmpegError.throwIfError(await e.open2(this._png),"pngDecoder.open2"),e}async decodePNG(e){var o=[];try{let t=y(o,await this.png());this.pkt.data=e;nodeAv.FFmpegError.throwIfError(await t.sendPacket(this.pkt),"pngDecoder.sendPacket");this.pkt.unref();nodeAv.FFmpegError.throwIfError(await t.receiveFrame(this.src),"pngDecoder.receiveFrame");return this.src}catch(i){var n=i,s=true;}finally{v(o,n,s);}}get sws(){if(!this._sws){let e=new nodeAv.SoftwareScaleContext,t=this.src.format;e.getContext(this.src.width,this.src.height,t,this.src.width,this.src.height,nodeAv.AV_PIX_FMT_YUVA420P,nodeAv.SWS_BILINEAR),this._sws=e;}return this._sws}[Symbol.dispose](){this.src[Symbol.dispose](),this.dst[Symbol.dispose](),this.pkt[Symbol.dispose](),this._sws?.[Symbol.dispose]();}};function le(r){let e=Buffer.alloc(r.length>>3);for(let t=0;t<e.length;t++){let o=0;for(let i=0;i<8;i++)o=o<<1|r[t*8+i];e[t]=o;}return e}var pe=class{bits=[];w(e,t){for(let o=t-1;o>=0;o--)this.bits.push(e>>o&1);}flag(e){this.bits.push(e?1:0);}ue(e){let t=e+1,o=32-Math.clz32(t);for(let i=0;i<o-1;i++)this.bits.push(0);for(let i=o-1;i>=0;i--)this.bits.push(t>>i&1);}align(e){for(;this.bits.length%8!==0;)this.bits.push(e);}copy(e,t,o){for(let i=0;i<o;i++)this.bits.push(e[t+i]);}},me=class{_bits;pos=0;constructor(e){this._bits=[];for(let t=0;t<e.length;t++)for(let o=7;o>=0;o--)this._bits.push(e[t]>>o&1);}get bits(){return this._bits}read(e){let t=0;for(let o=0;o<e;o++)t=t<<1|this._bits[this.pos++];return t}readUe(){let e=0;for(;this._bits[this.pos]===0;)e++,this.pos++;this.pos++;let t=1;for(let o=0;o<e;o++)t=t<<1|this._bits[this.pos++];return t-1}};var z=Buffer.from([0,0,0,1]);function Gt(r,e){let t=r>>1&63,o=(r&1)<<5|e>>3&31,i=e&7;return {type:t,layerId:o,temporalId:i}}function je(r,e,t){let o=(r&63)<<1|e>>5&1,i=(e&31)<<3|t&7;return [o,i]}function q(r){let e=[],t=0;for(;t<r.length;){let o=0;if(t+3<r.length&&r[t]===0&&r[t+1]===0&&r[t+2]===1)o=3;else if(t+4<r.length&&r[t]===0&&r[t+1]===0&&r[t+2]===0&&r[t+3]===1)o=4;else {t++;continue}let i=t+o;if(i+2>r.length)break;let n=r.length;for(let a=i+2;a<r.length-2;a++)if(r[a]===0&&r[a+1]===0&&(r[a+2]===1||a+3<r.length&&r[a+2]===0&&r[a+3]===1)){n=a;break}let{type:s,layerId:c}=Gt(r[i],r[i+1]);e.push({type:s,layerId:c,data:r.subarray(i,n)}),t=n;}return e}function ze(r,e){let t=Buffer.from(r),{type:o,temporalId:i}=Gt(t[0],t[1]),[n,s]=je(o,e,i);return t[0]=n,t[1]=s,t}function jt(r){let e=[];for(let t=0;t<r.length;t++)t+2<r.length&&r[t]===0&&r[t+1]===0&&r[t+2]===3?(e.push(0,0),t+=2):e.push(r[t]);return Buffer.from(e)}function zt(r){let e=[];e.push(r[0],r[1]);let t=0;for(let o=2;o<r.length;o++)t===2&&r[o]<=3&&(e.push(3),t=0),r[o]===0?t++:t=0,e.push(r[o]);return Buffer.from(e)}function so(r){let e=new me(jt(r));if(e.read(16),e.read(4),e.read(2),e.read(6)>0)return;let t=e.read(3);e.read(17);let o=e.pos;return e.read(96),t>0&&e.read(t*2+(8-t)*2),{ptlStart:o,ptlEnd:e.pos,ptlBits:e.bits,maxSubLayersMinus1:t}}function co(r,e){r.w(16385,16),r.w(0,4),r.flag(1),r.flag(1),r.w(1,6),r.w(e.maxSubLayersMinus1,3),r.flag(e.maxSubLayersMinus1===0),r.w(65535,16),r.copy(e.ptlBits,e.ptlStart,e.ptlEnd-e.ptlStart),r.flag(1);for(let t=0;t<=e.maxSubLayersMinus1;t++)r.ue(4),r.ue(2),r.ue(4);r.w(1,6),r.ue(1),r.flag(1),r.flag(1),r.flag(0),r.flag(1),r.align(1);}function uo(r,e,t,o){if(r.copy(e.ptlBits,e.ptlEnd-8,8),e.maxSubLayersMinus1>0){for(let i=0;i<e.maxSubLayersMinus1;i++)r.w(0,2);for(let i=e.maxSubLayersMinus1;i<8;i++)r.w(0,2);}r.flag(0);for(let i=0;i<16;i++)r.flag(i===2||i===3);r.w(0,3),r.w(0,3),r.flag(1),r.w(1,6),r.w(1,1),r.w(1,1),r.w(0,4),r.flag(0),r.ue(0),r.flag(0),r.flag(0),r.flag(0),r.ue(2),r.flag(1),r.copy(e.ptlBits,e.ptlStart,e.ptlEnd-e.ptlStart),r.ue(0),r.w(0,2),r.w(1,2),r.w(2,2),r.ue(0),r.w(t,16),r.w(o,16),r.flag(1),r.w(1,2),r.w(0,4),r.w(0,4),r.flag(0),r.flag(1),r.flag(0),r.flag(1),r.flag(0),r.ue(0),r.ue(0),r.ue(0),r.ue(0),r.ue(0),r.flag(0),r.ue(0),r.flag(0),r.flag(0);}function qt(r,e,t){let o=so(r);if(!o)return r;let i=new pe;return co(i,o),uo(i,o,e,t),i.bits.push(1),i.align(0),zt(le(i.bits))}var po=39;function Kt(r){let{baseExtradata:e,alphaExtradata:t}=r,o=q(e),i=q(t),n=new Map;for(let a of i){if(a.type===32)continue;let u=n.get(a.type)??[];u.push(a),n.set(a.type,u);}let s=[],c=new Set;for(let a of o){let u=a.type===32?qt(a.data,r.width,r.height):a.data;if(s.push(z,u),!c.has(a.type)){c.add(a.type);for(let d of n.get(a.type)??[])s.push(z,ze(d.data,1));}}return s.push(qe()),Buffer.concat(s)}function qe(){let[t,o]=je(po,0,1),i=[],n=(s,c)=>{for(let a=c-1;a>=0;a--)i.push(s>>a&1);};for(n(0,1),n(0,3),n(0,3),n(0,9),n(255,9),n(0,1),n(0,1),n(1,1);i.length%8!==0;)n(0,1);return Buffer.concat([z,Buffer.from([t,o]),Buffer.from([165,4]),le(i),Buffer.from([128])])}function Yt(r,e){let t=[];for(let o of r)t.push(z,o.data);for(let o of e)o.type<32&&t.push(z,ze(o.data,1));return Buffer.concat(t)}var fe=class r{_s;_seiBuffer;_pts=0n;_seiInjected=false;_alphaBuf;_alphaFrame;constructor(e){this._s=e,this._seiBuffer=qe();}static async create(e){let{width:t,height:o,fps:i,bitrate:n,muxer:s}=e,c=nodeAv.Codec.findEncoderByName(constants.FF_ENCODER_HEVC_NVENC);if(!c)throw new Error("hevc_nvenc encoder not found");let u={codec:c,width:t,height:o,fps:i,bitrate:n,options:{preset:"p4",bf:"0"}},d=await M({...u,pixelFormat:constants.AV_PIX_FMT_BGRA},"nvenc.base.open2"),p=await M({...u,pixelFormat:constants.AV_PIX_FMT_YUV420P},"nvenc.alpha.open2"),h=F(),l=F(),w=s.addStream(d,"hvc1"),x=d.extraData,b=p.extraData;return x&&b&&(w.codecpar.extradata=Kt({baseExtradata:x,alphaExtradata:b,width:t,height:o})),new r({baseCtx:d,alphaCtx:p,basePkt:h,alphaPkt:l,stream:w})}async encode(e,t){let{baseCtx:o,alphaCtx:i}=this._s,n=this._pts++;e.pts=n,e.duration=1n,nodeAv.FFmpegError.throwIfError(await o.sendFrame(e),"base.sendFrame");let s=e.data?.[0],c=e.linesize?.[0];if(!s||!c)throw new Error("encode: missing BGRA data");let a=e.width,u=e.height,d=a*u,p=(a>>1)*(u>>1);this._alphaBuf||(this._alphaBuf=Buffer.alloc(d+p*2));let h=this._alphaBuf;for(let l=0;l<u;l++)for(let w=0;w<a;w++)h[l*a+w]=s[l*c+w*4+3];h.fill(128,d,d+p*2),this._alphaFrame?.free(),this._alphaFrame=nodeAv.Frame.fromVideoBuffer(h,{format:constants.AV_PIX_FMT_YUV420P,width:a,height:u}),this._alphaFrame.pts=n,this._alphaFrame.duration=1n,nodeAv.FFmpegError.throwIfError(await i.sendFrame(this._alphaFrame),"alpha.sendFrame"),await this.drainInterleaved(t);}async flush(e){await this._s.baseCtx.sendFrame(null),await this._s.alphaCtx.sendFrame(null),await this.drainInterleaved(e);}[Symbol.dispose](){let{basePkt:e,alphaPkt:t,baseCtx:o,alphaCtx:i}=this._s;e.free(),t.free(),this._alphaFrame?.free(),o.freeContext(),i.freeContext();}async drainInterleaved(e){let{baseCtx:t,alphaCtx:o,basePkt:i,alphaPkt:n,stream:s}=this._s;for(;;){let c=await t.receivePacket(i),a=await o.receivePacket(n),u=c>=0,d=a>=0;if(!u&&!d)break;if(u!==d)throw new Error(`NVENC desync: base=${u}, alpha=${d}`);let p=q(i.data),h=q(n.data),l=[];this._seiInjected||(l.push(this._seiBuffer),this._seiInjected=true),l.push(Yt(p,h));let w=i.pts,x=i.dts,b=i.duration;i.data=Buffer.concat(l),i.pts=w,i.dts=x,i.duration=b===0n?1n:b,i.streamIndex=s.index,i.rescaleTs(t.timeBase,s.timeBase),await e.writePacket(i),i.unref(),n.unref();}}};var he=class r{_ctx;_pkt;_stream;_pts=0n;constructor(e,t,o){this._ctx=e,this._pkt=t,this._stream=o;}static async create(e){let{codecName:t,codecTag:o,codecOpts:i,muxer:n,...s}=e,c=nodeAv.Codec.findEncoderByName(t);if(!c)throw new Error(`Video encoder not found: ${t}`);let a=await M({codec:c,...s,codecTag:o,options:i},"videoCtx.open2"),u=n.addStream(a,o);return new r(a,F(),u)}async encode(e,t){e.pts=this._pts++,e.duration=1n,nodeAv.FFmpegError.throwIfError(await this._ctx.sendFrame(e),"videoCtx.sendFrame"),await this.drain(t);}async flush(e){await this._ctx.sendFrame(null),await this.drain(e);}[Symbol.dispose](){this._pkt.free(),this._ctx.freeContext();}drain(e){return $(this._ctx,this._pkt,this._stream,e)}};var we=class r{_ctx;_pkt;_stream;_pts=0n;constructor(e,t,o){this._ctx=e,this._pkt=t,this._stream=o;}static async create(e){let{width:t,height:o,fps:i,hw:n,bitrate:s,muxer:c}=e,a=n.getEncoderCodec("hevc");if(!a)throw new Error("hevc_videotoolbox encoder not found");let u=await M({codec:a,width:t,height:o,fps:i,bitrate:s,pixelFormat:constants.AV_PIX_FMT_BGRA,colorRange:constants.AVCOL_RANGE_JPEG,codecTag:"hvc1",options:{alpha_quality:"1"}},"vtEnc.open2"),d=c.addStream(u,"hvc1");return new r(u,F(),d)}async encode(e,t){e.pts=this._pts++,e.duration=1n,nodeAv.FFmpegError.throwIfError(await this._ctx.sendFrame(e),"vtEnc.sendFrame"),await this.drain(t);}async flush(e){await this._ctx.sendFrame(null),await this.drain(e);}[Symbol.dispose](){this._pkt.free(),this._ctx.freeContext();}drain(e){return $(this._ctx,this._pkt,this._stream,e)}};var ge="[Encoder]";async function Qt(r,e){let{width:t,height:o,fps:i,bitrate:n=8e6,disableHwCodec:s=false}=r,c=s?void 0:api.HardwareContext.auto()??void 0;try{if(c?.deviceTypeName===constants.FF_HWDEVICE_TYPE_VIDEOTOOLBOX&&c.getEncoderCodec("hevc"))return f.debug(ge,"using VideoToolbox HEVC alpha encoder"),{hwVideo:await we.create({width:t,height:o,fps:i,hw:c,bitrate:n,muxer:e}),hw:c};if(c?.deviceTypeName===constants.FF_HWDEVICE_TYPE_CUDA&&c.getEncoderCodec("hevc"))return f.debug(ge,"using NVENC dual-layer HEVC alpha encoder"),{hwVideo:await fe.create({width:t,height:o,fps:i,hw:c,bitrate:n,muxer:e}),hw:c}}catch(u){f.warn(ge,"Hardware codec session limits reached, use software encoder",u);}finally{c?.dispose();}return f.debug(ge,"using software libx265 HEVC alpha encoder"),c?.dispose(),{video:await he.create({width:t,height:o,fps:i,codecName:constants.FF_ENCODER_LIBX265,codecTag:"hvc1",codecOpts:{preset:"medium","x265-params":"log-level=1:bframes=3:pools=+:frame-threads=0"},bitrate:n,pixelFormat:constants.AV_PIX_FMT_YUVA420P,muxer:e}),codec:await j.create(t,o)}}var _e=class{_ctx;_opened=false;constructor(e,t){this._ctx=new nodeAv.FormatContext,nodeAv.FFmpegError.throwIfError(this._ctx.allocOutputContext2(null,t??null,e),"allocOutputContext2");}addStream(e,t){let o=this._ctx.newStream(null);return o.timeBase=e.timeBase,nodeAv.FFmpegError.throwIfError(o.codecpar.fromContext(e),"codecpar.fromContext"),t&&(o.codecpar.codecTag=t),o}async open(){this._opened||(nodeAv.FFmpegError.throwIfError(await this._ctx.openOutput(),"openOutput"),nodeAv.FFmpegError.throwIfError(await this._ctx.writeHeader(null),"writeHeader"),this._opened=true);}async writePacket(e){nodeAv.FFmpegError.throwIfError(await this._ctx.interleavedWriteFrame(e),"interleavedWriteFrame");}async[Symbol.asyncDispose](){this._opened&&(await this._ctx.writeTrailer(),await this._ctx.closeOutput(),await this._ctx[Symbol.asyncDispose](),this._opened=false);}};var K=class r{_s;_disposed=false;constructor(e){this._s=e;}static async create(e){let{width:t,height:o,outFile:i,withAudio:n=false}=e,s=new _e(i),{video:c,hwVideo:a,codec:u,hw:d}=await Qt(e,s),p;return n&&(p=await de.create({outSampleRate:44100,outSampleFmt:constants.AV_SAMPLE_FMT_FLTP,codecName:constants.FF_ENCODER_AAC,globalHeader:true,bitrate:128e3,muxer:s})),await s.open(),new r({video:c,hwVideo:a,audio:p,muxer:s,limiter:new W(1),outFile:i,codec:u,hw:d,width:t,height:o})}setupAudio(e){this._s.audio?.setInputRate(e);}async encodeBGRA(e){await this._s.limiter.schedule(async()=>{let{hwVideo:t,video:o,codec:i,muxer:n}=this._s;if(t){var u=[];try{let l=y(u,this.bgraFrame(e));await t.encode(l,n);return}catch(d){var p=d,h=true;}finally{v(u,p,h);}}let{src:s,dst:c,sws:a}=i;return assert.ok(a,"sws not initialized"),nodeAv.FFmpegError.throwIfError(s.makeWritable(),"bgraSrc.makeWritable"),nodeAv.FFmpegError.throwIfError(s.fromBuffer(e),"bgraSrc.fromBuffer"),nodeAv.FFmpegError.throwIfError(c.makeWritable(),"bgraDst.makeWritable"),nodeAv.FFmpegError.throwIfError(await a.scaleFrame(c,s),"bgraSws.scaleFrame"),o.encode(c,n)});}async encodePNG(e){await this._s.limiter.schedule(async()=>{let{hwVideo:t,video:o,codec:i,muxer:n,width:s,height:c}=this._s,a=i??await j.create(s,c);try{let u=await a.decodePNG(e);t?await t.encode(u,n):(nodeAv.FFmpegError.throwIfError(a.dst.makeWritable(),"pngDst.makeWritable"),nodeAv.FFmpegError.throwIfError(await a.sws.scaleFrame(a.dst,u),"pngSws.scaleFrame"),await o.encode(a.dst,n));}finally{i||a[Symbol.dispose]();}});}async encodeAudio(e){let{audio:t,limiter:o,muxer:i}=this._s;t&&await o.schedule(()=>t.encode(e,i));}async finish(){let{video:e,hwVideo:t,audio:o,muxer:i,limiter:n}=this._s;try{var s=[];try{let p=y(s,i,!0);let h=y(s,e);let l=y(s,t);let w=y(s,o);await n.drain();await o?.flush(i);t?await t.flush(i):await e.flush(i);}catch(c){var a=c,u=!0;}finally{var d=v(s,a,u);d&&await d;}}finally{this.free();}return this._s.outFile}async[Symbol.asyncDispose](){if(this._disposed)return;let{video:e,hwVideo:t,audio:o,muxer:i,limiter:n}=this._s;await n.drain(),e?.[Symbol.dispose](),t?.[Symbol.dispose](),o?.[Symbol.dispose](),await i[Symbol.asyncDispose](),this.free();}free(){var t=[];try{if(this._disposed)return;this._disposed=!0;let e=y(t,this._s.codec);this._s.hw?.dispose();}catch(o){var i=o,n=true;}finally{v(t,i,n);}}bgraFrame(e){let t=ie(this._s.width,this._s.height,constants.AV_PIX_FMT_BGRA);return nodeAv.FFmpegError.throwIfError(t.fromBuffer(e),"bgraFrame.fromBuffer"),t}};var be=class{_fps;_actual=0;_currentBurst=0;_bursts=[];constructor(e){this._fps=e;}wrote(e=1){this._currentBurst>0&&(this._bursts.push(this._currentBurst),this._currentBurst=0),this._actual+=e;}dropped(e=1){this._currentBurst+=e;}finalize(){this._currentBurst>0&&(this._bursts.push(this._currentBurst),this._currentBurst=0);let e=0,t=0,o=0;for(let a of this._bursts){e+=a,o=Math.max(o,a);let u=Math.max(0,a-1);t+=(u/this._fps)**2;}let i=this._actual+e,n=i>0?e/i:0,s=Math.min(1,t),c=1-(1-n)*(1-s);return {global:n,local:s,jank:c,expected:i,actual:this._actual,maxBurst:o}}};function xe(r){let e=r.getSize();return e.width===0||e.height===0?true:r.isEmpty()}var Ke="audio-meta",Ye="audio-chunk",No=`
90
96
  (function() {
91
97
  if (window.__pup_audio_capturing__) return;
92
98
  window.__pup_audio_capturing__ = true;
@@ -120,7 +126,7 @@
120
126
  capturedContexts.add(ctx);
121
127
  if (!metaSent) {
122
128
  metaSent = true;
123
- ipcRenderer.send('audio-meta', { sampleRate: ctx.sampleRate });
129
+ ipcRenderer.send('${Ke}', { sampleRate: ctx.sampleRate });
124
130
  }
125
131
  const node = ctx.createScriptProcessor(4096, 2, 2);
126
132
  node.onaudioprocess = (e) => {
@@ -131,7 +137,7 @@
131
137
  out[i * 2] = L[i];
132
138
  out[i * 2 + 1] = R[i];
133
139
  }
134
- ipcRenderer.send('audio-chunk', Buffer.from(out.buffer));
140
+ ipcRenderer.send('${Ye}', Buffer.from(out.buffer));
135
141
  };
136
142
  node.connect(ctx.destination);
137
143
  ctx.__pup_captureNode__ = node;
@@ -158,9 +164,9 @@
158
164
  return origPlay.call(this);
159
165
  };
160
166
  })();
161
- `;async function Yt({encoder:r,getVideoTimeMs:e,onError:t}){let o=path.join(os.tmpdir(),`pup_audio_preload_${crypto.randomUUID()}.js`);return await promises.writeFile(o,Bo),electron.session.defaultSession.registerPreloadScript({type:"frame",id:"pup-audio",filePath:o}),electron.ipcMain.on("audio-meta",async(i,n)=>{let c=n.sampleRate,s=e();r.setupAudio(c);let a=Math.ceil(s*c/1e3);if(!(a<=0))try{await r.encodeAudio(Buffer.alloc(a*2*4));}catch(u){t(u);}}),electron.ipcMain.on("audio-chunk",async(i,n)=>{try{await r.encodeAudio(n);}catch(c){t(c);}}),{async teardown(){electron.ipcMain.removeAllListeners("audio-meta"),electron.ipcMain.removeAllListeners("audio-chunk"),electron.session.defaultSession.unregisterPreloadScript("pup-audio"),await promises.rm(o,{force:true});}}}function be(r){return new Promise(e=>setTimeout(e,r))}function Jt({fn:r,maxAttempts:e=3,timeout:t}){let o=new Error(`timeout over ${t}ms`);return async function(...i){let n=0;for(;;)try{let c=[r(...i)];return t&&c.push(promises$1.setTimeout(t).then(()=>{throw o})),await Promise.race(c)}catch(c){if(n++,n>=e)throw c;await be(Math.pow(2,n)*100+Math.random()*100);}}}var qe=["file:","http:","https:","data:"],Mo=/^(file:|https?:|data:)/;function Kt(r){if(Mo.test(r))return;let e=r.split(":")[0]+":",t=qe.includes(e)?`unsupported protocol: ${e}, expected ${qe.join(", ")}`:`invalid source format, expected ${qe.join(", ")}`;throw new Error(t)}var xe=class{_promise;_resolve;_timeoutToken;wait(e){if(this._promise)throw new Error("already waiting");return this._promise=new Promise(t=>{this._resolve=t,e?.timeout!==void 0&&(this._timeoutToken=setTimeout(()=>{e.onTimeout?.(),t();},e.timeout));}),this._promise}signal(){clearTimeout(this._timeoutToken),this._promise=void 0,this._resolve?.();}};var ye="[Network]",Do=new Map([["jssz-boss.hdslb.com","jssz-boss.bilibili.co"],["boss.hdslb.com","shjd-boss.bilibili.co"]]);function Xe(r){if(!r.startsWith("http"))return r;let e=new url.URL(r),t=Do.get(e.hostname);return t?(e.hostname=t,e.protocol="http:",e.toString()):r}function Qt({source:r,window:e,useInnerProxy:t}){let o=e.webContents.session.webRequest,i=new G(64),n=new Map;async function c(a,u){let p=new xe;n.set(a,p),await p.wait({timeout:5e3,onTimeout:u}).finally(()=>n.delete(a));}function s(a){n.get(a)?.signal();}o.onBeforeRequest((a,u)=>{let p=a.url,d=t?Xe(p):p;i.schedule(()=>{let m=`${e.id}_${a.id}`;return _.debug(ye,"start:",{key:m,url:p,proxied:d,method:a.method,source:r,stats:i.stats}),u(d===p?{cancel:false}:{cancel:false,redirectURL:d}),c(m,()=>{_.warn(ye,"maybe timeout:",{key:m,url:p,proxied:d,method:a.method,source:r});})});}),o.onHeadersReceived(({responseHeaders:a},u)=>{delete a?.["x-frame-options"],delete a?.["X-Frame-Options"],delete a?.["content-security-policy"],delete a?.["Content-Security-Policy"],u({cancel:false,responseHeaders:a});}),o.onCompleted(a=>{let u=`${e.id}_${a.id}`;s(u),_.debug(ye,"completed:",{key:u,url:a.url,method:a.method,statusCode:a.statusCode,source:r});}),o.onErrorOccurred(a=>{let u=`${e.id}_${a.id}`;s(u),_.error(ye,"error:",{key:u,url:a.url,method:a.method,error:a.error,source:r});});}function Ye(r){let e=r.webContents.session.webRequest;e.onBeforeRequest(null),e.onHeadersReceived(null),e.onCompleted(null),e.onErrorOccurred(null);}var Je="[Window]";function Vo(r,e){return new Promise((t,o)=>{let i=setTimeout(()=>o(new Error("load window timeout")),3e4),n=c=>{clearTimeout(i),c?o(c):t();};r.webContents.once("did-stop-loading",()=>n()),r.webContents.once("did-frame-finish-load",(c,s,a,u)=>{_.debug(Je,"did-frame-finish-load:",{isMainFrame:s,frameProcessId:a,frameRoutingId:u});}),r.webContents.once("dom-ready",()=>{_.debug(Je,"dom-ready");}),r.webContents.once("did-fail-load",(c,s,a,u)=>n(new Error(`failed to load ${u}: [${s}] ${a}`))),r.webContents.once("render-process-gone",(c,{exitCode:s,reason:a})=>n(new Error(`renderer crashed: ${s}, ${a}`))),e();})}function er(r){return new Promise(e=>{Ye(r),r.once("closed",e),r.destroy();})}async function Zt({source:r,onCreated:e,renderer:t,warmup:o}){Kt(r);let{width:i,height:n,useInnerProxy:c}=t,s=c?Xe(r):r,a=new electron.BrowserWindow({width:i,height:n+1,show:false,transparent:true,backgroundColor:void 0,frame:false,webPreferences:{offscreen:true,backgroundThrottling:false,nodeIntegration:true,nodeIntegrationInSubFrames:true,nodeIntegrationInWorker:true,contextIsolation:false,webSecurity:false,allowRunningInsecureContent:true,experimentalFeatures:true}});Qt({source:r,window:a,useInnerProxy:c}),o||await e?.(a),a.webContents.on("console-message",({level:u,message:p,lineNumber:d,sourceId:m})=>{let l=[Je,"console:",{message:p,lineNumber:d,sourceId:m,source:r}];u==="error"?_.error(...l):_.debug(...l);});try{let u=At(s,{width:i,height:n});await Vo(a,()=>a.loadURL(u));}catch(u){throw await er(a),u}return a}async function Ee({source:r,onCreated:e,renderer:t}){let o;try{o=await Jt({fn:Zt,maxAttempts:2})({source:r,renderer:t,warmup:!0});}catch(i){let{message:n,stack:c}=i;throw new Error(`failed to load window: ${JSON.stringify({source:r,message:n,stack:c})}`)}o.webContents.removeAllListeners(),Ye(o),await be(2e3),await er(o);try{return await Zt({source:r,renderer:t,onCreated:e})}catch(i){let{message:n,stack:c}=i;throw new Error(`failed to load window: ${JSON.stringify({source:r,message:n,stack:c})}`)}}async function tr(r,e,t){var V=[];try{let{fps:o,width:i,height:n,duration:c,withAudio:s,outFile:a,disableGpu:u}=t;let p=v(V,await q.create({width:i,height:n,fps:o,outFile:a,withAudio:s,disableGpu:u}),!0);let d=Math.ceil(o*c);let m=1e3/o;let l=0;let g;let b=0;let w;let E;let x;let y=new we(o);let h;let A=R=>{l++,p.encodeBGRA(R).catch(ne=>w??=ne);};let Y=(R,ne,Pe)=>{if(w){x?.(w);return}if(_e(Pe))return;let Se=Pe.toBitmap(),Q=se(Se,Pe.getSize());if(Q===void 0){w??=new Error(`no timestamp @ ${l}`);return}let ur=i*4,Ce=Buffer.from(Se.buffer,Se.byteOffset,n*ur);if(g===void 0)A(Ce),y.wrote(),g=Q;else {let Ie=Q-g;if(Ie>=m*.8){if(Ie<=m*1.2)A(Ce),y.wrote();else {let et=Math.round(Ie/m);y.dropped(et-1),y.wrote();for(let tt=0;tt<et&&l<d;tt++)A(Ce);}g=Q;}}let Ze=Math.floor(l/d*100);Math.abs(Ze-b)>10&&(b=Ze,r.writeProgress(b));let dr=c*1e3;(Q>=dr-m*.5||l>=d)&&E?.();};let P=await Ee({source:e,renderer:t,onCreated:async()=>{s&&(h=await Yt({encoder:p,getVideoTimeMs:()=>g??0,onError:R=>w??=R}));}});let L=P.webContents.debugger;P.webContents.setFrameRate(o);P.webContents.isPainting()||P.webContents.startPainting();L.attach("1.3");P.webContents.on("paint",Y);try{await ce(L),await new Promise((R,ne)=>[E,x]=[R,ne]);}finally{await ue(L),P.webContents.off("paint",Y),P.close(),await h?.teardown(),await p.finish();}if(w||l===0)throw w??new Error("no frames captured");else {let R=y.finalize();return {written:l,jank:R.jank,outFile:a}}}catch(J){var ie=J,Fe=true;}finally{var K=F(V,ie,Fe);K&&await K;}}function rr(r,e){return new Promise((t,o)=>{let i=setTimeout(()=>{r.off("message",n),o(new Error("advanceVirtualTime timed out after 30000ms"));},3e4),n=(c,s)=>{s==="Emulation.virtualTimeBudgetExpired"&&(clearTimeout(i),r.off("message",n),t());};r.on("message",n),r.sendCommand("Emulation.setVirtualTimePolicy",{policy:"advance",budget:e});})}function or(r){return r.sendCommand("Emulation.setVirtualTimePolicy",{policy:"pause"})}function ir(r,e=100){let t;return function(...o){clearTimeout(t),t=setTimeout(()=>{r.apply(this,o),t=void 0;},e);}}var ve=class{constructor(e){this.makeValue=e;}makeValue;get value(){return this._initialized||(this._value=this.makeValue(),this._initialized=true),this._value}get initialized(){return this._initialized}_initialized=false;_value};var X="__pup_tick__";function nr(r){return `(function() {
162
- ${"if (window.self === window.top) return;"}
163
- if (typeof ${X} !== 'undefined') return;
167
+ `;async function er({encoder:r,getVideoTimeMs:e,onError:t}){let o=path.join(os.tmpdir(),`pup_audio_${crypto.randomUUID()}.js`);return await promises.writeFile(o,No),electron.session.defaultSession.registerPreloadScript({type:"frame",id:"pup-audio",filePath:o}),electron.ipcMain.on(Ke,async(i,n)=>{let s=n.sampleRate,c=e();r.setupAudio(s);let a=Math.ceil(c*s/1e3);if(!(a<=0))try{await r.encodeAudio(Buffer.alloc(a*2*4));}catch(u){t(u);}}),electron.ipcMain.on(Ye,async(i,n)=>{try{await r.encodeAudio(n);}catch(s){t(s);}}),{async teardown(){electron.ipcMain.removeAllListeners(Ke),electron.ipcMain.removeAllListeners(Ye),electron.session.defaultSession.unregisterPreloadScript("pup-audio"),await promises.rm(o,{force:true});}}}function Ee(r){return new Promise(e=>setTimeout(e,r))}function tr({fn:r,maxAttempts:e=3,timeout:t}){let o=new Error(`timeout over ${t}ms`);return async function(...i){let n=0;for(;;)try{let s=[r(...i)];return t&&s.push(promises$1.setTimeout(t).then(()=>{throw o})),await Promise.race(s)}catch(s){if(n++,n>=e)throw s;await Ee(Math.pow(2,n)*100+Math.random()*100);}}}var Xe=["file:","http:","https:","data:"],Lo=/^(file:|https?:|data:)/;function rr(r){if(Lo.test(r))return;let e=r.split(":")[0]+":",t=Xe.includes(e)?`unsupported protocol: ${e}, expected ${Xe.join(", ")}`:`invalid source format, expected ${Xe.join(", ")}`;throw new Error(t)}var ve=class{_promise;_resolve;_timeoutToken;wait(e){if(this._promise)throw new Error("already waiting");return this._promise=new Promise(t=>{this._resolve=t,e?.timeout!==void 0&&(this._timeoutToken=setTimeout(()=>{e.onTimeout?.(),t();},e.timeout));}),this._promise}signal(){clearTimeout(this._timeoutToken),this._promise=void 0,this._resolve?.();}};var Pe="[Network]",Uo=new Map([["jssz-boss.hdslb.com","jssz-boss.bilibili.co"],["boss.hdslb.com","shjd-boss.bilibili.co"]]);function Je(r){if(!r.startsWith("http"))return r;let e=new url.URL(r),t=Uo.get(e.hostname);return t?(e.hostname=t,e.protocol="http:",e.toString()):r}function or({source:r,window:e,useInnerProxy:t}){let o=e.webContents.session.webRequest,i=new W(64),n=new Map;async function s(a,u){let d=new ve;n.set(a,d),await d.wait({timeout:5e3,onTimeout:u}).finally(()=>n.delete(a));}function c(a){n.get(a)?.signal();}o.onBeforeRequest((a,u)=>{let d=a.url,p=t?Je(d):d;i.schedule(()=>{let h=`${e.id}_${a.id}`;return f.debug(Pe,"start:",{key:h,url:d,proxied:p,method:a.method,source:r,stats:i.stats}),u(p===d?{cancel:false}:{cancel:false,redirectURL:p}),s(h,()=>{f.warn(Pe,"maybe timeout:",{key:h,url:d,proxied:p,method:a.method,source:r});})});}),o.onHeadersReceived(({responseHeaders:a},u)=>{delete a?.["x-frame-options"],delete a?.["X-Frame-Options"],delete a?.["content-security-policy"],delete a?.["Content-Security-Policy"],u({cancel:false,responseHeaders:a});}),o.onCompleted(a=>{let u=`${e.id}_${a.id}`;c(u),f.debug(Pe,"completed:",{key:u,url:a.url,method:a.method,statusCode:a.statusCode,source:r});}),o.onErrorOccurred(a=>{let u=`${e.id}_${a.id}`;c(u),f.error(Pe,"error:",{key:u,url:a.url,method:a.method,error:a.error,source:r});});}function Qe(r){let e=r.webContents.session.webRequest;e.onBeforeRequest(null),e.onHeadersReceived(null),e.onCompleted(null),e.onErrorOccurred(null);}var Ce="[Window]",Ze=new Error("window timeout");function Wo(r,e,t=false){return new Promise((o,i)=>{let n=false,s=a=>{clearTimeout(c),a===Ze&&t&&n?o():a?i(a):o();},c=setTimeout(()=>s(Ze),3e4);r.webContents.once("dom-ready",()=>{f.debug(Ce,"dom-ready"),n=true;}),r.webContents.once("did-stop-loading",()=>s()),r.webContents.once("did-frame-finish-load",(a,u,d,p)=>{f.debug(Ce,"did-frame-finish-load:",{isMainFrame:u,frameProcessId:d,frameRoutingId:p});}),r.webContents.once("did-fail-load",(a,u,d,p)=>s(new Error(`failed to load ${p}: [${u}] ${d}`))),r.webContents.once("render-process-gone",(a,{exitCode:u,reason:d})=>s(new Error(`renderer crashed: ${u}, ${d}`))),e();})}function ir(r){return new Promise(e=>{Qe(r),r.once("closed",e),r.destroy();})}async function nr({source:r,onCreated:e,renderer:t,warmup:o,tolerant:i}){rr(r);let{width:n,height:s,useInnerProxy:c}=t,a=c?Je(r):r,u=new electron.BrowserWindow({width:n,height:s+1,show:false,transparent:true,backgroundColor:void 0,frame:false,webPreferences:{offscreen:true,backgroundThrottling:false,nodeIntegration:true,nodeIntegrationInSubFrames:true,nodeIntegrationInWorker:true,contextIsolation:false,webSecurity:false,allowRunningInsecureContent:true,experimentalFeatures:true}});or({source:r,window:u,useInnerProxy:c}),o||await e?.(u),u.webContents.on("console-message",({level:d,message:p,lineNumber:h,sourceId:l})=>{let w=[Ce,"console:",{message:p,lineNumber:h,sourceId:l,source:r}];d==="error"?f.error(...w):f.debug(...w);});try{let d=Nt(a,{width:n,height:s});await Wo(u,()=>u.loadURL(d),i);}catch(d){throw await ir(u),d}return u}var $o=tr({fn:nr,maxAttempts:2});async function Fe({source:r,onCreated:e,renderer:t}){let o,i;try{o=await $o({source:r,renderer:t,warmup:!0});}catch(s){i=s;}let n=()=>nr({source:r,renderer:t,onCreated:e,tolerant:t.windowTolerant});if(t.windowTolerant&&i===Ze)return f.warn(Ce,`warmup timeout: ${r}, falling back to dom-ready`),await n();if(i){let{message:s,stack:c}=i;throw new Error(`failed to warmup window: ${JSON.stringify({source:r,message:s,stack:c})}`)}o&&(o.webContents.removeAllListeners(),Qe(o),await Ee(2e3),await ir(o));try{return await n()}catch(s){let{message:c,stack:a}=s;throw new Error(`failed to load window: ${JSON.stringify({source:r,message:c,stack:a})}`)}}async function ar(r,e,t){var J=[];try{let{fps:o,width:i,height:n,duration:s,withAudio:c,outFile:a,disableHwCodec:u}=t;let d=y(J,await K.create({width:i,height:n,fps:o,outFile:a,withAudio:c,disableHwCodec:u}),!0);let p=Math.ceil(o*s);let h=1e3/o;let l=0;let w;let x=0;let b;let E;let _;let C=new be(o);let g;let S=A=>{l++,d.encodeBGRA(A).catch(L=>b??=L);};let ae=(A,L,V)=>{if(b){_?.(b);return}if(xe(V))return;let Ie=V.toBitmap(),ee=ue(Ie,V.getSize());if(ee===void 0){b??=new Error(`no timestamp @ ${l}`);return}let hr=i*4,ke=Buffer.from(Ie.buffer,Ie.byteOffset,n*hr);if(w===void 0)S(ke),C.wrote(),w=ee;else {let Te=ee-w;if(Te>=h*.8){if(Te<=h*1.2)S(ke),C.wrote();else {let rt=Math.round(Te/h);C.dropped(rt-1),C.wrote();for(let ot=0;ot<rt&&l<p;ot++)S(ke);}w=ee;}}let tt=Math.floor(l/p*100);Math.abs(tt-x)>10&&(x=tt,r.writeProgress(x));let wr=s*1e3;(ee>=wr-h*.5||l>=p)&&E?.();};let I=await Fe({source:e,renderer:t,onCreated:async()=>{c&&(g=await er({encoder:d,getVideoTimeMs:()=>w??0,onError:A=>b??=A}));}});let X=I.webContents.debugger;I.webContents.setFrameRate(o);I.webContents.isPainting()||I.webContents.startPainting();X.attach("1.3");I.webContents.on("paint",ae);try{await Tt(X),await new Promise((A,L)=>[E,_]=[A,L]);}finally{await Bt(X),I.webContents.off("paint",ae),I.close(),await g?.teardown(),await d.finish();}if(b||l===0)throw b??new Error("no frames captured");else {let A=C.finalize();return {written:l,jank:A.jank,outFile:a}}}catch(Q){var Ae=Q,Z=true;}finally{var D=v(J,Ae,Z);D&&await D;}}function sr(r,e){return new Promise((t,o)=>{let i=setTimeout(()=>{r.off("message",n),o(new Error("advanceVirtualTime timed out after 30000ms"));},3e4),n=(s,c)=>{c==="Emulation.virtualTimeBudgetExpired"&&(clearTimeout(i),r.off("message",n),t());};r.on("message",n),r.sendCommand("Emulation.setVirtualTimePolicy",{policy:"advance",budget:e});})}function cr(r){return r.sendCommand("Emulation.setVirtualTimePolicy",{policy:"pause"})}var jo="[HWAccel]";async function zo(){let r=api.HardwareContext.auto(),e=r!==null;return r?.dispose(),e}var ur=zo().then(r=>(f.debug(jo,"gpu:",r),r));var Y="__pup_tick__";function dr(){return `(function() {
168
+ if (window.self === window.top) return;
169
+ if (typeof ${Y} !== 'undefined') return;
164
170
 
165
171
  const orig = {
166
172
  Date: Date,
@@ -248,9 +254,9 @@
248
254
  window.clearTimeout = orig.clearTimeout;
249
255
  window.setInterval = orig.setInterval;
250
256
  window.clearInterval = orig.clearInterval;
251
- delete window.${X};
257
+ delete window.${Y};
252
258
  }
253
259
 
254
- window.${X} = { process: process, eject: eject };
255
- })();`}function Ke(r){return `${X}.process(${r})`}function ar(){return `if (typeof ${X} !== 'undefined') ${X}.eject()`}var Qe="[Shoot]";function Uo({win:r,size:e,afterTs:t}){let o=new Set,i=ir(()=>{let n=Array.from(o);o.clear(),_.debug(Qe,`skipped frames ${n.join(", ")}, expected > ${t}`);},1e3);return new Promise(n=>{let c=(s,a,u)=>{if(_e(u))return;let p=u.toBitmap(),d=se(p,u.getSize());if(d===void 0||d<t){o.add(d??-1),i();return}r.webContents.stopPainting(),r.webContents.off("paint",c),n(Buffer.from(p.buffer,p.byteOffset,e.height*e.width*4));};r.webContents.on("paint",c);})}async function sr(r,e,t){var x=[];try{let{fps:o,width:i,height:n,duration:c,withAudio:s,outFile:a,disableGpu:u}=t;s&&_.warn(Qe,"audio will be ignored on this mode");let p=v(x,await q.create({width:i,height:n,fps:o,outFile:a,withAudio:s,disableGpu:u}),!0);let d=Math.ceil(o*c);let m=1e3/o;let l=0;let g=0;let b=await Ee({source:e,renderer:t});let w=b.webContents.debugger;let E=new ve(()=>b.webContents.mainFrame.frames[0]);try{w.attach("1.3");let P=u?o:240,L=1e3/P;_.debug(Qe,{fps:o,frameInterval:m,renderFps:P,renderInterval:L}),b.webContents.stopPainting(),b.webContents.setFrameRate(P),await or(w);let V=E.value;await V?.executeJavaScript(nr()),await V?.executeJavaScript(Ke(0)),await ce(w);for(let J=0;J<d;J++){let ie=(J+1)*m,Fe=Uo({win:b,size:{width:i,height:n},afterTs:ie-L/2});await rr(w,m),await V?.executeJavaScript(Ke(ie)),b.webContents.startPainting(),await p.encodeBGRA(await Fe),l++;let K=Math.floor(l/d*100);Math.abs(K-g)>10&&(g=K,r.writeProgress(g));}}finally{await E.value?.executeJavaScript(ar()),await ue(w),w.detach(),b.close(),await p.finish();}if(l===0)throw new Error("no frames captured");else return {written:l,jank:0,outFile:a}}catch(y){var h=y,A=true;}finally{var Y=F(x,h,A);Y&&await Y;}}var $o="[App]";function cr(){_.debug($o,"gpu features:",electron.app.getGPUFeatureStatus());}electron.app.dock?.hide();electron.app.on("window-all-closed",()=>{});Ft({name:"app",defaults:{...Et,withAudio:false,deterministic:false,useInnerProxy:false,disableGpu:false},run:async(r,e)=>{let t=i=>{electron.app.quit(),process.exit(i);};process.once("SIGTERM",()=>t(143)),process.once("SIGINT",()=>t(130)),process.once("exit",i=>t(i)),assert.ok(Te,"pupIpcSocket not set");let o=await Pt(Te);try{electron.app.on("gpu-info-update",cr),await electron.app.whenReady(),It(),cr(),await promises.mkdir(path.dirname(e.outFile),{recursive:!0});let i=e.deterministic?sr:tr;o.writeDone(await i(o,r,e));}catch(i){let n=i;o.writeError(n.stack??"unknown error");}finally{electron.app.quit();}}});//# sourceMappingURL=app.cjs.map
256
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../node_modules/.bun/tsup@8.5.1+e235b8331389b404/node_modules/tsup/assets/cjs_shims.js","../src/base/env.ts","../src/base/parser.ts","../src/base/constants.ts","../src/base/logging.ts","../src/base/noerr.ts","../src/base/process.ts","../src/renderer/schema.ts","../src/common.ts","../src/renderer/ipc.ts","../src/renderer/stego.ts","../src/renderer/protocol.ts","../src/base/limiter.ts","../src/base/encoder/shared.ts","../src/base/encoder/audio.ts","../src/base/encoder/codec.ts","../src/base/encoder/nal.ts","../src/base/encoder/alpha.ts","../src/base/encoder/nvenc.ts","../src/base/encoder/video.ts","../src/base/encoder/videotoolbox.ts","../src/base/encoder/factory.ts","../src/base/encoder/muxer.ts","../src/base/encoder/pipeline.ts","../src/base/frame_drop.ts","../src/base/image.ts","../src/renderer/audio.ts","../src/base/timing.ts","../src/base/retry.ts","../src/renderer/html_check.ts","../src/base/waitable_event.ts","../src/renderer/network.ts","../src/renderer/window.ts","../src/renderer/render.ts","../src/base/cdp.ts","../src/base/debounce.ts","../src/base/lazy.ts","../src/renderer/tick.ts","../src/renderer/shoot.ts","../src/app.ts"],"names":["getImportMetaUrl","importMetaUrl","penv","name","parser","defaultValue","parseNumber","x","num","require","createRequire","env","pupLogLevel","pupUseInnerProxy","pupDisableGPU","pupDeterministic","pupPkgRoot","dirname","join","pupIpcSocket","DEBUG","INFO","WARN","ERROR","FATAL","stackHook","target","_context","messages","processed","msg","_fatal_dec","_error_dec","_warn_dec","_info_dec","_debug_dec","_init","Logger","_level","__runInitializers","__publicField","value","debug","info","warn","error","lv","message","proc","resolve","reject","fatal","dispatch","data","err","code","signal","reason","__decoratorStart","__decorateElement","__decoratorMetadata","logger","Log","level","AV_LOG_ERROR","AV_LOG_WARNING","noerr","fn","args","ret","PUP_ARGS_KEY","pargs","argv","priv","arg","DEFAULT_WIDTH","DEFAULT_HEIGHT","DEFAULT_FPS","DEFAULT_DURATION","DEFAULT_OUT_FILE","RenderSchema","z","defaultRenderOptions","makeCLI","options","shape","d","program","source","opts","e","HEADER_SIZE","IpcWriter","_socket","payload","type","header","connectIpc","socketPath","socket","createConnection","buildStegoHTML","targetURL","size","width","height","decodeStego","bitmap","markerRow","timestamp","i","pixelIdx","bit","startStego","cdp","stopStego","PUP_SCHEME","protocol","setupPupProtocol","req","url","src","html","createStegoURL","ConcurrencyLimiter","maxConcurrency","v","r","keep","entry","makeFrame","pixFmt","frame","Frame","FFmpegError","makePacket","pkt","Packet","drainPackets","ctx","stream","muxer","AVERROR_EAGAIN","AVERROR_EOF","SAMPLE_FMT_NAME","AV_SAMPLE_FMT_FLT","AV_SAMPLE_FMT_FLTP","AudioEncoder","_AudioEncoder","outFmt","codec","Codec","CodecContext","AV_CHANNEL_LAYOUT_STEREO","Rational","AV_CODEC_FLAG_GLOBAL_HEADER","inSampleRate","graph","FilterGraph","abuffer","Filter","bufSrc","abuffersink","bufSink","filterDesc","outputs","FilterInOut","inputs","pcm","_stack","nSamples","__using","_","_error","_hasError","__callDispose","CodecState","_CodecState","FF_DECODER_PNG","ok","png","AV_PIX_FMT_BGRA","AV_PIX_FMT_YUVA420P","pngData","sws","SoftwareScaleContext","fmt","SWS_BILINEAR","ANNEX_B_START_CODE","parseNalType","header0","header1","layerId","temporalId","encodeNalHeader","byte0","byte1","packBits","bits","buf","byte","b","splitNalUnits","bitstream","nals","scLen","nalStart","nalEnd","j","rewriteNalLayerId","nal","out","b0","b1","NAL_UNIT_PREFIX_SEI","buildUnifiedExtradata","baseExtradata","alphaExtradata","baseNals","alphaNals","alphaByType","arr","chunks","emitted","patchVPSForAlpha","alphaNal","buildAlphaChannelInfoSEI","vpsData","rbsp","bitPos","readBits","n","val","byteIdx","bitIdx","vpsBaseLayerInternalFlag","maxLayersPos","mlOffset","lastBit","h0","h1","writeBits","interleaveAccessUnits","NvencDualLayerEncoder","_NvencDualLayerEncoder","s","fps","bitrate","hw","FF_ENCODER_HEVC_NVENC","hwFramesCtx","HardwareFramesContext","AV_PIX_FMT_CUDA","AV_PIX_FMT_YUV420P","makeCtx","ctxOpts","AVCOL_RANGE_JPEG","baseCtx","alphaCtx","basePkt","alphaPkt","baseExtra","alphaExtra","baseSws","bgraFrame","yuvFrame","pts","srcLs","w","h","ySize","uvSize","y","baseHwFrame","alphaHwFrame","baseR","alphaR","baseReady","alphaReady","dts","duration","VideoEncoder","_VideoEncoder","codecName","codecTag","globalHeader","codecOpts","k","VideoToolboxEncoder","_VideoToolboxEncoder","TAG","createVideoEncoder","disableGpu","HardwareContext","FF_HWDEVICE_TYPE_VIDEOTOOLBOX","FF_HWDEVICE_TYPE_CUDA","FF_ENCODER_LIBX265","FormatMuxer","outPath","formatName","FormatContext","codecCtx","EncoderPipeline","_EncoderPipeline","outFile","withAudio","video","hwVideo","audio","FF_ENCODER_AAC","sampleRate","input","dst","cs","limiter","_m","_v","_hv","_a","_promise","_codec","FrameDropStats","count","totalDropped","localSum","maxBurst","burst","perceptible","expected","g","l","score","isEmpty","image","AUDIO_CAPTURE_SCRIPT","setupAudioCapture","encoder","getVideoTimeMs","onError","preloadPath","tmpdir","randomUUID","writeFile","session","ipcMain","_e","startMs","silenceSamples","buffer","rm","sleep","ms","useRetry","maxAttempts","timeout","timeoutError","attempt","promises","setTimeout","SUPPORTED_PROTOCOLS","SOURCE_PATTERN","checkHTML","WaitableEvent","map","proxiedUrl","parsed","URL","setInterceptor","window","useInnerProxy","events","wait","key","onTimeout","event","details","callback","proxied","responseHeaders","unsetInterceptor","waitForFinish","win","action","done","isMainFrame","frameProcessId","frameRoutingId","desc","exitCode","waitForDestroy","openWindow","onCreated","renderer","warmup","BrowserWindow","lineNumber","sourceId","msgs","loadWindow","stack","render","writer","total","frameInterval","written","lastWrittenTime","progress","encodeError","resolver","rejecter","dropStats","scheduleFrame","paint","_r","currentTime","bytesPerRow","cropped","timeDelta","framesToInsert","newProgress","durationMs","dropScore","advanceVirtualTime","budget","handler","method","pauseVirtualTime","debounce","delay","timer","Lazy","makeValue","TICK_SYMBOL","buildTickInjector","doProcess","timestampMs","doEject","awaitStegoFrame","afterTs","skipped","report","_d","ts","shoot","pipeline","rootFrame","renderFps","renderInterval","iframe","frameMs","printFeatures","app","exit","c","ipc","mkdir"],"mappings":"mjBAKA,IAAA,EAAA,CAAA,MAAA,CAAA,MAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,cAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,wBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,MAAA,CAAA,GAAA,CAAA,SAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,MAAA,SAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,UAAA,CAAA,IAAA,CAAA,YAAA,CAAA,IAAA,CAAA,QAAA,CAAA,IAAA,CAAA,KAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA,IAAA,EAAA,CAAA,IAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,OAAA,CAAA,QAAA,CAAA,QAAA,CAAA,QAAA,CAAA,UAAA,CAAA,OAAA,CAAA,OAAA,CAAA,KAAA,CAAA,KAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,GAAA,MAAA,EAAA,OAAA,CAAA,EAAA,UAAA,CAAA,CAAA,CAAA,mBAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,QAAA,CAAA,CAAA,CAAA,cAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,qBAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,EAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA,UAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,KAAA,CAAA,CAAA,CAAA,KAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,SAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,IAAA,IAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,GAAA,CAAA,CAAA,EAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,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","file":"app.cjs","sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n  typeof document === \"undefined\" \n    ? new URL(`file:${__filename}`).href \n    : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n      ? document.currentScript.src \n      : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nexport type EnvParser<T> = (value: unknown) => T;\n\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue: T): T;\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue?: T): T | undefined;\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue?: T): T | undefined {\n  try {\n    return parser(process.env[name]);\n  } catch {\n    return defaultValue;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nexport function parseNumber(x: unknown): number {\n  if (typeof x === \"number\") {\n    return x;\n  }\n  const num = Number(x);\n  if (Number.isNaN(num)) {\n    throw new Error(`Value ${x} is not a valid number`);\n  }\n  return num;\n}\n\nexport function parseString(x: unknown): string {\n  if (typeof x === \"string\") return x;\n  return String(x);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { createRequire } from \"module\";\nimport { dirname, join } from \"path\";\nimport { penv } from \"./env\";\nimport { parseNumber } from \"./parser\";\n\nconst require = createRequire(import.meta.url);\nconst env = process.env;\n\nexport const pupLogLevel = penv(\"PUP_LOG_LEVEL\", parseNumber, 2);\nexport const pupUseInnerProxy = env[\"PUP_USE_INNER_PROXY\"] === \"1\";\nexport const pupDisableGPU = env[\"PUP_DISABLE_GPU\"] === \"1\";\nexport const pupDeterministic = env[\"PUP_DETERMINISTIC\"] === \"1\";\n\nexport const pupPkgRoot = dirname(require.resolve(\"pup-recorder/package.json\"));\nexport const pupApp = join(pupPkgRoot, \"dist\", \"app.cjs\");\nexport const pupIpcSocket = env[\"PUP_IPC_SOCKET\"];\n\nexport const pupExperimentalPuppeteer = env[\"PUP_EXPERIMENTAL_PUPPETEER\"] === \"1\";\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport { ChildProcess, type Serializable } from \"child_process\";\nimport { Log } from \"node-av\";\nimport { AV_LOG_ERROR, AV_LOG_WARNING } from \"node-av/constants\";\nimport { pupLogLevel } from \"./constants\";\n\nexport interface LoggerLike {\n  debug?(this: void, ...messages: unknown[]): void;\n\n  info?(this: void, ...messages: unknown[]): void;\n\n  warn?(this: void, ...messages: unknown[]): void;\n\n  error?(this: void, ...messages: unknown[]): void;\n}\n\nconst DEBUG = \"<pup@debug>\";\nconst INFO = \"<pup@info>\";\nconst WARN = \"<pup@warn>\";\nconst ERROR = \"<pup@error>\";\nconst FATAL = \"<pup@fatal>\";\n\nfunction stackHook(target: Function, _context: ClassMethodDecoratorContext) {\n  return function (this: Logger, ...messages: unknown[]) {\n    const processed = messages.map((msg) => {\n      return msg instanceof Error ? (msg.stack ?? String(msg)) : msg;\n    });\n    return target.call(this, ...processed);\n  };\n}\n\nexport class Logger implements LoggerLike {\n  private _impl?: LoggerLike;\n\n  get level(): number {\n    return this._level;\n  }\n\n  set level(value: number) {\n    this._level = value;\n    this.impl = this._impl ?? console;\n  }\n\n  get impl(): LoggerLike | undefined {\n    return this._impl;\n  }\n\n  set impl(value: LoggerLike) {\n    const debug = value.debug ?? console.debug;\n    const info = value.info ?? console.info;\n    const warn = value.warn ?? console.warn;\n    const error = value.error ?? console.error;\n    const lv = this._level;\n    this._impl = {\n      debug: lv >= 3 ? debug : undefined,\n      info: lv >= 2 ? info : undefined,\n      warn: lv >= 1 ? warn : undefined,\n      error: lv >= 0 ? error : undefined,\n    };\n  }\n\n  constructor(private _level: number = pupLogLevel) {\n    this.impl = console;\n  }\n\n  @stackHook\n  debug(...messages: unknown[]): void {\n    this.impl?.debug?.(DEBUG, ...messages);\n  }\n\n  @stackHook\n  info(...messages: unknown[]): void {\n    this.impl?.info?.(INFO, ...messages);\n  }\n\n  @stackHook\n  warn(...messages: unknown[]): void {\n    this.impl?.warn?.(WARN, ...messages);\n  }\n\n  @stackHook\n  error(...messages: unknown[]): void {\n    this.impl?.error?.(ERROR, ...messages);\n  }\n\n  @stackHook\n  fatal(...messages: unknown[]): void {\n    this.impl?.error?.(FATAL, ...messages);\n    process.exit(1);\n  }\n\n  private dispatch(message: string) {\n    const msg = message.trimEnd();\n    if (msg.startsWith(DEBUG)) {\n      this.debug(msg.slice(DEBUG.length + 1));\n    } else if (msg.startsWith(INFO)) {\n      this.info(msg.slice(INFO.length + 1));\n    } else if (msg.startsWith(WARN)) {\n      this.warn(msg.slice(WARN.length + 1));\n    } else if (msg.startsWith(ERROR)) {\n      this.error(msg.slice(ERROR.length + 1));\n    } else {\n      this.info(msg);\n    }\n  }\n\n  attach(proc: ChildProcess, name: string) {\n    return new Promise<void>((resolve, reject) => {\n      this.debug(`${name}.attach`);\n      let fatal: string = \"\";\n      const dispatch = (data: Buffer | Serializable) => {\n        const message = data.toString();\n        if (message.startsWith(FATAL)) {\n          fatal += message.slice(FATAL.length + 1);\n        } else {\n          this.dispatch(message);\n        }\n      };\n      proc.stderr?.on(\"data\", dispatch);\n      proc.stdout?.on(\"data\", dispatch);\n      proc\n        .on(\"message\", dispatch)\n        .on(\"error\", (err) => {\n          fatal += err.message;\n          proc.kill();\n        })\n        .once(\"close\", (code, signal) => {\n          if (code || signal || fatal) {\n            fatal ||= `command failed: ${proc.spawnargs.join(\" \")}`;\n            this.debug(`${name}.close`, { code, signal, fatal });\n            reject(new Error(fatal));\n          } else {\n            this.debug(`${name}.close`);\n            resolve();\n          }\n        })\n        .on(\"unhandledRejection\", (reason) => {\n          this.error(`${name}.unhandled`, reason);\n        })\n        .on(\"uncaughtExceptionMonitor\", (err) => {\n          this.error(`${name}.unhandled`, err);\n        });\n    });\n  }\n}\n\nconst logger = new Logger();\n\n// Route ffmpeg native logs through pup's logger.\nLog.setCallback((level, message) => {\n  const msg = message.trimEnd();\n  if (!msg) return;\n  if (level <= AV_LOG_ERROR) logger.error(msg);\n  else if (level <= AV_LOG_WARNING) logger.warn(msg);\n});\n\nexport { logger };\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/24.\n\nexport function noerr<Fn extends (...args: any[]) => any, D>(\n  fn: Fn,\n  defaultValue: D,\n): (...args: Parameters<Fn>) => ReturnType<Fn> | D {\n  return (...args) => {\n    try {\n      const ret = fn(...args);\n      if (ret instanceof Promise) {\n        return ret.catch(() => defaultValue);\n      }\n      return ret;\n    } catch {\n      return defaultValue;\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { spawn, type ChildProcess, type SpawnOptions } from \"child_process\";\nimport { logger } from \"./logging\";\n\nexport const PUP_ARGS_KEY = \"--pup-priv-args\";\n\nexport function pargs() {\n  const argv = process.argv;\n  let priv = argv.find((arg) => arg.startsWith(PUP_ARGS_KEY));\n  if (!priv) {\n    logger.debug(\"procargv\", argv);\n    return process.argv;\n  }\n  const args = [\"exec\", ...argv.slice(-1)];\n  priv = Buffer.from(priv.split(\"=\")[1]!, \"base64\").toString();\n  args.push(...JSON.parse(priv));\n  logger.debug(\"pupargs\", args);\n  return args;\n}\n\nexport interface ProcessHandle {\n  process: ChildProcess;\n  wait: Promise<void>;\n}\n\nexport function exec(cmd: string, options?: SpawnOptions): ProcessHandle {\n  const parts = cmd.split(\" \").filter((s) => s.length);\n  const [command, ...args] = parts;\n  if (!command) throw new Error(\"empty command\");\n  const proc = spawn(command, args, {\n    stdio: \"inherit\",\n    ...options,\n  });\n  return { process: proc, wait: logger.attach(proc, command) };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport z from \"zod\";\nimport { pupDeterministic, pupDisableGPU, pupUseInnerProxy } from \"../base/constants\";\n\nexport const DEFAULT_WIDTH = 1920;\nexport const DEFAULT_HEIGHT = 1080;\nexport const DEFAULT_FPS = 30;\nexport const DEFAULT_DURATION = 5;\nexport const DEFAULT_OUT_FILE = \"output.mp4\";\n\nexport const RenderSchema = z.object({\n  duration: z.number().describe(\"Duration in seconds\"),\n  width: z.number().describe(\"Video width\"),\n  height: z.number().describe(\"Video height\"),\n  fps: z.number().describe(\"Frames per second\"),\n  withAudio: z.boolean().describe(\"Capture and encode audio\"),\n  outFile: z.string().describe(\"Output mp4 file path\"),\n  useInnerProxy: z.boolean().describe(\"Use bilibili inner proxy for resource access\"),\n  deterministic: z.boolean().describe(\"Render by frame rather than recording\"),\n  disableGpu: z.boolean().describe(\"Disable GPU rendering, may reduce performance but increase stability\"),\n});\n\nexport type RenderOptions = z.infer<typeof RenderSchema>;\n\nexport interface RenderResult {\n  options: RenderOptions;\n  written: number;\n  jank: number;\n  outFile: string;\n}\n\nexport const defaultRenderOptions: RenderOptions = {\n  width: DEFAULT_WIDTH,\n  height: DEFAULT_HEIGHT,\n  fps: DEFAULT_FPS,\n  duration: DEFAULT_DURATION,\n  outFile: DEFAULT_OUT_FILE,\n  withAudio: false,\n  useInnerProxy: pupUseInnerProxy,\n  deterministic: pupDeterministic,\n  disableGpu: pupDisableGPU,\n};\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { program } from \"commander\";\nimport { logger } from \"./base/logging\";\nimport { noerr } from \"./base/noerr\";\nimport { parseNumber } from \"./base/parser\";\nimport { pargs } from \"./base/process\";\nimport { RenderSchema, type RenderOptions } from \"./renderer/schema\";\n\nexport interface CLIOptions {\n  name: string;\n  defaults: RenderOptions;\n  run: (source: string, options: RenderOptions) => Promise<unknown>;\n}\n\nexport async function makeCLI(options: CLIOptions) {\n  const shape = RenderSchema.shape;\n  const d = options.defaults;\n  program\n    .name(options.name)\n    .argument(\"<source>\", \"file://, http(s)://, or data: URI\")\n    .option(\"-W, --width <number>\", shape.width.description, `${d.width}`)\n    .option(\"-H, --height <number>\", shape.height.description, `${d.height}`)\n    .option(\"-f, --fps <number>\", shape.fps.description, `${d.fps}`)\n    .option(\"-t, --duration <number>\", shape.duration.description, `${d.duration}`)\n    .option(\"-o, --out-file <path>\", shape.outFile.description, d.outFile)\n    .option(\"-a, --with-audio\", shape.withAudio.description, d.withAudio)\n    .option(\"-d, --deterministic\", shape.deterministic.description, d.deterministic)\n    .option(\"--use-inner-proxy\", shape.useInnerProxy.description, d.useInnerProxy)\n    .option(\"--disable-gpu\", shape.disableGpu.description, d.disableGpu)\n    .action(async (source: string, opts) => {\n      try {\n        await options.run(source, {\n          width: noerr(parseNumber, d.width)(opts.width),\n          height: noerr(parseNumber, d.height)(opts.height),\n          fps: noerr(parseNumber, d.fps)(opts.fps),\n          duration: noerr(parseNumber, d.duration)(opts.duration),\n          outFile: opts.outFile ?? d.outFile,\n          withAudio: opts.withAudio ?? d.withAudio,\n          useInnerProxy: opts.useInnerProxy ?? d.useInnerProxy,\n          deterministic: opts.deterministic ?? d.deterministic,\n          disableGpu: opts.disableGpu ?? d.disableGpu,\n        });\n      } catch (e) {\n        logger.fatal(e);\n      }\n    });\n  await program.parseAsync(pargs());\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { EventEmitter } from \"events\";\nimport { createConnection, createServer, type Socket } from \"net\";\n\nconst HEADER_SIZE = 8;\n\nexport const enum IpcMsgType {\n  PROGRESS = 1,\n  DONE = 2,\n  ERROR = 3,\n}\n\nexport interface IpcDonePayload {\n  written: number;\n  jank: number;\n  outFile: string;\n}\n\nexport class IpcWriter {\n  constructor(private readonly _socket: Socket) {}\n\n  writeProgress(value: number): void {\n    this.write(IpcMsgType.PROGRESS, Buffer.from(`${value}`));\n  }\n\n  writeError(error: string) {\n    this.write(IpcMsgType.ERROR, Buffer.from(error));\n    this._socket.end();\n  }\n\n  writeDone(payload: IpcDonePayload): void {\n    this.write(IpcMsgType.DONE, Buffer.from(JSON.stringify(payload)));\n    this._socket.end();\n  }\n\n  private write(type: IpcMsgType, payload: Buffer): void {\n    const header = Buffer.alloc(HEADER_SIZE);\n    header.writeUInt32LE(type, 0);\n    header.writeUInt32LE(payload.byteLength, 4);\n    this._socket.write(header);\n    this._socket.write(payload);\n  }\n}\n\nexport function connectIpc(socketPath: string): Promise<IpcWriter> {\n  return new Promise((resolve, reject) => {\n    const socket = createConnection(socketPath);\n    socket.once(\"connect\", () => resolve(new IpcWriter(socket)));\n    socket.once(\"error\", reject);\n  });\n}\n\nexport class IpcReader extends EventEmitter<{\n  progress: [value: number];\n  message: [type: IpcMsgType, buffer: Buffer];\n  done: [payload: IpcDonePayload];\n  error: [error: Error];\n  close: [];\n}> {\n  private _chunks: Buffer[] = [];\n  private _buffered = 0;\n\n  constructor(private readonly _socket: Socket) {\n    super();\n    this._socket.on(\"data\", (data) => this.onData(data));\n    this._socket.on(\"error\", (err) => this.emit(\"error\", err));\n    this._socket.on(\"close\", () => this.emit(\"close\"));\n  }\n\n  private onData(data: Buffer): void {\n    this._chunks.push(data);\n    this._buffered += data.byteLength;\n    this.flush();\n  }\n\n  private flush(): void {\n    for (;;) {\n      if (this._buffered < HEADER_SIZE) return;\n      const header = this.peek(HEADER_SIZE);\n      const type = header.readUInt32LE(0) as IpcMsgType;\n      const len = header.readUInt32LE(4);\n      if (this._buffered < HEADER_SIZE + len) return;\n      this.consume(HEADER_SIZE);\n      const payload = this.consume(len);\n      this.emit(\"message\", type, payload);\n      switch (type) {\n        case IpcMsgType.PROGRESS: {\n          this.emit(\"progress\", Number(payload.toString()));\n          break;\n        }\n        case IpcMsgType.DONE: {\n          this.emit(\"done\", JSON.parse(payload.toString()));\n          break;\n        }\n        case IpcMsgType.ERROR: {\n          this.emit(\"error\", new Error(payload.toString()));\n          break;\n        }\n      }\n    }\n  }\n\n  private peek(n: number): Buffer {\n    if (this._chunks[0] && this._chunks[0].byteLength >= n) return this._chunks[0];\n    return Buffer.concat(this._chunks).subarray(0, n);\n  }\n\n  private consume(n: number): Buffer {\n    const out = Buffer.allocUnsafe(n);\n    let offset = 0;\n    while (offset < n) {\n      const chunk = this._chunks[0]!;\n      const take = Math.min(chunk.byteLength, n - offset);\n      chunk.copy(out, offset, 0, take);\n      if (take === chunk.byteLength) {\n        this._chunks.shift();\n      } else {\n        this._chunks[0] = chunk.subarray(take);\n      }\n      offset += take;\n    }\n    this._buffered -= n;\n    return out;\n  }\n}\n\nexport interface IpcServer {\n  waitForConnection(): Promise<IpcReader>;\n  close(): void;\n}\n\nexport function createIpcServer(socketPath: string): Promise<IpcServer> {\n  return new Promise((resolve, reject) => {\n    const server = createServer();\n    server.once(\"error\", reject);\n    server.listen(socketPath, () => {\n      resolve({\n        waitForConnection() {\n          return new Promise<IpcReader>((ok, no) => {\n            server.once(\"connection\", (socket) => ok(new IpcReader(socket)));\n            server.once(\"error\", no);\n          });\n        },\n        close() {\n          server.close();\n        },\n      });\n    });\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport type { Debugger, Size } from \"electron\";\n\nexport const FRAME_SYNC_MARKER_WIDTH = 32;\nexport const FRAME_SYNC_MARKER_HEIGHT = 1;\n\nexport function buildStegoHTML(targetURL: string, size: Size): string {\n  const { width, height } = size;\n  return `<!DOCTYPE html>\n<html>\n<head>\n  <meta charset=\"UTF-8\">\n  <style>\n    * { margin: 0; padding: 0; box-sizing: border-box; }\n    html, body { width: ${width}px; height: ${height + 1}px; overflow: hidden; }\n    #target { \n      position: absolute; \n      top: 0; \n      left: 0; \n      width: ${width}px; \n      height: ${height}px; \n      border: none; \n      display: block;\n    }\n    #stego { \n      position: absolute; \n      top: ${height}px; \n      left: 0; \n      width: ${width}px; \n      height: 1px; \n      display: block;\n      image-rendering: pixelated;\n    }\n  </style>\n</head>\n<body>\n  <iframe id=\"target\" src=\"${targetURL}\"></iframe>\n  <canvas id=\"stego\" width=\"${width}\" height=\"1\"></canvas>\n  <script>\n    (function() {\n      const WIDTH = ${width};\n      const MARKER_WIDTH = ${FRAME_SYNC_MARKER_WIDTH};\n      const canvas = document.getElementById('stego');\n      const ctx = canvas.getContext('2d', { willReadFrequently: true });\n      let startTime = null;\n      let rafId = null;\n\n      function encodeTimestamp(timestampMs) {\n        const imageData = ctx.createImageData(WIDTH, 1);\n        const data = imageData.data;\n        \n        const timestampInt = Math.floor(timestampMs) >>> 0;\n        \n        for (let i = 0; i < MARKER_WIDTH; i++) {\n          const bit = (timestampInt >>> (MARKER_WIDTH - 1 - i)) & 1;\n          const value = bit ? 255 : 0;\n          const idx = i * 4;\n          data[idx] = value;\n          data[idx + 1] = value;\n          data[idx + 2] = value;\n          data[idx + 3] = 255;\n        }\n        \n        for (let i = MARKER_WIDTH; i < WIDTH; i++) {\n          const idx = i * 4;\n          data[idx] = 0;\n          data[idx + 1] = 0;\n          data[idx + 2] = 0;\n          data[idx + 3] = 255;\n        }\n        \n        ctx.putImageData(imageData, 0, 0);\n      }\n\n      function updateLoop() {\n        if (startTime === null) return;\n        const elapsed = performance.now() - startTime;\n        encodeTimestamp(elapsed);\n        rafId = requestAnimationFrame(updateLoop);\n      }\n\n      window.__pup_start_stego__ = () => {\n        startTime = performance.now();\n        encodeTimestamp(0);\n        requestAnimationFrame(updateLoop);\n      };\n\n      window.__pup_stop_stego__ = () => {\n        if (rafId !== null) {\n          cancelAnimationFrame(rafId);\n          rafId = null;\n        }\n      };\n    })();\n  </script>\n</body>\n</html>`;\n}\n\nexport function decodeStego(bitmap: Buffer, size: Size): number | undefined {\n  const { width, height } = size;\n  if (width < FRAME_SYNC_MARKER_WIDTH || height < 2) {\n    return undefined;\n  }\n\n  const markerRow = height - 1;\n\n  let timestamp = 0;\n  for (let i = 0; i < FRAME_SYNC_MARKER_WIDTH; i++) {\n    const pixelIdx = (markerRow * width + i) * 4;\n    const r = bitmap[pixelIdx] ?? 0;\n    const bit = r > 127 ? 1 : 0;\n    timestamp = (timestamp << 1) | bit;\n  }\n\n  timestamp = timestamp >>> 0;\n\n  if (!Number.isFinite(timestamp) || timestamp < 0 || timestamp > 1e7) {\n    return undefined;\n  }\n\n  return timestamp;\n}\n\nexport function startStego(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_start_stego__()`,\n  });\n}\n\nexport function stopStego(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_stop_stego__()`,\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport type { Size } from \"electron\";\nimport { protocol } from \"electron\";\nimport { buildStegoHTML } from \"./stego\";\n\nconst PUP_SCHEME = \"pup\";\n\n// Must be called synchronously before app is ready.\nprotocol.registerSchemesAsPrivileged([\n  {\n    scheme: PUP_SCHEME,\n    privileges: {\n      standard: true,\n      secure: true,\n      bypassCSP: true,\n      allowServiceWorkers: true,\n      supportFetchAPI: true,\n      corsEnabled: true,\n      stream: true,\n      codeCache: true,\n    },\n  },\n]);\n\n// Must be called after app is ready.\nexport function setupPupProtocol(): void {\n  protocol.handle(PUP_SCHEME, (req) => {\n    const url = new URL(req.url);\n    const src = url.searchParams.get(\"src\") ?? \"\";\n    const width = parseInt(url.searchParams.get(\"w\") ?? \"0\", 10);\n    const height = parseInt(url.searchParams.get(\"h\") ?? \"0\", 10);\n    const html = buildStegoHTML(src, { width, height });\n    return new Response(html, { headers: { \"content-type\": \"text/html\" } });\n  });\n}\n\nexport function createStegoURL(src: string, size: Size): string {\n  const url = new URL(`${PUP_SCHEME}://stego`);\n  url.searchParams.set(\"src\", src);\n  url.searchParams.set(\"w\", String(size.width));\n  url.searchParams.set(\"h\", String(size.height));\n  return url.toString();\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\ninterface QueueEntry {\n  run: VoidFunction;\n  reject: (reason: unknown) => void;\n  signal?: AbortSignal;\n}\n\nexport class ConcurrencyLimiter {\n  private _active = 0;\n  private _queue: QueueEntry[] = [];\n  private _signals = new WeakSet<AbortSignal>();\n  private _resolve?: VoidFunction;\n\n  constructor(readonly maxConcurrency: number) {}\n\n  get active(): number {\n    return this._active;\n  }\n\n  get pending(): number {\n    return this._queue.length;\n  }\n\n  get stats(): string {\n    return `active: ${this.active}, pending: ${this.pending}`;\n  }\n\n  async schedule<T>(fn: () => Promise<T>, signal?: AbortSignal): Promise<T> {\n    signal?.throwIfAborted();\n\n    if (signal && !this._signals.has(signal)) {\n      this._signals.add(signal);\n      signal.addEventListener(\"abort\", () => this.flush(signal), { once: true });\n    }\n\n    return new Promise<T>((resolve, reject) => {\n      this._queue.push({\n        run: () => {\n          if (signal?.aborted) {\n            reject(signal.reason);\n            this.next();\n            return;\n          }\n          this._active++;\n          fn()\n            .then((v) => {\n              this._active--;\n              resolve(v);\n              this.next();\n            })\n            .catch((e) => {\n              this._active--;\n              reject(e);\n              this.next();\n            });\n        },\n        reject,\n        signal,\n      });\n      this.next();\n    });\n  }\n\n  async drain(): Promise<void> {\n    if (this._active === 0 && this.pending === 0) return;\n    return new Promise((r) => (this._resolve = r));\n  }\n\n  private flush(signal: AbortSignal) {\n    const keep: QueueEntry[] = [];\n    for (const entry of this._queue) {\n      if (entry.signal === signal) {\n        entry.reject(signal.reason);\n      } else {\n        keep.push(entry);\n      }\n    }\n    this._queue = keep;\n    this.next();\n  }\n\n  private next() {\n    if (this._active === 0 && this.pending === 0) {\n      this._resolve?.();\n      this._resolve = undefined;\n      return;\n    }\n    if (this._active < this.maxConcurrency) {\n      this._queue.shift()?.run();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { CodecContext, FFmpegError, Frame, Packet, type Stream } from \"node-av\";\nimport { AVERROR_EAGAIN, AVERROR_EOF, type AVPixelFormat } from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport function makeFrame(width: number, height: number, pixFmt: AVPixelFormat): Frame {\n  const frame = new Frame();\n  frame.alloc();\n  frame.format = pixFmt;\n  frame.width = width;\n  frame.height = height;\n  FFmpegError.throwIfError(frame.getBuffer(0), \"frame.getBuffer\");\n  return frame;\n}\n\nexport function makePacket(): Packet {\n  const pkt = new Packet();\n  pkt.alloc();\n  return pkt;\n}\n\nexport async function drainPackets(ctx: CodecContext, pkt: Packet, stream: Stream, muxer: FormatMuxer): Promise<void> {\n  while (true) {\n    const r = await ctx.receivePacket(pkt);\n    if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n    FFmpegError.throwIfError(r, \"receivePacket\");\n    pkt.streamIndex = stream.index;\n    if (pkt.duration === 0n) pkt.duration = 1n;\n    pkt.rescaleTs(ctx.timeBase, stream.timeBase);\n    await muxer.writePacket(pkt);\n    pkt.unref();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport {\n  Codec,\n  CodecContext,\n  FFmpegError,\n  Filter,\n  FilterContext,\n  FilterGraph,\n  FilterInOut,\n  Frame,\n  type Packet,\n  Rational,\n  type Stream,\n} from \"node-av\";\nimport {\n  AV_CHANNEL_LAYOUT_STEREO,\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AV_SAMPLE_FMT_FLT,\n  AV_SAMPLE_FMT_FLTP,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  type FFAudioEncoder,\n} from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { drainPackets, makePacket } from \"./shared\";\n\nconst SAMPLE_FMT_NAME: Partial<Record<number, string>> = { [AV_SAMPLE_FMT_FLT]: \"flt\", [AV_SAMPLE_FMT_FLTP]: \"fltp\" };\n\nexport interface AudioEncoderOptions {\n  outSampleRate: number;\n  outSampleFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  codecName: FFAudioEncoder;\n  globalHeader: boolean;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class AudioEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _stream: Stream;\n  private _pkt: Packet;\n  private _outRate: number;\n  private _outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  private _frameSize: number;\n  private _filterFrame: Frame;\n  private _graph?: FilterGraph;\n  private _bufSrc?: FilterContext;\n  private _bufSink?: FilterContext;\n  private _inRate?: number;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, stream: Stream, outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP) {\n    this._ctx = ctx;\n    this._stream = stream;\n    this._outRate = ctx.sampleRate;\n    this._outFmt = outFmt;\n    this._frameSize = ctx.frameSize;\n    this._pkt = makePacket();\n    this._filterFrame = new Frame();\n    this._filterFrame.alloc();\n  }\n\n  static async create(opts: AudioEncoderOptions): Promise<AudioEncoder> {\n    const codec = Codec.findEncoderByName(opts.codecName);\n    if (!codec) throw new Error(`Audio encoder not found: ${opts.codecName}`);\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.sampleFormat = opts.outSampleFmt;\n    ctx.sampleRate = opts.outSampleRate;\n    ctx.channelLayout = AV_CHANNEL_LAYOUT_STEREO;\n    ctx.timeBase = new Rational(1, opts.outSampleRate);\n    ctx.bitRate = BigInt(opts.bitrate);\n    if (opts.globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"audioCtx.open2\");\n    const stream = opts.muxer.addStream(ctx);\n    return new AudioEncoder(ctx, stream, opts.outSampleFmt);\n  }\n\n  setInputRate(inSampleRate: number): void {\n    this._graph?.[Symbol.dispose]();\n    this._inRate = inSampleRate;\n    const graph = new FilterGraph();\n    graph.alloc();\n    const abuffer = Filter.getByName(\"abuffer\")!;\n    const bufSrc = graph.createFilter(\n      abuffer,\n      \"src\",\n      `sample_rate=${inSampleRate}:sample_fmt=flt:channel_layout=stereo:time_base=1/${inSampleRate}`,\n    );\n    if (!bufSrc) throw new Error(\"Failed to create abuffer\");\n    const abuffersink = Filter.getByName(\"abuffersink\")!;\n    const bufSink = graph.createFilter(abuffersink, \"sink\");\n    if (!bufSink) throw new Error(\"Failed to create abuffersink\");\n    const fmtName = SAMPLE_FMT_NAME[this._outFmt] ?? \"flt\";\n    const filterDesc = `aformat=sample_fmts=${fmtName}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`;\n    const outputs = FilterInOut.createList([{ name: \"in\", filterCtx: bufSrc, padIdx: 0 }]);\n    const inputs = FilterInOut.createList([{ name: \"out\", filterCtx: bufSink, padIdx: 0 }]);\n    FFmpegError.throwIfError(graph.parsePtr(filterDesc, inputs, outputs), \"graph.parsePtr\");\n    FFmpegError.throwIfError(graph.configSync(), \"graph.config\");\n    this._graph = graph;\n    this._bufSrc = bufSrc;\n    this._bufSink = bufSink;\n  }\n\n  async encode(pcm: Buffer, muxer: FormatMuxer): Promise<void> {\n    if (!this._bufSrc || !this._inRate) return;\n    const src = new Float32Array(pcm.buffer, pcm.byteOffset, pcm.byteLength / 4);\n    for (let i = 0; i < src.length; i++) if (!isFinite(src[i]!)) src[i] = 0;\n    const nSamples = src.length >> 1;\n    using frame = Frame.fromAudioBuffer(Buffer.from(src.buffer, src.byteOffset, src.byteLength), {\n      nbSamples: nSamples,\n      format: AV_SAMPLE_FMT_FLT,\n      sampleRate: this._inRate,\n      channelLayout: AV_CHANNEL_LAYOUT_STEREO,\n      pts: this._pts,\n      timeBase: { num: 1, den: this._inRate },\n    });\n    this._pts += BigInt(nSamples);\n    FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(frame), \"buffersrcAddFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    if (this._bufSrc) {\n      await this._bufSrc.buffersrcAddFrame(null);\n      await this.drain(muxer);\n    }\n    await this._ctx.sendFrame(null);\n    await this.drainCodec(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._filterFrame.free();\n    this._graph?.[Symbol.dispose]();\n    this._ctx.freeContext();\n  }\n\n  private async drain(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._bufSink!.buffersinkGetFrame(this._filterFrame);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"buffersinkGetFrame\");\n      FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame), \"audioCtx.sendFrame\");\n      this._filterFrame.unref();\n      await this.drainCodec(muxer);\n    }\n  }\n\n  private drainCodec(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/03.\n\nimport { ok } from \"assert\";\nimport {\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_YUVA420P,\n  Codec,\n  CodecContext,\n  FF_DECODER_PNG,\n  FFmpegError,\n  type Frame,\n  Packet,\n  SoftwareScaleContext,\n  SWS_BILINEAR,\n  type AVPixelFormat,\n} from \"node-av\";\nimport { makeFrame, makePacket } from \"./shared\";\n\nexport class CodecState implements Disposable {\n  readonly src: Frame;\n  readonly dst: Frame;\n  readonly pkt: Packet;\n  private _sws?: SoftwareScaleContext;\n  private _png?: Codec;\n\n  static async create(width: number, height: number) {\n    const codec = Codec.findDecoderByName(FF_DECODER_PNG);\n    ok(codec, \"png decoder unavailable\");\n    return new CodecState(width, height, codec);\n  }\n\n  private constructor(width: number, height: number, png: Codec) {\n    this._png = png;\n    this.src = makeFrame(width, height, AV_PIX_FMT_BGRA);\n    this.dst = makeFrame(width, height, AV_PIX_FMT_YUVA420P);\n    this.pkt = makePacket();\n  }\n\n  /**\n   * Create a fresh PNG decoder context.\n   * The FFmpeg PNG decoder accumulates APNG blending state\n   * across frames, so a shared instance corrupts output when decoding standalone PNGs.\n   */\n  async png(): Promise<CodecContext> {\n    const png = new CodecContext();\n    png.allocContext3(this._png);\n    FFmpegError.throwIfError(await png.open2(this._png), \"pngDecoder.open2\");\n    return png;\n  }\n\n  async decodePNG(pngData: Buffer): Promise<Frame> {\n    using png = await this.png();\n    this.pkt.data = pngData;\n    FFmpegError.throwIfError(await png.sendPacket(this.pkt), \"pngDecoder.sendPacket\");\n    this.pkt.unref();\n    FFmpegError.throwIfError(await png.receiveFrame(this.src), \"pngDecoder.receiveFrame\");\n    return this.src;\n  }\n\n  get sws() {\n    if (!this._sws) {\n      const sws = new SoftwareScaleContext();\n      const fmt = this.src.format as AVPixelFormat;\n      sws.getContext(\n        this.src.width,\n        this.src.height,\n        fmt,\n        this.src.width,\n        this.src.height,\n        AV_PIX_FMT_YUVA420P,\n        SWS_BILINEAR,\n      );\n      this._sws = sws;\n    }\n    return this._sws;\n  }\n\n  [Symbol.dispose](): void {\n    this.src[Symbol.dispose]();\n    this.dst[Symbol.dispose]();\n    this.pkt[Symbol.dispose]();\n    this._sws?.[Symbol.dispose]();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nconst NAL_HEADER_SIZE = 2;\nconst ANNEX_B_START_CODE = Buffer.from([0x00, 0x00, 0x00, 0x01]);\n\nexport { ANNEX_B_START_CODE, NAL_HEADER_SIZE };\n\nexport interface NalUnit {\n  type: number;\n  layerId: number;\n  data: Buffer;\n}\n\nfunction parseNalType(header0: number, header1: number): { type: number; layerId: number; temporalId: number } {\n  const type = (header0 >> 1) & 0x3f;\n  const layerId = ((header0 & 1) << 5) | ((header1 >> 3) & 0x1f);\n  const temporalId = header1 & 0x07;\n  return { type, layerId, temporalId };\n}\n\nexport function encodeNalHeader(type: number, layerId: number, temporalId: number): [number, number] {\n  const byte0 = ((type & 0x3f) << 1) | ((layerId >> 5) & 1);\n  const byte1 = ((layerId & 0x1f) << 3) | (temporalId & 0x07);\n  return [byte0, byte1];\n}\n\nexport function packBits(bits: number[]): Buffer {\n  const buf = Buffer.alloc(bits.length >> 3);\n  for (let i = 0; i < buf.length; i++) {\n    let byte = 0;\n    for (let b = 0; b < 8; b++) byte = (byte << 1) | bits[i * 8 + b]!;\n    buf[i] = byte;\n  }\n  return buf;\n}\n\n/** Split Annex B bitstream into NAL units. */\nexport function splitNalUnits(bitstream: Buffer): NalUnit[] {\n  const nals: NalUnit[] = [];\n  let i = 0;\n\n  while (i < bitstream.length) {\n    let scLen = 0;\n    if (i + 3 < bitstream.length && bitstream[i] === 0 && bitstream[i + 1] === 0 && bitstream[i + 2] === 1) {\n      scLen = 3;\n    } else if (\n      i + 4 < bitstream.length &&\n      bitstream[i] === 0 &&\n      bitstream[i + 1] === 0 &&\n      bitstream[i + 2] === 0 &&\n      bitstream[i + 3] === 1\n    ) {\n      scLen = 4;\n    } else {\n      i++;\n      continue;\n    }\n\n    const nalStart = i + scLen;\n    if (nalStart + NAL_HEADER_SIZE > bitstream.length) break;\n\n    let nalEnd = bitstream.length;\n    for (let j = nalStart + NAL_HEADER_SIZE; j < bitstream.length - 2; j++) {\n      if (\n        bitstream[j] === 0 &&\n        bitstream[j + 1] === 0 &&\n        (bitstream[j + 2] === 1 || (j + 3 < bitstream.length && bitstream[j + 2] === 0 && bitstream[j + 3] === 1))\n      ) {\n        nalEnd = j;\n        break;\n      }\n    }\n\n    const { type, layerId } = parseNalType(bitstream[nalStart]!, bitstream[nalStart + 1]!);\n    nals.push({ type, layerId, data: bitstream.subarray(nalStart, nalEnd) });\n    i = nalEnd;\n  }\n\n  return nals;\n}\n\n/** Rewrite nuh_layer_id in a NAL unit (returns copy). */\nexport function rewriteNalLayerId(nal: Buffer, layerId: number): Buffer {\n  const out = Buffer.from(nal);\n  const { type, temporalId } = parseNalType(out[0]!, out[1]!);\n  const [b0, b1] = encodeNalHeader(type, layerId, temporalId);\n  out[0] = b0;\n  out[1] = b1;\n  return out;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport {\n  ANNEX_B_START_CODE,\n  encodeNalHeader,\n  NAL_HEADER_SIZE,\n  type NalUnit,\n  packBits,\n  rewriteNalLayerId,\n  splitNalUnits,\n} from \"./nal\";\n\nconst NAL_UNIT_PREFIX_SEI = 39;\n\n/**\n * Build unified extradata: base VPS (patched for alpha) + interleaved SPS/PPS.\n * Alpha SPS/PPS follow their base counterparts so the HVCC serializer\n * groups them into the same NAL array (required for multi-layer).\n */\nexport function buildUnifiedExtradata(baseExtradata: Buffer, alphaExtradata: Buffer): Buffer {\n  const baseNals = splitNalUnits(baseExtradata);\n  const alphaNals = splitNalUnits(alphaExtradata);\n\n  const alphaByType = new Map<number, NalUnit[]>();\n  for (const nal of alphaNals) {\n    if (nal.type === 32) continue; // VPS is per-bitstream, not per-layer\n    const arr = alphaByType.get(nal.type) ?? [];\n    arr.push(nal);\n    alphaByType.set(nal.type, arr);\n  }\n\n  const chunks: Buffer[] = [];\n  const emitted = new Set<number>();\n  for (const nal of baseNals) {\n    // VPS needs alpha layer declaration for FFmpeg's HVCC serializer\n    const data = nal.type === 32 ? patchVPSForAlpha(nal.data) : nal.data;\n    chunks.push(ANNEX_B_START_CODE, data);\n    if (!emitted.has(nal.type)) {\n      emitted.add(nal.type);\n      for (const alphaNal of alphaByType.get(nal.type) ?? []) {\n        chunks.push(ANNEX_B_START_CODE, rewriteNalLayerId(alphaNal.data, 1));\n      }\n    }\n  }\n\n  // SEI must be in extradata for Apple's decoder to discover alpha channel\n  chunks.push(buildAlphaChannelInfoSEI());\n\n  return Buffer.concat(chunks);\n}\n\n/**\n * Patch a single-layer VPS to declare 2 layers with layer 1 = AUX_ALPHA.\n * FFmpeg 8.0's hvcc_parse_vps_extension reads this to set alpha_layer_nuh_id,\n * which allows layer_id=1 NALs to survive Annex B → HVCC conversion.\n */\nfunction patchVPSForAlpha(vpsData: Buffer): Buffer {\n  const rbsp = vpsData.subarray(NAL_HEADER_SIZE);\n\n  let bitPos = 0;\n  const readBits = (n: number): number => {\n    let val = 0;\n    for (let i = 0; i < n; i++) {\n      const byteIdx = (bitPos + i) >> 3;\n      const bitIdx = 7 - ((bitPos + i) & 7);\n      val = (val << 1) | ((rbsp[byteIdx]! >> bitIdx) & 1);\n    }\n    bitPos += n;\n    return val;\n  };\n\n  readBits(4); // vps_video_parameter_set_id\n  const vpsBaseLayerInternalFlag = readBits(1);\n  readBits(1); // vps_base_layer_available_flag\n  const maxLayersPos = bitPos;\n  const maxLayersMinus1 = readBits(6);\n\n  if (maxLayersMinus1 > 0) return vpsData;\n\n  const bits: number[] = [];\n  for (let i = 0; i < vpsData.length; i++) {\n    for (let b = 7; b >= 0; b--) bits.push((vpsData[i]! >> b) & 1);\n  }\n\n  const mlOffset = maxLayersPos + NAL_HEADER_SIZE * 8;\n  for (let i = 0; i < 6; i++) bits[mlOffset + i] = 0;\n  bits[mlOffset + 5] = 1; // vps_max_layers_minus1 = 1\n\n  let lastBit = bits.length - 1;\n  while (lastBit > 0 && bits[lastBit] === 0) lastBit--;\n  if (lastBit <= 1) throw new Error(\"Invalid VPS: no RBSP stop bit\");\n  bits[lastBit - 1] = 1; // vps_extension_flag = 1\n  bits.length = lastBit;\n\n  while (bits.length % 8 !== 0) bits.push(1); // byte-align\n\n  // Minimal VPS extension for FFmpeg's hvcc_parse_vps_extension\n  if (vpsBaseLayerInternalFlag) {\n    for (let i = 0; i < 8; i++) bits.push(0); // general_level_idc\n  }\n  bits.push(0); // splitting_flag\n  for (let i = 0; i < 16; i++) bits.push(i === 3 ? 1 : 0); // scalability_mask: AuxId\n  bits.push(0, 0, 0); // dimension_id_len_minus1 = 0\n  bits.push(0); // vps_nuh_layer_id_present_flag\n  bits.push(1); // dimension_id[1][0] = AUX_ALPHA\n\n  bits.push(1);\n  while (bits.length % 8 !== 0) bits.push(0);\n\n  return packBits(bits);\n}\n\n/**\n * Build alpha_channel_info SEI message (payloadType=165).\n * Layout from x265 SEIAlphaChannelInfo::writeSEI.\n */\nexport function buildAlphaChannelInfoSEI(): Buffer {\n  const payloadType = 165;\n  const payloadSize = 4;\n  const [h0, h1] = encodeNalHeader(NAL_UNIT_PREFIX_SEI, 0, 1);\n\n  const bits: number[] = [];\n  const writeBits = (val: number, n: number) => {\n    for (let i = n - 1; i >= 0; i--) bits.push((val >> i) & 1);\n  };\n\n  writeBits(0, 1); // alpha_channel_cancel_flag\n  writeBits(0, 3); // alpha_channel_use_idc (straight alpha)\n  writeBits(0, 3); // alpha_channel_bit_depth_minus8\n  writeBits(0, 9); // alpha_transparent_value\n  writeBits(255, 9); // alpha_opaque_value\n  writeBits(0, 1); // alpha_channel_incr_flag\n  writeBits(0, 1); // alpha_channel_clip_flag\n  writeBits(1, 1); // byte alignment\n  while (bits.length % 8 !== 0) writeBits(0, 1);\n\n  return Buffer.concat([\n    ANNEX_B_START_CODE,\n    Buffer.from([h0, h1]),\n    Buffer.from([payloadType, payloadSize]),\n    packBits(bits),\n    Buffer.from([0x80]),\n  ]);\n}\n\n/** Interleave base and alpha NALs for a single frame. */\nexport function interleaveAccessUnits(baseNals: NalUnit[], alphaNals: NalUnit[]): Buffer {\n  const chunks: Buffer[] = [];\n  for (const nal of baseNals) {\n    chunks.push(ANNEX_B_START_CODE, nal.data);\n  }\n  for (const nal of alphaNals) {\n    if (nal.type < 32) {\n      chunks.push(ANNEX_B_START_CODE, rewriteNalLayerId(nal.data, 1));\n    }\n  }\n  return Buffer.concat(chunks);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport {\n  Codec,\n  CodecContext,\n  FFmpegError,\n  Frame,\n  HardwareFramesContext,\n  Rational,\n  SoftwareScaleContext,\n  SWS_BILINEAR,\n  type Packet,\n  type Stream,\n} from \"node-av\";\nimport {\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_CUDA,\n  AV_PIX_FMT_YUV420P,\n  AVCOL_RANGE_JPEG,\n  FF_ENCODER_HEVC_NVENC,\n} from \"node-av/constants\";\nimport { buildAlphaChannelInfoSEI, buildUnifiedExtradata, interleaveAccessUnits } from \"./alpha\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { splitNalUnits } from \"./nal\";\nimport { makeFrame, makePacket } from \"./shared\";\nimport type { HwVideoEncoderOptions } from \"./videotoolbox\";\n\ninterface NvencState {\n  baseCtx: CodecContext;\n  alphaCtx: CodecContext;\n  basePkt: Packet;\n  alphaPkt: Packet;\n  stream: Stream;\n  baseSws: SoftwareScaleContext;\n  yuvFrame: Frame;\n  hwFramesCtx: HardwareFramesContext;\n}\n\nexport class NvencDualLayerEncoder implements Disposable {\n  private _s: NvencState;\n  private _seiBuffer: Buffer;\n  private _pts = 0n;\n  private _seiInjected = false;\n  private _alphaBuf?: Buffer;\n  private _alphaFrame?: Frame;\n\n  private constructor(s: NvencState) {\n    this._s = s;\n    this._seiBuffer = buildAlphaChannelInfoSEI();\n  }\n\n  static async create(opts: HwVideoEncoderOptions): Promise<NvencDualLayerEncoder> {\n    const { width, height, fps, bitrate, hw, muxer } = opts;\n\n    const codec = Codec.findEncoderByName(FF_ENCODER_HEVC_NVENC);\n    if (!codec) throw new Error(\"hevc_nvenc encoder not found\");\n\n    const hwFramesCtx = new HardwareFramesContext();\n    hwFramesCtx.alloc(hw.deviceContext);\n    hwFramesCtx.format = AV_PIX_FMT_CUDA;\n    hwFramesCtx.swFormat = AV_PIX_FMT_YUV420P; // NVENC only accepts YUV420P/NV12, not BGRA\n    hwFramesCtx.width = width;\n    hwFramesCtx.height = height;\n    hwFramesCtx.initialPoolSize = 20;\n    FFmpegError.throwIfError(hwFramesCtx.init(), \"hwFramesCtx.init\");\n\n    const makeCtx = async (ctxOpts: { br: number; fullRange?: boolean; cqp?: number }) => {\n      const ctx = new CodecContext();\n      ctx.allocContext3(codec);\n      ctx.codecId = codec.id;\n      ctx.width = width;\n      ctx.height = height;\n      ctx.pixelFormat = AV_PIX_FMT_CUDA;\n      if (ctxOpts.fullRange) ctx.colorRange = AVCOL_RANGE_JPEG;\n      ctx.timeBase = new Rational(1, fps);\n      ctx.framerate = new Rational(fps, 1);\n      ctx.gopSize = fps * 2;\n      ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n      ctx.setOption(\"preset\", \"p4\");\n      ctx.setOption(\"bf\", \"0\"); // no B-frames — keep base+alpha packet output in sync\n      if (ctxOpts.cqp !== undefined) {\n        ctx.setOption(\"rc\", \"constqp\");\n        ctx.setOption(\"qp\", String(ctxOpts.cqp));\n      } else {\n        ctx.bitRate = BigInt(ctxOpts.br);\n      }\n      ctx.hwFramesCtx = hwFramesCtx;\n      FFmpegError.throwIfError(await ctx.open2(codec, null), \"nvenc.open2\");\n      return ctx;\n    };\n\n    const baseCtx = await makeCtx({ br: bitrate });\n    const alphaCtx = await makeCtx({ br: bitrate, fullRange: true, cqp: 1 });\n\n    const basePkt = makePacket();\n    const alphaPkt = makePacket();\n\n    const stream = muxer.addStream(baseCtx, \"hvc1\");\n\n    const baseExtra = baseCtx.extraData;\n    const alphaExtra = alphaCtx.extraData;\n    if (baseExtra && alphaExtra) {\n      stream.codecpar.extradata = buildUnifiedExtradata(baseExtra, alphaExtra);\n    }\n\n    const baseSws = new SoftwareScaleContext();\n    baseSws.getContext(width, height, AV_PIX_FMT_BGRA, width, height, AV_PIX_FMT_YUV420P, SWS_BILINEAR);\n    return new NvencDualLayerEncoder({\n      baseCtx,\n      alphaCtx,\n      basePkt,\n      alphaPkt,\n      stream,\n      baseSws,\n      yuvFrame: makeFrame(width, height, AV_PIX_FMT_YUV420P),\n      hwFramesCtx,\n    });\n  }\n\n  async encode(bgraFrame: Frame, muxer: FormatMuxer): Promise<void> {\n    const { baseCtx, alphaCtx, baseSws, yuvFrame, hwFramesCtx } = this._s;\n    const pts = this._pts++;\n\n    // Base: BGRA → SWS → YUV420P sw frame\n    FFmpegError.throwIfError(yuvFrame.makeWritable(), \"yuv.makeWritable\");\n    FFmpegError.throwIfError(await baseSws.scaleFrame(yuvFrame, bgraFrame), \"sws.base\");\n\n    // Alpha: extract alpha channel → YUV420P sw frame (Buffer.copy pattern from hw-encode.ts)\n    const src = bgraFrame.data?.[0];\n    const srcLs = bgraFrame.linesize?.[0];\n    if (!src || !srcLs) throw new Error(\"encode: missing BGRA data\");\n    const w = bgraFrame.width;\n    const h = bgraFrame.height;\n    const ySize = w * h;\n    const uvSize = (w >> 1) * (h >> 1);\n    if (!this._alphaBuf) this._alphaBuf = Buffer.alloc(ySize + uvSize * 2);\n    const buf = this._alphaBuf;\n    for (let y = 0; y < h; y++) {\n      for (let x = 0; x < w; x++) {\n        buf[y * w + x] = src[y * srcLs + x * 4 + 3]!;\n      }\n    }\n    buf.fill(128, ySize, ySize + uvSize * 2);\n\n    // fromVideoBuffer is the only way to set native frame data on Linux\n    this._alphaFrame?.free();\n    this._alphaFrame = Frame.fromVideoBuffer(buf, { format: AV_PIX_FMT_YUV420P, width: w, height: h });\n\n    // Upload both to GPU + encode\n    const baseHwFrame = new Frame();\n    baseHwFrame.alloc();\n    FFmpegError.throwIfError(hwFramesCtx.getBuffer(baseHwFrame, 0), \"base.getBuffer\");\n    FFmpegError.throwIfError(await hwFramesCtx.transferData(baseHwFrame, yuvFrame, 0), \"base.transfer\");\n    baseHwFrame.pts = pts;\n    baseHwFrame.duration = 1n;\n\n    const alphaHwFrame = new Frame();\n    alphaHwFrame.alloc();\n    FFmpegError.throwIfError(hwFramesCtx.getBuffer(alphaHwFrame, 0), \"alpha.getBuffer\");\n    FFmpegError.throwIfError(await hwFramesCtx.transferData(alphaHwFrame, this._alphaFrame, 0), \"alpha.transfer\");\n    alphaHwFrame.pts = pts;\n    alphaHwFrame.duration = 1n;\n\n    FFmpegError.throwIfError(await baseCtx.sendFrame(baseHwFrame), \"base.sendFrame\");\n    FFmpegError.throwIfError(await alphaCtx.sendFrame(alphaHwFrame), \"alpha.sendFrame\");\n    await this.drainInterleaved(muxer);\n    baseHwFrame.free();\n    alphaHwFrame.free();\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._s.baseCtx.sendFrame(null);\n    await this._s.alphaCtx.sendFrame(null);\n    await this.drainInterleaved(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    const { basePkt, alphaPkt, yuvFrame, baseSws, hwFramesCtx, baseCtx, alphaCtx } = this._s;\n    basePkt.free();\n    alphaPkt.free();\n    yuvFrame[Symbol.dispose]();\n    this._alphaFrame?.free();\n    baseSws[Symbol.dispose]();\n    hwFramesCtx.free();\n    baseCtx.freeContext();\n    alphaCtx.freeContext();\n  }\n\n  private async drainInterleaved(muxer: FormatMuxer): Promise<void> {\n    const { baseCtx, alphaCtx, basePkt, alphaPkt, stream } = this._s;\n    while (true) {\n      const baseR = await baseCtx.receivePacket(basePkt);\n      const alphaR = await alphaCtx.receivePacket(alphaPkt);\n\n      const baseReady = baseR >= 0;\n      const alphaReady = alphaR >= 0;\n      if (!baseReady && !alphaReady) break;\n\n      // Both must produce packets together (bf=0 ensures this)\n      if (baseReady !== alphaReady) {\n        throw new Error(`NVENC desync: base=${baseReady}, alpha=${alphaReady}`);\n      }\n\n      const baseNals = splitNalUnits(basePkt.data!);\n      const alphaNals = splitNalUnits(alphaPkt.data!);\n\n      const chunks: Buffer[] = [];\n      if (!this._seiInjected) {\n        chunks.push(this._seiBuffer);\n        this._seiInjected = true;\n      }\n      chunks.push(interleaveAccessUnits(baseNals, alphaNals));\n\n      // Save timestamps before data replacement (setter may reset them)\n      const pts = basePkt.pts;\n      const dts = basePkt.dts;\n      const duration = basePkt.duration;\n      basePkt.data = Buffer.concat(chunks);\n      basePkt.pts = pts;\n      basePkt.dts = dts;\n      basePkt.duration = duration === 0n ? 1n : duration;\n      basePkt.streamIndex = stream.index;\n      basePkt.rescaleTs(baseCtx.timeBase, stream.timeBase);\n      await muxer.writePacket(basePkt);\n\n      basePkt.unref();\n      alphaPkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { Codec, CodecContext, FFmpegError, Frame, type Packet, Rational, type Stream } from \"node-av\";\nimport { AV_CODEC_FLAG_GLOBAL_HEADER, type AVPixelFormat, type FFVideoEncoder } from \"node-av/constants\";\nimport { drainPackets, makePacket } from \"./shared\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface VideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  codecName: FFVideoEncoder;\n  codecTag?: string;\n  globalHeader: boolean;\n  codecOpts: Record<string, string>;\n  bitrate: number;\n  pixelFormat: AVPixelFormat;\n  muxer: FormatMuxer;\n}\n\nexport class VideoEncoder implements Disposable {\n  private readonly _ctx: CodecContext;\n  private readonly _pkt: Packet;\n  private readonly _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: VideoEncoderOptions): Promise<VideoEncoder> {\n    const { width, height, fps, codecName, codecTag, globalHeader, codecOpts, bitrate, muxer } = opts;\n\n    const codec = Codec.findEncoderByName(codecName);\n    if (!codec) throw new Error(`Video encoder not found: ${codecName}`);\n\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.width = width;\n    ctx.height = height;\n    ctx.pixelFormat = opts.pixelFormat;\n    ctx.timeBase = new Rational(1, fps);\n    ctx.framerate = new Rational(fps, 1);\n    ctx.gopSize = fps * 2;\n    ctx.bitRate = BigInt(bitrate);\n    if (globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    for (const [k, v] of Object.entries(codecOpts)) ctx.setOption(k, v);\n    if (codecTag) ctx.codecTag = codecTag;\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"videoCtx.open2\");\n\n    const stream = muxer.addStream(ctx, codecTag);\n    return new VideoEncoder(ctx, makePacket(), stream);\n  }\n\n  async encode(frame: Frame, muxer: FormatMuxer): Promise<void> {\n    frame.pts = this._pts++;\n    frame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(frame), \"videoCtx.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private drain(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { CodecContext, FFmpegError, Frame, type Packet, Rational, type Stream } from \"node-av\";\nimport type { HardwareContext } from \"node-av/api\";\nimport { AV_CODEC_FLAG_GLOBAL_HEADER, AV_PIX_FMT_BGRA, AVCOL_RANGE_JPEG } from \"node-av/constants\";\nimport { drainPackets, makePacket } from \"./shared\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface HwVideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  hw: HardwareContext;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class VideoToolboxEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _pkt: Packet;\n  private _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: HwVideoEncoderOptions): Promise<VideoToolboxEncoder> {\n    const { width, height, fps, hw, bitrate, muxer } = opts;\n\n    const codec = hw.getEncoderCodec(\"hevc\");\n    if (!codec) throw new Error(\"hevc_videotoolbox encoder not found\");\n\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.width = width;\n    ctx.height = height;\n    ctx.pixelFormat = AV_PIX_FMT_BGRA;\n    ctx.colorRange = AVCOL_RANGE_JPEG;\n    ctx.timeBase = new Rational(1, fps);\n    ctx.framerate = new Rational(fps, 1);\n    ctx.gopSize = fps * 2;\n    ctx.bitRate = BigInt(bitrate);\n    ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    ctx.setOption(\"alpha_quality\", \"1\");\n    ctx.codecTag = \"hvc1\";\n\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"vtEnc.open2\");\n\n    const stream = muxer.addStream(ctx, \"hvc1\");\n    return new VideoToolboxEncoder(ctx, makePacket(), stream);\n  }\n\n  async encode(bgraFrame: Frame, muxer: FormatMuxer): Promise<void> {\n    bgraFrame.pts = this._pts++;\n    bgraFrame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(bgraFrame), \"vtEnc.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private drain(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/13.\n\nimport { HardwareContext } from \"node-av/api\";\nimport {\n  AV_PIX_FMT_YUVA420P,\n  FF_ENCODER_LIBX265,\n  FF_HWDEVICE_TYPE_CUDA,\n  FF_HWDEVICE_TYPE_VIDEOTOOLBOX,\n} from \"node-av/constants\";\n\nimport { logger } from \"../logging\";\nimport { CodecState } from \"./codec\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { NvencDualLayerEncoder } from \"./nvenc\";\nimport { VideoEncoder } from \"./video\";\nimport { VideoToolboxEncoder } from \"./videotoolbox\";\n\nconst TAG = \"[Encoder]\";\n\nexport type HwEncoder = VideoToolboxEncoder | NvencDualLayerEncoder;\n\nexport interface VideoSetup {\n  video?: VideoEncoder;\n  hwVideo?: HwEncoder;\n  codec?: CodecState;\n  hw?: HardwareContext;\n}\n\nexport interface VideoFactoryOptions {\n  width: number;\n  height: number;\n  fps: number;\n  bitrate?: number;\n  disableGpu?: boolean;\n}\n\nexport async function createVideoEncoder(opts: VideoFactoryOptions, muxer: FormatMuxer): Promise<VideoSetup> {\n  const { width, height, fps, bitrate = 8_000_000, disableGpu = false } = opts;\n  const hw = disableGpu ? undefined : (HardwareContext.auto() ?? undefined);\n\n  if (hw?.deviceTypeName === FF_HWDEVICE_TYPE_VIDEOTOOLBOX && hw.getEncoderCodec(\"hevc\")) {\n    logger.debug(TAG, \"using VideoToolbox HEVC alpha encoder\");\n    const hwVideo = await VideoToolboxEncoder.create({ width, height, fps, hw, bitrate, muxer });\n    return { hwVideo, hw };\n  }\n\n  if (hw?.deviceTypeName === FF_HWDEVICE_TYPE_CUDA && hw.getEncoderCodec(\"hevc\")) {\n    logger.debug(TAG, \"using NVENC dual-layer HEVC alpha encoder\");\n    const hwVideo = await NvencDualLayerEncoder.create({ width, height, fps, hw, bitrate, muxer });\n    return { hwVideo, hw };\n  }\n\n  logger.debug(TAG, \"using software libx265 HEVC alpha encoder\");\n  hw?.dispose();\n  const video = await VideoEncoder.create({\n    width,\n    height,\n    fps,\n    codecName: FF_ENCODER_LIBX265,\n    codecTag: \"hvc1\",\n    globalHeader: true,\n    codecOpts: { preset: \"medium\", \"x265-params\": \"log-level=1:bframes=3:pools=+:frame-threads=0\" },\n    bitrate,\n    pixelFormat: AV_PIX_FMT_YUVA420P,\n    muxer,\n  });\n  return { video, codec: await CodecState.create(width, height) };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { CodecContext, FFmpegError, FormatContext, Packet } from \"node-av\";\n\nexport class FormatMuxer {\n  private readonly _ctx: FormatContext;\n  private _opened = false;\n\n  constructor(outPath: string, formatName?: string) {\n    this._ctx = new FormatContext();\n    FFmpegError.throwIfError(this._ctx.allocOutputContext2(null, formatName ?? null, outPath), \"allocOutputContext2\");\n  }\n\n  addStream(codecCtx: CodecContext, codecTag?: string): ReturnType<FormatContext[\"newStream\"]> {\n    const stream = this._ctx.newStream(null);\n    stream.timeBase = codecCtx.timeBase;\n    FFmpegError.throwIfError(stream.codecpar.fromContext(codecCtx), \"codecpar.fromContext\");\n    if (codecTag) stream.codecpar.codecTag = codecTag;\n    return stream;\n  }\n\n  async open(): Promise<void> {\n    if (this._opened) return;\n    FFmpegError.throwIfError(await this._ctx.openOutput(), \"openOutput\");\n    FFmpegError.throwIfError(await this._ctx.writeHeader(null), \"writeHeader\");\n    this._opened = true;\n  }\n\n  async writePacket(pkt: Packet): Promise<void> {\n    FFmpegError.throwIfError(await this._ctx.interleavedWriteFrame(pkt), \"interleavedWriteFrame\");\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (!this._opened) return;\n    await this._ctx.writeTrailer();\n    await this._ctx.closeOutput();\n    await this._ctx[Symbol.asyncDispose]();\n    this._opened = false;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { FFmpegError, Frame } from \"node-av\";\nimport type { HardwareContext } from \"node-av/api\";\nimport { AV_PIX_FMT_BGRA, AV_SAMPLE_FMT_FLTP, FF_ENCODER_AAC } from \"node-av/constants\";\n\nimport { ok } from \"assert\";\nimport { ConcurrencyLimiter } from \"../limiter\";\nimport { AudioEncoder } from \"./audio\";\nimport { CodecState } from \"./codec\";\nimport { createVideoEncoder, type HwEncoder } from \"./factory\";\nimport { FormatMuxer } from \"./muxer\";\nimport { makeFrame } from \"./shared\";\nimport { VideoEncoder } from \"./video\";\n\nexport interface EncoderPipelineOptions {\n  width: number;\n  height: number;\n  fps: number;\n  outFile: string;\n  withAudio?: boolean;\n  disableGpu?: boolean;\n}\n\ninterface PipelineState {\n  video?: VideoEncoder;\n  hwVideo?: HwEncoder;\n  audio?: AudioEncoder;\n  muxer: FormatMuxer;\n  limiter: ConcurrencyLimiter;\n  outFile: string;\n  codec?: CodecState;\n  hw?: HardwareContext;\n  width: number;\n  height: number;\n}\n\nexport class EncoderPipeline {\n  private _s: PipelineState;\n  private _disposed = false;\n\n  private constructor(s: PipelineState) {\n    this._s = s;\n  }\n\n  static async create(opts: EncoderPipelineOptions): Promise<EncoderPipeline> {\n    const { width, height, outFile, withAudio = false } = opts;\n    const muxer = new FormatMuxer(outFile);\n    const { video, hwVideo, codec, hw } = await createVideoEncoder(opts, muxer);\n\n    let audio: AudioEncoder | undefined;\n    if (withAudio) {\n      audio = await AudioEncoder.create({\n        outSampleRate: 44_100,\n        outSampleFmt: AV_SAMPLE_FMT_FLTP,\n        codecName: FF_ENCODER_AAC,\n        globalHeader: true,\n        bitrate: 128_000,\n        muxer,\n      });\n    }\n\n    await muxer.open();\n    return new EncoderPipeline({\n      video,\n      hwVideo,\n      audio,\n      muxer,\n      limiter: new ConcurrencyLimiter(1),\n      outFile,\n      codec,\n      hw,\n      width,\n      height,\n    });\n  }\n\n  setupAudio(sampleRate: number): void {\n    this._s.audio?.setInputRate(sampleRate);\n  }\n\n  async encodeBGRA(input: Buffer): Promise<void> {\n    await this._s.limiter.schedule(async () => {\n      const { hwVideo, video, codec, muxer } = this._s;\n      if (hwVideo) {\n        using frame = this.bgraFrame(input);\n        await hwVideo.encode(frame, muxer);\n        return;\n      }\n      const { src, dst, sws } = codec!;\n      ok(sws, \"sws not initialized\");\n      FFmpegError.throwIfError(src.makeWritable(), \"bgraSrc.makeWritable\");\n      FFmpegError.throwIfError(src.fromBuffer(input), \"bgraSrc.fromBuffer\");\n      FFmpegError.throwIfError(dst.makeWritable(), \"bgraDst.makeWritable\");\n      FFmpegError.throwIfError(await sws.scaleFrame(dst, src), \"bgraSws.scaleFrame\");\n      return video!.encode(dst, muxer);\n    });\n  }\n\n  async encodePNG(pngData: Buffer): Promise<void> {\n    await this._s.limiter.schedule(async () => {\n      const { hwVideo, video, codec, muxer, width, height } = this._s;\n      const cs = codec ?? (await CodecState.create(width, height));\n      try {\n        const src = await cs.decodePNG(pngData);\n        if (hwVideo) {\n          await hwVideo.encode(src, muxer);\n        } else {\n          FFmpegError.throwIfError(cs.dst.makeWritable(), \"pngDst.makeWritable\");\n          FFmpegError.throwIfError(await cs.sws.scaleFrame(cs.dst, src), \"pngSws.scaleFrame\");\n          await video!.encode(cs.dst, muxer);\n        }\n      } finally {\n        if (!codec) cs[Symbol.dispose]();\n      }\n    });\n  }\n\n  async encodeAudio(pcm: Buffer): Promise<void> {\n    const { audio, limiter, muxer } = this._s;\n    if (audio) await limiter.schedule(() => audio.encode(pcm, muxer));\n  }\n\n  async finish(): Promise<string> {\n    const { video, hwVideo, audio, muxer, limiter } = this._s;\n    try {\n      await using _m = muxer;\n      using _v = video;\n      using _hv = hwVideo;\n      using _a = audio;\n      await limiter.drain();\n      await audio?.flush(muxer);\n      if (hwVideo) {\n        await hwVideo.flush(muxer);\n      } else {\n        await video!.flush(muxer);\n      }\n    } finally {\n      this.free();\n    }\n    return this._s.outFile;\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (this._disposed) return;\n    const { video, hwVideo, audio, muxer, limiter } = this._s;\n    await limiter.drain();\n    video?.[Symbol.dispose]();\n    hwVideo?.[Symbol.dispose]();\n    audio?.[Symbol.dispose]();\n    await muxer[Symbol.asyncDispose]();\n    this.free();\n  }\n\n  private free(): void {\n    if (this._disposed) return;\n    this._disposed = true;\n    using _codec = this._s.codec;\n    this._s.hw?.dispose();\n  }\n\n  private bgraFrame(input: Buffer): Frame {\n    const frame = makeFrame(this._s.width, this._s.height, AV_PIX_FMT_BGRA);\n    FFmpegError.throwIfError(frame.fromBuffer(input), \"bgraFrame.fromBuffer\");\n    return frame;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/23.\n\n/**\n * Frame drop quality score (0 = perfect, 1 = worst).\n *\n * Combines two dimensions:\n * - Global: overall drop rate across the timeline\n * - Local: perceptual severity of consecutive drops (bursts)\n *\n * Uses complementary multiplication: score = 1 - (1-g)(1-l)\n */\nexport interface FrameDropScore {\n  global: number;\n  local: number;\n  jank: number;\n  expected: number;\n  actual: number;\n  maxBurst: number;\n}\n\nexport class FrameDropStats {\n  private readonly _fps: number;\n  private _actual = 0;\n  private _currentBurst = 0;\n  private _bursts: number[] = [];\n\n  constructor(fps: number) {\n    this._fps = fps;\n  }\n\n  /** Call when a frame is actually written to the encoder. */\n  wrote(count = 1): void {\n    if (this._currentBurst > 0) {\n      this._bursts.push(this._currentBurst);\n      this._currentBurst = 0;\n    }\n    this._actual += count;\n  }\n\n  /** Call when a frame is dropped. */\n  dropped(count = 1): void {\n    this._currentBurst += count;\n  }\n\n  /** Finalize and return the score. */\n  finalize(): FrameDropScore {\n    if (this._currentBurst > 0) {\n      this._bursts.push(this._currentBurst);\n      this._currentBurst = 0;\n    }\n\n    let totalDropped = 0;\n    let localSum = 0;\n    let maxBurst = 0;\n    for (const burst of this._bursts) {\n      totalDropped += burst;\n      maxBurst = Math.max(maxBurst, burst);\n      const perceptible = Math.max(0, burst - 1);\n      localSum += (perceptible / this._fps) ** 2;\n    }\n\n    const expected = this._actual + totalDropped;\n    const g = expected > 0 ? totalDropped / expected : 0;\n    const l = Math.min(1, localSum);\n    const score = 1 - (1 - g) * (1 - l);\n\n    return { global: g, local: l, jank: score, expected, actual: this._actual, maxBurst };\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport type { NativeImage } from \"electron\";\n\nexport function isEmpty(image: NativeImage) {\n  const size = image.getSize();\n  if (size.width === 0 || size.height === 0) return true;\n  return image.isEmpty();\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/02.\n\nimport { randomUUID } from \"crypto\";\nimport { ipcMain, session } from \"electron\";\nimport { rm, writeFile } from \"fs/promises\";\nimport { tmpdir } from \"os\";\nimport { join } from \"path\";\nimport type { EncoderPipeline } from \"../base/encoder/pipeline\";\n\nconst AUDIO_CAPTURE_SCRIPT = `\n(function() {\n  if (window.__pup_audio_capturing__) return;\n  window.__pup_audio_capturing__ = true;\n\n  const { ipcRenderer } = require('electron');\n  const capturedContexts = new WeakSet();\n  const sourcedElements = new WeakSet();\n  let metaSent = false;\n\n  const origCreateMES = AudioContext.prototype.createMediaElementSource;\n  AudioContext.prototype.createMediaElementSource = function(el) {\n    sourcedElements.add(el);\n    return origCreateMES.call(this, el);\n  };\n\n  const origConnect = AudioNode.prototype.connect;\n  AudioNode.prototype.connect = function(dest, outIdx, inIdx) {\n    const captureNode = dest?.context?.__pup_captureNode__;\n    if (captureNode && dest === dest.context.destination && this !== captureNode) {\n      origConnect.call(this, captureNode, outIdx, inIdx);\n    }\n    return origConnect.call(this, dest, outIdx, inIdx);\n  };\n\n  const OrigAC = window.AudioContext || window.webkitAudioContext;\n  if (!OrigAC) return;\n\n  function PatchedAC() {\n    const ctx = new OrigAC(...arguments);\n    if (!capturedContexts.has(ctx)) {\n      capturedContexts.add(ctx);\n      if (!metaSent) {\n        metaSent = true;\n        ipcRenderer.send('audio-meta', { sampleRate: ctx.sampleRate });\n      }\n      const node = ctx.createScriptProcessor(4096, 2, 2);\n      node.onaudioprocess = (e) => {\n        const L = e.inputBuffer.getChannelData(0);\n        const R = e.inputBuffer.getChannelData(1);\n        const out = new Float32Array(L.length * 2);\n        for (let i = 0; i < L.length; i++) {\n          out[i * 2] = L[i];\n          out[i * 2 + 1] = R[i];\n        }\n        ipcRenderer.send('audio-chunk', Buffer.from(out.buffer));\n      };\n      node.connect(ctx.destination);\n      ctx.__pup_captureNode__ = node;\n    }\n    return ctx;\n  }\n  PatchedAC.prototype = OrigAC.prototype;\n  Object.setPrototypeOf(PatchedAC, OrigAC);\n  window.AudioContext = PatchedAC;\n  if ('webkitAudioContext' in window) window.webkitAudioContext = PatchedAC;\n\n  const origPlay = HTMLMediaElement.prototype.play;\n  HTMLMediaElement.prototype.play = function() {\n    if (!this.__pup_captured__) {\n      this.__pup_captured__ = true;\n      const el = this;\n      Promise.resolve().then(() => {\n        if (!sourcedElements.has(el)) {\n          const ctx = new PatchedAC();\n          ctx.createMediaElementSource(el).connect(ctx.destination);\n        }\n      });\n    }\n    return origPlay.call(this);\n  };\n})();\n`;\n\nexport interface AudioCapture {\n  teardown(): Promise<void>;\n}\n\nexport interface AudioCaptureOptions {\n  encoder: EncoderPipeline;\n  getVideoTimeMs: () => number;\n  onError: (error: Error) => void;\n}\n\nexport async function setupAudioCapture({\n  encoder,\n  getVideoTimeMs,\n  onError,\n}: AudioCaptureOptions): Promise<AudioCapture> {\n  const preloadPath = join(tmpdir(), `pup_audio_preload_${randomUUID()}.js`);\n  await writeFile(preloadPath, AUDIO_CAPTURE_SCRIPT);\n  session.defaultSession.registerPreloadScript({\n    type: \"frame\",\n    id: \"pup-audio\",\n    filePath: preloadPath,\n  });\n\n  ipcMain.on(\"audio-meta\", async (_e, data: { sampleRate: number }) => {\n    const sampleRate = data.sampleRate;\n    const startMs = getVideoTimeMs();\n    encoder.setupAudio(sampleRate);\n    const silenceSamples = Math.ceil((startMs * sampleRate) / 1000);\n    if (silenceSamples <= 0) {\n      return;\n    }\n    try {\n      await encoder.encodeAudio(Buffer.alloc(silenceSamples * 2 * 4));\n    } catch (error) {\n      onError(error as Error);\n    }\n  });\n\n  ipcMain.on(\"audio-chunk\", async (_e, buffer: Buffer) => {\n    try {\n      await encoder.encodeAudio(buffer);\n    } catch (error) {\n      onError(error as Error);\n    }\n  });\n\n  return {\n    async teardown() {\n      ipcMain.removeAllListeners(\"audio-meta\");\n      ipcMain.removeAllListeners(\"audio-chunk\");\n      session.defaultSession.unregisterPreloadScript(\"pup-audio\");\n      await rm(preloadPath, { force: true });\n    },\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nexport function sleep(ms: number) {\n  return new Promise<void>((resolve) => setTimeout(resolve, ms));\n}\n\nexport function periodical(callback: (count: number) => Promise<void> | void, ms: number) {\n  let token: NodeJS.Timeout;\n  let closed = false;\n  async function tick(count: number) {\n    await callback(count);\n    if (closed) return;\n    token = setTimeout(() => tick(count + 1), ms);\n  }\n  token = setTimeout(() => tick(0), ms);\n  return () => {\n    closed = true;\n    clearTimeout(token);\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/05.\n\nimport { setTimeout } from \"timers/promises\";\nimport { sleep } from \"./timing\";\n\nexport interface RetryOptions<Args extends any[], Ret> {\n  fn: (...args: Args) => Promise<Ret>;\n  maxAttempts?: number;\n  timeout?: number;\n}\n\nexport function useRetry<Args extends any[], Ret>({ fn, maxAttempts = 3, timeout }: RetryOptions<Args, Ret>) {\n  const timeoutError = new Error(`timeout over ${timeout}ms`);\n  return async function (...args: Args) {\n    let attempt = 0;\n    while (true) {\n      try {\n        const promises = [fn(...args)];\n        if (timeout) {\n          promises.push(\n            setTimeout(timeout).then(() => {\n              throw timeoutError;\n            }),\n          );\n        }\n        return await Promise.race(promises);\n      } catch (e) {\n        attempt++;\n        if (attempt >= maxAttempts) {\n          throw e;\n        }\n        await sleep(Math.pow(2, attempt) * 100 + Math.random() * 100);\n      }\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nconst SUPPORTED_PROTOCOLS = [\"file:\", \"http:\", \"https:\", \"data:\"];\nconst SOURCE_PATTERN = /^(file:|https?:|data:)/;\n\nexport function checkHTML(source: string): void {\n  if (SOURCE_PATTERN.test(source)) {\n    return;\n  }\n\n  const protocol = source.split(\":\")[0] + \":\";\n  const message = SUPPORTED_PROTOCOLS.includes(protocol)\n    ? `unsupported protocol: ${protocol}, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`\n    : `invalid source format, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`;\n\n  throw new Error(message);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/10.\n\nexport interface WaitOptions {\n  timeout: number;\n  onTimeout?: () => void;\n}\n\nexport class WaitableEvent {\n  private _promise?: Promise<void>;\n  private _resolve?: () => void;\n  private _timeoutToken?: NodeJS.Timeout;\n\n  wait(options?: WaitOptions): Promise<void> {\n    if (this._promise) {\n      throw new Error(\"already waiting\");\n    }\n    this._promise = new Promise((resolve) => {\n      this._resolve = resolve;\n      if (options?.timeout !== undefined) {\n        this._timeoutToken = setTimeout(() => {\n          options.onTimeout?.();\n          resolve();\n        }, options.timeout);\n      }\n    });\n    return this._promise;\n  }\n\n  signal() {\n    clearTimeout(this._timeoutToken);\n    this._promise = undefined;\n    this._resolve?.();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { BrowserWindow } from \"electron\";\nimport { URL } from \"url\";\nimport { ConcurrencyLimiter } from \"../base/limiter\";\nimport { logger } from \"../base/logging\";\nimport { WaitableEvent } from \"../base/waitable_event\";\n\nconst TAG = \"[Network]\";\n\nconst map = new Map([\n  [`jssz-boss.hdslb.com`, `jssz-boss.bilibili.co`], //\n  [`boss.hdslb.com`, `shjd-boss.bilibili.co`],\n]);\n\nexport function proxiedUrl(url: string) {\n  if (!url.startsWith(\"http\")) {\n    return url;\n  }\n  const parsed = new URL(url);\n  const target = map.get(parsed.hostname);\n  if (!target) {\n    return url;\n  }\n  parsed.hostname = target;\n  parsed.protocol = \"http:\";\n  return parsed.toString();\n}\n\nexport interface NetworkOptions {\n  source: string;\n  window: BrowserWindow;\n  useInnerProxy?: boolean;\n}\n\nexport function setInterceptor({ source, window, useInnerProxy }: NetworkOptions) {\n  const req = window.webContents.session.webRequest;\n  const limiter = new ConcurrencyLimiter(64);\n  const events = new Map<string, WaitableEvent>();\n\n  async function wait(key: string, onTimeout?: () => void) {\n    const event = new WaitableEvent();\n    events.set(key, event);\n    await event.wait({ timeout: 5_000, onTimeout }).finally(() => events.delete(key));\n  }\n\n  function signal(key: string) {\n    events.get(key)?.signal();\n  }\n\n  req.onBeforeRequest((details, callback) => {\n    const url = details.url;\n    const proxied = useInnerProxy ? proxiedUrl(url) : url;\n    limiter.schedule(() => {\n      const key = `${window.id}_${details.id}`;\n      logger.debug(TAG, `start:`, {\n        key,\n        url,\n        proxied,\n        method: details.method,\n        source,\n        stats: limiter.stats,\n      });\n      if (proxied === url) {\n        callback({ cancel: false });\n      } else {\n        callback({ cancel: false, redirectURL: proxied });\n      }\n      return wait(key, () => {\n        logger.warn(TAG, `maybe timeout:`, {\n          key,\n          url,\n          proxied,\n          method: details.method,\n          source,\n        });\n      });\n    });\n  });\n\n  req.onHeadersReceived(({ responseHeaders }, callback) => {\n    delete responseHeaders?.[\"x-frame-options\"];\n    delete responseHeaders?.[\"X-Frame-Options\"];\n    delete responseHeaders?.[\"content-security-policy\"];\n    delete responseHeaders?.[\"Content-Security-Policy\"];\n    callback({ cancel: false, responseHeaders });\n  });\n\n  req.onCompleted((details) => {\n    const key = `${window.id}_${details.id}`;\n    signal(key);\n    logger.debug(TAG, `completed:`, {\n      key,\n      url: details.url,\n      method: details.method,\n      statusCode: details.statusCode,\n      source,\n    });\n  });\n\n  req.onErrorOccurred((details) => {\n    const key = `${window.id}_${details.id}`;\n    signal(key);\n    logger.error(TAG, `error:`, {\n      key,\n      url: details.url,\n      method: details.method,\n      error: details.error,\n      source,\n    });\n  });\n}\n\nexport function unsetInterceptor(window: BrowserWindow) {\n  const req = window.webContents.session.webRequest;\n  req.onBeforeRequest(null);\n  req.onHeadersReceived(null);\n  req.onCompleted(null);\n  req.onErrorOccurred(null);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { BrowserWindow } from \"electron\";\nimport { logger } from \"../base/logging\";\nimport { useRetry } from \"../base/retry\";\nimport { sleep } from \"../base/timing\";\nimport { checkHTML } from \"./html_check\";\nimport { proxiedUrl, setInterceptor, unsetInterceptor } from \"./network\";\nimport { createStegoURL } from \"./protocol\";\nimport type { RenderOptions } from \"./schema\";\n\nconst TAG = \"[Window]\";\n\nfunction waitForFinish(win: BrowserWindow, action: () => void) {\n  return new Promise<void>((resolve, reject) => {\n    const timeout = setTimeout(() => reject(new Error(\"load window timeout\")), 30_000);\n    const done = (err?: Error) => {\n      clearTimeout(timeout);\n      err ? reject(err) : resolve();\n    };\n    win.webContents.once(\"did-stop-loading\", () => done());\n    win.webContents.once(\"did-frame-finish-load\", (_, isMainFrame, frameProcessId, frameRoutingId) => {\n      logger.debug(TAG, \"did-frame-finish-load:\", { isMainFrame, frameProcessId, frameRoutingId });\n    });\n    win.webContents.once(\"dom-ready\", () => {\n      logger.debug(TAG, \"dom-ready\");\n    });\n    win.webContents.once(\"did-fail-load\", (_e, code, desc, url) =>\n      done(new Error(`failed to load ${url}: [${code}] ${desc}`)),\n    );\n    win.webContents.once(\"render-process-gone\", (_e, { exitCode, reason }) =>\n      done(new Error(`renderer crashed: ${exitCode}, ${reason}`)),\n    );\n    action();\n  });\n}\n\nfunction waitForDestroy(win: BrowserWindow) {\n  return new Promise<void>((resolve) => {\n    unsetInterceptor(win);\n    win.once(\"closed\", resolve);\n    win.destroy();\n  });\n}\n\nexport interface WindowOptions {\n  source: string;\n  onCreated?: (window: BrowserWindow) => Promise<void>;\n  renderer: RenderOptions;\n  warmup?: boolean;\n}\n\nasync function openWindow({ source, onCreated, renderer, warmup }: WindowOptions): Promise<BrowserWindow> {\n  checkHTML(source);\n\n  const { width, height, useInnerProxy } = renderer;\n  const src = useInnerProxy ? proxiedUrl(source) : source;\n\n  const win = new BrowserWindow({\n    width,\n    height: height + 1,\n    show: false,\n    transparent: true,\n    backgroundColor: undefined,\n    frame: false,\n    webPreferences: {\n      offscreen: true,\n      backgroundThrottling: false,\n      nodeIntegration: true,\n      nodeIntegrationInSubFrames: true,\n      nodeIntegrationInWorker: true,\n      contextIsolation: false,\n      webSecurity: false,\n      allowRunningInsecureContent: true,\n      experimentalFeatures: true,\n    },\n  });\n  setInterceptor({ source, window: win, useInnerProxy });\n  if (!warmup) {\n    await onCreated?.(win);\n  }\n\n  win.webContents.on(\"console-message\", ({ level, message, lineNumber, sourceId }) => {\n    const msgs = [TAG, \"console:\", { message, lineNumber, sourceId, source }];\n    level === \"error\" ? logger.error(...msgs) : logger.debug(...msgs);\n  });\n\n  try {\n    const url = createStegoURL(src, { width, height });\n    await waitForFinish(win, () => win.loadURL(url));\n  } catch (e) {\n    await waitForDestroy(win);\n    throw e;\n  }\n\n  return win;\n}\n\nexport async function loadWindow({ source, onCreated, renderer }: WindowOptions): Promise<BrowserWindow> {\n  let warmup: BrowserWindow | undefined;\n  try {\n    warmup = await useRetry({ fn: openWindow, maxAttempts: 2 })({ source, renderer, warmup: true });\n  } catch (e) {\n    const { message, stack } = e as Error;\n    throw new Error(`failed to load window: ${JSON.stringify({ source, message, stack })}`);\n  }\n\n  warmup.webContents.removeAllListeners();\n  unsetInterceptor(warmup);\n\n  // warmup for shaders\n  await sleep(2000);\n  await waitForDestroy(warmup);\n\n  try {\n    return await openWindow({ source, renderer, onCreated });\n  } catch (e) {\n    const { message, stack } = e as Error;\n    throw new Error(`failed to load window: ${JSON.stringify({ source, message, stack })}`);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { type NativeImage } from \"electron\";\nimport { EncoderPipeline } from \"../base/encoder/pipeline\";\nimport { FrameDropStats } from \"../base/frame_drop\";\nimport { isEmpty } from \"../base/image\";\nimport { setupAudioCapture, type AudioCapture } from \"./audio\";\nimport type { IpcDonePayload, IpcWriter } from \"./ipc\";\nimport type { RenderOptions } from \"./schema\";\nimport { decodeStego, startStego, stopStego } from \"./stego\";\nimport { loadWindow } from \"./window\";\n\nexport async function render(writer: IpcWriter, source: string, options: RenderOptions): Promise<IpcDonePayload> {\n  const { fps, width, height, duration, withAudio, outFile, disableGpu } = options;\n\n  await using encoder = await EncoderPipeline.create({ width, height, fps, outFile, withAudio, disableGpu });\n\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n\n  let written = 0;\n  let lastWrittenTime: number | undefined;\n  let progress = 0;\n  let encodeError: Error | undefined;\n  let resolver: (() => void) | undefined;\n  let rejecter: ((reason?: unknown) => void) | undefined;\n  const dropStats = new FrameDropStats(fps);\n\n  let audio: AudioCapture | undefined;\n  const scheduleFrame = (frame: Buffer) => {\n    written++;\n    encoder.encodeBGRA(frame).catch((e) => (encodeError ??= e));\n  };\n\n  const paint = (_e: unknown, _r: unknown, image: NativeImage) => {\n    if (encodeError) {\n      rejecter?.(encodeError);\n      return;\n    }\n\n    if (isEmpty(image)) return;\n\n    const bitmap = image.toBitmap();\n    const currentTime = decodeStego(bitmap, image.getSize());\n    if (currentTime === undefined) {\n      encodeError ??= new Error(`no timestamp @ ${written}`);\n      return;\n    }\n\n    const bytesPerRow = width * 4;\n    const cropped = Buffer.from(bitmap.buffer, bitmap.byteOffset, height * bytesPerRow);\n\n    if (lastWrittenTime === undefined) {\n      scheduleFrame(cropped);\n      dropStats.wrote();\n      lastWrittenTime = currentTime;\n    } else {\n      const timeDelta = currentTime - lastWrittenTime;\n      if (timeDelta >= frameInterval * 0.8) {\n        if (timeDelta <= frameInterval * 1.2) {\n          scheduleFrame(cropped);\n          dropStats.wrote();\n        } else {\n          const framesToInsert = Math.round(timeDelta / frameInterval);\n          dropStats.dropped(framesToInsert - 1);\n          dropStats.wrote();\n          for (let i = 0; i < framesToInsert && written < total; i++) {\n            scheduleFrame(cropped);\n          }\n        }\n        lastWrittenTime = currentTime;\n      }\n    }\n\n    const newProgress = Math.floor((written / total) * 100);\n    if (Math.abs(newProgress - progress) > 10) {\n      progress = newProgress;\n      writer.writeProgress(progress);\n    }\n\n    const durationMs = duration * 1000;\n    if (currentTime >= durationMs - frameInterval * 0.5 || written >= total) {\n      resolver?.();\n    }\n  };\n\n  const win = await loadWindow({\n    source,\n    renderer: options,\n    onCreated: async () => {\n      if (withAudio) {\n        audio = await setupAudioCapture({\n          encoder,\n          getVideoTimeMs: () => lastWrittenTime ?? 0,\n          onError: (e) => (encodeError ??= e),\n        });\n      }\n    },\n  });\n  const cdp = win.webContents.debugger;\n  win.webContents.setFrameRate(fps);\n  if (!win.webContents.isPainting()) win.webContents.startPainting();\n  cdp.attach(\"1.3\");\n  win.webContents.on(\"paint\", paint);\n\n  try {\n    await startStego(cdp);\n    await new Promise<void>((r, j) => ([resolver, rejecter] = [r, j]));\n  } finally {\n    await stopStego(cdp);\n    win.webContents.off(\"paint\", paint);\n    win.close();\n    await audio?.teardown();\n    await encoder.finish();\n  }\n\n  if (encodeError || written === 0) {\n    throw encodeError ?? new Error(\"no frames captured\");\n  } else {\n    const dropScore = dropStats.finalize();\n    return { written, jank: dropScore.jank, outFile };\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/13.\n\nimport type { Debugger } from \"electron\";\n\nconst ADVANCE_TIMEOUT_MS = 30_000;\n\nexport function advanceVirtualTime(cdp: Debugger, budget: number): Promise<void> {\n  return new Promise((resolve, reject) => {\n    const timeout = setTimeout(() => {\n      cdp.off(\"message\", handler);\n      reject(new Error(`advanceVirtualTime timed out after ${ADVANCE_TIMEOUT_MS}ms`));\n    }, ADVANCE_TIMEOUT_MS);\n\n    const handler = (_: Electron.Event, method: string) => {\n      if (method === \"Emulation.virtualTimeBudgetExpired\") {\n        clearTimeout(timeout);\n        cdp.off(\"message\", handler);\n        resolve();\n      }\n    };\n    cdp.on(\"message\", handler);\n    cdp.sendCommand(\"Emulation.setVirtualTimePolicy\", {\n      policy: \"advance\",\n      budget,\n    });\n  });\n}\n\nexport function pauseVirtualTime(cdp: Debugger): Promise<void> {\n  return cdp.sendCommand(\"Emulation.setVirtualTimePolicy\", { policy: \"pause\" });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/10.\n\nexport function debounce<T extends (...args: unknown[]) => void>(fn: T, delay = 100): T {\n  let timer: NodeJS.Timeout | undefined;\n  return function (this: unknown, ...args: Parameters<T>) {\n    clearTimeout(timer);\n    timer = setTimeout(() => {\n      fn.apply(this, args);\n      timer = undefined;\n    }, delay);\n  } as T;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nexport class Lazy<T> {\n  constructor(readonly makeValue: () => T) {}\n\n  get value(): T {\n    if (!this._initialized) {\n      this._value = this.makeValue();\n      this._initialized = true;\n    }\n    return this._value!;\n  }\n\n  get initialized(): boolean {\n    return this._initialized;\n  }\n\n  private _initialized = false;\n  private _value: T | undefined;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nexport const TICK_SYMBOL = \"__pup_tick__\";\n\nexport interface TickInjectorOptions {\n  /**\n   * When true, skips the top-frame guard so the injector runs in the main document.\n   * Required for Puppeteer mode where the page is loaded directly (no stego iframe wrapper).\n   * Default: false (Electron/stego mode — only inject in iframes).\n   */\n  skipFrameGuard?: boolean;\n}\n\n/**\n * Builds the JS injector that hooks all time-related globals in the target frame.\n * In Electron/stego mode (default), guards against running in the top-level frame.\n * In Puppeteer mode (skipFrameGuard: true), injects directly into the main document.\n * Must be injected via Page.addScriptToEvaluateOnNewDocument AND directly into\n * already-loaded frames.\n */\nexport function buildTickInjector(opts?: TickInjectorOptions): string {\n  const frameGuard = opts?.skipFrameGuard ? \"\" : \"if (window.self === window.top) return;\";\n  return `(function() {\n  ${frameGuard}\n  if (typeof ${TICK_SYMBOL} !== 'undefined') return;\n\n  const orig = {\n    Date: Date,\n    dateNow: Date.now.bind(Date),\n    performanceNow: performance.now.bind(performance),\n    raf: requestAnimationFrame.bind(window),\n    caf: cancelAnimationFrame.bind(window),\n    setTimeout: setTimeout.bind(window),\n    clearTimeout: clearTimeout.bind(window),\n    setInterval: setInterval.bind(window),\n    clearInterval: clearInterval.bind(window),\n  };\n\n  let currMs = 0;\n  let rafQueue = [];\n  const timers = {};\n  let nextId = 1;\n  const dateOrigin = new orig.Date();\n  const perfOrigin = orig.performanceNow();\n\n  performance.now = function() { return perfOrigin + currMs; };\n  Date.now = function() { return dateOrigin.getTime() + currMs; };\n  Date = function() {\n    var O = orig.Date;\n    if (arguments.length === 0) return new O(dateOrigin.getTime() + currMs);\n    return new (Function.prototype.bind.apply(O, [null].concat(Array.prototype.slice.call(arguments))))();\n  };\n  Date.now = function() { return dateOrigin.getTime() + currMs; };\n  Date.parse = orig.Date.parse;\n  Date.UTC = orig.Date.UTC;\n  Date.prototype = orig.Date.prototype;\n\n  window.requestAnimationFrame = function(cb) {\n    const id = nextId++;\n    rafQueue.push({ id, cb });\n    return id;\n  };\n  window.cancelAnimationFrame = function(id) {\n    rafQueue = rafQueue.filter((r) => r.id !== id);\n  };\n\n  window.setTimeout = function(cb, delay, ...args) {\n    const id = nextId++;\n    timers[id] = { type: 'timeout', cb, delay: delay || 0, next: currMs + (delay || 0), args };\n    return id;\n  };\n  window.clearTimeout = function(id) { delete timers[id]; };\n\n  window.setInterval = function(cb, delay, ...args) {\n    const id = nextId++;\n    const d = Math.max(delay || 0, 1);\n    timers[id] = { type: 'interval', cb, delay: d, next: currMs + d, args };\n    return id;\n  };\n  window.clearInterval = function(id) { delete timers[id]; };\n\n  function process(timestampMs) {\n    currMs = timestampMs;\n    document.getAnimations().forEach(a => {\n      a.pause();\n      a.currentTime = currMs;\n    });\n    const ids = Object.keys(timers);\n    for (let i = 0; i < ids.length; i++) {\n      const t = timers[ids[i]];\n      if (!t) continue;\n      while (t.next <= currMs) {\n        if (typeof t.cb === 'string') eval(t.cb); else t.cb.apply(undefined, t.args);\n        if (t.type === 'timeout') { delete timers[ids[i]]; break; }\n        t.next += t.delay;\n      }\n    }\n    const rafs = rafQueue.splice(0);\n    for (let j = 0; j < rafs.length; j++) {\n      rafs[j].cb(currMs);\n    }\n  }\n\n  function eject() {\n    Date = orig.Date;\n    performance.now = orig.performanceNow;\n    window.requestAnimationFrame = orig.raf;\n    window.cancelAnimationFrame = orig.caf;\n    window.setTimeout = orig.setTimeout;\n    window.clearTimeout = orig.clearTimeout;\n    window.setInterval = orig.setInterval;\n    window.clearInterval = orig.clearInterval;\n    delete window.${TICK_SYMBOL};\n  }\n\n  window.${TICK_SYMBOL} = { process: process, eject: eject };\n})();`;\n}\n\nexport function doProcess(timestampMs: number): string {\n  return `${TICK_SYMBOL}.process(${timestampMs})`;\n}\n\nexport function doEject(): string {\n  return `if (typeof ${TICK_SYMBOL} !== 'undefined') ${TICK_SYMBOL}.eject()`;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/13.\n\nimport { type BrowserWindow, type NativeImage, type Size } from \"electron\";\nimport { advanceVirtualTime, pauseVirtualTime } from \"../base/cdp\";\nimport { debounce } from \"../base/debounce\";\nimport { EncoderPipeline } from \"../base/encoder/pipeline\";\nimport { isEmpty } from \"../base/image\";\nimport { Lazy } from \"../base/lazy\";\nimport { logger } from \"../base/logging\";\nimport { IpcWriter, type IpcDonePayload } from \"./ipc\";\nimport type { RenderOptions } from \"./schema\";\nimport { decodeStego, startStego, stopStego } from \"./stego\";\nimport { buildTickInjector, doEject, doProcess } from \"./tick\";\nimport { loadWindow } from \"./window\";\n\nconst TAG = \"[Shoot]\";\n\ninterface StegoOptions {\n  win: BrowserWindow;\n  size: Size;\n  afterTs: number;\n}\n\nfunction awaitStegoFrame({ win, size, afterTs }: StegoOptions): Promise<Buffer> {\n  const skipped = new Set<number>();\n  const report = debounce(() => {\n    const s = Array.from(skipped);\n    skipped.clear();\n    logger.debug(TAG, `skipped frames ${s.join(\", \")}, expected > ${afterTs}`);\n  }, 1000);\n  return new Promise((resolve) => {\n    const handler = (_e: unknown, _d: unknown, image: NativeImage) => {\n      if (isEmpty(image)) return;\n      const bitmap = image.toBitmap();\n      const ts = decodeStego(bitmap, image.getSize());\n      if (ts === undefined || ts < afterTs) {\n        skipped.add(ts ?? -1);\n        report();\n        return;\n      }\n      win.webContents.stopPainting();\n      win.webContents.off(\"paint\", handler);\n      resolve(Buffer.from(bitmap.buffer, bitmap.byteOffset, size.height * size.width * 4));\n    };\n    win.webContents.on(\"paint\", handler);\n  });\n}\n\nexport async function shoot(writer: IpcWriter, source: string, options: RenderOptions): Promise<IpcDonePayload> {\n  const { fps, width, height, duration, withAudio, outFile, disableGpu } = options;\n  if (withAudio) logger.warn(TAG, \"audio will be ignored on this mode\");\n\n  await using pipeline = await EncoderPipeline.create({ width, height, fps, outFile, withAudio, disableGpu });\n\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n  let written = 0;\n  let progress = 0;\n\n  const win = await loadWindow({ source, renderer: options });\n  const cdp = win.webContents.debugger;\n  const rootFrame = new Lazy(() => win.webContents.mainFrame.frames[0]);\n  try {\n    cdp.attach(\"1.3\");\n\n    const renderFps = disableGpu ? fps : 240;\n    const renderInterval = 1000 / renderFps;\n    logger.debug(TAG, { fps, frameInterval, renderFps, renderInterval });\n\n    // NOTE(Autokaka):\n    // 1. with gpu, the paint event callback at the exact point without extra renderings\n    // 2. without gpu, paint will callback each frame, so we set required fps to prevent too high CPU usage\n    win.webContents.stopPainting();\n    win.webContents.setFrameRate(renderFps);\n\n    await pauseVirtualTime(cdp);\n    const iframe = rootFrame.value;\n    await iframe?.executeJavaScript(buildTickInjector());\n    await iframe?.executeJavaScript(doProcess(0));\n    await startStego(cdp);\n\n    for (let frame = 0; frame < total; frame++) {\n      const frameMs = (frame + 1) * frameInterval;\n      const bitmap = awaitStegoFrame({\n        win,\n        size: { width, height },\n        afterTs: frameMs - renderInterval / 2,\n      });\n\n      await advanceVirtualTime(cdp, frameInterval);\n      await iframe?.executeJavaScript(doProcess(frameMs));\n\n      win.webContents.startPainting();\n      await pipeline.encodeBGRA(await bitmap);\n      written++;\n\n      const newProgress = Math.floor((written / total) * 100);\n      if (Math.abs(newProgress - progress) > 10) {\n        progress = newProgress;\n        writer.writeProgress(progress);\n      }\n    }\n  } finally {\n    await rootFrame.value?.executeJavaScript(doEject());\n    await stopStego(cdp);\n    cdp.detach();\n    win.close();\n    await pipeline.finish();\n  }\n\n  if (written === 0) {\n    throw new Error(\"no frames captured\");\n  } else {\n    return { written, jank: 0, outFile };\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { ok } from \"assert\";\nimport { app } from \"electron\";\nimport { mkdir } from \"fs/promises\";\nimport { dirname } from \"path\";\nimport { pupIpcSocket } from \"./base/constants\";\nimport { logger } from \"./base/logging\";\nimport { makeCLI } from \"./common\";\nimport { connectIpc } from \"./renderer/ipc\";\nimport { setupPupProtocol } from \"./renderer/protocol\";\nimport { render } from \"./renderer/render\";\nimport { defaultRenderOptions } from \"./renderer/schema\";\nimport { shoot } from \"./renderer/shoot\";\n\nconst TAG = \"[App]\";\n\nfunction printFeatures() {\n  logger.debug(TAG, \"gpu features:\", app.getGPUFeatureStatus());\n}\n\napp.dock?.hide();\napp.on(\"window-all-closed\", () => {});\n\nmakeCLI({\n  name: \"app\",\n  defaults: {\n    ...defaultRenderOptions,\n    withAudio: false,\n    deterministic: false,\n    useInnerProxy: false,\n    disableGpu: false,\n  },\n  run: async (source, options) => {\n    const exit = (code: number) => {\n      app.quit();\n      process.exit(code);\n    };\n    process.once(\"SIGTERM\", () => exit(143));\n    process.once(\"SIGINT\", () => exit(130));\n    process.once(\"exit\", (c) => exit(c));\n    ok(pupIpcSocket, \"pupIpcSocket not set\");\n    const ipc = await connectIpc(pupIpcSocket);\n    try {\n      app.on(\"gpu-info-update\", printFeatures);\n      await app.whenReady();\n      setupPupProtocol();\n      printFeatures();\n      await mkdir(dirname(options.outFile), { recursive: true });\n      const action = options.deterministic ? shoot : render;\n      ipc.writeDone(await action(ipc, source, options));\n    } catch (e) {\n      const error = e as Error;\n      ipc.writeError(error.stack ?? \"unknown error\");\n    } finally {\n      app.quit();\n    }\n  },\n});\n"]}
260
+ window.${Y} = { process: process, eject: eject };
261
+ })();`}function et(r){return `${Y}.process(${r})`}function pr(){return `if (typeof ${Y} !== 'undefined') ${Y}.eject()`}var Se="[Shoot]";function qo(r){return new Promise(e=>{let t=(o,i)=>{Math.abs(i-r)<=1&&(electron.ipcMain.off(ce,t),e(i));};electron.ipcMain.on(ce,t);})}async function Ko(r,e,t){let o=setInterval(()=>{f.warn(Se,`renderer is extremely slow @ ${t}`);},1e3);try{return await new Promise(i=>{let n=(s,c,a)=>{if(xe(a))return;let u=a.toBitmap(),d=ue(u,a.getSize());if(d===void 0||Math.abs(d-t)>1){f.warn(Se,`skip frame: ${d}, expected: ${t}, the render is slow`);return}r.webContents.stopPainting(),r.webContents.off("paint",n),i(Buffer.from(u.buffer,u.byteOffset,e.height*e.width*4));};r.webContents.on("paint",n);})}finally{clearInterval(o);}}async function lr(r,e,t){var S=[];try{let{fps:o,width:i,height:n,duration:s,withAudio:c,outFile:a,disableGpu:u,disableHwCodec:d}=t;c&&f.warn(Se,"audio will be ignored on this mode");let p=y(S,await K.create({width:i,height:n,fps:o,outFile:a,withAudio:c,disableHwCodec:d}),!0);let h=Math.ceil(o*s);let l=1e3/o;let w=0;let x=0;let b=await ur&&!u;let E=await Fe({source:e,renderer:t});let _=E.webContents.debugger;let C=E.webContents.mainFrame;let g=C.frames[0];try{_.attach("1.3");let Q=b?240:o,Ae=1e3/Q;f.debug(Se,{fps:o,frameInterval:l,renderFps:Q,renderInterval:Ae}),E.webContents.stopPainting(),E.webContents.setFrameRate(Q),await cr(_),await g?.executeJavaScript(dr()),g?.executeJavaScript(et(0));for(let Z=0;Z<h;Z++){let D=(Z+1)*l,A=qo(D);await g?.executeJavaScript(et(D)),await Rt(_,D),await sr(_,l);let L=Ko(E,{width:i,height:n},await A);E.webContents.startPainting(),await p.encodeBGRA(await L),w++;let V=Math.floor(w/h*100);Math.abs(V-x)>10&&(x=V,r.writeProgress(x));}}finally{g?.executeJavaScript(pr()),_.detach(),E.close(),await p.finish();}if(w===0)throw new Error("no frames captured");else return {written:w,jank:0,outFile:a}}catch(ae){var I=ae,X=true;}finally{var J=v(S,I,X);J&&await J;}}var Qo="[App]";function fr(){f.debug(Qo,"gpu features:",electron.app.getGPUFeatureStatus());}electron.app.dock?.hide();electron.app.on("window-all-closed",()=>{});At({name:"app",defaults:{...Ft,withAudio:false,deterministic:false,useInnerProxy:false,disableGpu:false,disableHwCodec:false,windowTolerant:false},run:async(r,e)=>{let t=i=>{electron.app.quit(),process.exit(i);};process.once("SIGTERM",()=>t(143)),process.once("SIGINT",()=>t(130)),process.once("exit",i=>t(i)),assert.ok(Oe,"pupIpcSocket not set");let o=await It(Oe);try{electron.app.on("gpu-info-update",fr),await electron.app.whenReady(),Ot(),fr(),await promises.mkdir(path.dirname(e.outFile),{recursive:!0});let i=e.deterministic?lr:ar;o.writeDone(await i(o,r,e));}catch(i){let n=i;o.writeError(n.stack??"unknown error");}finally{electron.app.quit();}}});//# sourceMappingURL=app.cjs.map
262
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../node_modules/.bun/tsup@8.5.1+fa526391f73a8616/node_modules/tsup/assets/cjs_shims.js","../src/base/env.ts","../src/base/parser.ts","../src/base/constants.ts","../src/base/logging.ts","../src/base/noerr.ts","../src/base/process.ts","../src/renderer/schema.ts","../src/common.ts","../src/renderer/ipc.ts","../src/renderer/stego.ts","../src/renderer/protocol.ts","../src/base/limiter.ts","../src/base/encoder/misc.ts","../src/base/encoder/audio.ts","../src/base/encoder/codec.ts","../src/base/encoder/bit.ts","../src/base/encoder/nal.ts","../src/base/encoder/vps.ts","../src/base/encoder/alpha.ts","../src/base/encoder/nvenc.ts","../src/base/encoder/video.ts","../src/base/encoder/videotoolbox.ts","../src/base/encoder/factory.ts","../src/base/encoder/muxer.ts","../src/base/encoder/pipeline.ts","../src/base/frame_drop.ts","../src/base/image.ts","../src/renderer/audio.ts","../src/base/timing.ts","../src/base/retry.ts","../src/renderer/html_check.ts","../src/base/waitable_event.ts","../src/renderer/network.ts","../src/renderer/window.ts","../src/renderer/render.ts","../src/base/cdp.ts","../src/base/hwaccel.ts","../src/renderer/tick.ts","../src/renderer/shoot.ts","../src/app.ts"],"names":["getImportMetaUrl","importMetaUrl","penv","name","parser","defaultValue","parseNumber","x","num","require","createRequire","env","pupLogLevel","pupUseInnerProxy","pupDisableGPU","pupDisableHwCodec","pupDeterministic","pupPkgRoot","dirname","join","pupIpcSocket","pupWindowTolerant","DEBUG","INFO","WARN","ERROR","FATAL","stackHook","target","_context","messages","processed","msg","_fatal_dec","_error_dec","_warn_dec","_info_dec","_debug_dec","_init","Logger","_level","__runInitializers","__publicField","value","debug","info","warn","error","lv","message","proc","resolve","reject","fatal","dispatch","data","err","code","signal","reason","__decoratorStart","__decorateElement","__decoratorMetadata","logger","Log","level","AV_LOG_ERROR","AV_LOG_WARNING","noerr","fn","args","ret","PUP_ARGS_KEY","pargs","argv","priv","arg","DEFAULT_WIDTH","DEFAULT_HEIGHT","DEFAULT_FPS","DEFAULT_DURATION","DEFAULT_OUT_FILE","RenderSchema","z","defaultRenderOptions","makeCLI","options","shape","d","program","source","opts","e","HEADER_SIZE","IpcWriter","_socket","payload","type","header","connectIpc","socketPath","socket","createConnection","STEGO_TICK_CHANNEL","buildStegoHTML","targetURL","size","width","height","decodeStego","bitmap","markerRow","timestamp","i","pixelIdx","bit","startStego","cdp","tickStego","ms","stopStego","PUP_SCHEME","protocol","setupPupProtocol","req","url","src","html","createStegoURL","ConcurrencyLimiter","maxConcurrency","v","r","keep","entry","openVideoCtx","label","ctx","CodecContext","Rational","AV_CODEC_FLAG_GLOBAL_HEADER","k","FFmpegError","makeFrame","pixFmt","frame","Frame","makePacket","pkt","Packet","drainPackets","stream","muxer","AVERROR_EAGAIN","AVERROR_EOF","SAMPLE_FMT_NAME","AV_SAMPLE_FMT_FLT","AV_SAMPLE_FMT_FLTP","AudioEncoder","_AudioEncoder","outFmt","codec","Codec","AV_CHANNEL_LAYOUT_STEREO","inSampleRate","graph","FilterGraph","abuffer","Filter","bufSrc","abuffersink","bufSink","filterDesc","outputs","FilterInOut","inputs","pcm","_stack","nSamples","__using","_","_error","_hasError","__callDispose","CodecState","_CodecState","FF_DECODER_PNG","ok","png","AV_PIX_FMT_BGRA","AV_PIX_FMT_YUVA420P","pngData","sws","SoftwareScaleContext","fmt","SWS_BILINEAR","packBits","bits","buf","byte","b","BitWriter","val","n","len","pad","start","BitReader","zeros","ANNEX_B_START_CODE","parseNalType","header0","header1","layerId","temporalId","encodeNalHeader","byte0","byte1","splitNalUnits","bitstream","nals","scLen","nalStart","nalEnd","j","rewriteNalLayerId","nal","out","b0","b1","removeEmulationPrevention","addEmulationPrevention","extractPTL","vpsData","br","maxSubLayersMinus1","ptlStart","writeBaseVPS","bw","ptl","writeVPSExtension","buildAlphaVPS","NAL_UNIT_PREFIX_SEI","buildUnifiedExtradata","baseExtradata","alphaExtradata","baseNals","alphaNals","alphaByType","arr","chunks","emitted","alphaNal","buildAlphaChannelInfoSEI","h0","h1","writeBits","interleaveAccessUnits","NvencDualLayerEncoder","_NvencDualLayerEncoder","s","fps","bitrate","FF_ENCODER_HEVC_NVENC","common","baseCtx","alphaCtx","AV_PIX_FMT_YUV420P","basePkt","alphaPkt","baseExtra","alphaExtra","bgraFrame","pts","srcLs","w","h","ySize","uvSize","y","baseR","alphaR","baseReady","alphaReady","dts","duration","VideoEncoder","_VideoEncoder","codecName","codecTag","codecOpts","rest","VideoToolboxEncoder","_VideoToolboxEncoder","hw","AVCOL_RANGE_JPEG","TAG","createVideoEncoder","disableHwCodec","HardwareContext","FF_HWDEVICE_TYPE_VIDEOTOOLBOX","FF_HWDEVICE_TYPE_CUDA","FF_ENCODER_LIBX265","FormatMuxer","outPath","formatName","FormatContext","codecCtx","EncoderPipeline","_EncoderPipeline","outFile","withAudio","video","hwVideo","audio","FF_ENCODER_AAC","sampleRate","input","dst","cs","limiter","_m","_v","_hv","_a","_promise","_codec","FrameDropStats","count","totalDropped","localSum","maxBurst","burst","perceptible","expected","g","l","score","isEmpty","image","AUDIO_META_CHANNEL","AUDIO_CHUNK_CHANNEL","AUDIO_CAPTURE_SCRIPT","setupAudioCapture","encoder","getVideoTimeMs","onError","preloadPath","tmpdir","randomUUID","writeFile","session","ipcMain","_e","startMs","silenceSamples","buffer","rm","sleep","useRetry","maxAttempts","timeout","timeoutError","attempt","promises","setTimeout","SUPPORTED_PROTOCOLS","SOURCE_PATTERN","checkHTML","WaitableEvent","map","proxiedUrl","parsed","URL","setInterceptor","window","useInnerProxy","events","wait","key","onTimeout","event","details","callback","proxied","responseHeaders","unsetInterceptor","TIMEOUT_ERROR","waitForFinish","win","action","tolerant","domReady","done","isMainFrame","frameProcessId","frameRoutingId","desc","exitCode","waitForDestroy","openWindow","onCreated","renderer","warmup","BrowserWindow","lineNumber","sourceId","msgs","openWindowWithRetry","loadWindow","open","stack","render","writer","total","frameInterval","written","lastWrittenTime","progress","encodeError","resolver","rejecter","dropStats","scheduleFrame","paint","_r","currentTime","bytesPerRow","cropped","timeDelta","framesToInsert","newProgress","durationMs","dropScore","advanceVirtualTime","budget","handler","method","pauseVirtualTime","detectGPUDriver","result","canIUseGPU","TICK_SYMBOL","buildTickInjector","doProcess","timestampMs","doEject","stego","interval","_d","ts","shoot","disableGpu","pipeline","gpu","main","iframe","renderFps","renderInterval","frameMs","tick","printFeatures","app","exit","c","ipc","mkdir"],"mappings":"4kBAKA,IAAA,EAAA,CAAA,MAAA,CAAA,MAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,cAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,wBAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,MAAA,CAAA,GAAA,CAAA,SAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,MAAA,SAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,UAAA,CAAA,IAAA,CAAA,YAAA,CAAA,IAAA,CAAA,QAAA,CAAA,IAAA,CAAA,KAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,CAAA,CAAA,EAAA,IAAA,EAAA,CAAA,IAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,OAAA,CAAA,QAAA,CAAA,QAAA,CAAA,QAAA,CAAA,UAAA,CAAA,OAAA,CAAA,OAAA,CAAA,KAAA,CAAA,KAAA,CAAA,CAAA,EAAA,CAAA,CAAA,EAAA,CAAA,GAAA,MAAA,EAAA,OAAA,CAAA,EAAA,UAAA,CAAA,CAAA,CAAA,mBAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,IAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,QAAA,CAAA,CAAA,CAAA,cAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,qBAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,EAAA,CAAA,CAAA,EAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA,UAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,KAAA,CAAA,CAAA,CAAA,KAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,SAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,IAAA,IAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,CAAA,CAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,MAAA,CAAA,CAAA,GAAA,CAAA,CAAA,EAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,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","file":"app.cjs","sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n  typeof document === \"undefined\" \n    ? new URL(`file:${__filename}`).href \n    : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n      ? document.currentScript.src \n      : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nexport type EnvParser<T> = (value: unknown) => T;\n\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue: T): T;\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue?: T): T | undefined;\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue?: T): T | undefined {\n  try {\n    return parser(process.env[name]);\n  } catch {\n    return defaultValue;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nexport function parseNumber(x: unknown): number {\n  if (typeof x === \"number\") {\n    return x;\n  }\n  const num = Number(x);\n  if (Number.isNaN(num)) {\n    throw new Error(`Value ${x} is not a valid number`);\n  }\n  return num;\n}\n\nexport function parseString(x: unknown): string {\n  if (typeof x === \"string\") return x;\n  return String(x);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { createRequire } from \"module\";\nimport { dirname, join } from \"path\";\nimport { penv } from \"./env\";\nimport { parseNumber } from \"./parser\";\n\nconst require = createRequire(import.meta.url);\nconst env = process.env;\n\nexport const pupLogLevel = penv(\"PUP_LOG_LEVEL\", parseNumber, 2);\nexport const pupUseInnerProxy = env[\"PUP_USE_INNER_PROXY\"] === \"1\";\nexport const pupDisableGPU = env[\"PUP_DISABLE_GPU\"] === \"1\";\nexport const pupDisableHwCodec = env[\"PUP_DISABLE_HW_CODEC\"] === \"1\";\nexport const pupDeterministic = env[\"PUP_DETERMINISTIC\"] === \"1\";\n\nexport const pupPkgRoot = dirname(require.resolve(\"pup-recorder/package.json\"));\nexport const pupApp = join(pupPkgRoot, \"dist\", \"app.cjs\");\nexport const pupIpcSocket = env[\"PUP_IPC_SOCKET\"];\n\nexport const pupWindowTolerant = env[\"PUP_WINDOW_TOLERANT\"] === \"1\";\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport { ChildProcess, type Serializable } from \"child_process\";\nimport { Log } from \"node-av\";\nimport { AV_LOG_ERROR, AV_LOG_WARNING } from \"node-av/constants\";\nimport { pupLogLevel } from \"./constants\";\n\nexport interface LoggerLike {\n  debug?(this: void, ...messages: unknown[]): void;\n\n  info?(this: void, ...messages: unknown[]): void;\n\n  warn?(this: void, ...messages: unknown[]): void;\n\n  error?(this: void, ...messages: unknown[]): void;\n}\n\nconst DEBUG = \"<pup@debug>\";\nconst INFO = \"<pup@info>\";\nconst WARN = \"<pup@warn>\";\nconst ERROR = \"<pup@error>\";\nconst FATAL = \"<pup@fatal>\";\n\nfunction stackHook(target: Function, _context: ClassMethodDecoratorContext) {\n  return function (this: Logger, ...messages: unknown[]) {\n    const processed = messages.map((msg) => {\n      return msg instanceof Error ? (msg.stack ?? String(msg)) : msg;\n    });\n    return target.call(this, ...processed);\n  };\n}\n\nexport class Logger implements LoggerLike {\n  private _impl?: LoggerLike;\n\n  get level(): number {\n    return this._level;\n  }\n\n  set level(value: number) {\n    this._level = value;\n    this.impl = this._impl ?? console;\n  }\n\n  get impl(): LoggerLike | undefined {\n    return this._impl;\n  }\n\n  set impl(value: LoggerLike) {\n    const debug = value.debug ?? console.debug;\n    const info = value.info ?? console.info;\n    const warn = value.warn ?? console.warn;\n    const error = value.error ?? console.error;\n    const lv = this._level;\n    this._impl = {\n      debug: lv >= 3 ? debug : undefined,\n      info: lv >= 2 ? info : undefined,\n      warn: lv >= 1 ? warn : undefined,\n      error: lv >= 0 ? error : undefined,\n    };\n  }\n\n  constructor(private _level: number = pupLogLevel) {\n    this.impl = console;\n  }\n\n  @stackHook\n  debug(...messages: unknown[]): void {\n    this.impl?.debug?.(DEBUG, ...messages);\n  }\n\n  @stackHook\n  info(...messages: unknown[]): void {\n    this.impl?.info?.(INFO, ...messages);\n  }\n\n  @stackHook\n  warn(...messages: unknown[]): void {\n    this.impl?.warn?.(WARN, ...messages);\n  }\n\n  @stackHook\n  error(...messages: unknown[]): void {\n    this.impl?.error?.(ERROR, ...messages);\n  }\n\n  @stackHook\n  fatal(...messages: unknown[]): void {\n    this.impl?.error?.(FATAL, ...messages);\n    process.exit(1);\n  }\n\n  private dispatch(message: string) {\n    const msg = message.trimEnd();\n    if (msg.startsWith(DEBUG)) {\n      this.debug(msg.slice(DEBUG.length + 1));\n    } else if (msg.startsWith(INFO)) {\n      this.info(msg.slice(INFO.length + 1));\n    } else if (msg.startsWith(WARN)) {\n      this.warn(msg.slice(WARN.length + 1));\n    } else if (msg.startsWith(ERROR)) {\n      this.error(msg.slice(ERROR.length + 1));\n    } else {\n      this.info(msg);\n    }\n  }\n\n  attach(proc: ChildProcess, name: string) {\n    return new Promise<void>((resolve, reject) => {\n      this.debug(`${name}.attach`);\n      let fatal: string = \"\";\n      const dispatch = (data: Buffer | Serializable) => {\n        const message = data.toString();\n        if (message.startsWith(FATAL)) {\n          fatal += message.slice(FATAL.length + 1);\n        } else {\n          this.dispatch(message);\n        }\n      };\n      proc.stderr?.on(\"data\", dispatch);\n      proc.stdout?.on(\"data\", dispatch);\n      proc\n        .on(\"message\", dispatch)\n        .on(\"error\", (err) => {\n          fatal += err.message;\n          proc.kill();\n        })\n        .once(\"close\", (code, signal) => {\n          if (code || signal || fatal) {\n            fatal ||= `command failed: ${proc.spawnargs.join(\" \")}`;\n            this.debug(`${name}.close`, { code, signal, fatal });\n            reject(new Error(fatal));\n          } else {\n            this.debug(`${name}.close`);\n            resolve();\n          }\n        })\n        .on(\"unhandledRejection\", (reason) => {\n          this.error(`${name}.unhandled`, reason);\n        })\n        .on(\"uncaughtExceptionMonitor\", (err) => {\n          this.error(`${name}.unhandled`, err);\n        });\n    });\n  }\n}\n\nconst logger = new Logger();\n\n// Route ffmpeg native logs through pup's logger.\nLog.setCallback((level, message) => {\n  const msg = message.trimEnd();\n  if (!msg) return;\n  if (level <= AV_LOG_ERROR) logger.error(msg);\n  else if (level <= AV_LOG_WARNING) logger.warn(msg);\n});\n\nexport { logger };\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/24.\n\nexport function noerr<Fn extends (...args: any[]) => any, D>(\n  fn: Fn,\n  defaultValue: D,\n): (...args: Parameters<Fn>) => ReturnType<Fn> | D {\n  return (...args) => {\n    try {\n      const ret = fn(...args);\n      if (ret instanceof Promise) {\n        return ret.catch(() => defaultValue);\n      }\n      return ret;\n    } catch {\n      return defaultValue;\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { spawn, type ChildProcess, type SpawnOptions } from \"child_process\";\nimport treeKill from \"tree-kill\";\nimport { logger } from \"./logging\";\n\nexport const PUP_ARGS_KEY = \"--pup-priv-args\";\n\nexport function pargs() {\n  const argv = process.argv;\n  let priv = argv.find((arg) => arg.startsWith(PUP_ARGS_KEY));\n  if (!priv) {\n    logger.debug(\"procargv\", argv);\n    return process.argv;\n  }\n  const args = [\"exec\", ...argv.slice(-1)];\n  priv = Buffer.from(priv.split(\"=\")[1]!, \"base64\").toString();\n  args.push(...JSON.parse(priv));\n  logger.debug(\"pupargs\", args);\n  return args;\n}\n\nexport interface ProcessHandle {\n  process: ChildProcess;\n  wait: Promise<void>;\n  kill(): void;\n}\n\nexport function exec(cmd: string, options?: SpawnOptions): ProcessHandle {\n  const parts = cmd.split(\" \").filter((s) => s.length);\n  const [command, ...args] = parts;\n  if (!command) throw new Error(\"empty command\");\n  const proc = spawn(command, args, {\n    stdio: \"inherit\",\n    ...options,\n  });\n  return {\n    process: proc,\n    wait: logger.attach(proc, command),\n    kill() {\n      const pid = proc.pid;\n      if (pid) treeKill(pid);\n      else proc.kill();\n    },\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport z from \"zod\";\nimport {\n  pupDeterministic,\n  pupDisableGPU,\n  pupDisableHwCodec,\n  pupUseInnerProxy,\n  pupWindowTolerant,\n} from \"../base/constants\";\n\nexport const DEFAULT_WIDTH = 1920;\nexport const DEFAULT_HEIGHT = 1080;\nexport const DEFAULT_FPS = 30;\nexport const DEFAULT_DURATION = 5;\nexport const DEFAULT_OUT_FILE = \"output.mp4\";\n\nexport const RenderSchema = z.object({\n  duration: z.number().describe(\"Duration in seconds\"),\n  width: z.number().describe(\"Video width\"),\n  height: z.number().describe(\"Video height\"),\n  fps: z.number().describe(\"Frames per second\"),\n  withAudio: z.boolean().describe(\"Capture and encode audio\"),\n  outFile: z.string().describe(\"Output mp4 file path\"),\n  useInnerProxy: z.boolean().describe(\"Use bilibili inner proxy for resource access\"),\n  deterministic: z.boolean().describe(\"Render by frame rather than recording\"),\n  disableGpu: z.boolean().describe(\"Disable GPU rendering, may reduce performance but increase stability\"),\n  disableHwCodec: z.boolean().describe(\"Disable hardware video encoder (NVENC/VideoToolbox), use software x265\"),\n  windowTolerant: z.boolean().describe(\"Fall back to dom-ready if warmup load times out\"),\n});\n\nexport type RenderOptions = z.infer<typeof RenderSchema>;\n\nexport interface RenderResult {\n  options: RenderOptions;\n  written: number;\n  jank: number;\n  outFile: string;\n}\n\nexport const defaultRenderOptions: RenderOptions = {\n  width: DEFAULT_WIDTH,\n  height: DEFAULT_HEIGHT,\n  fps: DEFAULT_FPS,\n  duration: DEFAULT_DURATION,\n  outFile: DEFAULT_OUT_FILE,\n  withAudio: false,\n  useInnerProxy: pupUseInnerProxy,\n  deterministic: pupDeterministic,\n  disableGpu: pupDisableGPU,\n  disableHwCodec: pupDisableHwCodec,\n  windowTolerant: pupWindowTolerant,\n};\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { program } from \"commander\";\nimport { logger } from \"./base/logging\";\nimport { noerr } from \"./base/noerr\";\nimport { parseNumber } from \"./base/parser\";\nimport { pargs } from \"./base/process\";\nimport { RenderSchema, type RenderOptions } from \"./renderer/schema\";\n\nexport interface CLIOptions {\n  name: string;\n  defaults: RenderOptions;\n  run: (source: string, options: RenderOptions) => Promise<unknown>;\n}\n\nexport async function makeCLI(options: CLIOptions) {\n  const shape = RenderSchema.shape;\n  const d = options.defaults;\n  program\n    .name(options.name)\n    .argument(\"<source>\", \"file://, http(s)://, or data: URI\")\n    .option(\"-W, --width <number>\", shape.width.description, `${d.width}`)\n    .option(\"-H, --height <number>\", shape.height.description, `${d.height}`)\n    .option(\"-f, --fps <number>\", shape.fps.description, `${d.fps}`)\n    .option(\"-t, --duration <number>\", shape.duration.description, `${d.duration}`)\n    .option(\"-o, --out-file <path>\", shape.outFile.description, d.outFile)\n    .option(\"-a, --with-audio\", shape.withAudio.description, d.withAudio)\n    .option(\"-d, --deterministic\", shape.deterministic.description, d.deterministic)\n    .option(\"--use-inner-proxy\", shape.useInnerProxy.description, d.useInnerProxy)\n    .option(\"--disable-gpu\", shape.disableGpu.description, d.disableGpu)\n    .option(\"--disable-hw-codec\", shape.disableHwCodec.description, d.disableHwCodec)\n    .option(\"--window-tolerant\", shape.windowTolerant.description, d.windowTolerant)\n    .action(async (source: string, opts) => {\n      try {\n        await options.run(source, {\n          width: noerr(parseNumber, d.width)(opts.width),\n          height: noerr(parseNumber, d.height)(opts.height),\n          fps: noerr(parseNumber, d.fps)(opts.fps),\n          duration: noerr(parseNumber, d.duration)(opts.duration),\n          outFile: opts.outFile ?? d.outFile,\n          withAudio: opts.withAudio ?? d.withAudio,\n          useInnerProxy: opts.useInnerProxy ?? d.useInnerProxy,\n          deterministic: opts.deterministic ?? d.deterministic,\n          disableGpu: opts.disableGpu ?? d.disableGpu,\n          disableHwCodec: opts.disableHwCodec ?? d.disableHwCodec,\n          windowTolerant: opts.windowTolerant ?? d.windowTolerant,\n        });\n      } catch (e) {\n        logger.fatal(e);\n      }\n    });\n  await program.parseAsync(pargs());\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { EventEmitter } from \"events\";\nimport { createConnection, createServer, type Socket } from \"net\";\n\nconst HEADER_SIZE = 8;\n\nexport const enum IpcMsgType {\n  PROGRESS = 1,\n  DONE = 2,\n  ERROR = 3,\n}\n\nexport interface IpcDonePayload {\n  written: number;\n  jank: number;\n  outFile: string;\n}\n\nexport class IpcWriter {\n  constructor(private readonly _socket: Socket) {}\n\n  writeProgress(value: number): void {\n    this.write(IpcMsgType.PROGRESS, Buffer.from(`${value}`));\n  }\n\n  writeError(error: string) {\n    this.write(IpcMsgType.ERROR, Buffer.from(error));\n    this._socket.end();\n  }\n\n  writeDone(payload: IpcDonePayload): void {\n    this.write(IpcMsgType.DONE, Buffer.from(JSON.stringify(payload)));\n    this._socket.end();\n  }\n\n  private write(type: IpcMsgType, payload: Buffer): void {\n    const header = Buffer.alloc(HEADER_SIZE);\n    header.writeUInt32LE(type, 0);\n    header.writeUInt32LE(payload.byteLength, 4);\n    this._socket.write(header);\n    this._socket.write(payload);\n  }\n}\n\nexport function connectIpc(socketPath: string): Promise<IpcWriter> {\n  return new Promise((resolve, reject) => {\n    const socket = createConnection(socketPath);\n    socket.once(\"connect\", () => resolve(new IpcWriter(socket)));\n    socket.once(\"error\", reject);\n  });\n}\n\nexport class IpcReader extends EventEmitter<{\n  progress: [value: number];\n  message: [type: IpcMsgType, buffer: Buffer];\n  done: [payload: IpcDonePayload];\n  error: [error: Error];\n  close: [];\n}> {\n  private _chunks: Buffer[] = [];\n  private _buffered = 0;\n\n  constructor(private readonly _socket: Socket) {\n    super();\n    this._socket.on(\"data\", (data) => this.onData(data));\n    this._socket.on(\"error\", (err) => this.emit(\"error\", err));\n    this._socket.on(\"close\", () => this.emit(\"close\"));\n  }\n\n  private onData(data: Buffer): void {\n    this._chunks.push(data);\n    this._buffered += data.byteLength;\n    this.flush();\n  }\n\n  private flush(): void {\n    for (;;) {\n      if (this._buffered < HEADER_SIZE) return;\n      const header = this.peek(HEADER_SIZE);\n      const type = header.readUInt32LE(0) as IpcMsgType;\n      const len = header.readUInt32LE(4);\n      if (this._buffered < HEADER_SIZE + len) return;\n      this.consume(HEADER_SIZE);\n      const payload = this.consume(len);\n      this.emit(\"message\", type, payload);\n      switch (type) {\n        case IpcMsgType.PROGRESS: {\n          this.emit(\"progress\", Number(payload.toString()));\n          break;\n        }\n        case IpcMsgType.DONE: {\n          this.emit(\"done\", JSON.parse(payload.toString()));\n          break;\n        }\n        case IpcMsgType.ERROR: {\n          this.emit(\"error\", new Error(payload.toString()));\n          break;\n        }\n      }\n    }\n  }\n\n  private peek(n: number): Buffer {\n    if (this._chunks[0] && this._chunks[0].byteLength >= n) return this._chunks[0];\n    return Buffer.concat(this._chunks).subarray(0, n);\n  }\n\n  private consume(n: number): Buffer {\n    const out = Buffer.allocUnsafe(n);\n    let offset = 0;\n    while (offset < n) {\n      const chunk = this._chunks[0]!;\n      const take = Math.min(chunk.byteLength, n - offset);\n      chunk.copy(out, offset, 0, take);\n      if (take === chunk.byteLength) {\n        this._chunks.shift();\n      } else {\n        this._chunks[0] = chunk.subarray(take);\n      }\n      offset += take;\n    }\n    this._buffered -= n;\n    return out;\n  }\n}\n\nexport interface IpcServer {\n  waitForConnection(): Promise<IpcReader>;\n  close(): void;\n}\n\nexport function createIpcServer(socketPath: string): Promise<IpcServer> {\n  return new Promise((resolve, reject) => {\n    const server = createServer();\n    server.once(\"error\", reject);\n    server.listen(socketPath, () => {\n      resolve({\n        waitForConnection() {\n          return new Promise<IpcReader>((ok, no) => {\n            server.once(\"connection\", (socket) => ok(new IpcReader(socket)));\n            server.once(\"error\", no);\n          });\n        },\n        close() {\n          server.close();\n        },\n      });\n    });\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport type { Debugger, Size } from \"electron\";\n\nexport const FRAME_SYNC_MARKER_WIDTH = 32;\nexport const FRAME_SYNC_MARKER_HEIGHT = 1;\nexport const STEGO_TICK_CHANNEL = \"stego-tick\";\n\nexport function buildStegoHTML(targetURL: string, size: Size): string {\n  const { width, height } = size;\n  return `<!DOCTYPE html>\n<html>\n<head>\n  <meta charset=\"UTF-8\">\n  <style>\n    * { margin: 0; padding: 0; box-sizing: border-box; }\n    html, body { width: ${width}px; height: ${height + 1}px; overflow: hidden; }\n    #target { \n      position: absolute; \n      top: 0; \n      left: 0; \n      width: ${width}px; \n      height: ${height}px; \n      border: none; \n      display: block;\n    }\n    #stego { \n      position: absolute; \n      top: ${height}px; \n      left: 0; \n      width: ${width}px; \n      height: 1px; \n      display: block;\n      image-rendering: pixelated;\n    }\n  </style>\n</head>\n<body>\n  <iframe id=\"target\" src=\"${targetURL}\"></iframe>\n  <canvas id=\"stego\" width=\"${width}\" height=\"1\"></canvas>\n  <script>\n    (function() {\n      const { ipcRenderer } = require('electron');\n      const WIDTH = ${width};\n      const MARKER_WIDTH = ${FRAME_SYNC_MARKER_WIDTH};\n      const canvas = document.getElementById('stego');\n      const ctx = canvas.getContext('2d', { willReadFrequently: true });\n      let startTime = null;\n      let rafId = null;\n\n      function encodeTimestamp(timestampMs) {\n        const imageData = ctx.createImageData(WIDTH, 1);\n        const data = imageData.data;\n        \n        const timestampInt = Math.floor(timestampMs) >>> 0;\n        \n        for (let i = 0; i < MARKER_WIDTH; i++) {\n          const bit = (timestampInt >>> (MARKER_WIDTH - 1 - i)) & 1;\n          const value = bit ? 255 : 0;\n          const idx = i * 4;\n          data[idx] = value;\n          data[idx + 1] = value;\n          data[idx + 2] = value;\n          data[idx + 3] = 255;\n        }\n        \n        for (let i = MARKER_WIDTH; i < WIDTH; i++) {\n          const idx = i * 4;\n          data[idx] = 0;\n          data[idx + 1] = 0;\n          data[idx + 2] = 0;\n          data[idx + 3] = 255;\n        }\n        \n        ctx.putImageData(imageData, 0, 0);\n        ipcRenderer.send(\"${STEGO_TICK_CHANNEL}\", timestampMs);\n      }\n\n      function updateLoop() {\n        if (startTime === null) return;\n        const elapsed = performance.now() - startTime;\n        encodeTimestamp(elapsed);\n        rafId = requestAnimationFrame(updateLoop);\n      }\n\n      window.__pup_start_stego__ = () => {\n        startTime = performance.now();\n        encodeTimestamp(0);\n        requestAnimationFrame(updateLoop);\n      };\n\n      window.__pup_tick_stego__ = (ms) => {\n        requestAnimationFrame(() => encodeTimestamp(ms));\n      };\n\n      window.__pup_stop_stego__ = () => {\n        if (rafId !== null) {\n          cancelAnimationFrame(rafId);\n          rafId = null;\n        }\n      };\n    })();\n  </script>\n</body>\n</html>`;\n}\n\nexport function decodeStego(bitmap: Buffer, size: Size): number | undefined {\n  const { width, height } = size;\n  if (width < FRAME_SYNC_MARKER_WIDTH || height < 2) {\n    return undefined;\n  }\n\n  const markerRow = height - 1;\n\n  let timestamp = 0;\n  for (let i = 0; i < FRAME_SYNC_MARKER_WIDTH; i++) {\n    const pixelIdx = (markerRow * width + i) * 4;\n    const r = bitmap[pixelIdx] ?? 0;\n    const bit = r > 127 ? 1 : 0;\n    timestamp = (timestamp << 1) | bit;\n  }\n\n  timestamp = timestamp >>> 0;\n\n  if (!Number.isFinite(timestamp) || timestamp < 0 || timestamp > 1e7) {\n    return undefined;\n  }\n\n  return timestamp;\n}\n\nexport function startStego(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_start_stego__()`,\n  });\n}\n\nexport function tickStego(cdp: Debugger, ms: number) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_tick_stego__(${ms})`,\n  });\n}\n\nexport function stopStego(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_stop_stego__()`,\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport type { Size } from \"electron\";\nimport { protocol } from \"electron\";\nimport { buildStegoHTML } from \"./stego\";\n\nconst PUP_SCHEME = \"pup\";\n\n// Must be called synchronously before app is ready.\nprotocol.registerSchemesAsPrivileged([\n  {\n    scheme: PUP_SCHEME,\n    privileges: {\n      standard: true,\n      secure: true,\n      bypassCSP: true,\n      allowServiceWorkers: true,\n      supportFetchAPI: true,\n      corsEnabled: true,\n      stream: true,\n      codeCache: true,\n    },\n  },\n]);\n\n// Must be called after app is ready.\nexport function setupPupProtocol(): void {\n  protocol.handle(PUP_SCHEME, (req) => {\n    const url = new URL(req.url);\n    const src = url.searchParams.get(\"src\") ?? \"\";\n    const width = parseInt(url.searchParams.get(\"w\") ?? \"0\", 10);\n    const height = parseInt(url.searchParams.get(\"h\") ?? \"0\", 10);\n    const html = buildStegoHTML(src, { width, height });\n    return new Response(html, { headers: { \"content-type\": \"text/html\" } });\n  });\n}\n\nexport function createStegoURL(src: string, size: Size): string {\n  const url = new URL(`${PUP_SCHEME}://stego`);\n  url.searchParams.set(\"src\", src);\n  url.searchParams.set(\"w\", String(size.width));\n  url.searchParams.set(\"h\", String(size.height));\n  return url.toString();\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\ninterface QueueEntry {\n  run: VoidFunction;\n  reject: (reason: unknown) => void;\n  signal?: AbortSignal;\n}\n\nexport class ConcurrencyLimiter {\n  private _active = 0;\n  private _queue: QueueEntry[] = [];\n  private _signals = new WeakSet<AbortSignal>();\n  private _resolve?: VoidFunction;\n\n  constructor(readonly maxConcurrency: number) {}\n\n  get active(): number {\n    return this._active;\n  }\n\n  get pending(): number {\n    return this._queue.length;\n  }\n\n  get stats(): string {\n    return `active: ${this.active}, pending: ${this.pending}`;\n  }\n\n  async schedule<T>(fn: () => Promise<T>, signal?: AbortSignal): Promise<T> {\n    signal?.throwIfAborted();\n\n    if (signal && !this._signals.has(signal)) {\n      this._signals.add(signal);\n      signal.addEventListener(\"abort\", () => this.flush(signal), { once: true });\n    }\n\n    return new Promise<T>((resolve, reject) => {\n      this._queue.push({\n        run: () => {\n          if (signal?.aborted) {\n            reject(signal.reason);\n            this.next();\n            return;\n          }\n          this._active++;\n          fn()\n            .then((v) => {\n              this._active--;\n              resolve(v);\n              this.next();\n            })\n            .catch((e) => {\n              this._active--;\n              reject(e);\n              this.next();\n            });\n        },\n        reject,\n        signal,\n      });\n      this.next();\n    });\n  }\n\n  async drain(): Promise<void> {\n    if (this._active === 0 && this.pending === 0) return;\n    return new Promise((r) => (this._resolve = r));\n  }\n\n  private flush(signal: AbortSignal) {\n    const keep: QueueEntry[] = [];\n    for (const entry of this._queue) {\n      if (entry.signal === signal) {\n        entry.reject(signal.reason);\n      } else {\n        keep.push(entry);\n      }\n    }\n    this._queue = keep;\n    this.next();\n  }\n\n  private next() {\n    if (this._active === 0 && this.pending === 0) {\n      this._resolve?.();\n      this._resolve = undefined;\n      return;\n    }\n    if (this._active < this.maxConcurrency) {\n      this._queue.shift()?.run();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { Codec, CodecContext, FFmpegError, Frame, Packet, Rational, type Stream } from \"node-av\";\nimport {\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  type AVColorRange,\n  type AVPixelFormat,\n} from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface VideoCtxOptions {\n  codec: Codec;\n  width: number;\n  height: number;\n  fps: number;\n  bitrate: number;\n  pixelFormat: AVPixelFormat;\n  codecTag?: string;\n  colorRange?: AVColorRange;\n  options?: Record<string, string>;\n}\n\nexport async function openVideoCtx(opts: VideoCtxOptions, label: string): Promise<CodecContext> {\n  const ctx = new CodecContext();\n  ctx.allocContext3(opts.codec);\n  ctx.codecId = opts.codec.id;\n  ctx.width = opts.width;\n  ctx.height = opts.height;\n  ctx.pixelFormat = opts.pixelFormat;\n  ctx.timeBase = new Rational(1, opts.fps);\n  ctx.framerate = new Rational(opts.fps, 1);\n  ctx.gopSize = opts.fps * 2;\n  ctx.bitRate = BigInt(opts.bitrate);\n  ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n  if (opts.codecTag) ctx.codecTag = opts.codecTag;\n  if (opts.colorRange !== undefined) ctx.colorRange = opts.colorRange;\n  for (const [k, v] of Object.entries(opts.options ?? {})) ctx.setOption(k, v);\n  FFmpegError.throwIfError(await ctx.open2(opts.codec, null), label);\n  return ctx;\n}\n\nexport function makeFrame(width: number, height: number, pixFmt: AVPixelFormat): Frame {\n  const frame = new Frame();\n  frame.alloc();\n  frame.format = pixFmt;\n  frame.width = width;\n  frame.height = height;\n  FFmpegError.throwIfError(frame.getBuffer(0), \"frame.getBuffer\");\n  return frame;\n}\n\nexport function makePacket(): Packet {\n  const pkt = new Packet();\n  pkt.alloc();\n  return pkt;\n}\n\nexport async function drainPackets(ctx: CodecContext, pkt: Packet, stream: Stream, muxer: FormatMuxer): Promise<void> {\n  while (true) {\n    const r = await ctx.receivePacket(pkt);\n    if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n    FFmpegError.throwIfError(r, \"receivePacket\");\n    pkt.streamIndex = stream.index;\n    if (pkt.duration === 0n) pkt.duration = 1n;\n    pkt.rescaleTs(ctx.timeBase, stream.timeBase);\n    await muxer.writePacket(pkt);\n    pkt.unref();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport {\n  Codec,\n  CodecContext,\n  FFmpegError,\n  Filter,\n  FilterContext,\n  FilterGraph,\n  FilterInOut,\n  Frame,\n  type Packet,\n  Rational,\n  type Stream,\n} from \"node-av\";\nimport {\n  AV_CHANNEL_LAYOUT_STEREO,\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AV_SAMPLE_FMT_FLT,\n  AV_SAMPLE_FMT_FLTP,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  type FFAudioEncoder,\n} from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { drainPackets, makePacket } from \"./misc\";\n\nconst SAMPLE_FMT_NAME: Partial<Record<number, string>> = { [AV_SAMPLE_FMT_FLT]: \"flt\", [AV_SAMPLE_FMT_FLTP]: \"fltp\" };\n\nexport interface AudioEncoderOptions {\n  outSampleRate: number;\n  outSampleFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  codecName: FFAudioEncoder;\n  globalHeader: boolean;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class AudioEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _stream: Stream;\n  private _pkt: Packet;\n  private _outRate: number;\n  private _outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  private _frameSize: number;\n  private _filterFrame: Frame;\n  private _graph?: FilterGraph;\n  private _bufSrc?: FilterContext;\n  private _bufSink?: FilterContext;\n  private _inRate?: number;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, stream: Stream, outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP) {\n    this._ctx = ctx;\n    this._stream = stream;\n    this._outRate = ctx.sampleRate;\n    this._outFmt = outFmt;\n    this._frameSize = ctx.frameSize;\n    this._pkt = makePacket();\n    this._filterFrame = new Frame();\n    this._filterFrame.alloc();\n  }\n\n  static async create(opts: AudioEncoderOptions): Promise<AudioEncoder> {\n    const codec = Codec.findEncoderByName(opts.codecName);\n    if (!codec) throw new Error(`Audio encoder not found: ${opts.codecName}`);\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.sampleFormat = opts.outSampleFmt;\n    ctx.sampleRate = opts.outSampleRate;\n    ctx.channelLayout = AV_CHANNEL_LAYOUT_STEREO;\n    ctx.timeBase = new Rational(1, opts.outSampleRate);\n    ctx.bitRate = BigInt(opts.bitrate);\n    if (opts.globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"audioCtx.open2\");\n    const stream = opts.muxer.addStream(ctx);\n    return new AudioEncoder(ctx, stream, opts.outSampleFmt);\n  }\n\n  setInputRate(inSampleRate: number): void {\n    this._graph?.[Symbol.dispose]();\n    this._inRate = inSampleRate;\n    const graph = new FilterGraph();\n    graph.alloc();\n    const abuffer = Filter.getByName(\"abuffer\")!;\n    const bufSrc = graph.createFilter(\n      abuffer,\n      \"src\",\n      `sample_rate=${inSampleRate}:sample_fmt=flt:channel_layout=stereo:time_base=1/${inSampleRate}`,\n    );\n    if (!bufSrc) throw new Error(\"Failed to create abuffer\");\n    const abuffersink = Filter.getByName(\"abuffersink\")!;\n    const bufSink = graph.createFilter(abuffersink, \"sink\");\n    if (!bufSink) throw new Error(\"Failed to create abuffersink\");\n    const fmtName = SAMPLE_FMT_NAME[this._outFmt] ?? \"flt\";\n    const filterDesc = `aformat=sample_fmts=${fmtName}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`;\n    const outputs = FilterInOut.createList([{ name: \"in\", filterCtx: bufSrc, padIdx: 0 }]);\n    const inputs = FilterInOut.createList([{ name: \"out\", filterCtx: bufSink, padIdx: 0 }]);\n    FFmpegError.throwIfError(graph.parsePtr(filterDesc, inputs, outputs), \"graph.parsePtr\");\n    FFmpegError.throwIfError(graph.configSync(), \"graph.config\");\n    this._graph = graph;\n    this._bufSrc = bufSrc;\n    this._bufSink = bufSink;\n  }\n\n  async encode(pcm: Buffer, muxer: FormatMuxer): Promise<void> {\n    if (!this._bufSrc || !this._inRate) return;\n    const src = new Float32Array(pcm.buffer, pcm.byteOffset, pcm.byteLength / 4);\n    for (let i = 0; i < src.length; i++) if (!isFinite(src[i]!)) src[i] = 0;\n    const nSamples = src.length >> 1;\n    using frame = Frame.fromAudioBuffer(Buffer.from(src.buffer, src.byteOffset, src.byteLength), {\n      nbSamples: nSamples,\n      format: AV_SAMPLE_FMT_FLT,\n      sampleRate: this._inRate,\n      channelLayout: AV_CHANNEL_LAYOUT_STEREO,\n      pts: this._pts,\n      timeBase: { num: 1, den: this._inRate },\n    });\n    this._pts += BigInt(nSamples);\n    FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(frame), \"buffersrcAddFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    if (this._bufSrc) {\n      await this._bufSrc.buffersrcAddFrame(null);\n      await this.drain(muxer);\n    }\n    await this._ctx.sendFrame(null);\n    await this.drainCodec(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._filterFrame.free();\n    this._graph?.[Symbol.dispose]();\n    this._ctx.freeContext();\n  }\n\n  private async drain(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._bufSink!.buffersinkGetFrame(this._filterFrame);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"buffersinkGetFrame\");\n      FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame), \"audioCtx.sendFrame\");\n      this._filterFrame.unref();\n      await this.drainCodec(muxer);\n    }\n  }\n\n  private drainCodec(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/03.\n\nimport { ok } from \"assert\";\nimport {\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_YUVA420P,\n  Codec,\n  CodecContext,\n  FF_DECODER_PNG,\n  FFmpegError,\n  type Frame,\n  Packet,\n  SoftwareScaleContext,\n  SWS_BILINEAR,\n  type AVPixelFormat,\n} from \"node-av\";\nimport { makeFrame, makePacket } from \"./misc\";\n\nexport class CodecState implements Disposable {\n  readonly src: Frame;\n  readonly dst: Frame;\n  readonly pkt: Packet;\n  private _sws?: SoftwareScaleContext;\n  private _png?: Codec;\n\n  static async create(width: number, height: number) {\n    const codec = Codec.findDecoderByName(FF_DECODER_PNG);\n    ok(codec, \"png decoder unavailable\");\n    return new CodecState(width, height, codec);\n  }\n\n  private constructor(width: number, height: number, png: Codec) {\n    this._png = png;\n    this.src = makeFrame(width, height, AV_PIX_FMT_BGRA);\n    this.dst = makeFrame(width, height, AV_PIX_FMT_YUVA420P);\n    this.pkt = makePacket();\n  }\n\n  /**\n   * Create a fresh PNG decoder context.\n   * The FFmpeg PNG decoder accumulates APNG blending state\n   * across frames, so a shared instance corrupts output when decoding standalone PNGs.\n   */\n  async png(): Promise<CodecContext> {\n    const png = new CodecContext();\n    png.allocContext3(this._png);\n    FFmpegError.throwIfError(await png.open2(this._png), \"pngDecoder.open2\");\n    return png;\n  }\n\n  async decodePNG(pngData: Buffer): Promise<Frame> {\n    using png = await this.png();\n    this.pkt.data = pngData;\n    FFmpegError.throwIfError(await png.sendPacket(this.pkt), \"pngDecoder.sendPacket\");\n    this.pkt.unref();\n    FFmpegError.throwIfError(await png.receiveFrame(this.src), \"pngDecoder.receiveFrame\");\n    return this.src;\n  }\n\n  get sws() {\n    if (!this._sws) {\n      const sws = new SoftwareScaleContext();\n      const fmt = this.src.format as AVPixelFormat;\n      sws.getContext(\n        this.src.width,\n        this.src.height,\n        fmt,\n        this.src.width,\n        this.src.height,\n        AV_PIX_FMT_YUVA420P,\n        SWS_BILINEAR,\n      );\n      this._sws = sws;\n    }\n    return this._sws;\n  }\n\n  [Symbol.dispose](): void {\n    this.src[Symbol.dispose]();\n    this.dst[Symbol.dispose]();\n    this.pkt[Symbol.dispose]();\n    this._sws?.[Symbol.dispose]();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/13.\n\nexport function packBits(bits: number[]): Buffer {\n  const buf = Buffer.alloc(bits.length >> 3);\n  for (let i = 0; i < buf.length; i++) {\n    let byte = 0;\n    for (let b = 0; b < 8; b++) byte = (byte << 1) | bits[i * 8 + b]!;\n    buf[i] = byte;\n  }\n  return buf;\n}\n\nexport class BitWriter {\n  bits: number[] = [];\n  w(val: number, n: number) {\n    for (let i = n - 1; i >= 0; i--) this.bits.push((val >> i) & 1);\n  }\n  flag(val: boolean | number) {\n    this.bits.push(val ? 1 : 0);\n  }\n  ue(val: number) {\n    const v = val + 1;\n    const len = 32 - Math.clz32(v);\n    for (let i = 0; i < len - 1; i++) this.bits.push(0);\n    for (let i = len - 1; i >= 0; i--) this.bits.push((v >> i) & 1);\n  }\n  align(pad: number) {\n    while (this.bits.length % 8 !== 0) this.bits.push(pad);\n  }\n  copy(src: number[], start: number, len: number) {\n    for (let i = 0; i < len; i++) this.bits.push(src[start + i]!);\n  }\n}\n\nexport class BitReader {\n  private _bits: number[];\n  pos = 0;\n  constructor(data: Buffer) {\n    this._bits = [];\n    for (let i = 0; i < data.length; i++) {\n      for (let b = 7; b >= 0; b--) this._bits.push((data[i]! >> b) & 1);\n    }\n  }\n  get bits() {\n    return this._bits;\n  }\n  read(n: number): number {\n    let val = 0;\n    for (let i = 0; i < n; i++) val = (val << 1) | this._bits[this.pos++]!;\n    return val;\n  }\n  readUe(): number {\n    let zeros = 0;\n    while (this._bits[this.pos] === 0) {\n      zeros++;\n      this.pos++;\n    }\n    this.pos++;\n    let val = 1;\n    for (let i = 0; i < zeros; i++) val = (val << 1) | this._bits[this.pos++]!;\n    return val - 1;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nconst NAL_HEADER_SIZE = 2;\nconst ANNEX_B_START_CODE = Buffer.from([0x00, 0x00, 0x00, 0x01]);\n\nexport { ANNEX_B_START_CODE, NAL_HEADER_SIZE };\n\nexport interface NalUnit {\n  type: number;\n  layerId: number;\n  data: Buffer;\n}\n\nfunction parseNalType(header0: number, header1: number): { type: number; layerId: number; temporalId: number } {\n  const type = (header0 >> 1) & 0x3f;\n  const layerId = ((header0 & 1) << 5) | ((header1 >> 3) & 0x1f);\n  const temporalId = header1 & 0x07;\n  return { type, layerId, temporalId };\n}\n\nexport function encodeNalHeader(type: number, layerId: number, temporalId: number): [number, number] {\n  const byte0 = ((type & 0x3f) << 1) | ((layerId >> 5) & 1);\n  const byte1 = ((layerId & 0x1f) << 3) | (temporalId & 0x07);\n  return [byte0, byte1];\n}\n\n/** Split Annex B bitstream into NAL units. */\nexport function splitNalUnits(bitstream: Buffer): NalUnit[] {\n  const nals: NalUnit[] = [];\n  let i = 0;\n\n  while (i < bitstream.length) {\n    let scLen = 0;\n    if (i + 3 < bitstream.length && bitstream[i] === 0 && bitstream[i + 1] === 0 && bitstream[i + 2] === 1) {\n      scLen = 3;\n    } else if (\n      i + 4 < bitstream.length &&\n      bitstream[i] === 0 &&\n      bitstream[i + 1] === 0 &&\n      bitstream[i + 2] === 0 &&\n      bitstream[i + 3] === 1\n    ) {\n      scLen = 4;\n    } else {\n      i++;\n      continue;\n    }\n\n    const nalStart = i + scLen;\n    if (nalStart + NAL_HEADER_SIZE > bitstream.length) break;\n\n    let nalEnd = bitstream.length;\n    for (let j = nalStart + NAL_HEADER_SIZE; j < bitstream.length - 2; j++) {\n      if (\n        bitstream[j] === 0 &&\n        bitstream[j + 1] === 0 &&\n        (bitstream[j + 2] === 1 || (j + 3 < bitstream.length && bitstream[j + 2] === 0 && bitstream[j + 3] === 1))\n      ) {\n        nalEnd = j;\n        break;\n      }\n    }\n\n    const { type, layerId } = parseNalType(bitstream[nalStart]!, bitstream[nalStart + 1]!);\n    nals.push({ type, layerId, data: bitstream.subarray(nalStart, nalEnd) });\n    i = nalEnd;\n  }\n\n  return nals;\n}\n\n/** Rewrite nuh_layer_id in a NAL unit (returns copy). */\nexport function rewriteNalLayerId(nal: Buffer, layerId: number): Buffer {\n  const out = Buffer.from(nal);\n  const { type, temporalId } = parseNalType(out[0]!, out[1]!);\n  const [b0, b1] = encodeNalHeader(type, layerId, temporalId);\n  out[0] = b0;\n  out[1] = b1;\n  return out;\n}\n\n/** Remove emulation prevention bytes (00 00 03 → 00 00) from RBSP. */\nexport function removeEmulationPrevention(data: Buffer): Buffer {\n  const out: number[] = [];\n  for (let i = 0; i < data.length; i++) {\n    if (i + 2 < data.length && data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 3) {\n      out.push(0, 0);\n      i += 2;\n    } else {\n      out.push(data[i]!);\n    }\n  }\n  return Buffer.from(out);\n}\n\n/** Insert emulation prevention bytes (00 00 03) for Annex B compliance. */\nexport function addEmulationPrevention(nal: Buffer): Buffer {\n  const out: number[] = [];\n  out.push(nal[0]!, nal[1]!);\n  let zeros = 0;\n  for (let i = 2; i < nal.length; i++) {\n    if (zeros === 2 && nal[i]! <= 3) {\n      out.push(3);\n      zeros = 0;\n    }\n    if (nal[i] === 0) zeros++;\n    else zeros = 0;\n    out.push(nal[i]!);\n  }\n  return Buffer.from(out);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/13.\n\nimport { BitReader, BitWriter, packBits } from \"./bit\";\nimport { addEmulationPrevention, removeEmulationPrevention } from \"./nal\";\n\ninterface ParsedPTL {\n  ptlStart: number;\n  ptlEnd: number;\n  ptlBits: number[];\n  maxSubLayersMinus1: number;\n}\n\nfunction extractPTL(vpsData: Buffer): ParsedPTL | undefined {\n  const br = new BitReader(removeEmulationPrevention(vpsData));\n  br.read(16); // NAL header\n  br.read(4); // vps_id\n  br.read(2); // base_layer_internal + available\n  if (br.read(6) > 0) return undefined; // already multi-layer\n  const maxSubLayersMinus1 = br.read(3);\n  br.read(1 + 16); // temporal_nesting + reserved\n\n  const ptlStart = br.pos;\n  br.read(96); // general PTL (profile_space + tier + idc + compat + constraints + level)\n  if (maxSubLayersMinus1 > 0) br.read(maxSubLayersMinus1 * 2 + (8 - maxSubLayersMinus1) * 2);\n  return { ptlStart, ptlEnd: br.pos, ptlBits: br.bits, maxSubLayersMinus1 };\n}\n\n/** Write base VPS fields for 2-layer alpha. */\nfunction writeBaseVPS(bw: BitWriter, ptl: ParsedPTL) {\n  bw.w(0x4001, 16); // NAL header\n  bw.w(0, 4); // vps_id\n  bw.flag(1); // base_layer_internal\n  bw.flag(1); // base_layer_available\n  bw.w(1, 6); // max_layers_minus1 = 1\n  bw.w(ptl.maxSubLayersMinus1, 3);\n  // temporal_nesting: true when single sub-layer (all refs layer 0)\n  bw.flag(ptl.maxSubLayersMinus1 === 0);\n  bw.w(0xffff, 16); // reserved\n  bw.copy(ptl.ptlBits, ptl.ptlStart, ptl.ptlEnd - ptl.ptlStart);\n\n  bw.flag(1); // sub_layer_ordering_info_present\n  for (let i = 0; i <= ptl.maxSubLayersMinus1; i++) {\n    bw.ue(4); // maxDecPicBuffering - 1\n    bw.ue(2); // numReorderPics\n    bw.ue(4); // maxLatencyIncrease + 1\n  }\n\n  bw.w(1, 6); // max_nuh_layer_id = 1\n  bw.ue(1); // num_layer_sets_minus1 = 1\n  bw.flag(1); // layer_id_included[1][0]\n  bw.flag(1); // layer_id_included[1][1]\n  bw.flag(0); // timing_info_present\n  bw.flag(1); // vps_extension_flag\n  bw.align(1); // extension alignment bits = 1\n}\n\n/** Write VPS extension matching x265 4.1 ENABLE_ALPHA. */\nfunction writeVPSExtension(bw: BitWriter, ptl: ParsedPTL, width: number, height: number) {\n  // Extension PTL: level_idc only (profilePresentFlag=0)\n  bw.copy(ptl.ptlBits, ptl.ptlEnd - 8, 8);\n  if (ptl.maxSubLayersMinus1 > 0) {\n    for (let i = 0; i < ptl.maxSubLayersMinus1; i++) bw.w(0, 2);\n    for (let i = ptl.maxSubLayersMinus1; i < 8; i++) bw.w(0, 2);\n  }\n\n  bw.flag(0); // splitting_flag\n  for (let i = 0; i < 16; i++) bw.flag(i === 2 || i === 3); // scalability: spatial + aux\n  bw.w(0, 3); // dimension_id_len[0] = 1\n  bw.w(0, 3); // dimension_id_len[1] = 1\n  bw.flag(1); // nuh_layer_id_present\n  bw.w(1, 6); // layer_id_in_nuh[1] = 1\n  bw.w(1, 1); // dimension_id[1][0] = 1\n  bw.w(1, 1); // dimension_id[1][1] = AUX_ALPHA\n  bw.w(0, 4); // view_id_len = 0\n\n  bw.flag(0); // direct_dependency_flag[1][0]\n  bw.ue(0); // num_add_layer_sets\n  bw.flag(0); // sub_layers_max_minus1_present\n  bw.flag(0); // max_tid_ref_present\n  bw.flag(0); // default_ref_layers_active\n\n  // FFmpeg loops from index 2 to nb_ptl-1, so nptl_m1=2 → 1 entry at index 2\n  bw.ue(2); // vps_num_profile_tier_level_minus1\n  bw.flag(1); // profile_present_flag[2]\n  bw.copy(ptl.ptlBits, ptl.ptlStart, ptl.ptlEnd - ptl.ptlStart);\n\n  bw.ue(0); // num_add_olss\n  bw.w(0, 2); // default_output_layer_idc\n  bw.w(1, 2); // ptl_idx[1][0] = 1 (ceil_log2(3) = 2 bits)\n  bw.w(2, 2); // ptl_idx[1][1] = 2\n\n  bw.ue(0); // vps_num_rep_formats_minus1\n  bw.w(width, 16);\n  bw.w(height, 16);\n  bw.flag(1); // chroma_and_bit_depth_vps_present\n  bw.w(1, 2); // chroma_format_idc = 4:2:0\n  bw.w(0, 4); // bit_depth_luma_minus8\n  bw.w(0, 4); // bit_depth_chroma_minus8\n  bw.flag(0); // conformance_window_vps_flag\n\n  bw.flag(1); // max_one_active_ref_layer\n  bw.flag(0); // poc_lsb_aligned\n  bw.flag(1); // poc_lsb_not_present\n\n  // DPB for OLS 1 (2 layers, 1 sub-layer)\n  bw.flag(0); // sub_layer_flag_info_present\n  bw.ue(0); // max_dec_pic_buffering (layer 0)\n  bw.ue(0); // max_dec_pic_buffering (layer 1)\n  bw.ue(0); // max_num_reorder_pics\n  bw.ue(0); // max_latency_increase\n\n  bw.ue(0); // direct_dep_type_len_minus2\n  bw.flag(0); // default_direct_dependency_flag\n  bw.ue(0); // non_vui_extension_length\n  bw.flag(0); // vps_vui_present\n  bw.flag(0); // vps_extension2_flag\n}\n\n/**\n * Build a complete alpha VPS from scratch, using the original NVENC VPS\n * only as a source for the PTL (profile/tier/level) bytes.\n * Matches x265 4.1 ENABLE_ALPHA VPS structure.\n */\nexport function buildAlphaVPS(vpsData: Buffer, width: number, height: number): Buffer {\n  const ptl = extractPTL(vpsData);\n  if (!ptl) return vpsData;\n\n  const bw = new BitWriter();\n  writeBaseVPS(bw, ptl);\n  writeVPSExtension(bw, ptl, width, height);\n\n  bw.bits.push(1); // RBSP stop bit\n  bw.align(0);\n  return addEmulationPrevention(packBits(bw.bits));\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { packBits } from \"./bit\";\nimport { ANNEX_B_START_CODE, encodeNalHeader, type NalUnit, rewriteNalLayerId, splitNalUnits } from \"./nal\";\nimport { buildAlphaVPS } from \"./vps\";\n\nconst NAL_UNIT_PREFIX_SEI = 39;\n\nexport interface UnifiedExtradataOptions {\n  baseExtradata: Buffer;\n  alphaExtradata: Buffer;\n  width: number;\n  height: number;\n}\n\nexport function buildUnifiedExtradata(opts: UnifiedExtradataOptions): Buffer {\n  const { baseExtradata, alphaExtradata } = opts;\n  const baseNals = splitNalUnits(baseExtradata);\n  const alphaNals = splitNalUnits(alphaExtradata);\n\n  const alphaByType = new Map<number, NalUnit[]>();\n  for (const nal of alphaNals) {\n    if (nal.type === 32) continue;\n    const arr = alphaByType.get(nal.type) ?? [];\n    arr.push(nal);\n    alphaByType.set(nal.type, arr);\n  }\n\n  const chunks: Buffer[] = [];\n  const emitted = new Set<number>();\n  for (const nal of baseNals) {\n    const data = nal.type === 32 ? buildAlphaVPS(nal.data, opts.width, opts.height) : nal.data;\n    chunks.push(ANNEX_B_START_CODE, data);\n    if (!emitted.has(nal.type)) {\n      emitted.add(nal.type);\n      for (const alphaNal of alphaByType.get(nal.type) ?? []) {\n        chunks.push(ANNEX_B_START_CODE, rewriteNalLayerId(alphaNal.data, 1));\n      }\n    }\n  }\n\n  chunks.push(buildAlphaChannelInfoSEI());\n  return Buffer.concat(chunks);\n}\n\nexport function buildAlphaChannelInfoSEI(): Buffer {\n  const payloadType = 165;\n  const payloadSize = 4;\n  const [h0, h1] = encodeNalHeader(NAL_UNIT_PREFIX_SEI, 0, 1);\n\n  const bits: number[] = [];\n  const writeBits = (val: number, n: number) => {\n    for (let i = n - 1; i >= 0; i--) bits.push((val >> i) & 1);\n  };\n\n  writeBits(0, 1); // alpha_channel_cancel_flag\n  writeBits(0, 3); // alpha_channel_use_idc\n  writeBits(0, 3); // alpha_channel_bit_depth_minus8\n  writeBits(0, 9); // alpha_transparent_value\n  writeBits(255, 9); // alpha_opaque_value\n  writeBits(0, 1); // alpha_channel_incr_flag\n  writeBits(0, 1); // alpha_channel_clip_flag\n  writeBits(1, 1); // byte alignment\n  while (bits.length % 8 !== 0) writeBits(0, 1);\n\n  return Buffer.concat([\n    ANNEX_B_START_CODE,\n    Buffer.from([h0, h1]),\n    Buffer.from([payloadType, payloadSize]),\n    packBits(bits),\n    Buffer.from([0x80]),\n  ]);\n}\n\nexport function interleaveAccessUnits(baseNals: NalUnit[], alphaNals: NalUnit[]): Buffer {\n  const chunks: Buffer[] = [];\n  for (const nal of baseNals) {\n    chunks.push(ANNEX_B_START_CODE, nal.data);\n  }\n  for (const nal of alphaNals) {\n    if (nal.type < 32) {\n      chunks.push(ANNEX_B_START_CODE, rewriteNalLayerId(nal.data, 1));\n    }\n  }\n  return Buffer.concat(chunks);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { Codec, type CodecContext, FFmpegError, Frame, type Packet, type Stream } from \"node-av\";\nimport { AV_PIX_FMT_BGRA, AV_PIX_FMT_YUV420P, FF_ENCODER_HEVC_NVENC } from \"node-av/constants\";\nimport { buildAlphaChannelInfoSEI, buildUnifiedExtradata, interleaveAccessUnits } from \"./alpha\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { splitNalUnits } from \"./nal\";\nimport { makePacket, openVideoCtx } from \"./misc\";\nimport type { HwVideoEncoderOptions } from \"./videotoolbox\";\n\ninterface NvencState {\n  baseCtx: CodecContext;\n  alphaCtx: CodecContext;\n  basePkt: Packet;\n  alphaPkt: Packet;\n  stream: Stream;\n}\n\nexport class NvencDualLayerEncoder implements Disposable {\n  private _s: NvencState;\n  private _seiBuffer: Buffer;\n  private _pts = 0n;\n  private _seiInjected = false;\n  private _alphaBuf?: Buffer;\n  private _alphaFrame?: Frame;\n\n  private constructor(s: NvencState) {\n    this._s = s;\n    this._seiBuffer = buildAlphaChannelInfoSEI();\n  }\n\n  static async create(opts: HwVideoEncoderOptions): Promise<NvencDualLayerEncoder> {\n    const { width, height, fps, bitrate, muxer } = opts;\n\n    const codec = Codec.findEncoderByName(FF_ENCODER_HEVC_NVENC);\n    if (!codec) throw new Error(\"hevc_nvenc encoder not found\");\n\n    const nvencOpts = { preset: \"p4\", bf: \"0\" };\n    const common = { codec, width, height, fps, bitrate, options: nvencOpts };\n    // BGRA direct — NVENC converts internally, no SWS needed\n    const baseCtx = await openVideoCtx({ ...common, pixelFormat: AV_PIX_FMT_BGRA }, \"nvenc.base.open2\");\n    // Alpha as YUV420P — matching bitrate/GOP for compatible SPS across layers\n    const alphaCtx = await openVideoCtx({ ...common, pixelFormat: AV_PIX_FMT_YUV420P }, \"nvenc.alpha.open2\");\n\n    const basePkt = makePacket();\n    const alphaPkt = makePacket();\n\n    const stream = muxer.addStream(baseCtx, \"hvc1\");\n\n    const baseExtra = baseCtx.extraData;\n    const alphaExtra = alphaCtx.extraData;\n    if (baseExtra && alphaExtra) {\n      stream.codecpar.extradata = buildUnifiedExtradata({\n        baseExtradata: baseExtra,\n        alphaExtradata: alphaExtra,\n        width,\n        height,\n      });\n    }\n\n    return new NvencDualLayerEncoder({ baseCtx, alphaCtx, basePkt, alphaPkt, stream });\n  }\n\n  async encode(bgraFrame: Frame, muxer: FormatMuxer): Promise<void> {\n    const { baseCtx, alphaCtx } = this._s;\n    const pts = this._pts++;\n\n    bgraFrame.pts = pts;\n    bgraFrame.duration = 1n;\n    FFmpegError.throwIfError(await baseCtx.sendFrame(bgraFrame), \"base.sendFrame\");\n\n    // Alpha: extract alpha channel → YUV420P\n    const src = bgraFrame.data?.[0];\n    const srcLs = bgraFrame.linesize?.[0];\n    if (!src || !srcLs) throw new Error(\"encode: missing BGRA data\");\n    const w = bgraFrame.width;\n    const h = bgraFrame.height;\n    const ySize = w * h;\n    const uvSize = (w >> 1) * (h >> 1);\n    if (!this._alphaBuf) this._alphaBuf = Buffer.alloc(ySize + uvSize * 2);\n    const buf = this._alphaBuf;\n    for (let y = 0; y < h; y++) {\n      for (let x = 0; x < w; x++) {\n        buf[y * w + x] = src[y * srcLs + x * 4 + 3]!;\n      }\n    }\n    buf.fill(128, ySize, ySize + uvSize * 2);\n\n    this._alphaFrame?.free();\n    this._alphaFrame = Frame.fromVideoBuffer(buf, { format: AV_PIX_FMT_YUV420P, width: w, height: h });\n    this._alphaFrame.pts = pts;\n    this._alphaFrame.duration = 1n;\n    FFmpegError.throwIfError(await alphaCtx.sendFrame(this._alphaFrame), \"alpha.sendFrame\");\n\n    await this.drainInterleaved(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._s.baseCtx.sendFrame(null);\n    await this._s.alphaCtx.sendFrame(null);\n    await this.drainInterleaved(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    const { basePkt, alphaPkt, baseCtx, alphaCtx } = this._s;\n    basePkt.free();\n    alphaPkt.free();\n    this._alphaFrame?.free();\n    baseCtx.freeContext();\n    alphaCtx.freeContext();\n  }\n\n  private async drainInterleaved(muxer: FormatMuxer): Promise<void> {\n    const { baseCtx, alphaCtx, basePkt, alphaPkt, stream } = this._s;\n    while (true) {\n      const baseR = await baseCtx.receivePacket(basePkt);\n      const alphaR = await alphaCtx.receivePacket(alphaPkt);\n\n      const baseReady = baseR >= 0;\n      const alphaReady = alphaR >= 0;\n      if (!baseReady && !alphaReady) break;\n\n      // Both must produce packets together (bf=0 ensures this)\n      if (baseReady !== alphaReady) {\n        throw new Error(`NVENC desync: base=${baseReady}, alpha=${alphaReady}`);\n      }\n\n      const baseNals = splitNalUnits(basePkt.data!);\n      const alphaNals = splitNalUnits(alphaPkt.data!);\n\n      const chunks: Buffer[] = [];\n      if (!this._seiInjected) {\n        chunks.push(this._seiBuffer);\n        this._seiInjected = true;\n      }\n      chunks.push(interleaveAccessUnits(baseNals, alphaNals));\n\n      // Save timestamps before data replacement (setter may reset them)\n      const pts = basePkt.pts;\n      const dts = basePkt.dts;\n      const duration = basePkt.duration;\n      basePkt.data = Buffer.concat(chunks);\n      basePkt.pts = pts;\n      basePkt.dts = dts;\n      basePkt.duration = duration === 0n ? 1n : duration;\n      basePkt.streamIndex = stream.index;\n      basePkt.rescaleTs(baseCtx.timeBase, stream.timeBase);\n      await muxer.writePacket(basePkt);\n\n      basePkt.unref();\n      alphaPkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { Codec, type CodecContext, FFmpegError, Frame, type Packet, type Stream } from \"node-av\";\nimport { type AVPixelFormat, type FFVideoEncoder } from \"node-av/constants\";\nimport { drainPackets, makePacket, openVideoCtx } from \"./misc\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface VideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  codecName: FFVideoEncoder;\n  codecTag?: string;\n  codecOpts: Record<string, string>;\n  bitrate: number;\n  pixelFormat: AVPixelFormat;\n  muxer: FormatMuxer;\n}\n\nexport class VideoEncoder implements Disposable {\n  private readonly _ctx: CodecContext;\n  private readonly _pkt: Packet;\n  private readonly _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: VideoEncoderOptions): Promise<VideoEncoder> {\n    const { codecName, codecTag, codecOpts, muxer, ...rest } = opts;\n\n    const codec = Codec.findEncoderByName(codecName);\n    if (!codec) throw new Error(`Video encoder not found: ${codecName}`);\n\n    const ctx = await openVideoCtx({ codec, ...rest, codecTag, options: codecOpts }, \"videoCtx.open2\");\n    const stream = muxer.addStream(ctx, codecTag);\n    return new VideoEncoder(ctx, makePacket(), stream);\n  }\n\n  async encode(frame: Frame, muxer: FormatMuxer): Promise<void> {\n    frame.pts = this._pts++;\n    frame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(frame), \"videoCtx.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private drain(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { type CodecContext, FFmpegError, Frame, type Packet, type Stream } from \"node-av\";\nimport type { HardwareContext } from \"node-av/api\";\nimport { AV_PIX_FMT_BGRA, AVCOL_RANGE_JPEG } from \"node-av/constants\";\nimport { drainPackets, makePacket, openVideoCtx } from \"./misc\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface HwVideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  hw: HardwareContext;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class VideoToolboxEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _pkt: Packet;\n  private _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: HwVideoEncoderOptions): Promise<VideoToolboxEncoder> {\n    const { width, height, fps, hw, bitrate, muxer } = opts;\n\n    const codec = hw.getEncoderCodec(\"hevc\");\n    if (!codec) throw new Error(\"hevc_videotoolbox encoder not found\");\n\n    const ctx = await openVideoCtx(\n      {\n        codec,\n        width,\n        height,\n        fps,\n        bitrate,\n        pixelFormat: AV_PIX_FMT_BGRA,\n        colorRange: AVCOL_RANGE_JPEG,\n        codecTag: \"hvc1\",\n        options: { alpha_quality: \"1\" },\n      },\n      \"vtEnc.open2\",\n    );\n    const stream = muxer.addStream(ctx, \"hvc1\");\n    return new VideoToolboxEncoder(ctx, makePacket(), stream);\n  }\n\n  async encode(bgraFrame: Frame, muxer: FormatMuxer): Promise<void> {\n    bgraFrame.pts = this._pts++;\n    bgraFrame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(bgraFrame), \"vtEnc.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private drain(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/13.\n\nimport { HardwareContext } from \"node-av/api\";\nimport {\n  AV_PIX_FMT_YUVA420P,\n  FF_ENCODER_LIBX265,\n  FF_HWDEVICE_TYPE_CUDA,\n  FF_HWDEVICE_TYPE_VIDEOTOOLBOX,\n} from \"node-av/constants\";\n\nimport { logger } from \"../logging\";\nimport { CodecState } from \"./codec\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { NvencDualLayerEncoder } from \"./nvenc\";\nimport { VideoEncoder } from \"./video\";\nimport { VideoToolboxEncoder } from \"./videotoolbox\";\n\nconst TAG = \"[Encoder]\";\n\nexport type HwEncoder = VideoToolboxEncoder | NvencDualLayerEncoder;\n\nexport interface VideoSetup {\n  video?: VideoEncoder;\n  hwVideo?: HwEncoder;\n  codec?: CodecState;\n  hw?: HardwareContext;\n}\n\nexport interface VideoFactoryOptions {\n  width: number;\n  height: number;\n  fps: number;\n  bitrate?: number;\n  disableHwCodec?: boolean;\n}\n\nexport async function createVideoEncoder(opts: VideoFactoryOptions, muxer: FormatMuxer): Promise<VideoSetup> {\n  const { width, height, fps, bitrate = 8_000_000, disableHwCodec = false } = opts;\n  const hw = disableHwCodec ? undefined : (HardwareContext.auto() ?? undefined);\n\n  try {\n    if (hw?.deviceTypeName === FF_HWDEVICE_TYPE_VIDEOTOOLBOX && hw.getEncoderCodec(\"hevc\")) {\n      logger.debug(TAG, \"using VideoToolbox HEVC alpha encoder\");\n      const hwVideo = await VideoToolboxEncoder.create({ width, height, fps, hw, bitrate, muxer });\n      return { hwVideo, hw };\n    }\n    if (hw?.deviceTypeName === FF_HWDEVICE_TYPE_CUDA && hw.getEncoderCodec(\"hevc\")) {\n      logger.debug(TAG, \"using NVENC dual-layer HEVC alpha encoder\");\n      const hwVideo = await NvencDualLayerEncoder.create({ width, height, fps, hw, bitrate, muxer });\n      return { hwVideo, hw };\n    }\n  } catch (e) {\n    logger.warn(TAG, \"Hardware codec session limits reached, use software encoder\", e);\n  } finally {\n    hw?.dispose();\n  }\n\n  logger.debug(TAG, \"using software libx265 HEVC alpha encoder\");\n  hw?.dispose();\n  const video = await VideoEncoder.create({\n    width,\n    height,\n    fps,\n    codecName: FF_ENCODER_LIBX265,\n    codecTag: \"hvc1\",\n    codecOpts: { preset: \"medium\", \"x265-params\": \"log-level=1:bframes=3:pools=+:frame-threads=0\" },\n    bitrate,\n    pixelFormat: AV_PIX_FMT_YUVA420P,\n    muxer,\n  });\n  return { video, codec: await CodecState.create(width, height) };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { CodecContext, FFmpegError, FormatContext, Packet } from \"node-av\";\n\nexport class FormatMuxer {\n  private readonly _ctx: FormatContext;\n  private _opened = false;\n\n  constructor(outPath: string, formatName?: string) {\n    this._ctx = new FormatContext();\n    FFmpegError.throwIfError(this._ctx.allocOutputContext2(null, formatName ?? null, outPath), \"allocOutputContext2\");\n  }\n\n  addStream(codecCtx: CodecContext, codecTag?: string): ReturnType<FormatContext[\"newStream\"]> {\n    const stream = this._ctx.newStream(null);\n    stream.timeBase = codecCtx.timeBase;\n    FFmpegError.throwIfError(stream.codecpar.fromContext(codecCtx), \"codecpar.fromContext\");\n    if (codecTag) stream.codecpar.codecTag = codecTag;\n    return stream;\n  }\n\n  async open(): Promise<void> {\n    if (this._opened) return;\n    FFmpegError.throwIfError(await this._ctx.openOutput(), \"openOutput\");\n    FFmpegError.throwIfError(await this._ctx.writeHeader(null), \"writeHeader\");\n    this._opened = true;\n  }\n\n  async writePacket(pkt: Packet): Promise<void> {\n    FFmpegError.throwIfError(await this._ctx.interleavedWriteFrame(pkt), \"interleavedWriteFrame\");\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (!this._opened) return;\n    await this._ctx.writeTrailer();\n    await this._ctx.closeOutput();\n    await this._ctx[Symbol.asyncDispose]();\n    this._opened = false;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { FFmpegError, Frame } from \"node-av\";\nimport type { HardwareContext } from \"node-av/api\";\nimport { AV_PIX_FMT_BGRA, AV_SAMPLE_FMT_FLTP, FF_ENCODER_AAC } from \"node-av/constants\";\n\nimport { ok } from \"assert\";\nimport { ConcurrencyLimiter } from \"../limiter\";\nimport { AudioEncoder } from \"./audio\";\nimport { CodecState } from \"./codec\";\nimport { createVideoEncoder, type HwEncoder } from \"./factory\";\nimport { FormatMuxer } from \"./muxer\";\nimport { makeFrame } from \"./misc\";\nimport { VideoEncoder } from \"./video\";\n\nexport interface EncoderPipelineOptions {\n  width: number;\n  height: number;\n  fps: number;\n  outFile: string;\n  withAudio?: boolean;\n  disableHwCodec?: boolean;\n}\n\ninterface PipelineState {\n  video?: VideoEncoder;\n  hwVideo?: HwEncoder;\n  audio?: AudioEncoder;\n  muxer: FormatMuxer;\n  limiter: ConcurrencyLimiter;\n  outFile: string;\n  codec?: CodecState;\n  hw?: HardwareContext;\n  width: number;\n  height: number;\n}\n\nexport class EncoderPipeline {\n  private _s: PipelineState;\n  private _disposed = false;\n\n  private constructor(s: PipelineState) {\n    this._s = s;\n  }\n\n  static async create(opts: EncoderPipelineOptions): Promise<EncoderPipeline> {\n    const { width, height, outFile, withAudio = false } = opts;\n    const muxer = new FormatMuxer(outFile);\n    const { video, hwVideo, codec, hw } = await createVideoEncoder(opts, muxer);\n\n    let audio: AudioEncoder | undefined;\n    if (withAudio) {\n      audio = await AudioEncoder.create({\n        outSampleRate: 44_100,\n        outSampleFmt: AV_SAMPLE_FMT_FLTP,\n        codecName: FF_ENCODER_AAC,\n        globalHeader: true,\n        bitrate: 128_000,\n        muxer,\n      });\n    }\n\n    await muxer.open();\n    return new EncoderPipeline({\n      video,\n      hwVideo,\n      audio,\n      muxer,\n      limiter: new ConcurrencyLimiter(1),\n      outFile,\n      codec,\n      hw,\n      width,\n      height,\n    });\n  }\n\n  setupAudio(sampleRate: number): void {\n    this._s.audio?.setInputRate(sampleRate);\n  }\n\n  async encodeBGRA(input: Buffer): Promise<void> {\n    await this._s.limiter.schedule(async () => {\n      const { hwVideo, video, codec, muxer } = this._s;\n      if (hwVideo) {\n        using frame = this.bgraFrame(input);\n        await hwVideo.encode(frame, muxer);\n        return;\n      }\n      const { src, dst, sws } = codec!;\n      ok(sws, \"sws not initialized\");\n      FFmpegError.throwIfError(src.makeWritable(), \"bgraSrc.makeWritable\");\n      FFmpegError.throwIfError(src.fromBuffer(input), \"bgraSrc.fromBuffer\");\n      FFmpegError.throwIfError(dst.makeWritable(), \"bgraDst.makeWritable\");\n      FFmpegError.throwIfError(await sws.scaleFrame(dst, src), \"bgraSws.scaleFrame\");\n      return video!.encode(dst, muxer);\n    });\n  }\n\n  async encodePNG(pngData: Buffer): Promise<void> {\n    await this._s.limiter.schedule(async () => {\n      const { hwVideo, video, codec, muxer, width, height } = this._s;\n      const cs = codec ?? (await CodecState.create(width, height));\n      try {\n        const src = await cs.decodePNG(pngData);\n        if (hwVideo) {\n          await hwVideo.encode(src, muxer);\n        } else {\n          FFmpegError.throwIfError(cs.dst.makeWritable(), \"pngDst.makeWritable\");\n          FFmpegError.throwIfError(await cs.sws.scaleFrame(cs.dst, src), \"pngSws.scaleFrame\");\n          await video!.encode(cs.dst, muxer);\n        }\n      } finally {\n        if (!codec) cs[Symbol.dispose]();\n      }\n    });\n  }\n\n  async encodeAudio(pcm: Buffer): Promise<void> {\n    const { audio, limiter, muxer } = this._s;\n    if (audio) await limiter.schedule(() => audio.encode(pcm, muxer));\n  }\n\n  async finish(): Promise<string> {\n    const { video, hwVideo, audio, muxer, limiter } = this._s;\n    try {\n      await using _m = muxer;\n      using _v = video;\n      using _hv = hwVideo;\n      using _a = audio;\n      await limiter.drain();\n      await audio?.flush(muxer);\n      if (hwVideo) {\n        await hwVideo.flush(muxer);\n      } else {\n        await video!.flush(muxer);\n      }\n    } finally {\n      this.free();\n    }\n    return this._s.outFile;\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (this._disposed) return;\n    const { video, hwVideo, audio, muxer, limiter } = this._s;\n    await limiter.drain();\n    video?.[Symbol.dispose]();\n    hwVideo?.[Symbol.dispose]();\n    audio?.[Symbol.dispose]();\n    await muxer[Symbol.asyncDispose]();\n    this.free();\n  }\n\n  private free(): void {\n    if (this._disposed) return;\n    this._disposed = true;\n    using _codec = this._s.codec;\n    this._s.hw?.dispose();\n  }\n\n  private bgraFrame(input: Buffer): Frame {\n    const frame = makeFrame(this._s.width, this._s.height, AV_PIX_FMT_BGRA);\n    FFmpegError.throwIfError(frame.fromBuffer(input), \"bgraFrame.fromBuffer\");\n    return frame;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/23.\n\n/**\n * Frame drop quality score (0 = perfect, 1 = worst).\n *\n * Combines two dimensions:\n * - Global: overall drop rate across the timeline\n * - Local: perceptual severity of consecutive drops (bursts)\n *\n * Uses complementary multiplication: score = 1 - (1-g)(1-l)\n */\nexport interface FrameDropScore {\n  global: number;\n  local: number;\n  jank: number;\n  expected: number;\n  actual: number;\n  maxBurst: number;\n}\n\nexport class FrameDropStats {\n  private readonly _fps: number;\n  private _actual = 0;\n  private _currentBurst = 0;\n  private _bursts: number[] = [];\n\n  constructor(fps: number) {\n    this._fps = fps;\n  }\n\n  /** Call when a frame is actually written to the encoder. */\n  wrote(count = 1): void {\n    if (this._currentBurst > 0) {\n      this._bursts.push(this._currentBurst);\n      this._currentBurst = 0;\n    }\n    this._actual += count;\n  }\n\n  /** Call when a frame is dropped. */\n  dropped(count = 1): void {\n    this._currentBurst += count;\n  }\n\n  /** Finalize and return the score. */\n  finalize(): FrameDropScore {\n    if (this._currentBurst > 0) {\n      this._bursts.push(this._currentBurst);\n      this._currentBurst = 0;\n    }\n\n    let totalDropped = 0;\n    let localSum = 0;\n    let maxBurst = 0;\n    for (const burst of this._bursts) {\n      totalDropped += burst;\n      maxBurst = Math.max(maxBurst, burst);\n      const perceptible = Math.max(0, burst - 1);\n      localSum += (perceptible / this._fps) ** 2;\n    }\n\n    const expected = this._actual + totalDropped;\n    const g = expected > 0 ? totalDropped / expected : 0;\n    const l = Math.min(1, localSum);\n    const score = 1 - (1 - g) * (1 - l);\n\n    return { global: g, local: l, jank: score, expected, actual: this._actual, maxBurst };\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport type { NativeImage } from \"electron\";\n\nexport function isEmpty(image: NativeImage) {\n  const size = image.getSize();\n  if (size.width === 0 || size.height === 0) return true;\n  return image.isEmpty();\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/02.\n\nimport { randomUUID } from \"crypto\";\nimport { ipcMain, session } from \"electron\";\nimport { rm, writeFile } from \"fs/promises\";\nimport { tmpdir } from \"os\";\nimport { join } from \"path\";\nimport type { EncoderPipeline } from \"../base/encoder/pipeline\";\n\nconst AUDIO_META_CHANNEL = \"audio-meta\";\nconst AUDIO_CHUNK_CHANNEL = \"audio-chunk\";\n\nconst AUDIO_CAPTURE_SCRIPT = `\n(function() {\n  if (window.__pup_audio_capturing__) return;\n  window.__pup_audio_capturing__ = true;\n\n  const { ipcRenderer } = require('electron');\n  const capturedContexts = new WeakSet();\n  const sourcedElements = new WeakSet();\n  let metaSent = false;\n\n  const origCreateMES = AudioContext.prototype.createMediaElementSource;\n  AudioContext.prototype.createMediaElementSource = function(el) {\n    sourcedElements.add(el);\n    return origCreateMES.call(this, el);\n  };\n\n  const origConnect = AudioNode.prototype.connect;\n  AudioNode.prototype.connect = function(dest, outIdx, inIdx) {\n    const captureNode = dest?.context?.__pup_captureNode__;\n    if (captureNode && dest === dest.context.destination && this !== captureNode) {\n      origConnect.call(this, captureNode, outIdx, inIdx);\n    }\n    return origConnect.call(this, dest, outIdx, inIdx);\n  };\n\n  const OrigAC = window.AudioContext || window.webkitAudioContext;\n  if (!OrigAC) return;\n\n  function PatchedAC() {\n    const ctx = new OrigAC(...arguments);\n    if (!capturedContexts.has(ctx)) {\n      capturedContexts.add(ctx);\n      if (!metaSent) {\n        metaSent = true;\n        ipcRenderer.send('${AUDIO_META_CHANNEL}', { sampleRate: ctx.sampleRate });\n      }\n      const node = ctx.createScriptProcessor(4096, 2, 2);\n      node.onaudioprocess = (e) => {\n        const L = e.inputBuffer.getChannelData(0);\n        const R = e.inputBuffer.getChannelData(1);\n        const out = new Float32Array(L.length * 2);\n        for (let i = 0; i < L.length; i++) {\n          out[i * 2] = L[i];\n          out[i * 2 + 1] = R[i];\n        }\n        ipcRenderer.send('${AUDIO_CHUNK_CHANNEL}', Buffer.from(out.buffer));\n      };\n      node.connect(ctx.destination);\n      ctx.__pup_captureNode__ = node;\n    }\n    return ctx;\n  }\n  PatchedAC.prototype = OrigAC.prototype;\n  Object.setPrototypeOf(PatchedAC, OrigAC);\n  window.AudioContext = PatchedAC;\n  if ('webkitAudioContext' in window) window.webkitAudioContext = PatchedAC;\n\n  const origPlay = HTMLMediaElement.prototype.play;\n  HTMLMediaElement.prototype.play = function() {\n    if (!this.__pup_captured__) {\n      this.__pup_captured__ = true;\n      const el = this;\n      Promise.resolve().then(() => {\n        if (!sourcedElements.has(el)) {\n          const ctx = new PatchedAC();\n          ctx.createMediaElementSource(el).connect(ctx.destination);\n        }\n      });\n    }\n    return origPlay.call(this);\n  };\n})();\n`;\n\nexport interface AudioCapture {\n  teardown(): Promise<void>;\n}\n\nexport interface AudioCaptureOptions {\n  encoder: EncoderPipeline;\n  getVideoTimeMs: () => number;\n  onError: (error: Error) => void;\n}\n\nexport async function setupAudioCapture({\n  encoder,\n  getVideoTimeMs,\n  onError,\n}: AudioCaptureOptions): Promise<AudioCapture> {\n  const preloadPath = join(tmpdir(), `pup_audio_${randomUUID()}.js`);\n  await writeFile(preloadPath, AUDIO_CAPTURE_SCRIPT);\n  session.defaultSession.registerPreloadScript({\n    type: \"frame\",\n    id: \"pup-audio\",\n    filePath: preloadPath,\n  });\n\n  ipcMain.on(AUDIO_META_CHANNEL, async (_e, data: { sampleRate: number }) => {\n    const sampleRate = data.sampleRate;\n    const startMs = getVideoTimeMs();\n    encoder.setupAudio(sampleRate);\n    const silenceSamples = Math.ceil((startMs * sampleRate) / 1000);\n    if (silenceSamples <= 0) {\n      return;\n    }\n    try {\n      await encoder.encodeAudio(Buffer.alloc(silenceSamples * 2 * 4));\n    } catch (error) {\n      onError(error as Error);\n    }\n  });\n\n  ipcMain.on(AUDIO_CHUNK_CHANNEL, async (_e, buffer: Buffer) => {\n    try {\n      await encoder.encodeAudio(buffer);\n    } catch (error) {\n      onError(error as Error);\n    }\n  });\n\n  return {\n    async teardown() {\n      ipcMain.removeAllListeners(AUDIO_META_CHANNEL);\n      ipcMain.removeAllListeners(AUDIO_CHUNK_CHANNEL);\n      session.defaultSession.unregisterPreloadScript(\"pup-audio\");\n      await rm(preloadPath, { force: true });\n    },\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nexport function sleep(ms: number) {\n  return new Promise<void>((resolve) => setTimeout(resolve, ms));\n}\n\nexport function periodical(callback: (count: number) => Promise<void> | void, ms: number) {\n  let token: NodeJS.Timeout;\n  let closed = false;\n  async function tick(count: number) {\n    await callback(count);\n    if (closed) return;\n    token = setTimeout(() => tick(count + 1), ms);\n  }\n  token = setTimeout(() => tick(0), ms);\n  return () => {\n    closed = true;\n    clearTimeout(token);\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/05.\n\nimport { setTimeout } from \"timers/promises\";\nimport { sleep } from \"./timing\";\n\nexport interface RetryOptions<Args extends any[], Ret> {\n  fn: (...args: Args) => Promise<Ret>;\n  maxAttempts?: number;\n  timeout?: number;\n}\n\nexport function useRetry<Args extends any[], Ret>({ fn, maxAttempts = 3, timeout }: RetryOptions<Args, Ret>) {\n  const timeoutError = new Error(`timeout over ${timeout}ms`);\n  return async function (...args: Args) {\n    let attempt = 0;\n    while (true) {\n      try {\n        const promises = [fn(...args)];\n        if (timeout) {\n          promises.push(\n            setTimeout(timeout).then(() => {\n              throw timeoutError;\n            }),\n          );\n        }\n        return await Promise.race(promises);\n      } catch (e) {\n        attempt++;\n        if (attempt >= maxAttempts) {\n          throw e;\n        }\n        await sleep(Math.pow(2, attempt) * 100 + Math.random() * 100);\n      }\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nconst SUPPORTED_PROTOCOLS = [\"file:\", \"http:\", \"https:\", \"data:\"];\nconst SOURCE_PATTERN = /^(file:|https?:|data:)/;\n\nexport function checkHTML(source: string): void {\n  if (SOURCE_PATTERN.test(source)) {\n    return;\n  }\n\n  const protocol = source.split(\":\")[0] + \":\";\n  const message = SUPPORTED_PROTOCOLS.includes(protocol)\n    ? `unsupported protocol: ${protocol}, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`\n    : `invalid source format, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`;\n\n  throw new Error(message);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/10.\n\nexport interface WaitOptions {\n  timeout: number;\n  onTimeout?: () => void;\n}\n\nexport class WaitableEvent {\n  private _promise?: Promise<void>;\n  private _resolve?: () => void;\n  private _timeoutToken?: NodeJS.Timeout;\n\n  wait(options?: WaitOptions): Promise<void> {\n    if (this._promise) {\n      throw new Error(\"already waiting\");\n    }\n    this._promise = new Promise((resolve) => {\n      this._resolve = resolve;\n      if (options?.timeout !== undefined) {\n        this._timeoutToken = setTimeout(() => {\n          options.onTimeout?.();\n          resolve();\n        }, options.timeout);\n      }\n    });\n    return this._promise;\n  }\n\n  signal() {\n    clearTimeout(this._timeoutToken);\n    this._promise = undefined;\n    this._resolve?.();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { BrowserWindow } from \"electron\";\nimport { URL } from \"url\";\nimport { ConcurrencyLimiter } from \"../base/limiter\";\nimport { logger } from \"../base/logging\";\nimport { WaitableEvent } from \"../base/waitable_event\";\n\nconst TAG = \"[Network]\";\n\nconst map = new Map([\n  [`jssz-boss.hdslb.com`, `jssz-boss.bilibili.co`], //\n  [`boss.hdslb.com`, `shjd-boss.bilibili.co`],\n]);\n\nexport function proxiedUrl(url: string) {\n  if (!url.startsWith(\"http\")) {\n    return url;\n  }\n  const parsed = new URL(url);\n  const target = map.get(parsed.hostname);\n  if (!target) {\n    return url;\n  }\n  parsed.hostname = target;\n  parsed.protocol = \"http:\";\n  return parsed.toString();\n}\n\nexport interface NetworkOptions {\n  source: string;\n  window: BrowserWindow;\n  useInnerProxy?: boolean;\n}\n\nexport function setInterceptor({ source, window, useInnerProxy }: NetworkOptions) {\n  const req = window.webContents.session.webRequest;\n  const limiter = new ConcurrencyLimiter(64);\n  const events = new Map<string, WaitableEvent>();\n\n  async function wait(key: string, onTimeout?: () => void) {\n    const event = new WaitableEvent();\n    events.set(key, event);\n    await event.wait({ timeout: 5_000, onTimeout }).finally(() => events.delete(key));\n  }\n\n  function signal(key: string) {\n    events.get(key)?.signal();\n  }\n\n  req.onBeforeRequest((details, callback) => {\n    const url = details.url;\n    const proxied = useInnerProxy ? proxiedUrl(url) : url;\n    limiter.schedule(() => {\n      const key = `${window.id}_${details.id}`;\n      logger.debug(TAG, `start:`, {\n        key,\n        url,\n        proxied,\n        method: details.method,\n        source,\n        stats: limiter.stats,\n      });\n      if (proxied === url) {\n        callback({ cancel: false });\n      } else {\n        callback({ cancel: false, redirectURL: proxied });\n      }\n      return wait(key, () => {\n        logger.warn(TAG, `maybe timeout:`, {\n          key,\n          url,\n          proxied,\n          method: details.method,\n          source,\n        });\n      });\n    });\n  });\n\n  req.onHeadersReceived(({ responseHeaders }, callback) => {\n    delete responseHeaders?.[\"x-frame-options\"];\n    delete responseHeaders?.[\"X-Frame-Options\"];\n    delete responseHeaders?.[\"content-security-policy\"];\n    delete responseHeaders?.[\"Content-Security-Policy\"];\n    callback({ cancel: false, responseHeaders });\n  });\n\n  req.onCompleted((details) => {\n    const key = `${window.id}_${details.id}`;\n    signal(key);\n    logger.debug(TAG, `completed:`, {\n      key,\n      url: details.url,\n      method: details.method,\n      statusCode: details.statusCode,\n      source,\n    });\n  });\n\n  req.onErrorOccurred((details) => {\n    const key = `${window.id}_${details.id}`;\n    signal(key);\n    logger.error(TAG, `error:`, {\n      key,\n      url: details.url,\n      method: details.method,\n      error: details.error,\n      source,\n    });\n  });\n}\n\nexport function unsetInterceptor(window: BrowserWindow) {\n  const req = window.webContents.session.webRequest;\n  req.onBeforeRequest(null);\n  req.onHeadersReceived(null);\n  req.onCompleted(null);\n  req.onErrorOccurred(null);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { BrowserWindow } from \"electron\";\nimport { logger } from \"../base/logging\";\nimport { useRetry } from \"../base/retry\";\nimport { sleep } from \"../base/timing\";\nimport { checkHTML } from \"./html_check\";\nimport { proxiedUrl, setInterceptor, unsetInterceptor } from \"./network\";\nimport { createStegoURL } from \"./protocol\";\nimport type { RenderOptions } from \"./schema\";\n\nconst TAG = \"[Window]\";\nconst TIMEOUT_ERROR = new Error(\"window timeout\");\n\nfunction waitForFinish(win: BrowserWindow, action: () => void, tolerant = false) {\n  return new Promise<void>((resolve, reject) => {\n    let domReady = false;\n    const done = (err?: unknown) => {\n      clearTimeout(timeout);\n      if (err === TIMEOUT_ERROR && tolerant && domReady) {\n        // tolerant on timeout failure\n        resolve();\n      } else if (err) {\n        reject(err);\n      } else {\n        resolve();\n      }\n    };\n    const timeout = setTimeout(() => done(TIMEOUT_ERROR), 30_000);\n    win.webContents.once(\"dom-ready\", () => {\n      logger.debug(TAG, \"dom-ready\");\n      domReady = true;\n    });\n    win.webContents.once(\"did-stop-loading\", () => done());\n    win.webContents.once(\"did-frame-finish-load\", (_, isMainFrame, frameProcessId, frameRoutingId) => {\n      logger.debug(TAG, \"did-frame-finish-load:\", { isMainFrame, frameProcessId, frameRoutingId });\n    });\n    win.webContents.once(\"did-fail-load\", (_e, code, desc, url) =>\n      done(new Error(`failed to load ${url}: [${code}] ${desc}`)),\n    );\n    win.webContents.once(\"render-process-gone\", (_e, { exitCode, reason }) =>\n      done(new Error(`renderer crashed: ${exitCode}, ${reason}`)),\n    );\n    action();\n  });\n}\n\nfunction waitForDestroy(win: BrowserWindow) {\n  return new Promise<void>((resolve) => {\n    unsetInterceptor(win);\n    win.once(\"closed\", resolve);\n    win.destroy();\n  });\n}\n\nexport interface WindowOptions {\n  source: string;\n  onCreated?: (window: BrowserWindow) => Promise<void>;\n  renderer: RenderOptions;\n  warmup?: boolean;\n  tolerant?: boolean;\n}\n\nasync function openWindow({ source, onCreated, renderer, warmup, tolerant }: WindowOptions): Promise<BrowserWindow> {\n  checkHTML(source);\n\n  const { width, height, useInnerProxy } = renderer;\n  const src = useInnerProxy ? proxiedUrl(source) : source;\n\n  const win = new BrowserWindow({\n    width,\n    height: height + 1,\n    show: false,\n    transparent: true,\n    backgroundColor: undefined,\n    frame: false,\n    webPreferences: {\n      offscreen: true,\n      backgroundThrottling: false,\n      nodeIntegration: true,\n      nodeIntegrationInSubFrames: true,\n      nodeIntegrationInWorker: true,\n      contextIsolation: false,\n      webSecurity: false,\n      allowRunningInsecureContent: true,\n      experimentalFeatures: true,\n    },\n  });\n  setInterceptor({ source, window: win, useInnerProxy });\n  if (!warmup) {\n    await onCreated?.(win);\n  }\n\n  win.webContents.on(\"console-message\", ({ level, message, lineNumber, sourceId }) => {\n    const msgs = [TAG, \"console:\", { message, lineNumber, sourceId, source }];\n    level === \"error\" ? logger.error(...msgs) : logger.debug(...msgs);\n  });\n\n  try {\n    const url = createStegoURL(src, { width, height });\n    await waitForFinish(win, () => win.loadURL(url), tolerant);\n  } catch (e) {\n    await waitForDestroy(win);\n    throw e;\n  }\n\n  return win;\n}\n\nconst openWindowWithRetry = useRetry({ fn: openWindow, maxAttempts: 2 });\n\nexport async function loadWindow({ source, onCreated, renderer }: WindowOptions): Promise<BrowserWindow> {\n  let warmup: BrowserWindow | undefined;\n  let error: unknown;\n  try {\n    warmup = await openWindowWithRetry({ source, renderer, warmup: true });\n  } catch (e) {\n    error = e;\n  }\n\n  const open = () => {\n    return openWindow({\n      source,\n      renderer,\n      onCreated,\n      tolerant: renderer.windowTolerant,\n    });\n  };\n\n  if (renderer.windowTolerant && error === TIMEOUT_ERROR) {\n    logger.warn(TAG, `warmup timeout: ${source}, falling back to dom-ready`);\n    return await open();\n  }\n\n  if (error) {\n    const { message, stack } = error as Error;\n    throw new Error(`failed to warmup window: ${JSON.stringify({ source, message, stack })}`);\n  }\n\n  if (warmup) {\n    warmup.webContents.removeAllListeners();\n    unsetInterceptor(warmup);\n    await sleep(2000);\n    await waitForDestroy(warmup);\n  }\n\n  try {\n    return await open();\n  } catch (e) {\n    const { message, stack } = e as Error;\n    throw new Error(`failed to load window: ${JSON.stringify({ source, message, stack })}`);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { type NativeImage } from \"electron\";\nimport { EncoderPipeline } from \"../base/encoder/pipeline\";\nimport { FrameDropStats } from \"../base/frame_drop\";\nimport { isEmpty } from \"../base/image\";\nimport { setupAudioCapture, type AudioCapture } from \"./audio\";\nimport type { IpcDonePayload, IpcWriter } from \"./ipc\";\nimport type { RenderOptions } from \"./schema\";\nimport { decodeStego, startStego, stopStego } from \"./stego\";\nimport { loadWindow } from \"./window\";\n\nexport async function render(writer: IpcWriter, source: string, options: RenderOptions): Promise<IpcDonePayload> {\n  const { fps, width, height, duration, withAudio, outFile, disableHwCodec } = options;\n\n  await using encoder = await EncoderPipeline.create({ width, height, fps, outFile, withAudio, disableHwCodec });\n\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n\n  let written = 0;\n  let lastWrittenTime: number | undefined;\n  let progress = 0;\n  let encodeError: Error | undefined;\n  let resolver: (() => void) | undefined;\n  let rejecter: ((reason?: unknown) => void) | undefined;\n  const dropStats = new FrameDropStats(fps);\n\n  let audio: AudioCapture | undefined;\n  const scheduleFrame = (frame: Buffer) => {\n    written++;\n    encoder.encodeBGRA(frame).catch((e) => (encodeError ??= e));\n  };\n\n  const paint = (_e: unknown, _r: unknown, image: NativeImage) => {\n    if (encodeError) {\n      rejecter?.(encodeError);\n      return;\n    }\n\n    if (isEmpty(image)) return;\n\n    const bitmap = image.toBitmap();\n    const currentTime = decodeStego(bitmap, image.getSize());\n    if (currentTime === undefined) {\n      encodeError ??= new Error(`no timestamp @ ${written}`);\n      return;\n    }\n\n    const bytesPerRow = width * 4;\n    const cropped = Buffer.from(bitmap.buffer, bitmap.byteOffset, height * bytesPerRow);\n\n    if (lastWrittenTime === undefined) {\n      scheduleFrame(cropped);\n      dropStats.wrote();\n      lastWrittenTime = currentTime;\n    } else {\n      const timeDelta = currentTime - lastWrittenTime;\n      if (timeDelta >= frameInterval * 0.8) {\n        if (timeDelta <= frameInterval * 1.2) {\n          scheduleFrame(cropped);\n          dropStats.wrote();\n        } else {\n          const framesToInsert = Math.round(timeDelta / frameInterval);\n          dropStats.dropped(framesToInsert - 1);\n          dropStats.wrote();\n          for (let i = 0; i < framesToInsert && written < total; i++) {\n            scheduleFrame(cropped);\n          }\n        }\n        lastWrittenTime = currentTime;\n      }\n    }\n\n    const newProgress = Math.floor((written / total) * 100);\n    if (Math.abs(newProgress - progress) > 10) {\n      progress = newProgress;\n      writer.writeProgress(progress);\n    }\n\n    const durationMs = duration * 1000;\n    if (currentTime >= durationMs - frameInterval * 0.5 || written >= total) {\n      resolver?.();\n    }\n  };\n\n  const win = await loadWindow({\n    source,\n    renderer: options,\n    onCreated: async () => {\n      if (withAudio) {\n        audio = await setupAudioCapture({\n          encoder,\n          getVideoTimeMs: () => lastWrittenTime ?? 0,\n          onError: (e) => (encodeError ??= e),\n        });\n      }\n    },\n  });\n  const cdp = win.webContents.debugger;\n  win.webContents.setFrameRate(fps);\n  if (!win.webContents.isPainting()) win.webContents.startPainting();\n  cdp.attach(\"1.3\");\n  win.webContents.on(\"paint\", paint);\n\n  try {\n    await startStego(cdp);\n    await new Promise<void>((r, j) => ([resolver, rejecter] = [r, j]));\n  } finally {\n    await stopStego(cdp);\n    win.webContents.off(\"paint\", paint);\n    win.close();\n    await audio?.teardown();\n    await encoder.finish();\n  }\n\n  if (encodeError || written === 0) {\n    throw encodeError ?? new Error(\"no frames captured\");\n  } else {\n    const dropScore = dropStats.finalize();\n    return { written, jank: dropScore.jank, outFile };\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/13.\n\nimport type { Debugger } from \"electron\";\n\nconst ADVANCE_TIMEOUT_MS = 30_000;\n\nexport function advanceVirtualTime(cdp: Debugger, budget: number): Promise<void> {\n  return new Promise((resolve, reject) => {\n    const timeout = setTimeout(() => {\n      cdp.off(\"message\", handler);\n      reject(new Error(`advanceVirtualTime timed out after ${ADVANCE_TIMEOUT_MS}ms`));\n    }, ADVANCE_TIMEOUT_MS);\n\n    const handler = (_: Electron.Event, method: string) => {\n      if (method === \"Emulation.virtualTimeBudgetExpired\") {\n        clearTimeout(timeout);\n        cdp.off(\"message\", handler);\n        resolve();\n      }\n    };\n    cdp.on(\"message\", handler);\n    cdp.sendCommand(\"Emulation.setVirtualTimePolicy\", {\n      policy: \"advance\",\n      budget,\n    });\n  });\n}\n\nexport function pauseVirtualTime(cdp: Debugger): Promise<void> {\n  return cdp.sendCommand(\"Emulation.setVirtualTimePolicy\", { policy: \"pause\" });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { HardwareContext } from \"node-av/api\";\nimport { logger } from \"./logging\";\n\nconst TAG = \"[HWAccel]\";\n\nasync function detectGPUDriver() {\n  const hw = HardwareContext.auto();\n  const result = hw !== null;\n  hw?.dispose();\n  return result;\n}\n\nexport const canIUseGPU = detectGPUDriver().then((result) => {\n  logger.debug(TAG, \"gpu:\", result);\n  return result;\n});\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nexport const TICK_SYMBOL = \"__pup_tick__\";\n\nexport function buildTickInjector(): string {\n  return `(function() {\n  if (window.self === window.top) return;\n  if (typeof ${TICK_SYMBOL} !== 'undefined') return;\n\n  const orig = {\n    Date: Date,\n    dateNow: Date.now.bind(Date),\n    performanceNow: performance.now.bind(performance),\n    raf: requestAnimationFrame.bind(window),\n    caf: cancelAnimationFrame.bind(window),\n    setTimeout: setTimeout.bind(window),\n    clearTimeout: clearTimeout.bind(window),\n    setInterval: setInterval.bind(window),\n    clearInterval: clearInterval.bind(window),\n  };\n\n  let currMs = 0;\n  let rafQueue = [];\n  const timers = {};\n  let nextId = 1;\n  const dateOrigin = new orig.Date();\n  const perfOrigin = orig.performanceNow();\n\n  performance.now = function() { return perfOrigin + currMs; };\n  Date.now = function() { return dateOrigin.getTime() + currMs; };\n  Date = function() {\n    var O = orig.Date;\n    if (arguments.length === 0) return new O(dateOrigin.getTime() + currMs);\n    return new (Function.prototype.bind.apply(O, [null].concat(Array.prototype.slice.call(arguments))))();\n  };\n  Date.now = function() { return dateOrigin.getTime() + currMs; };\n  Date.parse = orig.Date.parse;\n  Date.UTC = orig.Date.UTC;\n  Date.prototype = orig.Date.prototype;\n\n  window.requestAnimationFrame = function(cb) {\n    const id = nextId++;\n    rafQueue.push({ id, cb });\n    return id;\n  };\n  window.cancelAnimationFrame = function(id) {\n    rafQueue = rafQueue.filter((r) => r.id !== id);\n  };\n\n  window.setTimeout = function(cb, delay, ...args) {\n    const id = nextId++;\n    timers[id] = { type: 'timeout', cb, delay: delay || 0, next: currMs + (delay || 0), args };\n    return id;\n  };\n  window.clearTimeout = function(id) { delete timers[id]; };\n\n  window.setInterval = function(cb, delay, ...args) {\n    const id = nextId++;\n    const d = Math.max(delay || 0, 1);\n    timers[id] = { type: 'interval', cb, delay: d, next: currMs + d, args };\n    return id;\n  };\n  window.clearInterval = function(id) { delete timers[id]; };\n\n  function process(timestampMs) {\n    currMs = timestampMs;\n    document.getAnimations().forEach(a => {\n      a.pause();\n      a.currentTime = currMs;\n    });\n    const ids = Object.keys(timers);\n    for (let i = 0; i < ids.length; i++) {\n      const t = timers[ids[i]];\n      if (!t) continue;\n      while (t.next <= currMs) {\n        if (typeof t.cb === 'string') eval(t.cb); else t.cb.apply(undefined, t.args);\n        if (t.type === 'timeout') { delete timers[ids[i]]; break; }\n        t.next += t.delay;\n      }\n    }\n    const rafs = rafQueue.splice(0);\n    for (let j = 0; j < rafs.length; j++) {\n      rafs[j].cb(currMs);\n    }\n  }\n\n  function eject() {\n    Date = orig.Date;\n    performance.now = orig.performanceNow;\n    window.requestAnimationFrame = orig.raf;\n    window.cancelAnimationFrame = orig.caf;\n    window.setTimeout = orig.setTimeout;\n    window.clearTimeout = orig.clearTimeout;\n    window.setInterval = orig.setInterval;\n    window.clearInterval = orig.clearInterval;\n    delete window.${TICK_SYMBOL};\n  }\n\n  window.${TICK_SYMBOL} = { process: process, eject: eject };\n})();`;\n}\n\nexport function doProcess(timestampMs: number): string {\n  return `${TICK_SYMBOL}.process(${timestampMs})`;\n}\n\nexport function doEject(): string {\n  return `if (typeof ${TICK_SYMBOL} !== 'undefined') ${TICK_SYMBOL}.eject()`;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/13.\n\nimport { ipcMain, type BrowserWindow, type IpcMainEvent, type NativeImage, type Size } from \"electron\";\nimport { advanceVirtualTime, pauseVirtualTime } from \"../base/cdp\";\nimport { EncoderPipeline } from \"../base/encoder/pipeline\";\nimport { canIUseGPU } from \"../base/hwaccel\";\nimport { isEmpty } from \"../base/image\";\nimport { logger } from \"../base/logging\";\nimport { IpcWriter, type IpcDonePayload } from \"./ipc\";\nimport type { RenderOptions } from \"./schema\";\nimport { decodeStego, STEGO_TICK_CHANNEL, tickStego } from \"./stego\";\nimport { buildTickInjector, doEject, doProcess } from \"./tick\";\nimport { loadWindow } from \"./window\";\n\nconst TAG = \"[Shoot]\";\n\nfunction stego(expected: number): Promise<number> {\n  return new Promise<number>((resolve) => {\n    const handler = (_e: IpcMainEvent, ms: number) => {\n      if (Math.abs(ms - expected) <= 1) {\n        ipcMain.off(STEGO_TICK_CHANNEL, handler);\n        resolve(ms);\n      }\n    };\n    ipcMain.on(STEGO_TICK_CHANNEL, handler);\n  });\n}\n\nasync function paint(win: BrowserWindow, size: Size, ms: number): Promise<Buffer> {\n  const interval = setInterval(() => {\n    logger.warn(TAG, `renderer is extremely slow @ ${ms}`);\n  }, 1000);\n  try {\n    return await new Promise<Buffer>((resolve) => {\n      const handler = (_e: unknown, _d: unknown, image: NativeImage) => {\n        if (isEmpty(image)) return;\n        const bitmap = image.toBitmap();\n        const ts = decodeStego(bitmap, image.getSize());\n        if (ts === undefined || Math.abs(ts - ms) > 1) {\n          logger.warn(TAG, `skip frame: ${ts}, expected: ${ms}, the render is slow`);\n          return;\n        }\n        win.webContents.stopPainting();\n        win.webContents.off(\"paint\", handler);\n        resolve(Buffer.from(bitmap.buffer, bitmap.byteOffset, size.height * size.width * 4));\n      };\n      win.webContents.on(\"paint\", handler);\n    });\n  } finally {\n    clearInterval(interval);\n  }\n}\n\nexport async function shoot(writer: IpcWriter, source: string, options: RenderOptions): Promise<IpcDonePayload> {\n  const { fps, width, height, duration, withAudio, outFile, disableGpu, disableHwCodec } = options;\n  if (withAudio) logger.warn(TAG, \"audio will be ignored on this mode\");\n\n  await using pipeline = await EncoderPipeline.create({ width, height, fps, outFile, withAudio, disableHwCodec });\n\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n  let written = 0;\n  let progress = 0;\n\n  const gpu = (await canIUseGPU) && !disableGpu;\n  const win = await loadWindow({ source, renderer: options });\n  const cdp = win.webContents.debugger;\n  const main = win.webContents.mainFrame;\n  const iframe = main.frames[0];\n  try {\n    cdp.attach(\"1.3\");\n\n    const renderFps = gpu ? 240 : fps;\n    const renderInterval = 1000 / renderFps;\n    logger.debug(TAG, { fps, frameInterval, renderFps, renderInterval });\n\n    // NOTE(Autokaka):\n    // 1. with gpu, the paint event callback at the exact point without extra renderings\n    // 2. without gpu, paint will callback each frame, so we set required fps to prevent too high CPU usage\n    win.webContents.stopPainting();\n    win.webContents.setFrameRate(renderFps);\n\n    await pauseVirtualTime(cdp);\n    await iframe?.executeJavaScript(buildTickInjector());\n    iframe?.executeJavaScript(doProcess(0));\n\n    for (let frame = 0; frame < total; frame++) {\n      const frameMs = (frame + 1) * frameInterval;\n\n      const tick = stego(frameMs);\n      await iframe?.executeJavaScript(doProcess(frameMs));\n      await tickStego(cdp, frameMs);\n      await advanceVirtualTime(cdp, frameInterval);\n\n      const bitmap = paint(win, { width, height }, await tick);\n      win.webContents.startPainting();\n      await pipeline.encodeBGRA(await bitmap);\n      written++;\n\n      const newProgress = Math.floor((written / total) * 100);\n      if (Math.abs(newProgress - progress) > 10) {\n        progress = newProgress;\n        writer.writeProgress(progress);\n      }\n    }\n  } finally {\n    iframe?.executeJavaScript(doEject());\n    cdp.detach();\n    win.close();\n    await pipeline.finish();\n  }\n\n  if (written === 0) {\n    throw new Error(\"no frames captured\");\n  } else {\n    return { written, jank: 0, outFile };\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { ok } from \"assert\";\nimport { app } from \"electron\";\nimport { mkdir } from \"fs/promises\";\nimport { dirname } from \"path\";\nimport { pupIpcSocket } from \"./base/constants\";\nimport { logger } from \"./base/logging\";\nimport { makeCLI } from \"./common\";\nimport { connectIpc } from \"./renderer/ipc\";\nimport { setupPupProtocol } from \"./renderer/protocol\";\nimport { render } from \"./renderer/render\";\nimport { defaultRenderOptions } from \"./renderer/schema\";\nimport { shoot } from \"./renderer/shoot\";\n\nconst TAG = \"[App]\";\n\nfunction printFeatures() {\n  logger.debug(TAG, \"gpu features:\", app.getGPUFeatureStatus());\n}\n\napp.dock?.hide();\napp.on(\"window-all-closed\", () => {});\n\nmakeCLI({\n  name: \"app\",\n  defaults: {\n    ...defaultRenderOptions,\n    withAudio: false,\n    deterministic: false,\n    useInnerProxy: false,\n    disableGpu: false,\n    disableHwCodec: false,\n    windowTolerant: false,\n  },\n  run: async (source, options) => {\n    const exit = (code: number) => {\n      app.quit();\n      process.exit(code);\n    };\n    process.once(\"SIGTERM\", () => exit(143));\n    process.once(\"SIGINT\", () => exit(130));\n    process.once(\"exit\", (c) => exit(c));\n    ok(pupIpcSocket, \"pupIpcSocket not set\");\n    const ipc = await connectIpc(pupIpcSocket);\n    try {\n      app.on(\"gpu-info-update\", printFeatures);\n      await app.whenReady();\n      setupPupProtocol();\n      printFeatures();\n      await mkdir(dirname(options.outFile), { recursive: true });\n      const action = options.deterministic ? shoot : render;\n      ipc.writeDone(await action(ipc, source, options));\n    } catch (e) {\n      const error = e as Error;\n      ipc.writeError(error.stack ?? \"unknown error\");\n    } finally {\n      app.quit();\n    }\n  },\n});\n"]}