pup-recorder 0.2.7 → 0.2.8
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/build.ts +0 -3
- package/dist/_tsup-dts-rollup.d.ts +46 -10
- package/dist/app.cjs +26 -14
- package/dist/chunk-BG7244QU.js +92 -0
- package/dist/cli.js +2 -2
- package/dist/index.d.ts +1 -0
- package/dist/index.js +2 -2
- package/package.json +3 -2
- package/dist/chunk-3POZKRKH.js +0 -2
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'),
|
|
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'),S=require('zod'),net=require('net'),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 S__default=/*#__PURE__*/_interopDefault(S);var $t=Object.create;var _e=Object.defineProperty;var Ut=Object.getOwnPropertyDescriptor;var J=(r,e)=>(e=Symbol[r])?e:Symbol.for("Symbol."+r),T=r=>{throw TypeError(r)};var Ue=(r,e,t)=>e in r?_e(r,e,{enumerable:true,configurable:true,writable:true,value:t}):r[e]=t;var Ve=r=>[,,,$t(null)],Ge=["class","method","getter","setter","accessor","field","value","get","set"],G=r=>r!==void 0&&typeof r!="function"?T("Function expected"):r,Vt=(r,e,t,o,i)=>({kind:Ge[r],name:e,metadata:o,addInitializer:n=>t._?T("Already initialized"):i.push(G(n||null))}),ge=(r,e)=>Ue(e,J("metadata"),r[3]),je=(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},B=(r,e,t,o,i,n)=>{var c,a,u,m,d=e&7,p=false,f=false,b=2,w=Ge[d+5],R=r[b]||(r[b]=[]),_=((i=i.prototype),Ut(i,t));for(var I=o.length-1;I>=0;I--)u=Vt(d,t,a={},r[3],R),(u.static=p,u.private=f,m=u.access={has:g=>t in g},(m.get=g=>g[t]),d>2),c=(0, o[I])(_[w],u),a._=1,G(c)&&(_[w]=c);return _&&_e(i,t,_),i},He=(r,e,t)=>Ue(r,e+"",t);var x=(r,e,t)=>{if(e!=null){typeof e!="object"&&typeof e!="function"&&T("Object expected");var o,i;t&&(o=e[J("asyncDispose")]),o===void 0&&(o=e[J("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},E=(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 Ht=()=>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,l=Ht();function ze(r,e,t){try{return e(process.env[r])}catch{return t}}function O(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 Yt=module$1.createRequire(l),j=process.env,qe=ze("PUP_LOG_LEVEL",O,2),Ke=j.PUP_USE_INNER_PROXY==="1";j.PUP_DISABLE_GPU==="1";var Ye=j.PUP_DETERMINISTIC==="1",Jt=path.dirname(Yt.resolve("pup-recorder/package.json"));path.join(Jt,"dist","app.cjs");var xe=j.PUP_IPC_SOCKET;j.PUP_EXPERIMENTAL_PUPPETEER==="1";var ye="<pup@debug>",ve="<pup@info>",Ee="<pup@warn>",Pe="<pup@error>",Fe="<pup@fatal>";function H(r,e){return function(...t){let o=t.map(i=>i instanceof Error?i.stack??String(i):i);return r.call(this,...o)}}var Je,Xe,Qe,Ze,et,M;et=[H],Ze=[H],Qe=[H],Xe=[H],Je=[H];var F=class{constructor(e=qe){this._level=e;je(M,5,this);He(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?.(ye,...e);}info(...e){this.impl?.info?.(ve,...e);}warn(...e){this.impl?.warn?.(Ee,...e);}error(...e){this.impl?.error?.(Pe,...e);}fatal(...e){this.impl?.error?.(Fe,...e),process.exit(1);}dispatch(e){let t=e.trimEnd();t.startsWith(ye)?this.debug(t.slice(ye.length+1)):t.startsWith(ve)?this.info(t.slice(ve.length+1)):t.startsWith(Ee)?this.warn(t.slice(Ee.length+1)):t.startsWith(Pe)?this.error(t.slice(Pe.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(Fe)?n+=a.slice(Fe.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);});})}};M=Ve(),B(M,1,"debug",et,F),B(M,1,"info",Ze,F),B(M,1,"warn",Qe,F),B(M,1,"error",Xe,F),B(M,1,"fatal",Je,F),ge(M,F);var h=new F;nodeAv.Log.setCallback((r,e)=>{let t=e.trimEnd();t&&(r<=constants.AV_LOG_ERROR?h.error(t):r<=constants.AV_LOG_WARNING&&h.warn(t));});function z(r,e){return (...t)=>{try{let o=r(...t);return o instanceof Promise?o.catch(()=>e):o}catch{return e}}}var er="--pup-priv-args";function tt(){let r=process.argv,e=r.find(o=>o.startsWith(er));if(!e)return h.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)),h.debug("pupargs",t),t}var tr=1920,rr=1080,or=30,ir=5,nr="output.mp4",rt=S__default.default.object({duration:S__default.default.number().describe("Duration in seconds"),width:S__default.default.number().describe("Video width"),height:S__default.default.number().describe("Video height"),fps:S__default.default.number().describe("Frames per second"),withAudio:S__default.default.boolean().describe("Capture and encode audio"),outFile:S__default.default.string().describe("Output mp4 file path"),useInnerProxy:S__default.default.boolean().describe("Use bilibili inner proxy for resource access"),deterministic:S__default.default.boolean().describe("Render by frame rather than recording")}),ot={width:tr,height:rr,fps:or,duration:ir,outFile:nr,withAudio:false,useInnerProxy:Ke,deterministic:Ye};async function nt(r){let e=rt.shape,t=r.defaults;commander.program.name(r.name).argument("<source>","file://, http(s)://, \u6216 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("--use-inner-proxy",e.useInnerProxy.description,t.useInnerProxy).option("-d, --deterministic",e.deterministic.description,t.deterministic).action(async(o,i)=>{try{await r.run(o,{width:z(O,t.width)(i.width),height:z(O,t.height)(i.height),fps:z(O,t.fps)(i.fps),duration:z(O,t.duration)(i.duration),outFile:i.outFile??t.outFile,withAudio:i.withAudio??t.withAudio,useInnerProxy:i.useInnerProxy??t.useInnerProxy,deterministic:i.deterministic??t.deterministic});}catch(n){h.fatal(n);}}),await commander.program.parseAsync(tt());}var ar=8;var Se=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(ar);o.writeUInt32LE(e,0),o.writeUInt32LE(t.byteLength,4),this._socket.write(o),this._socket.write(t);}};function st(r){return new Promise((e,t)=>{let o=net.createConnection(r);o.once("connect",()=>e(new Se(o))),o.once("error",t);})}function at(r,e){let{width:t,height:o}=e;return `<!DOCTYPE html>
|
|
2
2
|
<html>
|
|
3
3
|
<head>
|
|
4
4
|
<meta charset="UTF-8">
|
|
@@ -86,7 +86,7 @@
|
|
|
86
86
|
})();
|
|
87
87
|
</script>
|
|
88
88
|
</body>
|
|
89
|
-
</html>`}function Z(r,e){let{width:t,height:o}=e;if(t<32||o<2)return;let i=o-1,n=0;for(let a=0;a<32;a++){let c=(i*t+a)*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 ee(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_start_stego__()"})}function te(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_stop_stego__()"})}var Re="pup";electron.protocol.registerSchemesAsPrivileged([{scheme:Re,privileges:{standard:true,secure:true,bypassCSP:true,allowServiceWorkers:true,supportFetchAPI:true,corsEnabled:true,stream:true,codeCache:true}}]);function dt(){electron.protocol.handle(Re,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=ct(t,{width:o,height:i});return new Response(n,{headers:{"content-type":"text/html"}})});}function pt(r,e){let t=new URL(`${Re}://stego`);return t.searchParams.set("src",r),t.searchParams.set("w",String(e.width)),t.searchParams.set("h",String(e.height)),t.toString()}var N=class{constructor(e){this.maxConcurrency=e;}_active=0;_queue=[];_ended=false;get active(){return this._active}get pending(){return this._queue.length}get stats(){return `active: ${this.active}, pending: ${this.pending}`}async schedule(e){if(this._ended)throw new Error("ended");return new Promise((t,o)=>{let i=()=>{this._active++,e().then(n=>{this._active--,t(n),this.next();}).catch(n=>{this._active--,o(n),this.next();});};this._queue.push(i),this.next();})}async end(){if(!this._ended)for(this._ended=true;this._active>0||this.pending>0;)await new Promise(e=>setTimeout(e,50));}next(){this._active<this.maxConcurrency&&this._queue.shift()?.();}};var fr={[constants.AV_SAMPLE_FMT_FLT]:"flt",[constants.AV_SAMPLE_FMT_FLTP]:"fltp"},re=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=new nodeAv.Packet,this._pkt.alloc(),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"),a=t.createFilter(n,"sink");if(!a)throw new Error("Failed to create abuffersink");let s=`aformat=sample_fmts=${fr[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}]),m=nodeAv.FilterInOut.createList([{name:"out",filterCtx:a,padIdx:0}]);nodeAv.FFmpegError.throwIfError(t.parsePtr(s,m,u),"graph.parsePtr"),nodeAv.FFmpegError.throwIfError(t.configSync(),"graph.config"),this._graph=t,this._bufSrc=i,this._bufSink=a;}async encode(e,t){var a=[];try{if(!this._bufSrc||!this._inRate)return;let o=new Float32Array(e.buffer,e.byteOffset,e.byteLength/4);for(let m=0;m<o.length;m++)isFinite(o[m])||(o[m]=0);let i=o.length>>1;let n=v(a,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 s=c,u=true;}finally{A(a,s,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);}}async drainCodec(e){for(;;){let t=await this._ctx.receivePacket(this._pkt);if(t===constants.AVERROR_EAGAIN||t===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(t,"audio.receivePacket"),this._pkt.streamIndex=this._stream.index,this._pkt.rescaleTs(this._ctx.timeBase,this._stream.timeBase),await e.writePacket(this._pkt),this._pkt.unref();}}};var oe=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 ie=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:a,globalHeader:c,codecOpts:s,bitrate:u,threadCount:m,muxer:d}=e,f=nodeAv.Codec.findEncoderByName(n);if(!f)throw new Error(`Video encoder not found: ${n}`);let p=new nodeAv.CodecContext;p.allocContext3(f),p.codecId=f.id,p.width=t,p.height=o,p.pixelFormat=e.pixelFormat,p.timeBase=new nodeAv.Rational(1,i),p.framerate=new nodeAv.Rational(i,1),p.gopSize=i*2,p.bitRate=BigInt(u),m&&(p.threadCount=m,p.threadType=constants.FF_THREAD_SLICE),c&&p.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER);for(let[x,E]of Object.entries(s))p.setOption(x,E);a&&(p.codecTag=a),nodeAv.FFmpegError.throwIfError(await p.open2(f,null),"videoCtx.open2");let b=new nodeAv.Packet;b.alloc();let w=d.addStream(p,a);return new r(p,b,w)}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();}async drain(e){let t=this._pkt;for(;;){let o=await this._ctx.receivePacket(t);if(o===constants.AVERROR_EAGAIN||o===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(o,"video.receivePacket"),t.streamIndex=this._stream.index,t.duration===0n&&(t.duration=1n),t.rescaleTs(this._ctx.timeBase,this._stream.timeBase),await e.writePacket(t),t.unref();}}};var $=class r{constructor(e,t,o,i,n,a,c,s){this._video=e;this._audio=t;this._muxer=o;this._limiter=i;this._outFile=n;this._sws=a;this._srcFrame=c;this._dstFrame=s;}_disposed=false;static async create(e){let{width:t,height:o,fps:i,outFile:n,withAudio:a=false}=e,c=new oe(n),s=await ie.create({width:t,height:o,fps:i,codecName:constants.FF_ENCODER_LIBX265,codecTag:"hvc1",globalHeader:true,codecOpts:{preset:"ultrafast","x265-params":"log-level=1:bframes=0"},bitrate:8e6,pixelFormat:constants.AV_PIX_FMT_YUVA420P,threadCount:os.cpus().length,muxer:c}),u;a&&(u=await re.create({outSampleRate:44100,outSampleFmt:constants.AV_SAMPLE_FMT_FLTP,codecName:constants.FF_ENCODER_AAC,globalHeader:true,bitrate:128e3,muxer:c})),await c.open();let m=new N(1),d=new nodeAv.Frame;d.alloc(),d.format=constants.AV_PIX_FMT_BGRA,d.width=t,d.height=o,nodeAv.FFmpegError.throwIfError(d.getBuffer(0),"srcFrame.getBuffer");let f=new nodeAv.SoftwareScaleContext;f.getContext(t,o,constants.AV_PIX_FMT_BGRA,t,o,constants.AV_PIX_FMT_YUVA420P,constants.SWS_BILINEAR);let p=new nodeAv.Frame;return p.alloc(),p.format=constants.AV_PIX_FMT_YUVA420P,p.width=t,p.height=o,nodeAv.FFmpegError.throwIfError(p.getBuffer(0),"dstFrame.getBuffer"),new r(s,u,c,m,n,f,d,p)}setupAudio(e){this._audio?.setInputRate(e);}async encodeFrame(e){await this._limiter.schedule(async()=>(nodeAv.FFmpegError.throwIfError(this._srcFrame.makeWritable(),"srcFrame.makeWritable"),nodeAv.FFmpegError.throwIfError(this._srcFrame.fromBuffer(e),"srcFrame.fromBuffer"),nodeAv.FFmpegError.throwIfError(await this._sws.scaleFrame(this._dstFrame,this._srcFrame),"sws.scaleFrame"),nodeAv.FFmpegError.throwIfError(this._dstFrame.makeWritable(),"dstFrame.makeWritable"),this._video.encode(this._dstFrame,this._muxer)));}async encodeAudio(e){this._audio&&await this._limiter.schedule(()=>this._audio.encode(e,this._muxer));}async finish(){try{var e=[];try{let a=v(e,this._muxer,!0);let c=v(e,this._video);let s=v(e,this._audio);await this._limiter.end();await this._audio?.flush(this._muxer);await this._video.flush(this._muxer);}catch(t){var o=t,i=!0;}finally{var n=A(e,o,i);n&&await n;}}finally{this.free();}return this._outFile}async[Symbol.asyncDispose](){this._disposed||(await this._limiter.end(),this._video[Symbol.dispose](),this._audio?.[Symbol.dispose](),await this._muxer[Symbol.asyncDispose](),this.free());}free(){this._disposed||(this._disposed=true,this._srcFrame.free(),this._dstFrame.free(),this._sws[Symbol.dispose]());}};var ne=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 s of this._bursts){e+=s,o=Math.max(o,s);let u=Math.max(0,s-1);t+=(u/this._fps)**2;}let i=this._actual+e,n=i>0?e/i:0,a=Math.min(1,t),c=1-(1-n)*(1-a);return {global:n,local:a,jank:c,expected:i,actual:this._actual,maxBurst:o}}};function se(r){let e=r.getSize();return e.width===0||e.height===0?true:r.isEmpty()}var Or=`
|
|
89
|
+
</html>`}function X(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 Q(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_start_stego__()"})}function Z(r){return r.sendCommand("Runtime.evaluate",{expression:"window.__pup_stop_stego__()"})}var Ie="pup";electron.protocol.registerSchemesAsPrivileged([{scheme:Ie,privileges:{standard:true,secure:true,bypassCSP:true,allowServiceWorkers:true,supportFetchAPI:true,corsEnabled:true,stream:true,codeCache:true}}]);function ut(){electron.protocol.handle(Ie,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=at(t,{width:o,height:i});return new Response(n,{headers:{"content-type":"text/html"}})});}function dt(r,e){let t=new URL(`${Ie}://stego`);return t.searchParams.set("src",r),t.searchParams.set("w",String(e.width)),t.searchParams.set("h",String(e.height)),t.toString()}var N=class{constructor(e){this.maxConcurrency=e;}maxConcurrency;_active=0;_queue=[];_ended=false;get active(){return this._active}get pending(){return this._queue.length}get stats(){return `active: ${this.active}, pending: ${this.pending}`}async schedule(e){if(this._ended)throw new Error("ended");return new Promise((t,o)=>{let i=()=>{this._active++,e().then(n=>{this._active--,t(n),this.next();}).catch(n=>{this._active--,o(n),this.next();});};this._queue.push(i),this.next();})}async end(){if(!this._ended)for(this._ended=true;this._active>0||this.pending>0;)await new Promise(e=>setTimeout(e,50));}next(){this._active<this.maxConcurrency&&this._queue.shift()?.();}};var hr={[constants.AV_SAMPLE_FMT_FLT]:"flt",[constants.AV_SAMPLE_FMT_FLTP]:"fltp"},ee=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=new nodeAv.Packet,this._pkt.alloc(),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=${hr[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}]),m=nodeAv.FilterInOut.createList([{name:"out",filterCtx:s,padIdx:0}]);nodeAv.FFmpegError.throwIfError(t.parsePtr(a,m,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 m=0;m<o.length;m++)isFinite(o[m])||(o[m]=0);let i=o.length>>1;let n=x(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{E(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);}}async drainCodec(e){for(;;){let t=await this._ctx.receivePacket(this._pkt);if(t===constants.AVERROR_EAGAIN||t===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(t,"audio.receivePacket"),this._pkt.streamIndex=this._stream.index,this._pkt.rescaleTs(this._ctx.timeBase,this._stream.timeBase),await e.writePacket(this._pkt),this._pkt.unref();}}};function gt(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 Fr(r,e,t){let o=new nodeAv.SoftwareScaleContext;return o.getContext(r,e,t,r,e,nodeAv.AV_PIX_FMT_YUVA420P,nodeAv.SWS_BILINEAR),o}var te=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=gt(e,t,nodeAv.AV_PIX_FMT_BGRA),this.dst=gt(e,t,nodeAv.AV_PIX_FMT_YUVA420P),this.pkt=new nodeAv.Packet,this.pkt.alloc();}async png(){let e=new nodeAv.CodecContext;return e.allocContext3(this._png),nodeAv.FFmpegError.throwIfError(await e.open2(this._png),"pngDecoder.open2"),e}get sws(){return this._sws||(this._sws=Fr(this.src.width,this.src.height,this.src.format)),this._sws}[Symbol.dispose](){this.src[Symbol.dispose](),this.dst[Symbol.dispose](),this.pkt[Symbol.dispose](),this._sws?.[Symbol.dispose]();}};var re=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 oe=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:s,globalHeader:c,codecOpts:a,bitrate:u,muxer:m}=e,d=nodeAv.Codec.findEncoderByName(n);if(!d)throw new Error(`Video encoder not found: ${n}`);let p=new nodeAv.CodecContext;p.allocContext3(d),p.codecId=d.id,p.width=t,p.height=o,p.pixelFormat=e.pixelFormat,p.timeBase=new nodeAv.Rational(1,i),p.framerate=new nodeAv.Rational(i,1),p.gopSize=i*2,p.bitRate=BigInt(u),c&&p.setFlags(constants.AV_CODEC_FLAG_GLOBAL_HEADER);for(let[w,v]of Object.entries(a))p.setOption(w,v);s&&(p.codecTag=s),nodeAv.FFmpegError.throwIfError(await p.open2(d,null),"videoCtx.open2");let f=new nodeAv.Packet;f.alloc();let b=m.addStream(p,s);return new r(p,f,b)}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();}async drain(e){let t=this._pkt;for(;;){let o=await this._ctx.receivePacket(t);if(o===constants.AVERROR_EAGAIN||o===constants.AVERROR_EOF)break;nodeAv.FFmpegError.throwIfError(o,"video.receivePacket"),t.streamIndex=this._stream.index,t.duration===0n&&(t.duration=1n),t.rescaleTs(this._ctx.timeBase,this._stream.timeBase),await e.writePacket(t),t.unref();}}};var W=class r{constructor(e,t,o,i,n,s){this._video=e;this._audio=t;this._muxer=o;this._limiter=i;this._outFile=n;this._codec=s;}_video;_audio;_muxer;_limiter;_outFile;_codec;_disposed=false;static async create(e){let{width:t,height:o,fps:i,outFile:n,withAudio:s=false}=e,c=new re(n),a=await oe.create({width:t,height:o,fps:i,codecName:constants.FF_ENCODER_LIBX265,codecTag:"hvc1",globalHeader:true,codecOpts:{preset:"ultrafast","x265-params":"log-level=1:bframes=0"},bitrate:8e6,pixelFormat:constants.AV_PIX_FMT_YUVA420P,muxer:c}),u;return s&&(u=await ee.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(a,u,c,new N(1),n,await te.create(t,o))}setupAudio(e){this._audio?.setInputRate(e);}async encodeBGRA(e){await this._limiter.schedule(async()=>{let{src:t,dst:o,sws:i}=this._codec;return assert.ok(i,"sws not initialized"),nodeAv.FFmpegError.throwIfError(t.makeWritable(),"bgraSrc.makeWritable"),nodeAv.FFmpegError.throwIfError(t.fromBuffer(e),"bgraSrc.fromBuffer"),nodeAv.FFmpegError.throwIfError(o.makeWritable(),"bgraDst.makeWritable"),nodeAv.FFmpegError.throwIfError(await i.scaleFrame(o,t),"bgraSws.scaleFrame"),this._video.encode(o,this._muxer)});}async encodePNG(e){await this._limiter.schedule(async()=>{var s=[];try{let{pkt:t,src:o,dst:i}=this._codec;let n=x(s,await this._codec.png());t.data=e;nodeAv.FFmpegError.throwIfError(await n.sendPacket(t),"pngDecoder.sendPacket");t.unref();nodeAv.FFmpegError.throwIfError(await n.receiveFrame(o),"pngDecoder.receiveFrame");nodeAv.FFmpegError.throwIfError(i.makeWritable(),"pngDst.makeWritable");nodeAv.FFmpegError.throwIfError(await this._codec.sws.scaleFrame(i,o),"pngSws.scaleFrame");return this._video.encode(i,this._muxer)}catch(c){var a=c,u=true;}finally{E(s,a,u);}});}async encodeAudio(e){this._audio&&await this._limiter.schedule(()=>this._audio.encode(e,this._muxer));}async finish(){try{var e=[];try{let s=x(e,this._muxer,!0);let c=x(e,this._video);let a=x(e,this._audio);await this._limiter.end();await this._audio?.flush(this._muxer);await this._video.flush(this._muxer);}catch(t){var o=t,i=!0;}finally{var n=E(e,o,i);n&&await n;}}finally{this.free();}return this._outFile}async[Symbol.asyncDispose](){this._disposed||(await this._limiter.end(),this._video[Symbol.dispose](),this._audio?.[Symbol.dispose](),await this._muxer[Symbol.asyncDispose](),this.free());}free(){var t=[];try{if(this._disposed)return;this._disposed=!0;let e=x(t,this._codec);}catch(o){var i=o,n=true;}finally{E(t,i,n);}}};var ie=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 ne(r){let e=r.getSize();return e.width===0||e.height===0?true:r.isEmpty()}var Gr=`
|
|
90
90
|
(function() {
|
|
91
91
|
if (window.__pup_audio_capturing__) return;
|
|
92
92
|
window.__pup_audio_capturing__ = true;
|
|
@@ -158,13 +158,14 @@
|
|
|
158
158
|
return origPlay.call(this);
|
|
159
159
|
};
|
|
160
160
|
})();
|
|
161
|
-
`;async function Et({encoder:r,getVideoTimeMs:e,onError:t}){let o=path.join(os.tmpdir(),`pup_audio_preload_${crypto.randomUUID()}.js`);return await promises.writeFile(o,
|
|
162
|
-
if (window.self === window.top) return;
|
|
163
|
-
if (typeof ${
|
|
161
|
+
`;async function Et({encoder:r,getVideoTimeMs:e,onError:t}){let o=path.join(os.tmpdir(),`pup_audio_preload_${crypto.randomUUID()}.js`);return await promises.writeFile(o,Gr),electron.session.defaultSession.registerPreloadScript({type:"frame",id:"pup-audio",filePath:o}),electron.ipcMain.on("audio-meta",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("audio-chunk",async(i,n)=>{try{await r.encodeAudio(n);}catch(s){t(s);}}),{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 ae(r){return new Promise(e=>setTimeout(e,r))}function Pt({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 ae(Math.pow(2,n)*100+Math.random()*100);}}}var ke=["file:","http:","https:","data:"],Hr=/^(file:|https?:|data:)/;function Ft(r){if(Hr.test(r))return;let e=r.split(":")[0]+":",t=ke.includes(e)?`unsupported protocol: ${e}, expected ${ke.join(", ")}`:`invalid source format, expected ${ke.join(", ")}`;throw new Error(t)}var ce=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 ue="[Network]",qr=new Map([["jssz-boss.hdslb.com","jssz-boss.bilibili.co"],["boss.hdslb.com","shjd-boss.bilibili.co"]]);function Re(r){if(!r.startsWith("http"))return r;let e=new url.URL(r),t=qr.get(e.hostname);return t?(e.hostname=t,e.protocol="http:",e.toString()):r}function St({source:r,window:e,useInnerProxy:t}){let o=e.webContents.session.webRequest,i=new N(64),n=new Map;async function s(a,u){let m=new ce;n.set(a,m),await m.wait({timeout:5e3,onTimeout:u}).finally(()=>n.delete(a));}function c(a){n.get(a)?.signal();}o.onBeforeRequest((a,u)=>{let m=a.url,d=t?Re(m):m;i.schedule(()=>{let p=`${e.id}_${a.id}`;return h.debug(ue,"start:",{key:p,url:m,proxied:d,method:a.method,source:r,stats:i.stats}),u(d===m?{cancel:false}:{cancel:false,redirectURL:d}),s(p,()=>{h.warn(ue,"maybe timeout:",{key:p,url:m,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}`;c(u),h.debug(ue,"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),h.error(ue,"error:",{key:u,url:a.url,method:a.method,error:a.error,source:r});});}function Ce(r){let e=r.webContents.session.webRequest;e.onBeforeRequest(null),e.onHeadersReceived(null),e.onCompleted(null),e.onErrorOccurred(null);}var Te="[Window]";function Yr(r,e){return new Promise((t,o)=>{let i=setTimeout(()=>o(new Error("load window timeout")),3e4),n=s=>{clearTimeout(i),s?o(s):t();};r.webContents.once("did-stop-loading",()=>n()),r.webContents.once("did-frame-finish-load",(s,c,a,u)=>{h.debug(Te,"did-frame-finish-load:",{isMainFrame:c,frameProcessId:a,frameRoutingId:u});}),r.webContents.once("dom-ready",()=>{h.debug(Te,"dom-ready");}),r.webContents.once("did-fail-load",(s,c,a,u)=>n(new Error(`failed to load ${u}: [${c}] ${a}`))),r.webContents.once("render-process-gone",(s,{exitCode:c,reason:a})=>n(new Error(`renderer crashed: ${c}, ${a}`))),e();})}function At(r){return new Promise(e=>{Ce(r),r.once("closed",e),r.destroy();})}async function It({source:r,onCreated:e,renderer:t,warmup:o}){Ft(r);let{width:i,height:n,useInnerProxy:s}=t,c=s?Re(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}});St({source:r,window:a,useInnerProxy:s}),o||await e?.(a),a.webContents.on("console-message",({level:u,message:m,lineNumber:d,sourceId:p})=>{let f=[Te,"console:",{message:m,lineNumber:d,sourceId:p,source:r}];u==="error"?h.error(...f):h.debug(...f);});try{let u=dt(c,{width:i,height:n});await Yr(a,()=>a.loadURL(u));}catch(u){throw await At(a),u}return a}async function de({source:r,onCreated:e,renderer:t}){let o;try{o=await Pt({fn:It,maxAttempts:2})({source:r,renderer:t,warmup:!0});}catch(i){let{message:n,stack:s}=i;throw new Error(`failed to load window: ${JSON.stringify({source:r,message:n,stack:s})}`)}o.webContents.removeAllListeners(),Ce(o),await ae(2e3),await At(o);try{return await It({source:r,renderer:t,onCreated:e})}catch(i){let{message:n,stack:s}=i;throw new Error(`failed to load window: ${JSON.stringify({source:r,message:n,stack:s})}`)}}async function kt(r,e,t){var U=[];try{let{fps:o,width:i,height:n,duration:s,withAudio:c,outFile:a}=t;let u=x(U,await W.create({width:i,height:n,fps:o,outFile:a,withAudio:c}),!0);let m=Math.ceil(o*s);let d=1e3/o;let p=0;let f;let b=0;let w;let v;let R;let _=new ie(o);let I;let g=A=>{p++,u.encodeBGRA(A).catch(Y=>w??=Y);};let P=(A,Y,le)=>{if(w){R?.(w);return}if(ne(le))return;let fe=le.toBitmap(),V=X(fe,le.getSize());if(V===void 0){w??=new Error(`no timestamp @ ${p}`);return}let Nt=i*4,he=Buffer.from(fe.buffer,fe.byteOffset,n*Nt);if(f===void 0)g(he),_.wrote(),f=V;else {let we=V-f;if(we>=d*.8){if(we<=d*1.2)g(he),_.wrote();else {let Le=Math.round(we/d);_.dropped(Le-1),_.wrote();for(let Be=0;Be<Le&&p<m;Be++)g(he);}f=V;}}let De=Math.floor(p/m*100);Math.abs(De-b)>10&&(b=De,r.writeProgress(b));let Wt=s*1e3;(V>=Wt-d*.5||p>=m)&&v?.();};let y=await de({source:e,renderer:t,onCreated:async()=>{c&&(I=await Et({encoder:u,getVideoTimeMs:()=>f??0,onError:A=>w??=A}));}});let C=y.webContents.debugger;y.webContents.setFrameRate(o);y.webContents.isPainting()||y.webContents.startPainting();C.attach("1.3");y.webContents.on("paint",P);try{await Q(C),await new Promise((A,Y)=>[v,R]=[A,Y]);}finally{await Z(C),y.webContents.off("paint",P),y.close(),await I?.teardown(),await u.finish();}if(w||p===0)throw w??new Error("no frames captured");else {let A=_.finalize();return {written:p,jank:A.jank,outFile:a}}}catch(me){var K=me,Bt=true;}finally{var Me=E(U,K,Bt);Me&&await Me;}}function Rt(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 Ct(r){return r.sendCommand("Emulation.setVirtualTimePolicy",{policy:"pause"})}var pe=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 $="__pup_tick__";function Tt(r){return `(function() {
|
|
162
|
+
${"if (window.self === window.top) return;"}
|
|
163
|
+
if (typeof ${$} !== 'undefined') return;
|
|
164
164
|
|
|
165
165
|
const orig = {
|
|
166
|
-
|
|
166
|
+
Date: Date,
|
|
167
167
|
dateNow: Date.now.bind(Date),
|
|
168
|
+
performanceNow: performance.now.bind(performance),
|
|
168
169
|
raf: requestAnimationFrame.bind(window),
|
|
169
170
|
caf: cancelAnimationFrame.bind(window),
|
|
170
171
|
setTimeout: setTimeout.bind(window),
|
|
@@ -177,9 +178,20 @@
|
|
|
177
178
|
let rafQueue = [];
|
|
178
179
|
const timers = {};
|
|
179
180
|
let nextId = 1;
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
181
|
+
const dateOrigin = new orig.Date();
|
|
182
|
+
const perfOrigin = orig.performanceNow();
|
|
183
|
+
|
|
184
|
+
performance.now = function() { return perfOrigin + currMs; };
|
|
185
|
+
Date.now = function() { return dateOrigin.getTime() + currMs; };
|
|
186
|
+
Date = function() {
|
|
187
|
+
var O = orig.Date;
|
|
188
|
+
if (arguments.length === 0) return new O(dateOrigin.getTime() + currMs);
|
|
189
|
+
return new (Function.prototype.bind.apply(O, [null].concat(Array.prototype.slice.call(arguments))))();
|
|
190
|
+
};
|
|
191
|
+
Date.now = function() { return dateOrigin.getTime() + currMs; };
|
|
192
|
+
Date.parse = orig.Date.parse;
|
|
193
|
+
Date.UTC = orig.Date.UTC;
|
|
194
|
+
Date.prototype = orig.Date.prototype;
|
|
183
195
|
|
|
184
196
|
window.requestAnimationFrame = function(cb) {
|
|
185
197
|
const id = nextId++;
|
|
@@ -224,17 +236,17 @@
|
|
|
224
236
|
}
|
|
225
237
|
|
|
226
238
|
function eject() {
|
|
239
|
+
Date = orig.Date;
|
|
227
240
|
performance.now = orig.performanceNow;
|
|
228
|
-
Date.now = orig.dateNow;
|
|
229
241
|
window.requestAnimationFrame = orig.raf;
|
|
230
242
|
window.cancelAnimationFrame = orig.caf;
|
|
231
243
|
window.setTimeout = orig.setTimeout;
|
|
232
244
|
window.clearTimeout = orig.clearTimeout;
|
|
233
245
|
window.setInterval = orig.setInterval;
|
|
234
246
|
window.clearInterval = orig.clearInterval;
|
|
235
|
-
delete window.${
|
|
247
|
+
delete window.${$};
|
|
236
248
|
}
|
|
237
249
|
|
|
238
|
-
window.${
|
|
239
|
-
})();`}function
|
|
240
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../node_modules/.bun/tsup@8.5.1+21dc88144ebc6324/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/audio.ts","../src/base/encoder/muxer.ts","../src/base/encoder/video.ts","../src/base/encoder/encoder.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/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","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","run","v","r","SAMPLE_FMT_NAME","AV_SAMPLE_FMT_FLT","AV_SAMPLE_FMT_FLTP","AudioEncoder","_AudioEncoder","ctx","stream","outFmt","Packet","Frame","codec","Codec","CodecContext","AV_CHANNEL_LAYOUT_STEREO","Rational","AV_CODEC_FLAG_GLOBAL_HEADER","FFmpegError","inSampleRate","graph","FilterGraph","abuffer","Filter","bufSrc","abuffersink","bufSink","filterDesc","outputs","FilterInOut","inputs","pcm","muxer","_stack","nSamples","frame","__using","_","_error","_hasError","__callDispose","AVERROR_EAGAIN","AVERROR_EOF","FormatMuxer","outPath","formatName","FormatContext","codecCtx","codecTag","pkt","VideoEncoder","_VideoEncoder","fps","codecName","globalHeader","codecOpts","bitrate","threadCount","FF_THREAD_SLICE","k","EncoderPipeline","_EncoderPipeline","_video","_audio","_muxer","_limiter","_outFile","_sws","_srcFrame","_dstFrame","outFile","withAudio","video","FF_ENCODER_LIBX265","AV_PIX_FMT_YUVA420P","cpus","audio","FF_ENCODER_AAC","limiter","srcFrame","AV_PIX_FMT_BGRA","sws","SoftwareScaleContext","SWS_BILINEAR","dstFrame","sampleRate","input","_m","_v","_a","_promise","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","TAG","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","duration","total","frameInterval","written","lastWrittenTime","progress","encodeError","resolver","rejecter","dropStats","scheduleFrame","paint","_r","currentTime","bytesPerRow","cropped","timeDelta","framesToInsert","newProgress","durationMs","j","dropScore","advanceVirtualTime","budget","handler","method","pauseVirtualTime","Lazy","makeValue","TICK_SYMBOL","buildTickInjector","doProcess","timestampMs","doEject","awaitStegoFrame","afterTs","_d","ts","shoot","pipeline","frameError","rootFrame","iframe","frameMs","printFeatures","app","exit","c","ok","ipc","mkdir"],"mappings":"whBAKA,IAAA,EAAA,CAAA,MAAA,CAAA,MAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,cAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,wBAAA,CAAA,IAAA,CAAA,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,CAAA,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","// 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, 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.mov\";\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});\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};\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)://, 或 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(\"--use-inner-proxy\", shape.useInnerProxy.description, d.useInnerProxy)\n    .option(\"-d, --deterministic\", shape.deterministic.description, d.deterministic)\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        });\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\nexport class ConcurrencyLimiter {\n  private _active = 0;\n  private _queue: VoidFunction[] = [];\n  private _ended = false;\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>): Promise<T> {\n    if (this._ended) {\n      throw new Error(\"ended\");\n    }\n    return new Promise<T>((resolve, reject) => {\n      const run = () => {\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      this._queue.push(run);\n      this.next();\n    });\n  }\n\n  async end() {\n    if (this._ended) {\n      return;\n    }\n    this._ended = true;\n    while (this._active > 0 || this.pending > 0) {\n      await new Promise((r) => setTimeout(r, 50));\n    }\n  }\n\n  private next() {\n    if (this._active < this.maxConcurrency) {\n      this._queue.shift()?.();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { Codec, CodecContext, FFmpegError, Filter, FilterGraph, FilterInOut, Frame, Packet, Rational } 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\";\n\nconst SAMPLE_FMT_NAME: Partial<Record<number, string>> = { [AV_SAMPLE_FMT_FLT]: \"flt\", [AV_SAMPLE_FMT_FLTP]: \"fltp\" };\ntype Stream = ReturnType<import(\"node-av\").FormatContext[\"newStream\"]>;\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?: any;\n  private _bufSink?: any;\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 = new Packet();\n    this._pkt.alloc();\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 async drainCodec(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._ctx.receivePacket(this._pkt);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"audio.receivePacket\");\n      this._pkt.streamIndex = this._stream.index;\n      this._pkt.rescaleTs(this._ctx.timeBase, this._stream.timeBase);\n      await muxer.writePacket(this._pkt);\n      this._pkt.unref();\n    }\n  }\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/03/21.\n\nimport { Codec, CodecContext, FFmpegError, Frame, Packet, Rational } from \"node-av\";\nimport {\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  FF_THREAD_SLICE,\n  type AVPixelFormat,\n  type FFVideoEncoder,\n} from \"node-av/constants\";\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  threadCount?: number;\n  muxer: FormatMuxer;\n}\n\ntype Stream = ReturnType<import(\"node-av\").FormatContext[\"newStream\"]>;\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, threadCount, 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 (threadCount) {\n      ctx.threadCount = threadCount;\n      ctx.threadType = FF_THREAD_SLICE;\n    }\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 pkt = new Packet();\n    pkt.alloc();\n\n    const stream = muxer.addStream(ctx, codecTag);\n    return new VideoEncoder(ctx, pkt, 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 async drain(muxer: FormatMuxer): Promise<void> {\n    const pkt = this._pkt;\n    while (true) {\n      const r = await this._ctx.receivePacket(pkt);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"video.receivePacket\");\n      pkt.streamIndex = this._stream.index;\n      if (pkt.duration === 0n) pkt.duration = 1n;\n      pkt.rescaleTs(this._ctx.timeBase, this._stream.timeBase);\n      await muxer.writePacket(pkt);\n      pkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { cpus } from \"os\";\nimport { FFmpegError, Frame, SoftwareScaleContext } from \"node-av\";\nimport {\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_YUVA420P,\n  AV_SAMPLE_FMT_FLTP,\n  FF_ENCODER_AAC,\n  FF_ENCODER_LIBX265,\n  SWS_BILINEAR,\n} from \"node-av/constants\";\n\nimport { ConcurrencyLimiter } from \"../limiter\";\nimport { AudioEncoder } from \"./audio\";\nimport { FormatMuxer } from \"./muxer\";\nimport { VideoEncoder } from \"./video\";\n\nexport interface EncoderPipelineOptions {\n  width: number;\n  height: number;\n  fps: number;\n  outFile: string;\n  withAudio?: boolean;\n}\n\nexport class EncoderPipeline {\n  private _disposed = false;\n\n  private constructor(\n    private _video: VideoEncoder,\n    private _audio: AudioEncoder | undefined,\n    private _muxer: FormatMuxer,\n    private _limiter: ConcurrencyLimiter,\n    private _outFile: string,\n    private _sws: SoftwareScaleContext,\n    private _srcFrame: Frame,\n    private _dstFrame: Frame,\n  ) {}\n\n  static async create(opts: EncoderPipelineOptions): Promise<EncoderPipeline> {\n    const { width, height, fps, outFile, withAudio = false } = opts;\n    const muxer = new FormatMuxer(outFile);\n\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: \"ultrafast\", \"x265-params\": \"log-level=1:bframes=0\" },\n      bitrate: 8_000_000,\n      pixelFormat: AV_PIX_FMT_YUVA420P,\n      threadCount: cpus().length,\n      muxer,\n    });\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    const limiter = new ConcurrencyLimiter(1);\n\n    const srcFrame = new Frame();\n    srcFrame.alloc();\n    srcFrame.format = AV_PIX_FMT_BGRA;\n    srcFrame.width = width;\n    srcFrame.height = height;\n    FFmpegError.throwIfError(srcFrame.getBuffer(0), \"srcFrame.getBuffer\");\n\n    const sws = new SoftwareScaleContext();\n    sws.getContext(width, height, AV_PIX_FMT_BGRA, width, height, AV_PIX_FMT_YUVA420P, SWS_BILINEAR);\n    const dstFrame = new Frame();\n    dstFrame.alloc();\n    dstFrame.format = AV_PIX_FMT_YUVA420P;\n    dstFrame.width = width;\n    dstFrame.height = height;\n    FFmpegError.throwIfError(dstFrame.getBuffer(0), \"dstFrame.getBuffer\");\n\n    return new EncoderPipeline(video, audio, muxer, limiter, outFile, sws, srcFrame, dstFrame);\n  }\n\n  setupAudio(sampleRate: number): void {\n    this._audio?.setInputRate(sampleRate);\n  }\n\n  async encodeFrame(input: Buffer): Promise<void> {\n    await this._limiter.schedule(async () => {\n      FFmpegError.throwIfError(this._srcFrame.makeWritable(), \"srcFrame.makeWritable\");\n      FFmpegError.throwIfError(this._srcFrame.fromBuffer(input), \"srcFrame.fromBuffer\");\n      FFmpegError.throwIfError(await this._sws.scaleFrame(this._dstFrame, this._srcFrame), \"sws.scaleFrame\");\n      FFmpegError.throwIfError(this._dstFrame.makeWritable(), \"dstFrame.makeWritable\");\n      return this._video.encode(this._dstFrame, this._muxer);\n    });\n  }\n\n  async encodeAudio(pcm: Buffer): Promise<void> {\n    if (this._audio) await this._limiter.schedule(() => this._audio!.encode(pcm, this._muxer));\n  }\n\n  async finish(): Promise<string> {\n    try {\n      await using _m = this._muxer;\n      using _v = this._video;\n      using _a = this._audio;\n      await this._limiter.end();\n      await this._audio?.flush(this._muxer);\n      await this._video.flush(this._muxer);\n    } finally {\n      this.free();\n    }\n    return this._outFile;\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (this._disposed) return;\n    await this._limiter.end();\n    this._video[Symbol.dispose]();\n    this._audio?.[Symbol.dispose]();\n    await this._muxer[Symbol.asyncDispose]();\n    this.free();\n  }\n\n  private free(): void {\n    if (this._disposed) return;\n    this._disposed = true;\n    this._srcFrame.free();\n    this._dstFrame.free();\n    this._sws[Symbol.dispose]();\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/encoder\";\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/encoder\";\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 } = options;\n\n  await using encoder = await EncoderPipeline.create({ width, height, fps, outFile, withAudio });\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.encodeFrame(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\nexport function advanceVirtualTime(cdp: Debugger, budget: number): Promise<void> {\n  return new Promise((resolve) => {\n    const handler = (_: Electron.Event, method: string) => {\n      if (method === \"Emulation.virtualTimeBudgetExpired\") {\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/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\n/**\n * Builds the JS injector that hooks all time-related globals in the target iframe.\n * Guards against running in the wrapper (top-level) frame so the stego canvas is unaffected.\n * Must be injected via Page.addScriptToEvaluateOnNewDocument AND directly into\n * already-loaded sub-frames.\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    performanceNow: performance.now.bind(performance),\n    dateNow: Date.now.bind(Date),\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\n  performance.now = function() { return currMs; };\n  Date.now = function() { return currMs; };\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    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    performance.now = orig.performanceNow;\n    Date.now = orig.dateNow;\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 } from \"electron\";\nimport { advanceVirtualTime, pauseVirtualTime } from \"../base/cdp\";\nimport { EncoderPipeline } from \"../base/encoder/encoder\";\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\nfunction awaitStegoFrame(win: BrowserWindow, width: number, height: number, afterTs: number): Promise<Buffer> {\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        logger.warn(TAG, `skipping frame ${ts}, expected > ${afterTs}`);\n        return;\n      }\n      win.webContents.stopPainting();\n      win.webContents.off(\"paint\", handler);\n      resolve(Buffer.from(bitmap.buffer, bitmap.byteOffset, height * 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 } = 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: false });\n\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n  let written = 0;\n  let progress = 0;\n  let frameError: Error | undefined;\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    win.webContents.stopPainting();\n    win.webContents.setFrameRate(fps);\n    await pauseVirtualTime(cdp);\n\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      if (frameError) throw frameError;\n\n      const frameMs = (frame + 1) * frameInterval;\n      const bitmap = awaitStegoFrame(win, width, height, frameMs - frameInterval / 2);\n\n      await advanceVirtualTime(cdp, frameInterval);\n      await iframe?.executeJavaScript(doProcess(frameMs));\n\n      win.webContents.startPainting();\n      pipeline.encodeFrame(await bitmap).catch((e) => (frameError ??= e));\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 (frameError || written === 0) {\n    throw frameError ?? 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  },\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"]}
|
|
250
|
+
window.${$} = { process: process, eject: eject };
|
|
251
|
+
})();`}function Oe(r){return `${$}.process(${r})`}function Ot(){return `if (typeof ${$} !== 'undefined') ${$}.eject()`}var Mt="[Shoot]";function Jr(r,e,t,o){return new Promise(i=>{let n=(s,c,a)=>{if(ne(a))return;let u=a.toBitmap(),m=X(u,a.getSize());if(m===void 0||m<o){h.warn(Mt,`skipping frame ${m}, expected > ${o}`);return}r.webContents.stopPainting(),r.webContents.off("paint",n),i(Buffer.from(u.buffer,u.byteOffset,t*e*4));};r.webContents.on("paint",n);})}async function Dt(r,e,t){var R=[];try{let{fps:o,width:i,height:n,duration:s,withAudio:c,outFile:a}=t;c&&h.warn(Mt,"audio will be ignored on this mode");let u=x(R,await W.create({width:i,height:n,fps:o,outFile:a,withAudio:c}),!0);let m=Math.ceil(o*s);let d=1e3/o;let p=0;let f=0;let b=await de({source:e,renderer:t});let w=b.webContents.debugger;let v=new pe(()=>b.webContents.mainFrame.frames[0]);try{w.attach("1.3"),b.webContents.stopPainting(),b.webContents.setFrameRate(o),await Ct(w);let y=v.value;await y?.executeJavaScript(Tt()),await y?.executeJavaScript(Oe(0)),await Q(w);for(let C=0;C<m;C++){let U=(C+1)*d,me=Jr(b,i,n,U-d/2);await Rt(w,d),await y?.executeJavaScript(Oe(U)),b.webContents.startPainting(),await u.encodeBGRA(await me),p++;let K=Math.floor(p/m*100);Math.abs(K-f)>10&&(f=K,r.writeProgress(f));}}finally{await v.value?.executeJavaScript(Ot()),await Z(w),w.detach(),b.close(),await u.finish();}if(p===0)throw new Error("no frames captured");else return {written:p,jank:0,outFile:a}}catch(_){var I=_,g=true;}finally{var P=E(R,I,g);P&&await P;}}var eo="[App]";function Lt(){h.debug(eo,"gpu features:",electron.app.getGPUFeatureStatus());}electron.app.dock?.hide();electron.app.on("window-all-closed",()=>{});nt({name:"app",defaults:{...ot,withAudio:false,deterministic:false,useInnerProxy: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(xe,"pupIpcSocket not set");let o=await st(xe);try{electron.app.on("gpu-info-update",Lt),await electron.app.whenReady(),ut(),Lt(),await promises.mkdir(path.dirname(e.outFile),{recursive:!0});let i=e.deterministic?Dt:kt;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
|
|
252
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../node_modules/.bun/tsup@8.5.1+a6d91f13707ae0fd/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/audio.ts","../src/base/encoder/codec.ts","../src/base/encoder/muxer.ts","../src/base/encoder/video.ts","../src/base/encoder/encoder.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/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","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","run","v","r","SAMPLE_FMT_NAME","AV_SAMPLE_FMT_FLT","AV_SAMPLE_FMT_FLTP","AudioEncoder","_AudioEncoder","ctx","stream","outFmt","Packet","Frame","codec","Codec","CodecContext","AV_CHANNEL_LAYOUT_STEREO","Rational","AV_CODEC_FLAG_GLOBAL_HEADER","FFmpegError","inSampleRate","graph","FilterGraph","abuffer","Filter","bufSrc","abuffersink","bufSink","filterDesc","outputs","FilterInOut","inputs","pcm","muxer","_stack","nSamples","frame","__using","_","_error","_hasError","__callDispose","AVERROR_EAGAIN","AVERROR_EOF","makeFrame","pixFmt","makeSWSContext","sws","SoftwareScaleContext","AV_PIX_FMT_YUVA420P","SWS_BILINEAR","CodecState","_CodecState","FF_DECODER_PNG","ok","png","AV_PIX_FMT_BGRA","FormatMuxer","outPath","formatName","FormatContext","codecCtx","codecTag","pkt","VideoEncoder","_VideoEncoder","fps","codecName","globalHeader","codecOpts","bitrate","k","EncoderPipeline","_EncoderPipeline","_video","_audio","_muxer","_limiter","_outFile","_codec","outFile","withAudio","video","FF_ENCODER_LIBX265","audio","FF_ENCODER_AAC","sampleRate","input","dst","pngData","_m","_v","_a","_promise","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","TAG","map","proxiedUrl","parsed","URL","setInterceptor","window","useInnerProxy","limiter","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","duration","total","frameInterval","written","lastWrittenTime","progress","encodeError","resolver","rejecter","dropStats","scheduleFrame","paint","_r","currentTime","bytesPerRow","cropped","timeDelta","framesToInsert","newProgress","durationMs","j","dropScore","advanceVirtualTime","budget","handler","method","pauseVirtualTime","Lazy","makeValue","TICK_SYMBOL","buildTickInjector","doProcess","timestampMs","doEject","awaitStegoFrame","afterTs","_d","ts","shoot","pipeline","rootFrame","iframe","frameMs","printFeatures","app","exit","c","ipc","mkdir"],"mappings":"whBAKA,IAAA,EAAA,CAAA,MAAA,CAAA,MAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,cAAA,CAAA,IAAA,EAAA,CAAA,MAAA,CAAA,wBAAA,CAAA,IAAA,CAAA,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,CAAA,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, 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});\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};\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)://, 或 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(\"--use-inner-proxy\", shape.useInnerProxy.description, d.useInnerProxy)\n    .option(\"-d, --deterministic\", shape.deterministic.description, d.deterministic)\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        });\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\nexport class ConcurrencyLimiter {\n  private _active = 0;\n  private _queue: VoidFunction[] = [];\n  private _ended = false;\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>): Promise<T> {\n    if (this._ended) {\n      throw new Error(\"ended\");\n    }\n    return new Promise<T>((resolve, reject) => {\n      const run = () => {\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      this._queue.push(run);\n      this.next();\n    });\n  }\n\n  async end() {\n    if (this._ended) {\n      return;\n    }\n    this._ended = true;\n    while (this._active > 0 || this.pending > 0) {\n      await new Promise((r) => setTimeout(r, 50));\n    }\n  }\n\n  private next() {\n    if (this._active < this.maxConcurrency) {\n      this._queue.shift()?.();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { Codec, CodecContext, FFmpegError, Filter, FilterGraph, FilterInOut, Frame, Packet, Rational } 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\";\n\nconst SAMPLE_FMT_NAME: Partial<Record<number, string>> = { [AV_SAMPLE_FMT_FLT]: \"flt\", [AV_SAMPLE_FMT_FLTP]: \"fltp\" };\ntype Stream = ReturnType<import(\"node-av\").FormatContext[\"newStream\"]>;\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?: any;\n  private _bufSink?: any;\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 = new Packet();\n    this._pkt.alloc();\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 async drainCodec(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._ctx.receivePacket(this._pkt);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"audio.receivePacket\");\n      this._pkt.streamIndex = this._stream.index;\n      this._pkt.rescaleTs(this._ctx.timeBase, this._stream.timeBase);\n      await muxer.writePacket(this._pkt);\n      this._pkt.unref();\n    }\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  Frame,\n  Packet,\n  SoftwareScaleContext,\n  SWS_BILINEAR,\n  type AVPixelFormat,\n} from \"node-av\";\n\nfunction 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\nfunction makeSWSContext(width: number, height: number, pixFmt: AVPixelFormat) {\n  const sws = new SoftwareScaleContext();\n  sws.getContext(width, height, pixFmt, width, height, AV_PIX_FMT_YUVA420P, SWS_BILINEAR);\n  return sws;\n}\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 = new Packet();\n    this.pkt.alloc();\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  get sws() {\n    if (!this._sws) {\n      this._sws = makeSWSContext(this.src.width, this.src.height, this.src.format as AVPixelFormat);\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/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/03/21.\n\nimport { Codec, CodecContext, FFmpegError, Frame, Packet, Rational } from \"node-av\";\nimport {\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  type AVPixelFormat,\n  type FFVideoEncoder,\n} from \"node-av/constants\";\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\ntype Stream = ReturnType<import(\"node-av\").FormatContext[\"newStream\"]>;\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 pkt = new Packet();\n    pkt.alloc();\n\n    const stream = muxer.addStream(ctx, codecTag);\n    return new VideoEncoder(ctx, pkt, 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 async drain(muxer: FormatMuxer): Promise<void> {\n    const pkt = this._pkt;\n    while (true) {\n      const r = await this._ctx.receivePacket(pkt);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"video.receivePacket\");\n      pkt.streamIndex = this._stream.index;\n      if (pkt.duration === 0n) pkt.duration = 1n;\n      pkt.rescaleTs(this._ctx.timeBase, this._stream.timeBase);\n      await muxer.writePacket(pkt);\n      pkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { FFmpegError } from \"node-av\";\nimport { AV_PIX_FMT_YUVA420P, AV_SAMPLE_FMT_FLTP, FF_ENCODER_AAC, FF_ENCODER_LIBX265 } from \"node-av/constants\";\n\nimport { ok } from \"assert\";\nimport { ConcurrencyLimiter } from \"../limiter.js\";\nimport { AudioEncoder } from \"./audio\";\nimport { CodecState } from \"./codec.js\";\nimport { FormatMuxer } from \"./muxer\";\nimport { VideoEncoder } from \"./video\";\n\nexport interface EncoderPipelineOptions {\n  width: number;\n  height: number;\n  fps: number;\n  outFile: string;\n  withAudio?: boolean;\n}\n\nexport class EncoderPipeline {\n  private _disposed = false;\n\n  private constructor(\n    private _video: VideoEncoder,\n    private _audio: AudioEncoder | undefined,\n    private _muxer: FormatMuxer,\n    private _limiter: ConcurrencyLimiter,\n    private _outFile: string,\n    private _codec: CodecState,\n  ) {}\n\n  static async create(opts: EncoderPipelineOptions): Promise<EncoderPipeline> {\n    const { width, height, fps, outFile, withAudio = false } = opts;\n    const muxer = new FormatMuxer(outFile);\n\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: \"ultrafast\", \"x265-params\": \"log-level=1:bframes=0\" },\n      bitrate: 8_000_000,\n      pixelFormat: AV_PIX_FMT_YUVA420P,\n      muxer,\n    });\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\n    return new EncoderPipeline(\n      video,\n      audio,\n      muxer,\n      new ConcurrencyLimiter(1),\n      outFile,\n      await CodecState.create(width, height),\n    );\n  }\n\n  setupAudio(sampleRate: number): void {\n    this._audio?.setInputRate(sampleRate);\n  }\n\n  async encodeBGRA(input: Buffer): Promise<void> {\n    await this._limiter.schedule(async () => {\n      const { src, dst, sws } = this._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 this._video.encode(dst, this._muxer);\n    });\n  }\n\n  async encodePNG(pngData: Buffer): Promise<void> {\n    await this._limiter.schedule(async () => {\n      const { pkt, src, dst } = this._codec;\n      using png = await this._codec.png();\n      pkt.data = pngData;\n      FFmpegError.throwIfError(await png.sendPacket(pkt), \"pngDecoder.sendPacket\");\n      pkt.unref();\n      FFmpegError.throwIfError(await png.receiveFrame(src), \"pngDecoder.receiveFrame\");\n      FFmpegError.throwIfError(dst.makeWritable(), \"pngDst.makeWritable\");\n      // NOTE(Autokaka): Must access sws here since it depends on src format\n      FFmpegError.throwIfError(await this._codec.sws.scaleFrame(dst, src), \"pngSws.scaleFrame\");\n      return this._video.encode(dst, this._muxer);\n    });\n  }\n\n  async encodeAudio(pcm: Buffer): Promise<void> {\n    if (this._audio) await this._limiter.schedule(() => this._audio!.encode(pcm, this._muxer));\n  }\n\n  async finish(): Promise<string> {\n    try {\n      await using _m = this._muxer;\n      using _v = this._video;\n      using _a = this._audio;\n      await this._limiter.end();\n      await this._audio?.flush(this._muxer);\n      await this._video.flush(this._muxer);\n    } finally {\n      this.free();\n    }\n    return this._outFile;\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (this._disposed) return;\n    await this._limiter.end();\n    this._video[Symbol.dispose]();\n    this._audio?.[Symbol.dispose]();\n    await this._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._codec;\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/encoder\";\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/encoder\";\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 } = options;\n\n  await using encoder = await EncoderPipeline.create({ width, height, fps, outFile, withAudio });\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/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    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 } from \"electron\";\nimport { advanceVirtualTime, pauseVirtualTime } from \"../base/cdp\";\nimport { EncoderPipeline } from \"../base/encoder/encoder\";\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\nfunction awaitStegoFrame(win: BrowserWindow, width: number, height: number, afterTs: number): Promise<Buffer> {\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        logger.warn(TAG, `skipping frame ${ts}, expected > ${afterTs}`);\n        return;\n      }\n      win.webContents.stopPainting();\n      win.webContents.off(\"paint\", handler);\n      resolve(Buffer.from(bitmap.buffer, bitmap.byteOffset, height * 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 } = 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 });\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    win.webContents.stopPainting();\n    win.webContents.setFrameRate(fps);\n    await pauseVirtualTime(cdp);\n\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(win, width, height, frameMs - frameInterval / 2);\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  },\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"]}
|