pup-recorder 0.3.0 → 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,96 +0,0 @@
1
- import'source-map-support/register.js';import {createRequire}from'module';import {dirname,join}from'path';import {Log,FormatContext,FFmpegError,Frame,Codec,CodecContext,Rational,FilterGraph,Filter,FilterInOut,FF_DECODER_PNG,SoftwareScaleContext,AV_PIX_FMT_YUVA420P as AV_PIX_FMT_YUVA420P$1,SWS_BILINEAR,HardwareFramesContext,Packet,AV_PIX_FMT_BGRA as AV_PIX_FMT_BGRA$1}from'node-av';import {AV_LOG_ERROR,AV_LOG_WARNING,FF_ENCODER_AAC,AV_SAMPLE_FMT_FLTP,FF_HWDEVICE_TYPE_VIDEOTOOLBOX,FF_HWDEVICE_TYPE_CUDA,AV_PIX_FMT_YUVA420P,FF_ENCODER_LIBX265,AV_CHANNEL_LAYOUT_STEREO,AV_CODEC_FLAG_GLOBAL_HEADER,AV_SAMPLE_FMT_FLT,AVERROR_EAGAIN,AVERROR_EOF,AV_PIX_FMT_BGRA,AVCOL_RANGE_JPEG,FF_ENCODER_HEVC_NVENC,AV_PIX_FMT_CUDA,AV_PIX_FMT_YUV420P}from'node-av/constants';import {spawn}from'child_process';import S from'zod';import {ok}from'assert';import {HardwareContext}from'node-av/api';import {randomUUID}from'crypto';import {rmSync}from'fs';import {mkdir}from'fs/promises';import {tmpdir,platform}from'os';import no from'tree-kill';import Wr from'electron';import {EventEmitter}from'events';import {createServer}from'net';import Zr from'puppeteer';var At=Object.create;var ue=Object.defineProperty;var Ct=Object.getOwnPropertyDescriptor;var Q=(o,e)=>(e=Symbol[o])?e:Symbol.for("Symbol."+o),T=o=>{throw TypeError(o)};var Oe=(o,e,t)=>e in o?ue(o,e,{enumerable:true,configurable:true,writable:true,value:t}):o[e]=t;var De=o=>[,,,At(null)],Ne=["class","method","getter","setter","accessor","field","value","get","set"],W=o=>o!==void 0&&typeof o!="function"?T("Function expected"):o,It=(o,e,t,r,i)=>({kind:Ne[o],name:e,metadata:r,addInitializer:n=>t._?T("Already initialized"):i.push(W(n||null))}),pe=(o,e)=>Oe(e,Q("metadata"),o[3]),Le=(o,e,t,r)=>{for(var i=0,n=o[e>>1],s=n&&n.length;i<s;i++)n[i].call(t);return r},L=(o,e,t,r,i,n)=>{var a,c,u,d,p=e&7,m=false,f=false,_=2,x=Ne[p+5],E=o[_]||(o[_]=[]),h=((i=i.prototype),Ct(i,t));for(var y=r.length-1;y>=0;y--)u=It(p,t,c={},o[3],E),(u.static=m,u.private=f,d=u.access={has:l=>t in l},(d.get=l=>l[t]),p>2),a=(0, r[y])(h[x],u),c._=1,W(a)&&(h[x]=a);return h&&ue(i,t,h),i},Ve=(o,e,t)=>Oe(o,e+"",t);var F=(o,e,t)=>{if(e!=null){typeof e!="object"&&typeof e!="function"&&T("Object expected");var r,i;t&&(r=e[Q("asyncDispose")]),r===void 0&&(r=e[Q("dispose")],t&&(i=r)),typeof r!="function"&&T("Object not disposable"),i&&(r=function(){try{i.call(this);}catch(n){return Promise.reject(n)}}),o.push([t,r,e]);}else t&&o.push([t]);return e},k=(o,e,t)=>{var r=typeof SuppressedError=="function"?SuppressedError:function(s,a,c,u){return u=Error(c),u.name="SuppressedError",u.error=s,u.suppressed=a,u},i=s=>e=t?new r(s,e,"An error was suppressed during disposal"):(t=true,s),n=s=>{for(;s=o.pop();)try{var a=s[1]&&s[1].call(s[2]);if(s[0])return Promise.resolve(a).then(n,c=>(i(c),n()))}catch(c){i(c);}if(t)throw e};return n()};function Me(o,e,t){try{return e(process.env[o])}catch{return t}}function Ge(o){if(typeof o=="number")return o;let e=Number(o);if(Number.isNaN(e))throw new Error(`Value ${o} is not a valid number`);return e}function po(o){return typeof o=="string"?o:String(o)}var Nt=createRequire(import.meta.url),z=process.env,K=Me("PUP_LOG_LEVEL",Ge,2),Ue=z.PUP_USE_INNER_PROXY==="1",He=z.PUP_DISABLE_GPU==="1",$e=z.PUP_DETERMINISTIC==="1",Lt=dirname(Nt.resolve("pup-recorder/package.json")),je=join(Lt,"dist","app.cjs"),go=z.PUP_IPC_SOCKET,We=z.PUP_EXPERIMENTAL_PUPPETEER==="1";var me="<pup@debug>",le="<pup@info>",fe="<pup@warn>",he="<pup@error>",we="<pup@fatal>";function q(o,e){return function(...t){let r=t.map(i=>i instanceof Error?i.stack??String(i):i);return o.call(this,...r)}}var ze,qe,Xe,Ye,Qe,B;Qe=[q],Ye=[q],Xe=[q],qe=[q],ze=[q];var I=class{constructor(e=K){this._level=e;Le(B,5,this);Ve(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,r=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?r:void 0,warn:s>=1?i:void 0,error:s>=0?n:void 0};}debug(...e){this.impl?.debug?.(me,...e);}info(...e){this.impl?.info?.(le,...e);}warn(...e){this.impl?.warn?.(fe,...e);}error(...e){this.impl?.error?.(he,...e);}fatal(...e){this.impl?.error?.(we,...e),process.exit(1);}dispatch(e){let t=e.trimEnd();t.startsWith(me)?this.debug(t.slice(me.length+1)):t.startsWith(le)?this.info(t.slice(le.length+1)):t.startsWith(fe)?this.warn(t.slice(fe.length+1)):t.startsWith(he)?this.error(t.slice(he.length+1)):this.info(t);}attach(e,t){return new Promise((r,i)=>{this.debug(`${t}.attach`);let n="",s=a=>{let c=a.toString();c.startsWith(we)?n+=c.slice(we.length+1):this.dispatch(c);};e.stderr?.on("data",s),e.stdout?.on("data",s),e.on("message",s).on("error",a=>{n+=a.message,e.kill();}).once("close",(a,c)=>{a||c||n?(n||=`command failed: ${e.spawnargs.join(" ")}`,this.debug(`${t}.close`,{code:a,signal:c,fatal:n}),i(new Error(n))):(this.debug(`${t}.close`),r());}).on("unhandledRejection",a=>{this.error(`${t}.unhandled`,a);}).on("uncaughtExceptionMonitor",a=>{this.error(`${t}.unhandled`,a);});})}};B=De(),L(B,1,"debug",Qe,I),L(B,1,"info",Ye,I),L(B,1,"warn",Xe,I),L(B,1,"error",qe,I),L(B,1,"fatal",ze,I),pe(B,I);var g=new I;Log.setCallback((o,e)=>{let t=e.trimEnd();t&&(o<=AV_LOG_ERROR?g.error(t):o<=AV_LOG_WARNING&&g.warn(t));});function So(o,e){return (...t)=>{try{let r=o(...t);return r instanceof Promise?r.catch(()=>e):r}catch{return e}}}var be="--pup-priv-args";function To(){let o=process.argv,e=o.find(r=>r.startsWith(be));if(!e)return g.debug("procargv",o),process.argv;let t=["exec",...o.slice(-1)];return e=Buffer.from(e.split("=")[1],"base64").toString(),t.push(...JSON.parse(e)),g.debug("pupargs",t),t}function Ke(o,e){let t=o.split(" ").filter(s=>s.length),[r,...i]=t;if(!r)throw new Error("empty command");let n=spawn(r,i,{stdio:"inherit",...e});return {process:n,wait:g.attach(n,r)}}var Ht=1920,$t=1080,jt=30,Wt=5,zt="output.mp4",Lo=S.object({duration:S.number().describe("Duration in seconds"),width:S.number().describe("Video width"),height:S.number().describe("Video height"),fps:S.number().describe("Frames per second"),withAudio:S.boolean().describe("Capture and encode audio"),outFile:S.string().describe("Output mp4 file path"),useInnerProxy:S.boolean().describe("Use bilibili inner proxy for resource access"),deterministic:S.boolean().describe("Render by frame rather than recording"),disableGpu:S.boolean().describe("Disable GPU rendering, may reduce performance but increase stability")}),Je={width:Ht,height:$t,fps:jt,duration:Wt,outFile:zt,withAudio:false,useInnerProxy:Ue,deterministic:$e,disableGpu:He};var J=class{constructor(e){this.maxConcurrency=e;}maxConcurrency;_active=0;_queue=[];_signals=new WeakSet;_resolve;get active(){return this._active}get pending(){return this._queue.length}get stats(){return `active: ${this.active}, pending: ${this.pending}`}async schedule(e,t){return t?.throwIfAborted(),t&&!this._signals.has(t)&&(this._signals.add(t),t.addEventListener("abort",()=>this.flush(t),{once:true})),new Promise((r,i)=>{this._queue.push({run:()=>{if(t?.aborted){i(t.reason),this.next();return}this._active++,e().then(n=>{this._active--,r(n),this.next();}).catch(n=>{this._active--,i(n),this.next();});},reject:i,signal:t}),this.next();})}async drain(){if(!(this._active===0&&this.pending===0))return new Promise(e=>this._resolve=e)}flush(e){let t=[];for(let r of this._queue)r.signal===e?r.reject(e.reason):t.push(r);this._queue=t,this.next();}next(){if(this._active===0&&this.pending===0){this._resolve?.(),this._resolve=void 0;return}this._active<this.maxConcurrency&&this._queue.shift()?.run();}};var Z=class{_ctx;_opened=false;constructor(e,t){this._ctx=new FormatContext,FFmpegError.throwIfError(this._ctx.allocOutputContext2(null,t??null,e),"allocOutputContext2");}addStream(e,t){let r=this._ctx.newStream(null);return r.timeBase=e.timeBase,FFmpegError.throwIfError(r.codecpar.fromContext(e),"codecpar.fromContext"),t&&(r.codecpar.codecTag=t),r}async open(){this._opened||(FFmpegError.throwIfError(await this._ctx.openOutput(),"openOutput"),FFmpegError.throwIfError(await this._ctx.writeHeader(null),"writeHeader"),this._opened=true);}async writePacket(e){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);}};function O(o,e,t){let r=new Frame;return r.alloc(),r.format=t,r.width=o,r.height=e,FFmpegError.throwIfError(r.getBuffer(0),"frame.getBuffer"),r}function P(){let o=new Packet;return o.alloc(),o}async function V(o,e,t,r){for(;;){let i=await o.receivePacket(e);if(i===AVERROR_EAGAIN||i===AVERROR_EOF)break;FFmpegError.throwIfError(i,"receivePacket"),e.streamIndex=t.index,e.duration===0n&&(e.duration=1n),e.rescaleTs(o.timeBase,t.timeBase),await r.writePacket(e),e.unref();}}var ar={[AV_SAMPLE_FMT_FLT]:"flt",[AV_SAMPLE_FMT_FLTP]:"fltp"},ee=class o{_ctx;_stream;_pkt;_outRate;_outFmt;_frameSize;_filterFrame;_graph;_bufSrc;_bufSink;_inRate;_pts=0n;constructor(e,t,r){this._ctx=e,this._stream=t,this._outRate=e.sampleRate,this._outFmt=r,this._frameSize=e.frameSize,this._pkt=P(),this._filterFrame=new Frame,this._filterFrame.alloc();}static async create(e){let t=Codec.findEncoderByName(e.codecName);if(!t)throw new Error(`Audio encoder not found: ${e.codecName}`);let r=new CodecContext;r.allocContext3(t),r.codecId=t.id,r.sampleFormat=e.outSampleFmt,r.sampleRate=e.outSampleRate,r.channelLayout=AV_CHANNEL_LAYOUT_STEREO,r.timeBase=new Rational(1,e.outSampleRate),r.bitRate=BigInt(e.bitrate),e.globalHeader&&r.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER),FFmpegError.throwIfError(await r.open2(t,null),"audioCtx.open2");let i=e.muxer.addStream(r);return new o(r,i,e.outSampleFmt)}setInputRate(e){this._graph?.[Symbol.dispose](),this._inRate=e;let t=new FilterGraph;t.alloc();let r=Filter.getByName("abuffer"),i=t.createFilter(r,"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=Filter.getByName("abuffersink"),s=t.createFilter(n,"sink");if(!s)throw new Error("Failed to create abuffersink");let c=`aformat=sample_fmts=${ar[this._outFmt]??"flt"}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`,u=FilterInOut.createList([{name:"in",filterCtx:i,padIdx:0}]),d=FilterInOut.createList([{name:"out",filterCtx:s,padIdx:0}]);FFmpegError.throwIfError(t.parsePtr(c,d,u),"graph.parsePtr"),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 r=new Float32Array(e.buffer,e.byteOffset,e.byteLength/4);for(let d=0;d<r.length;d++)isFinite(r[d])||(r[d]=0);let i=r.length>>1;let n=F(s,Frame.fromAudioBuffer(Buffer.from(r.buffer,r.byteOffset,r.byteLength),{nbSamples:i,format:AV_SAMPLE_FMT_FLT,sampleRate:this._inRate,channelLayout:AV_CHANNEL_LAYOUT_STEREO,pts:this._pts,timeBase:{num:1,den:this._inRate}}));this._pts+=BigInt(i);FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(n),"buffersrcAddFrame");await this.drain(t);}catch(a){var c=a,u=true;}finally{k(s,c,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===AVERROR_EAGAIN||t===AVERROR_EOF)break;FFmpegError.throwIfError(t,"buffersinkGetFrame"),FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame),"audioCtx.sendFrame"),this._filterFrame.unref(),await this.drainCodec(e);}}drainCodec(e){return V(this._ctx,this._pkt,this._stream,e)}};var G=class o{src;dst;pkt;_sws;_png;static async create(e,t){let r=Codec.findDecoderByName(FF_DECODER_PNG);return ok(r,"png decoder unavailable"),new o(e,t,r)}constructor(e,t,r){this._png=r,this.src=O(e,t,AV_PIX_FMT_BGRA$1),this.dst=O(e,t,AV_PIX_FMT_YUVA420P$1),this.pkt=P();}async png(){let e=new CodecContext;return e.allocContext3(this._png),FFmpegError.throwIfError(await e.open2(this._png),"pngDecoder.open2"),e}async decodePNG(e){var r=[];try{let t=F(r,await this.png());this.pkt.data=e;FFmpegError.throwIfError(await t.sendPacket(this.pkt),"pngDecoder.sendPacket");this.pkt.unref();FFmpegError.throwIfError(await t.receiveFrame(this.src),"pngDecoder.receiveFrame");return this.src}catch(i){var n=i,s=true;}finally{k(r,n,s);}}get sws(){if(!this._sws){let e=new SoftwareScaleContext,t=this.src.format;e.getContext(this.src.width,this.src.height,t,this.src.width,this.src.height,AV_PIX_FMT_YUVA420P$1,SWS_BILINEAR),this._sws=e;}return this._sws}[Symbol.dispose](){this.src[Symbol.dispose](),this.dst[Symbol.dispose](),this.pkt[Symbol.dispose](),this._sws?.[Symbol.dispose]();}};var U=Buffer.from([0,0,0,1]);function at(o,e){let t=o>>1&63,r=(o&1)<<5|e>>3&31,i=e&7;return {type:t,layerId:r,temporalId:i}}function _e(o,e,t){let r=(o&63)<<1|e>>5&1,i=(e&31)<<3|t&7;return [r,i]}function xe(o){let e=Buffer.alloc(o.length>>3);for(let t=0;t<e.length;t++){let r=0;for(let i=0;i<8;i++)r=r<<1|o[t*8+i];e[t]=r;}return e}function H(o){let e=[],t=0;for(;t<o.length;){let r=0;if(t+3<o.length&&o[t]===0&&o[t+1]===0&&o[t+2]===1)r=3;else if(t+4<o.length&&o[t]===0&&o[t+1]===0&&o[t+2]===0&&o[t+3]===1)r=4;else {t++;continue}let i=t+r;if(i+2>o.length)break;let n=o.length;for(let c=i+2;c<o.length-2;c++)if(o[c]===0&&o[c+1]===0&&(o[c+2]===1||c+3<o.length&&o[c+2]===0&&o[c+3]===1)){n=c;break}let{type:s,layerId:a}=at(o[i],o[i+1]);e.push({type:s,layerId:a,data:o.subarray(i,n)}),t=n;}return e}function ye(o,e){let t=Buffer.from(o),{type:r,temporalId:i}=at(t[0],t[1]),[n,s]=_e(r,e,i);return t[0]=n,t[1]=s,t}var fr=39;function ct(o,e){let t=H(o),r=H(e),i=new Map;for(let a of r){if(a.type===32)continue;let c=i.get(a.type)??[];c.push(a),i.set(a.type,c);}let n=[],s=new Set;for(let a of t){let c=a.type===32?hr(a.data):a.data;if(n.push(U,c),!s.has(a.type)){s.add(a.type);for(let u of i.get(a.type)??[])n.push(U,ye(u.data,1));}}return n.push(ve()),Buffer.concat(n)}function hr(o){let e=o.subarray(2),t=0,r=d=>{let p=0;for(let m=0;m<d;m++){let f=t+m>>3,_=7-(t+m&7);p=p<<1|e[f]>>_&1;}return t+=d,p};r(4);let i=r(1);r(1);let n=t;if(r(6)>0)return o;let a=[];for(let d=0;d<o.length;d++)for(let p=7;p>=0;p--)a.push(o[d]>>p&1);let c=n+16;for(let d=0;d<6;d++)a[c+d]=0;a[c+5]=1;let u=a.length-1;for(;u>0&&a[u]===0;)u--;if(u<=1)throw new Error("Invalid VPS: no RBSP stop bit");for(a[u-1]=1,a.length=u;a.length%8!==0;)a.push(1);if(i)for(let d=0;d<8;d++)a.push(0);a.push(0);for(let d=0;d<16;d++)a.push(d===3?1:0);for(a.push(0,0,0),a.push(0),a.push(1),a.push(1);a.length%8!==0;)a.push(0);return xe(a)}function ve(){let[t,r]=_e(fr,0,1),i=[],n=(s,a)=>{for(let c=a-1;c>=0;c--)i.push(s>>c&1);};for(n(0,1),n(0,3),n(0,3),n(0,9),n(255,9),n(0,1),n(0,1),n(1,1);i.length%8!==0;)n(0,1);return Buffer.concat([U,Buffer.from([t,r]),Buffer.from([165,4]),xe(i),Buffer.from([128])])}function ut(o,e){let t=[];for(let r of o)t.push(U,r.data);for(let r of e)r.type<32&&t.push(U,ye(r.data,1));return Buffer.concat(t)}var re=class o{_s;_seiBuffer;_pts=0n;_seiInjected=false;_alphaBuf;_alphaFrame;constructor(e){this._s=e,this._seiBuffer=ve();}static async create(e){let{width:t,height:r,fps:i,bitrate:n,hw:s,muxer:a}=e,c=Codec.findEncoderByName(FF_ENCODER_HEVC_NVENC);if(!c)throw new Error("hevc_nvenc encoder not found");let u=new HardwareFramesContext;u.alloc(s.deviceContext),u.format=AV_PIX_FMT_CUDA,u.swFormat=AV_PIX_FMT_YUV420P,u.width=t,u.height=r,u.initialPoolSize=20,FFmpegError.throwIfError(u.init(),"hwFramesCtx.init");let d=async y=>{let l=new CodecContext;return l.allocContext3(c),l.codecId=c.id,l.width=t,l.height=r,l.pixelFormat=AV_PIX_FMT_CUDA,y.fullRange&&(l.colorRange=AVCOL_RANGE_JPEG),l.timeBase=new Rational(1,i),l.framerate=new Rational(i,1),l.gopSize=i*2,l.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER),l.setOption("preset","p4"),l.setOption("bf","0"),y.cqp!==void 0?(l.setOption("rc","constqp"),l.setOption("qp",String(y.cqp))):l.bitRate=BigInt(y.br),l.hwFramesCtx=u,FFmpegError.throwIfError(await l.open2(c,null),"nvenc.open2"),l},p=await d({br:n}),m=await d({br:n,fullRange:true,cqp:1}),f=P(),_=P(),x=a.addStream(p,"hvc1"),v=p.extraData,E=m.extraData;v&&E&&(x.codecpar.extradata=ct(v,E));let h=new SoftwareScaleContext;return h.getContext(t,r,AV_PIX_FMT_BGRA,t,r,AV_PIX_FMT_YUV420P,SWS_BILINEAR),new o({baseCtx:p,alphaCtx:m,basePkt:f,alphaPkt:_,stream:x,baseSws:h,yuvFrame:O(t,r,AV_PIX_FMT_YUV420P),hwFramesCtx:u})}async encode(e,t){let{baseCtx:r,alphaCtx:i,baseSws:n,yuvFrame:s,hwFramesCtx:a}=this._s,c=this._pts++;FFmpegError.throwIfError(s.makeWritable(),"yuv.makeWritable"),FFmpegError.throwIfError(await n.scaleFrame(s,e),"sws.base");let u=e.data?.[0],d=e.linesize?.[0];if(!u||!d)throw new Error("encode: missing BGRA data");let p=e.width,m=e.height,f=p*m,_=(p>>1)*(m>>1);this._alphaBuf||(this._alphaBuf=Buffer.alloc(f+_*2));let x=this._alphaBuf;for(let h=0;h<m;h++)for(let y=0;y<p;y++)x[h*p+y]=u[h*d+y*4+3];x.fill(128,f,f+_*2),this._alphaFrame?.free(),this._alphaFrame=Frame.fromVideoBuffer(x,{format:AV_PIX_FMT_YUV420P,width:p,height:m});let v=new Frame;v.alloc(),FFmpegError.throwIfError(a.getBuffer(v,0),"base.getBuffer"),FFmpegError.throwIfError(await a.transferData(v,s,0),"base.transfer"),v.pts=c,v.duration=1n;let E=new Frame;E.alloc(),FFmpegError.throwIfError(a.getBuffer(E,0),"alpha.getBuffer"),FFmpegError.throwIfError(await a.transferData(E,this._alphaFrame,0),"alpha.transfer"),E.pts=c,E.duration=1n,FFmpegError.throwIfError(await r.sendFrame(v),"base.sendFrame"),FFmpegError.throwIfError(await i.sendFrame(E),"alpha.sendFrame"),await this.drainInterleaved(t),v.free(),E.free();}async flush(e){await this._s.baseCtx.sendFrame(null),await this._s.alphaCtx.sendFrame(null),await this.drainInterleaved(e);}[Symbol.dispose](){let{basePkt:e,alphaPkt:t,yuvFrame:r,baseSws:i,hwFramesCtx:n,baseCtx:s,alphaCtx:a}=this._s;e.free(),t.free(),r[Symbol.dispose](),this._alphaFrame?.free(),i[Symbol.dispose](),n.free(),s.freeContext(),a.freeContext();}async drainInterleaved(e){let{baseCtx:t,alphaCtx:r,basePkt:i,alphaPkt:n,stream:s}=this._s;for(;;){let a=await t.receivePacket(i),c=await r.receivePacket(n),u=a>=0,d=c>=0;if(!u&&!d)break;if(u!==d)throw new Error(`NVENC desync: base=${u}, alpha=${d}`);let p=H(i.data),m=H(n.data),f=[];this._seiInjected||(f.push(this._seiBuffer),this._seiInjected=true),f.push(ut(p,m));let _=i.pts,x=i.dts,v=i.duration;i.data=Buffer.concat(f),i.pts=_,i.dts=x,i.duration=v===0n?1n:v,i.streamIndex=s.index,i.rescaleTs(t.timeBase,s.timeBase),await e.writePacket(i),i.unref(),n.unref();}}};var oe=class o{_ctx;_pkt;_stream;_pts=0n;constructor(e,t,r){this._ctx=e,this._pkt=t,this._stream=r;}static async create(e){let{width:t,height:r,fps:i,codecName:n,codecTag:s,globalHeader:a,codecOpts:c,bitrate:u,muxer:d}=e,p=Codec.findEncoderByName(n);if(!p)throw new Error(`Video encoder not found: ${n}`);let m=new CodecContext;m.allocContext3(p),m.codecId=p.id,m.width=t,m.height=r,m.pixelFormat=e.pixelFormat,m.timeBase=new Rational(1,i),m.framerate=new Rational(i,1),m.gopSize=i*2,m.bitRate=BigInt(u),a&&m.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);for(let[_,x]of Object.entries(c))m.setOption(_,x);s&&(m.codecTag=s),FFmpegError.throwIfError(await m.open2(p,null),"videoCtx.open2");let f=d.addStream(m,s);return new o(m,P(),f)}async encode(e,t){e.pts=this._pts++,e.duration=1n,FFmpegError.throwIfError(await this._ctx.sendFrame(e),"videoCtx.sendFrame"),await this.drain(t);}async flush(e){await this._ctx.sendFrame(null),await this.drain(e);}[Symbol.dispose](){this._pkt.free(),this._ctx.freeContext();}drain(e){return V(this._ctx,this._pkt,this._stream,e)}};var ie=class o{_ctx;_pkt;_stream;_pts=0n;constructor(e,t,r){this._ctx=e,this._pkt=t,this._stream=r;}static async create(e){let{width:t,height:r,fps:i,hw:n,bitrate:s,muxer:a}=e,c=n.getEncoderCodec("hevc");if(!c)throw new Error("hevc_videotoolbox encoder not found");let u=new CodecContext;u.allocContext3(c),u.codecId=c.id,u.width=t,u.height=r,u.pixelFormat=AV_PIX_FMT_BGRA,u.colorRange=AVCOL_RANGE_JPEG,u.timeBase=new Rational(1,i),u.framerate=new Rational(i,1),u.gopSize=i*2,u.bitRate=BigInt(s),u.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER),u.setOption("alpha_quality","1"),u.codecTag="hvc1",FFmpegError.throwIfError(await u.open2(c,null),"vtEnc.open2");let d=a.addStream(u,"hvc1");return new o(u,P(),d)}async encode(e,t){e.pts=this._pts++,e.duration=1n,FFmpegError.throwIfError(await this._ctx.sendFrame(e),"vtEnc.sendFrame"),await this.drain(t);}async flush(e){await this._ctx.sendFrame(null),await this.drain(e);}[Symbol.dispose](){this._pkt.free(),this._ctx.freeContext();}drain(e){return V(this._ctx,this._pkt,this._stream,e)}};var Fe="[Encoder]";async function wt(o,e){let{width:t,height:r,fps:i,bitrate:n=8e6,disableGpu:s=false}=o,a=s?void 0:HardwareContext.auto()??void 0;return a?.deviceTypeName===FF_HWDEVICE_TYPE_VIDEOTOOLBOX&&a.getEncoderCodec("hevc")?(g.debug(Fe,"using VideoToolbox HEVC alpha encoder"),{hwVideo:await ie.create({width:t,height:r,fps:i,hw:a,bitrate:n,muxer:e}),hw:a}):a?.deviceTypeName===FF_HWDEVICE_TYPE_CUDA&&a.getEncoderCodec("hevc")?(g.debug(Fe,"using NVENC dual-layer HEVC alpha encoder"),{hwVideo:await re.create({width:t,height:r,fps:i,hw:a,bitrate:n,muxer:e}),hw:a}):(g.debug(Fe,"using software libx265 HEVC alpha encoder"),a?.dispose(),{video:await oe.create({width:t,height:r,fps:i,codecName:FF_ENCODER_LIBX265,codecTag:"hvc1",globalHeader:true,codecOpts:{preset:"medium","x265-params":"log-level=1:bframes=3:pools=+:frame-threads=0"},bitrate:n,pixelFormat:AV_PIX_FMT_YUVA420P,muxer:e}),codec:await G.create(t,r)})}var ne=class o{_s;_disposed=false;constructor(e){this._s=e;}static async create(e){let{width:t,height:r,outFile:i,withAudio:n=false}=e,s=new Z(i),{video:a,hwVideo:c,codec:u,hw:d}=await wt(e,s),p;return n&&(p=await ee.create({outSampleRate:44100,outSampleFmt:AV_SAMPLE_FMT_FLTP,codecName:FF_ENCODER_AAC,globalHeader:true,bitrate:128e3,muxer:s})),await s.open(),new o({video:a,hwVideo:c,audio:p,muxer:s,limiter:new J(1),outFile:i,codec:u,hw:d,width:t,height:r})}setupAudio(e){this._s.audio?.setInputRate(e);}async encodeBGRA(e){await this._s.limiter.schedule(async()=>{let{hwVideo:t,video:r,codec:i,muxer:n}=this._s;if(t){var u=[];try{let f=F(u,this.bgraFrame(e));await t.encode(f,n);return}catch(d){var p=d,m=true;}finally{k(u,p,m);}}let{src:s,dst:a,sws:c}=i;return ok(c,"sws not initialized"),FFmpegError.throwIfError(s.makeWritable(),"bgraSrc.makeWritable"),FFmpegError.throwIfError(s.fromBuffer(e),"bgraSrc.fromBuffer"),FFmpegError.throwIfError(a.makeWritable(),"bgraDst.makeWritable"),FFmpegError.throwIfError(await c.scaleFrame(a,s),"bgraSws.scaleFrame"),r.encode(a,n)});}async encodePNG(e){await this._s.limiter.schedule(async()=>{let{hwVideo:t,video:r,codec:i,muxer:n,width:s,height:a}=this._s,c=i??await G.create(s,a);try{let u=await c.decodePNG(e);t?await t.encode(u,n):(FFmpegError.throwIfError(c.dst.makeWritable(),"pngDst.makeWritable"),FFmpegError.throwIfError(await c.sws.scaleFrame(c.dst,u),"pngSws.scaleFrame"),await r.encode(c.dst,n));}finally{i||c[Symbol.dispose]();}});}async encodeAudio(e){let{audio:t,limiter:r,muxer:i}=this._s;t&&await r.schedule(()=>t.encode(e,i));}async finish(){let{video:e,hwVideo:t,audio:r,muxer:i,limiter:n}=this._s;try{var s=[];try{let p=F(s,i,!0);let m=F(s,e);let f=F(s,t);let _=F(s,r);await n.drain();await r?.flush(i);t?await t.flush(i):await e.flush(i);}catch(a){var c=a,u=!0;}finally{var d=k(s,c,u);d&&await d;}}finally{this.free();}return this._s.outFile}async[Symbol.asyncDispose](){if(this._disposed)return;let{video:e,hwVideo:t,audio:r,muxer:i,limiter:n}=this._s;await n.drain(),e?.[Symbol.dispose](),t?.[Symbol.dispose](),r?.[Symbol.dispose](),await i[Symbol.asyncDispose](),this.free();}free(){var t=[];try{if(this._disposed)return;this._disposed=!0;let e=F(t,this._s.codec);this._s.hw?.dispose();}catch(r){var i=r,n=true;}finally{k(t,i,n);}}bgraFrame(e){let t=O(this._s.width,this._s.height,AV_PIX_FMT_BGRA);return FFmpegError.throwIfError(t.fromBuffer(e),"bgraFrame.fromBuffer"),t}};var Hr="[HWAccel]";async function $r(){let o=HardwareContext.auto(),e=o!==null;return o?.dispose(),e}var bt=$r().then(o=>(g.debug(Hr,"gpu:",o),o));async function ae(o){let e=["no-sandbox","disable-dev-shm-usage","disable-web-security","disable-site-isolation-trials","ignore-certificate-errors","disable-blink-features=AutomationControlled","mute-audio","autoplay-policy=no-user-gesture-required","disable-extensions","force-device-scale-factor=1","force-color-profile=srgb","ignore-gpu-blocklist","use-gl=angle","deterministic-mode","enable-begin-frame-control","disable-new-content-rendering-timeout","run-all-compositor-stages-before-draw","disable-threaded-animation","disable-threaded-scrolling","disable-checker-imaging","disable-image-animation-resync","enable-surface-synchronization","font-render-hinting=none","disable-background-networking"];K<3&&e.push("log-level=3");let t=["FontationBackend"];if(!(await bt&&!o))e.push("use-angle=swiftshader","enable-unsafe-swiftshader");else {e.push("disable-gpu-sandbox","enable-unsafe-webgpu");let i=platform();i==="darwin"?e.push("use-angle=metal"):i==="win32"?e.push("use-angle=d3d11"):(e.push("use-angle=vulkan","disable-vulkan-surface"),t.push("Vulkan"));}return e.push(`enable-features=${t.join(",")}`),e}async function qr(o){return [...await ae(o),"headless=new"]}var Xr="[Electron]";async function gt(o,e,t){let r=[],i=platform();i==="linux"&&r.push("xvfb-run","--auto-servernum",`--server-args="-screen 0 ${o.width}x${o.height}x24"`);let s=(await qr(e.includes("--disable-gpu"))).map(u=>`--${u}`),a=Buffer.from(JSON.stringify(e)).toString("base64");s.push(`${be}=${a}`),r.push(Wr,...s,je);let c=r.join(" ");return g.debug(Xr,c),Ke(c,{stdio:["ignore","pipe","pipe"],shell:i==="linux",env:{...process.env,RUST_BACKTRACE:"full",PUP_IPC_SOCKET:t}})}var se=8;var Pe=class extends EventEmitter{constructor(t){super();this._socket=t;this._socket.on("data",r=>this.onData(r)),this._socket.on("error",r=>this.emit("error",r)),this._socket.on("close",()=>this.emit("close"));}_socket;_chunks=[];_buffered=0;onData(t){this._chunks.push(t),this._buffered+=t.byteLength,this.flush();}flush(){for(;;){if(this._buffered<se)return;let t=this.peek(se),r=t.readUInt32LE(0),i=t.readUInt32LE(4);if(this._buffered<se+i)return;this.consume(se);let n=this.consume(i);switch(this.emit("message",r,n),r){case 1:{this.emit("progress",Number(n.toString()));break}case 2:{this.emit("done",JSON.parse(n.toString()));break}case 3:{this.emit("error",new Error(n.toString()));break}}}}peek(t){return this._chunks[0]&&this._chunks[0].byteLength>=t?this._chunks[0]:Buffer.concat(this._chunks).subarray(0,t)}consume(t){let r=Buffer.allocUnsafe(t),i=0;for(;i<t;){let n=this._chunks[0],s=Math.min(n.byteLength,t-i);n.copy(r,i,0,s),s===n.byteLength?this._chunks.shift():this._chunks[0]=n.subarray(s),i+=s;}return this._buffered-=t,r}};function _t(o){return new Promise((e,t)=>{let r=createServer();r.once("error",t),r.listen(o,()=>{e({waitForConnection(){return new Promise((i,n)=>{r.once("connection",s=>i(new Pe(s))),r.once("error",n);})},close(){r.close();}});});})}var $="__pup_tick__";function xt(o){return `(function() {
2
- ${""}
3
- if (typeof ${$} !== 'undefined') return;
4
-
5
- const orig = {
6
- Date: Date,
7
- dateNow: Date.now.bind(Date),
8
- performanceNow: performance.now.bind(performance),
9
- raf: requestAnimationFrame.bind(window),
10
- caf: cancelAnimationFrame.bind(window),
11
- setTimeout: setTimeout.bind(window),
12
- clearTimeout: clearTimeout.bind(window),
13
- setInterval: setInterval.bind(window),
14
- clearInterval: clearInterval.bind(window),
15
- };
16
-
17
- let currMs = 0;
18
- let rafQueue = [];
19
- const timers = {};
20
- let nextId = 1;
21
- const dateOrigin = new orig.Date();
22
- const perfOrigin = orig.performanceNow();
23
-
24
- performance.now = function() { return perfOrigin + currMs; };
25
- Date.now = function() { return dateOrigin.getTime() + currMs; };
26
- Date = function() {
27
- var O = orig.Date;
28
- if (arguments.length === 0) return new O(dateOrigin.getTime() + currMs);
29
- return new (Function.prototype.bind.apply(O, [null].concat(Array.prototype.slice.call(arguments))))();
30
- };
31
- Date.now = function() { return dateOrigin.getTime() + currMs; };
32
- Date.parse = orig.Date.parse;
33
- Date.UTC = orig.Date.UTC;
34
- Date.prototype = orig.Date.prototype;
35
-
36
- window.requestAnimationFrame = function(cb) {
37
- const id = nextId++;
38
- rafQueue.push({ id, cb });
39
- return id;
40
- };
41
- window.cancelAnimationFrame = function(id) {
42
- rafQueue = rafQueue.filter((r) => r.id !== id);
43
- };
44
-
45
- window.setTimeout = function(cb, delay, ...args) {
46
- const id = nextId++;
47
- timers[id] = { type: 'timeout', cb, delay: delay || 0, next: currMs + (delay || 0), args };
48
- return id;
49
- };
50
- window.clearTimeout = function(id) { delete timers[id]; };
51
-
52
- window.setInterval = function(cb, delay, ...args) {
53
- const id = nextId++;
54
- const d = Math.max(delay || 0, 1);
55
- timers[id] = { type: 'interval', cb, delay: d, next: currMs + d, args };
56
- return id;
57
- };
58
- window.clearInterval = function(id) { delete timers[id]; };
59
-
60
- function process(timestampMs) {
61
- currMs = timestampMs;
62
- document.getAnimations().forEach(a => {
63
- a.pause();
64
- a.currentTime = currMs;
65
- });
66
- const ids = Object.keys(timers);
67
- for (let i = 0; i < ids.length; i++) {
68
- const t = timers[ids[i]];
69
- if (!t) continue;
70
- while (t.next <= currMs) {
71
- if (typeof t.cb === 'string') eval(t.cb); else t.cb.apply(undefined, t.args);
72
- if (t.type === 'timeout') { delete timers[ids[i]]; break; }
73
- t.next += t.delay;
74
- }
75
- }
76
- const rafs = rafQueue.splice(0);
77
- for (let j = 0; j < rafs.length; j++) {
78
- rafs[j].cb(currMs);
79
- }
80
- }
81
-
82
- function eject() {
83
- Date = orig.Date;
84
- performance.now = orig.performanceNow;
85
- window.requestAnimationFrame = orig.raf;
86
- window.cancelAnimationFrame = orig.caf;
87
- window.setTimeout = orig.setTimeout;
88
- window.clearTimeout = orig.clearTimeout;
89
- window.setInterval = orig.setInterval;
90
- window.clearInterval = orig.clearInterval;
91
- delete window.${$};
92
- }
93
-
94
- window.${$} = { process: process, eject: eject };
95
- })();`}function ke(o){return `${$}.process(${o})`}function yt(){return `if (typeof ${$} !== 'undefined') ${$}.eject()`}var vt="[Puppeteer]";async function Et(o,e,t){var f=[];try{let{fps:r,width:i,height:n,duration:s,outFile:a,disableGpu:c}=e;e.withAudio&&g.warn(vt,"audio capture is not supported in Puppeteer mode");let u=Math.ceil(r*s);let d=1e3/r;await mkdir(dirname(a),{recursive:!0});let p=F(f,await ne.create({width:i,height:n,fps:r,outFile:a,disableGpu:c}),!0);let m=await Zr.launch({headless:"shell",defaultViewport:{width:i,height:n},args:(await ae(c)).map(h=>`--${h}`)});try{let h=(await m.pages())[0],y=await h.createCDPSession(),l=h._client(),N=xt({skipFrameGuard:!0}),{identifier:kt}=await l.send("Page.addScriptToEvaluateOnNewDocument",{source:N});try{await h.goto(o,{waitUntil:"networkidle0",timeout:3e4});for(let C of h.frames())await C.evaluate(N),await C.evaluate(ke(0));await y.send("HeadlessExperimental.enable"),await y.send("HeadlessExperimental.beginFrame",{frameTimeTicks:0,interval:d,noDisplayUpdates:!1});let Y=0,ce=0,Se=0,Ae=d;for(let C=0;C<u;C++){Se+=d,await Promise.all(h.frames().map(St=>St.evaluate(ke(Se))));let Ce=await y.send("HeadlessExperimental.beginFrame",{frameTimeTicks:Ae,interval:d,noDisplayUpdates:!1,screenshot:{format:"png"}});if(Ae+=d,!Ce.screenshotData){g.warn(vt,`frame ${C} produced no screenshot`);continue}await p.encodePNG(Buffer.from(Ce.screenshotData,"base64")),Y++;let Ie=Math.floor(Y/u*100);Math.abs(Ie-ce)>10&&(ce=Ie,t?.(ce));}for(let C of h.frames())C.detached||await C.evaluate(yt());if(Y===0)throw new Error("no frames captured");return {written:Y,jank:0,outFile:a}}finally{await y.send("HeadlessExperimental.disable"),await l.send("Page.removeScriptToEvaluateOnNewDocument",{identifier:kt}),await y.detach();}}finally{await m.close();}}catch(_){var x=_,v=true;}finally{var E=k(f,x,v);E&&await E;}}var j="[pup]";async function ao(o,e,t){g.debug(j,"runPupApp",o,e);let r=[o,"--width",`${e.width}`,"--height",`${e.height}`,"--fps",`${e.fps}`,"--duration",`${e.duration}`,"--out-file",`${e.outFile}`];return e.withAudio&&r.push("--with-audio"),e.useInnerProxy&&r.push("--use-inner-proxy"),e.deterministic&&r.push("--deterministic"),e.disableGpu&&r.push("--disable-gpu"),gt(e,r,t)}var R=Je;async function ta(o,e){g.debug(j,"pup",o,e);let{signal:t}=e;if(t?.aborted)throw t.reason;let r=e.outFile??R.outFile,i={width:e.width??R.width,height:e.height??R.height,fps:e.fps??R.fps,duration:e.duration??R.duration,withAudio:e.withAudio??R.withAudio,useInnerProxy:e.useInnerProxy??R.useInnerProxy,deterministic:e.deterministic??R.deterministic,disableGpu:e.disableGpu??R.disableGpu,outFile:r},n=join(tmpdir(),"pup",randomUUID());await mkdir(n,{recursive:true});let s=join(n,"pup.sock"),a=performance.now(),c=m=>(g.info(j,`${o} progress: ${m}%`),e.onProgress?.(m));if(platform()==="linux"&&i.deterministic&&We){c(0);let m=await Et(o,i,c);return c(100),g.info(j,`done ${r} in ${Math.round(performance.now()-a)}ms`),{...m,options:i}}let u=await _t(s),d=await ao(o,{...i,signal:t},s),p=()=>{g.debug(j,"aborted");let m=d.process.pid;m?no(m):d.process.kill(),rmSync(n,{recursive:true,force:true});};t?.addEventListener("abort",p,{once:true});try{let m=new Promise(async(_,x)=>{(await u.waitForConnection()).on("close",()=>x(new Error("IPC closed without result"))).on("message",()=>t?.aborted&&x(t.reason)).on("progress",c).on("done",_).on("error",x);}).finally(()=>u.close());c(0);let f=await Promise.race([m,d.wait]);return ok(f,"no summary received"),c(100),g.info(j,`done ${r} in ${Math.round(performance.now()-a)}ms`),{...f,options:i}}catch(m){throw t?.aborted?t.reason:m}finally{rmSync(n,{recursive:true,force:true});}}export{ne as A,ta as B,Me as a,Ge as b,po as c,K as d,Ue as e,He as f,$e as g,Lt as h,je as i,go as j,We as k,I as l,g as m,So as n,be as o,To as p,Ke as q,Ht as r,$t as s,jt as t,Wt as u,zt as v,Lo as w,Je as x,J as y,Z as z};//# sourceMappingURL=chunk-G3FZJBQC.js.map
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../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/base/limiter.ts","../src/base/encoder/muxer.ts","../src/base/encoder/shared.ts","../src/base/encoder/audio.ts","../src/base/encoder/codec.ts","../src/base/encoder/nal.ts","../src/base/encoder/alpha.ts","../src/base/encoder/nvenc.ts","../src/base/encoder/video.ts","../src/base/encoder/videotoolbox.ts","../src/base/encoder/factory.ts","../src/base/encoder/pipeline.ts","../src/base/hwaccel.ts","../src/base/chromium.ts","../src/renderer/electron.ts","../src/renderer/ipc.ts","../src/renderer/tick.ts","../src/renderer/puppeteer.ts","../src/pup.ts"],"names":["penv","name","parser","defaultValue","parseNumber","x","num","parseString","require","createRequire","env","pupLogLevel","pupUseInnerProxy","pupDisableGPU","pupDeterministic","pupPkgRoot","dirname","pupApp","join","pupIpcSocket","pupExperimentalPuppeteer","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","exec","cmd","options","parts","command","spawn","DEFAULT_WIDTH","DEFAULT_HEIGHT","DEFAULT_FPS","DEFAULT_DURATION","DEFAULT_OUT_FILE","RenderSchema","z","defaultRenderOptions","ConcurrencyLimiter","maxConcurrency","v","e","r","keep","entry","FormatMuxer","outPath","formatName","FormatContext","FFmpegError","codecCtx","codecTag","stream","pkt","makeFrame","width","height","pixFmt","frame","Frame","makePacket","Packet","drainPackets","ctx","muxer","AVERROR_EAGAIN","AVERROR_EOF","SAMPLE_FMT_NAME","AV_SAMPLE_FMT_FLT","AV_SAMPLE_FMT_FLTP","AudioEncoder","_AudioEncoder","outFmt","opts","codec","Codec","CodecContext","AV_CHANNEL_LAYOUT_STEREO","Rational","AV_CODEC_FLAG_GLOBAL_HEADER","inSampleRate","graph","FilterGraph","abuffer","Filter","bufSrc","abuffersink","bufSink","filterDesc","outputs","FilterInOut","inputs","pcm","_stack","src","i","nSamples","__using","_","_error","_hasError","__callDispose","CodecState","_CodecState","FF_DECODER_PNG","ok","png","AV_PIX_FMT_BGRA","AV_PIX_FMT_YUVA420P","pngData","sws","SoftwareScaleContext","fmt","SWS_BILINEAR","ANNEX_B_START_CODE","parseNalType","header0","header1","type","layerId","temporalId","encodeNalHeader","byte0","byte1","packBits","bits","buf","byte","b","splitNalUnits","bitstream","nals","scLen","nalStart","nalEnd","j","rewriteNalLayerId","nal","out","b0","b1","NAL_UNIT_PREFIX_SEI","buildUnifiedExtradata","baseExtradata","alphaExtradata","baseNals","alphaNals","alphaByType","arr","chunks","emitted","patchVPSForAlpha","alphaNal","buildAlphaChannelInfoSEI","vpsData","rbsp","bitPos","readBits","n","val","byteIdx","bitIdx","vpsBaseLayerInternalFlag","maxLayersPos","mlOffset","lastBit","h0","h1","writeBits","interleaveAccessUnits","NvencDualLayerEncoder","_NvencDualLayerEncoder","s","fps","bitrate","hw","FF_ENCODER_HEVC_NVENC","hwFramesCtx","HardwareFramesContext","AV_PIX_FMT_CUDA","AV_PIX_FMT_YUV420P","makeCtx","ctxOpts","AVCOL_RANGE_JPEG","baseCtx","alphaCtx","basePkt","alphaPkt","baseExtra","alphaExtra","baseSws","bgraFrame","yuvFrame","pts","srcLs","w","h","ySize","uvSize","y","baseHwFrame","alphaHwFrame","baseR","alphaR","baseReady","alphaReady","dts","duration","VideoEncoder","_VideoEncoder","codecName","globalHeader","codecOpts","k","VideoToolboxEncoder","_VideoToolboxEncoder","TAG","createVideoEncoder","disableGpu","HardwareContext","FF_HWDEVICE_TYPE_VIDEOTOOLBOX","FF_HWDEVICE_TYPE_CUDA","FF_ENCODER_LIBX265","EncoderPipeline","_EncoderPipeline","outFile","withAudio","video","hwVideo","audio","FF_ENCODER_AAC","sampleRate","input","dst","cs","limiter","_m","_v","_hv","_a","_promise","_codec","detectGPUDriver","result","canIUseGPU","chromiumOptions","features","plat","platform","electronOpts","runElectronApp","size","ipcSocketPath","cmdParts","electronArgs","a","base64Args","electron","HEADER_SIZE","IpcReader","EventEmitter","_socket","header","len","payload","offset","chunk","take","createIpcServer","socketPath","server","createServer","no","socket","TICK_SYMBOL","buildTickInjector","doProcess","timestampMs","doEject","doPuppeteer","source","onProgress","total","frameInterval","mkdir","pipeline","browser","puppeteer","page","session","pageClient","tickScript","identifier","written","progress","captureTimestamp","frameTimeTicks","newProgress","runPupApp","d","pup","renderOpts","tmpDir","tmpdir","randomUUID","t0","tick","p","summary","handle","onAbort","pid","treeKill","rmSync"],"mappings":"knCAMO,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":"chunk-G3FZJBQC.js","sourcesContent":["// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nexport type EnvParser<T> = (value: unknown) => T;\n\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue: T): T;\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue?: T): T | undefined;\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue?: T): T | undefined {\n  try {\n    return parser(process.env[name]);\n  } catch {\n    return defaultValue;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nexport function parseNumber(x: unknown): number {\n  if (typeof x === \"number\") {\n    return x;\n  }\n  const num = Number(x);\n  if (Number.isNaN(num)) {\n    throw new Error(`Value ${x} is not a valid number`);\n  }\n  return num;\n}\n\nexport function parseString(x: unknown): string {\n  if (typeof x === \"string\") return x;\n  return String(x);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { createRequire } from \"module\";\nimport { dirname, join } from \"path\";\nimport { penv } from \"./env\";\nimport { parseNumber } from \"./parser\";\n\nconst require = createRequire(import.meta.url);\nconst env = process.env;\n\nexport const pupLogLevel = penv(\"PUP_LOG_LEVEL\", parseNumber, 2);\nexport const pupUseInnerProxy = env[\"PUP_USE_INNER_PROXY\"] === \"1\";\nexport const pupDisableGPU = env[\"PUP_DISABLE_GPU\"] === \"1\";\nexport const pupDeterministic = env[\"PUP_DETERMINISTIC\"] === \"1\";\n\nexport const pupPkgRoot = dirname(require.resolve(\"pup-recorder/package.json\"));\nexport const pupApp = join(pupPkgRoot, \"dist\", \"app.cjs\");\nexport const pupIpcSocket = env[\"PUP_IPC_SOCKET\"];\n\nexport const pupExperimentalPuppeteer = env[\"PUP_EXPERIMENTAL_PUPPETEER\"] === \"1\";\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport { ChildProcess, type Serializable } from \"child_process\";\nimport { Log } from \"node-av\";\nimport { AV_LOG_ERROR, AV_LOG_WARNING } from \"node-av/constants\";\nimport { pupLogLevel } from \"./constants\";\n\nexport interface LoggerLike {\n  debug?(this: void, ...messages: unknown[]): void;\n\n  info?(this: void, ...messages: unknown[]): void;\n\n  warn?(this: void, ...messages: unknown[]): void;\n\n  error?(this: void, ...messages: unknown[]): void;\n}\n\nconst DEBUG = \"<pup@debug>\";\nconst INFO = \"<pup@info>\";\nconst WARN = \"<pup@warn>\";\nconst ERROR = \"<pup@error>\";\nconst FATAL = \"<pup@fatal>\";\n\nfunction stackHook(target: Function, _context: ClassMethodDecoratorContext) {\n  return function (this: Logger, ...messages: unknown[]) {\n    const processed = messages.map((msg) => {\n      return msg instanceof Error ? (msg.stack ?? String(msg)) : msg;\n    });\n    return target.call(this, ...processed);\n  };\n}\n\nexport class Logger implements LoggerLike {\n  private _impl?: LoggerLike;\n\n  get level(): number {\n    return this._level;\n  }\n\n  set level(value: number) {\n    this._level = value;\n    this.impl = this._impl ?? console;\n  }\n\n  get impl(): LoggerLike | undefined {\n    return this._impl;\n  }\n\n  set impl(value: LoggerLike) {\n    const debug = value.debug ?? console.debug;\n    const info = value.info ?? console.info;\n    const warn = value.warn ?? console.warn;\n    const error = value.error ?? console.error;\n    const lv = this._level;\n    this._impl = {\n      debug: lv >= 3 ? debug : undefined,\n      info: lv >= 2 ? info : undefined,\n      warn: lv >= 1 ? warn : undefined,\n      error: lv >= 0 ? error : undefined,\n    };\n  }\n\n  constructor(private _level: number = pupLogLevel) {\n    this.impl = console;\n  }\n\n  @stackHook\n  debug(...messages: unknown[]): void {\n    this.impl?.debug?.(DEBUG, ...messages);\n  }\n\n  @stackHook\n  info(...messages: unknown[]): void {\n    this.impl?.info?.(INFO, ...messages);\n  }\n\n  @stackHook\n  warn(...messages: unknown[]): void {\n    this.impl?.warn?.(WARN, ...messages);\n  }\n\n  @stackHook\n  error(...messages: unknown[]): void {\n    this.impl?.error?.(ERROR, ...messages);\n  }\n\n  @stackHook\n  fatal(...messages: unknown[]): void {\n    this.impl?.error?.(FATAL, ...messages);\n    process.exit(1);\n  }\n\n  private dispatch(message: string) {\n    const msg = message.trimEnd();\n    if (msg.startsWith(DEBUG)) {\n      this.debug(msg.slice(DEBUG.length + 1));\n    } else if (msg.startsWith(INFO)) {\n      this.info(msg.slice(INFO.length + 1));\n    } else if (msg.startsWith(WARN)) {\n      this.warn(msg.slice(WARN.length + 1));\n    } else if (msg.startsWith(ERROR)) {\n      this.error(msg.slice(ERROR.length + 1));\n    } else {\n      this.info(msg);\n    }\n  }\n\n  attach(proc: ChildProcess, name: string) {\n    return new Promise<void>((resolve, reject) => {\n      this.debug(`${name}.attach`);\n      let fatal: string = \"\";\n      const dispatch = (data: Buffer | Serializable) => {\n        const message = data.toString();\n        if (message.startsWith(FATAL)) {\n          fatal += message.slice(FATAL.length + 1);\n        } else {\n          this.dispatch(message);\n        }\n      };\n      proc.stderr?.on(\"data\", dispatch);\n      proc.stdout?.on(\"data\", dispatch);\n      proc\n        .on(\"message\", dispatch)\n        .on(\"error\", (err) => {\n          fatal += err.message;\n          proc.kill();\n        })\n        .once(\"close\", (code, signal) => {\n          if (code || signal || fatal) {\n            fatal ||= `command failed: ${proc.spawnargs.join(\" \")}`;\n            this.debug(`${name}.close`, { code, signal, fatal });\n            reject(new Error(fatal));\n          } else {\n            this.debug(`${name}.close`);\n            resolve();\n          }\n        })\n        .on(\"unhandledRejection\", (reason) => {\n          this.error(`${name}.unhandled`, reason);\n        })\n        .on(\"uncaughtExceptionMonitor\", (err) => {\n          this.error(`${name}.unhandled`, err);\n        });\n    });\n  }\n}\n\nconst logger = new Logger();\n\n// Route ffmpeg native logs through pup's logger.\nLog.setCallback((level, message) => {\n  const msg = message.trimEnd();\n  if (!msg) return;\n  if (level <= AV_LOG_ERROR) logger.error(msg);\n  else if (level <= AV_LOG_WARNING) logger.warn(msg);\n});\n\nexport { logger };\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/24.\n\nexport function noerr<Fn extends (...args: any[]) => any, D>(\n  fn: Fn,\n  defaultValue: D,\n): (...args: Parameters<Fn>) => ReturnType<Fn> | D {\n  return (...args) => {\n    try {\n      const ret = fn(...args);\n      if (ret instanceof Promise) {\n        return ret.catch(() => defaultValue);\n      }\n      return ret;\n    } catch {\n      return defaultValue;\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { spawn, type ChildProcess, type SpawnOptions } from \"child_process\";\nimport { logger } from \"./logging\";\n\nexport const PUP_ARGS_KEY = \"--pup-priv-args\";\n\nexport function pargs() {\n  const argv = process.argv;\n  let priv = argv.find((arg) => arg.startsWith(PUP_ARGS_KEY));\n  if (!priv) {\n    logger.debug(\"procargv\", argv);\n    return process.argv;\n  }\n  const args = [\"exec\", ...argv.slice(-1)];\n  priv = Buffer.from(priv.split(\"=\")[1]!, \"base64\").toString();\n  args.push(...JSON.parse(priv));\n  logger.debug(\"pupargs\", args);\n  return args;\n}\n\nexport interface ProcessHandle {\n  process: ChildProcess;\n  wait: Promise<void>;\n}\n\nexport function exec(cmd: string, options?: SpawnOptions): ProcessHandle {\n  const parts = cmd.split(\" \").filter((s) => s.length);\n  const [command, ...args] = parts;\n  if (!command) throw new Error(\"empty command\");\n  const proc = spawn(command, args, {\n    stdio: \"inherit\",\n    ...options,\n  });\n  return { process: proc, wait: logger.attach(proc, command) };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport z from \"zod\";\nimport { pupDeterministic, pupDisableGPU, pupUseInnerProxy } from \"../base/constants\";\n\nexport const DEFAULT_WIDTH = 1920;\nexport const DEFAULT_HEIGHT = 1080;\nexport const DEFAULT_FPS = 30;\nexport const DEFAULT_DURATION = 5;\nexport const DEFAULT_OUT_FILE = \"output.mp4\";\n\nexport const RenderSchema = z.object({\n  duration: z.number().describe(\"Duration in seconds\"),\n  width: z.number().describe(\"Video width\"),\n  height: z.number().describe(\"Video height\"),\n  fps: z.number().describe(\"Frames per second\"),\n  withAudio: z.boolean().describe(\"Capture and encode audio\"),\n  outFile: z.string().describe(\"Output mp4 file path\"),\n  useInnerProxy: z.boolean().describe(\"Use bilibili inner proxy for resource access\"),\n  deterministic: z.boolean().describe(\"Render by frame rather than recording\"),\n  disableGpu: z.boolean().describe(\"Disable GPU rendering, may reduce performance but increase stability\"),\n});\n\nexport type RenderOptions = z.infer<typeof RenderSchema>;\n\nexport interface RenderResult {\n  options: RenderOptions;\n  written: number;\n  jank: number;\n  outFile: string;\n}\n\nexport const defaultRenderOptions: RenderOptions = {\n  width: DEFAULT_WIDTH,\n  height: DEFAULT_HEIGHT,\n  fps: DEFAULT_FPS,\n  duration: DEFAULT_DURATION,\n  outFile: DEFAULT_OUT_FILE,\n  withAudio: false,\n  useInnerProxy: pupUseInnerProxy,\n  deterministic: pupDeterministic,\n  disableGpu: pupDisableGPU,\n};\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\ninterface QueueEntry {\n  run: VoidFunction;\n  reject: (reason: unknown) => void;\n  signal?: AbortSignal;\n}\n\nexport class ConcurrencyLimiter {\n  private _active = 0;\n  private _queue: QueueEntry[] = [];\n  private _signals = new WeakSet<AbortSignal>();\n  private _resolve?: VoidFunction;\n\n  constructor(readonly maxConcurrency: number) {}\n\n  get active(): number {\n    return this._active;\n  }\n\n  get pending(): number {\n    return this._queue.length;\n  }\n\n  get stats(): string {\n    return `active: ${this.active}, pending: ${this.pending}`;\n  }\n\n  async schedule<T>(fn: () => Promise<T>, signal?: AbortSignal): Promise<T> {\n    signal?.throwIfAborted();\n\n    if (signal && !this._signals.has(signal)) {\n      this._signals.add(signal);\n      signal.addEventListener(\"abort\", () => this.flush(signal), { once: true });\n    }\n\n    return new Promise<T>((resolve, reject) => {\n      this._queue.push({\n        run: () => {\n          if (signal?.aborted) {\n            reject(signal.reason);\n            this.next();\n            return;\n          }\n          this._active++;\n          fn()\n            .then((v) => {\n              this._active--;\n              resolve(v);\n              this.next();\n            })\n            .catch((e) => {\n              this._active--;\n              reject(e);\n              this.next();\n            });\n        },\n        reject,\n        signal,\n      });\n      this.next();\n    });\n  }\n\n  async drain(): Promise<void> {\n    if (this._active === 0 && this.pending === 0) return;\n    return new Promise((r) => (this._resolve = r));\n  }\n\n  private flush(signal: AbortSignal) {\n    const keep: QueueEntry[] = [];\n    for (const entry of this._queue) {\n      if (entry.signal === signal) {\n        entry.reject(signal.reason);\n      } else {\n        keep.push(entry);\n      }\n    }\n    this._queue = keep;\n    this.next();\n  }\n\n  private next() {\n    if (this._active === 0 && this.pending === 0) {\n      this._resolve?.();\n      this._resolve = undefined;\n      return;\n    }\n    if (this._active < this.maxConcurrency) {\n      this._queue.shift()?.run();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { CodecContext, FFmpegError, FormatContext, Packet } from \"node-av\";\n\nexport class FormatMuxer {\n  private readonly _ctx: FormatContext;\n  private _opened = false;\n\n  constructor(outPath: string, formatName?: string) {\n    this._ctx = new FormatContext();\n    FFmpegError.throwIfError(this._ctx.allocOutputContext2(null, formatName ?? null, outPath), \"allocOutputContext2\");\n  }\n\n  addStream(codecCtx: CodecContext, codecTag?: string): ReturnType<FormatContext[\"newStream\"]> {\n    const stream = this._ctx.newStream(null);\n    stream.timeBase = codecCtx.timeBase;\n    FFmpegError.throwIfError(stream.codecpar.fromContext(codecCtx), \"codecpar.fromContext\");\n    if (codecTag) stream.codecpar.codecTag = codecTag;\n    return stream;\n  }\n\n  async open(): Promise<void> {\n    if (this._opened) return;\n    FFmpegError.throwIfError(await this._ctx.openOutput(), \"openOutput\");\n    FFmpegError.throwIfError(await this._ctx.writeHeader(null), \"writeHeader\");\n    this._opened = true;\n  }\n\n  async writePacket(pkt: Packet): Promise<void> {\n    FFmpegError.throwIfError(await this._ctx.interleavedWriteFrame(pkt), \"interleavedWriteFrame\");\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (!this._opened) return;\n    await this._ctx.writeTrailer();\n    await this._ctx.closeOutput();\n    await this._ctx[Symbol.asyncDispose]();\n    this._opened = false;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { CodecContext, FFmpegError, Frame, Packet, type Stream } from \"node-av\";\nimport { AVERROR_EAGAIN, AVERROR_EOF, type AVPixelFormat } from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport function makeFrame(width: number, height: number, pixFmt: AVPixelFormat): Frame {\n  const frame = new Frame();\n  frame.alloc();\n  frame.format = pixFmt;\n  frame.width = width;\n  frame.height = height;\n  FFmpegError.throwIfError(frame.getBuffer(0), \"frame.getBuffer\");\n  return frame;\n}\n\nexport function makePacket(): Packet {\n  const pkt = new Packet();\n  pkt.alloc();\n  return pkt;\n}\n\nexport async function drainPackets(ctx: CodecContext, pkt: Packet, stream: Stream, muxer: FormatMuxer): Promise<void> {\n  while (true) {\n    const r = await ctx.receivePacket(pkt);\n    if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n    FFmpegError.throwIfError(r, \"receivePacket\");\n    pkt.streamIndex = stream.index;\n    if (pkt.duration === 0n) pkt.duration = 1n;\n    pkt.rescaleTs(ctx.timeBase, stream.timeBase);\n    await muxer.writePacket(pkt);\n    pkt.unref();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport {\n  Codec,\n  CodecContext,\n  FFmpegError,\n  Filter,\n  FilterContext,\n  FilterGraph,\n  FilterInOut,\n  Frame,\n  type Packet,\n  Rational,\n  type Stream,\n} from \"node-av\";\nimport {\n  AV_CHANNEL_LAYOUT_STEREO,\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AV_SAMPLE_FMT_FLT,\n  AV_SAMPLE_FMT_FLTP,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  type FFAudioEncoder,\n} from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { drainPackets, makePacket } from \"./shared\";\n\nconst SAMPLE_FMT_NAME: Partial<Record<number, string>> = { [AV_SAMPLE_FMT_FLT]: \"flt\", [AV_SAMPLE_FMT_FLTP]: \"fltp\" };\n\nexport interface AudioEncoderOptions {\n  outSampleRate: number;\n  outSampleFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  codecName: FFAudioEncoder;\n  globalHeader: boolean;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class AudioEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _stream: Stream;\n  private _pkt: Packet;\n  private _outRate: number;\n  private _outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  private _frameSize: number;\n  private _filterFrame: Frame;\n  private _graph?: FilterGraph;\n  private _bufSrc?: FilterContext;\n  private _bufSink?: FilterContext;\n  private _inRate?: number;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, stream: Stream, outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP) {\n    this._ctx = ctx;\n    this._stream = stream;\n    this._outRate = ctx.sampleRate;\n    this._outFmt = outFmt;\n    this._frameSize = ctx.frameSize;\n    this._pkt = makePacket();\n    this._filterFrame = new Frame();\n    this._filterFrame.alloc();\n  }\n\n  static async create(opts: AudioEncoderOptions): Promise<AudioEncoder> {\n    const codec = Codec.findEncoderByName(opts.codecName);\n    if (!codec) throw new Error(`Audio encoder not found: ${opts.codecName}`);\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.sampleFormat = opts.outSampleFmt;\n    ctx.sampleRate = opts.outSampleRate;\n    ctx.channelLayout = AV_CHANNEL_LAYOUT_STEREO;\n    ctx.timeBase = new Rational(1, opts.outSampleRate);\n    ctx.bitRate = BigInt(opts.bitrate);\n    if (opts.globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"audioCtx.open2\");\n    const stream = opts.muxer.addStream(ctx);\n    return new AudioEncoder(ctx, stream, opts.outSampleFmt);\n  }\n\n  setInputRate(inSampleRate: number): void {\n    this._graph?.[Symbol.dispose]();\n    this._inRate = inSampleRate;\n    const graph = new FilterGraph();\n    graph.alloc();\n    const abuffer = Filter.getByName(\"abuffer\")!;\n    const bufSrc = graph.createFilter(\n      abuffer,\n      \"src\",\n      `sample_rate=${inSampleRate}:sample_fmt=flt:channel_layout=stereo:time_base=1/${inSampleRate}`,\n    );\n    if (!bufSrc) throw new Error(\"Failed to create abuffer\");\n    const abuffersink = Filter.getByName(\"abuffersink\")!;\n    const bufSink = graph.createFilter(abuffersink, \"sink\");\n    if (!bufSink) throw new Error(\"Failed to create abuffersink\");\n    const fmtName = SAMPLE_FMT_NAME[this._outFmt] ?? \"flt\";\n    const filterDesc = `aformat=sample_fmts=${fmtName}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`;\n    const outputs = FilterInOut.createList([{ name: \"in\", filterCtx: bufSrc, padIdx: 0 }]);\n    const inputs = FilterInOut.createList([{ name: \"out\", filterCtx: bufSink, padIdx: 0 }]);\n    FFmpegError.throwIfError(graph.parsePtr(filterDesc, inputs, outputs), \"graph.parsePtr\");\n    FFmpegError.throwIfError(graph.configSync(), \"graph.config\");\n    this._graph = graph;\n    this._bufSrc = bufSrc;\n    this._bufSink = bufSink;\n  }\n\n  async encode(pcm: Buffer, muxer: FormatMuxer): Promise<void> {\n    if (!this._bufSrc || !this._inRate) return;\n    const src = new Float32Array(pcm.buffer, pcm.byteOffset, pcm.byteLength / 4);\n    for (let i = 0; i < src.length; i++) if (!isFinite(src[i]!)) src[i] = 0;\n    const nSamples = src.length >> 1;\n    using frame = Frame.fromAudioBuffer(Buffer.from(src.buffer, src.byteOffset, src.byteLength), {\n      nbSamples: nSamples,\n      format: AV_SAMPLE_FMT_FLT,\n      sampleRate: this._inRate,\n      channelLayout: AV_CHANNEL_LAYOUT_STEREO,\n      pts: this._pts,\n      timeBase: { num: 1, den: this._inRate },\n    });\n    this._pts += BigInt(nSamples);\n    FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(frame), \"buffersrcAddFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    if (this._bufSrc) {\n      await this._bufSrc.buffersrcAddFrame(null);\n      await this.drain(muxer);\n    }\n    await this._ctx.sendFrame(null);\n    await this.drainCodec(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._filterFrame.free();\n    this._graph?.[Symbol.dispose]();\n    this._ctx.freeContext();\n  }\n\n  private async drain(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._bufSink!.buffersinkGetFrame(this._filterFrame);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"buffersinkGetFrame\");\n      FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame), \"audioCtx.sendFrame\");\n      this._filterFrame.unref();\n      await this.drainCodec(muxer);\n    }\n  }\n\n  private drainCodec(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/03.\n\nimport { ok } from \"assert\";\nimport {\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_YUVA420P,\n  Codec,\n  CodecContext,\n  FF_DECODER_PNG,\n  FFmpegError,\n  type Frame,\n  Packet,\n  SoftwareScaleContext,\n  SWS_BILINEAR,\n  type AVPixelFormat,\n} from \"node-av\";\nimport { makeFrame, makePacket } from \"./shared\";\n\nexport class CodecState implements Disposable {\n  readonly src: Frame;\n  readonly dst: Frame;\n  readonly pkt: Packet;\n  private _sws?: SoftwareScaleContext;\n  private _png?: Codec;\n\n  static async create(width: number, height: number) {\n    const codec = Codec.findDecoderByName(FF_DECODER_PNG);\n    ok(codec, \"png decoder unavailable\");\n    return new CodecState(width, height, codec);\n  }\n\n  private constructor(width: number, height: number, png: Codec) {\n    this._png = png;\n    this.src = makeFrame(width, height, AV_PIX_FMT_BGRA);\n    this.dst = makeFrame(width, height, AV_PIX_FMT_YUVA420P);\n    this.pkt = makePacket();\n  }\n\n  /**\n   * Create a fresh PNG decoder context.\n   * The FFmpeg PNG decoder accumulates APNG blending state\n   * across frames, so a shared instance corrupts output when decoding standalone PNGs.\n   */\n  async png(): Promise<CodecContext> {\n    const png = new CodecContext();\n    png.allocContext3(this._png);\n    FFmpegError.throwIfError(await png.open2(this._png), \"pngDecoder.open2\");\n    return png;\n  }\n\n  async decodePNG(pngData: Buffer): Promise<Frame> {\n    using png = await this.png();\n    this.pkt.data = pngData;\n    FFmpegError.throwIfError(await png.sendPacket(this.pkt), \"pngDecoder.sendPacket\");\n    this.pkt.unref();\n    FFmpegError.throwIfError(await png.receiveFrame(this.src), \"pngDecoder.receiveFrame\");\n    return this.src;\n  }\n\n  get sws() {\n    if (!this._sws) {\n      const sws = new SoftwareScaleContext();\n      const fmt = this.src.format as AVPixelFormat;\n      sws.getContext(\n        this.src.width,\n        this.src.height,\n        fmt,\n        this.src.width,\n        this.src.height,\n        AV_PIX_FMT_YUVA420P,\n        SWS_BILINEAR,\n      );\n      this._sws = sws;\n    }\n    return this._sws;\n  }\n\n  [Symbol.dispose](): void {\n    this.src[Symbol.dispose]();\n    this.dst[Symbol.dispose]();\n    this.pkt[Symbol.dispose]();\n    this._sws?.[Symbol.dispose]();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nconst NAL_HEADER_SIZE = 2;\nconst ANNEX_B_START_CODE = Buffer.from([0x00, 0x00, 0x00, 0x01]);\n\nexport { ANNEX_B_START_CODE, NAL_HEADER_SIZE };\n\nexport interface NalUnit {\n  type: number;\n  layerId: number;\n  data: Buffer;\n}\n\nfunction parseNalType(header0: number, header1: number): { type: number; layerId: number; temporalId: number } {\n  const type = (header0 >> 1) & 0x3f;\n  const layerId = ((header0 & 1) << 5) | ((header1 >> 3) & 0x1f);\n  const temporalId = header1 & 0x07;\n  return { type, layerId, temporalId };\n}\n\nexport function encodeNalHeader(type: number, layerId: number, temporalId: number): [number, number] {\n  const byte0 = ((type & 0x3f) << 1) | ((layerId >> 5) & 1);\n  const byte1 = ((layerId & 0x1f) << 3) | (temporalId & 0x07);\n  return [byte0, byte1];\n}\n\nexport function packBits(bits: number[]): Buffer {\n  const buf = Buffer.alloc(bits.length >> 3);\n  for (let i = 0; i < buf.length; i++) {\n    let byte = 0;\n    for (let b = 0; b < 8; b++) byte = (byte << 1) | bits[i * 8 + b]!;\n    buf[i] = byte;\n  }\n  return buf;\n}\n\n/** Split Annex B bitstream into NAL units. */\nexport function splitNalUnits(bitstream: Buffer): NalUnit[] {\n  const nals: NalUnit[] = [];\n  let i = 0;\n\n  while (i < bitstream.length) {\n    let scLen = 0;\n    if (i + 3 < bitstream.length && bitstream[i] === 0 && bitstream[i + 1] === 0 && bitstream[i + 2] === 1) {\n      scLen = 3;\n    } else if (\n      i + 4 < bitstream.length &&\n      bitstream[i] === 0 &&\n      bitstream[i + 1] === 0 &&\n      bitstream[i + 2] === 0 &&\n      bitstream[i + 3] === 1\n    ) {\n      scLen = 4;\n    } else {\n      i++;\n      continue;\n    }\n\n    const nalStart = i + scLen;\n    if (nalStart + NAL_HEADER_SIZE > bitstream.length) break;\n\n    let nalEnd = bitstream.length;\n    for (let j = nalStart + NAL_HEADER_SIZE; j < bitstream.length - 2; j++) {\n      if (\n        bitstream[j] === 0 &&\n        bitstream[j + 1] === 0 &&\n        (bitstream[j + 2] === 1 || (j + 3 < bitstream.length && bitstream[j + 2] === 0 && bitstream[j + 3] === 1))\n      ) {\n        nalEnd = j;\n        break;\n      }\n    }\n\n    const { type, layerId } = parseNalType(bitstream[nalStart]!, bitstream[nalStart + 1]!);\n    nals.push({ type, layerId, data: bitstream.subarray(nalStart, nalEnd) });\n    i = nalEnd;\n  }\n\n  return nals;\n}\n\n/** Rewrite nuh_layer_id in a NAL unit (returns copy). */\nexport function rewriteNalLayerId(nal: Buffer, layerId: number): Buffer {\n  const out = Buffer.from(nal);\n  const { type, temporalId } = parseNalType(out[0]!, out[1]!);\n  const [b0, b1] = encodeNalHeader(type, layerId, temporalId);\n  out[0] = b0;\n  out[1] = b1;\n  return out;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport {\n  ANNEX_B_START_CODE,\n  encodeNalHeader,\n  NAL_HEADER_SIZE,\n  type NalUnit,\n  packBits,\n  rewriteNalLayerId,\n  splitNalUnits,\n} from \"./nal\";\n\nconst NAL_UNIT_PREFIX_SEI = 39;\n\n/**\n * Build unified extradata: base VPS (patched for alpha) + interleaved SPS/PPS.\n * Alpha SPS/PPS follow their base counterparts so the HVCC serializer\n * groups them into the same NAL array (required for multi-layer).\n */\nexport function buildUnifiedExtradata(baseExtradata: Buffer, alphaExtradata: Buffer): Buffer {\n  const baseNals = splitNalUnits(baseExtradata);\n  const alphaNals = splitNalUnits(alphaExtradata);\n\n  const alphaByType = new Map<number, NalUnit[]>();\n  for (const nal of alphaNals) {\n    if (nal.type === 32) continue; // VPS is per-bitstream, not per-layer\n    const arr = alphaByType.get(nal.type) ?? [];\n    arr.push(nal);\n    alphaByType.set(nal.type, arr);\n  }\n\n  const chunks: Buffer[] = [];\n  const emitted = new Set<number>();\n  for (const nal of baseNals) {\n    // VPS needs alpha layer declaration for FFmpeg's HVCC serializer\n    const data = nal.type === 32 ? patchVPSForAlpha(nal.data) : nal.data;\n    chunks.push(ANNEX_B_START_CODE, data);\n    if (!emitted.has(nal.type)) {\n      emitted.add(nal.type);\n      for (const alphaNal of alphaByType.get(nal.type) ?? []) {\n        chunks.push(ANNEX_B_START_CODE, rewriteNalLayerId(alphaNal.data, 1));\n      }\n    }\n  }\n\n  // SEI must be in extradata for Apple's decoder to discover alpha channel\n  chunks.push(buildAlphaChannelInfoSEI());\n\n  return Buffer.concat(chunks);\n}\n\n/**\n * Patch a single-layer VPS to declare 2 layers with layer 1 = AUX_ALPHA.\n * FFmpeg 8.0's hvcc_parse_vps_extension reads this to set alpha_layer_nuh_id,\n * which allows layer_id=1 NALs to survive Annex B → HVCC conversion.\n */\nfunction patchVPSForAlpha(vpsData: Buffer): Buffer {\n  const rbsp = vpsData.subarray(NAL_HEADER_SIZE);\n\n  let bitPos = 0;\n  const readBits = (n: number): number => {\n    let val = 0;\n    for (let i = 0; i < n; i++) {\n      const byteIdx = (bitPos + i) >> 3;\n      const bitIdx = 7 - ((bitPos + i) & 7);\n      val = (val << 1) | ((rbsp[byteIdx]! >> bitIdx) & 1);\n    }\n    bitPos += n;\n    return val;\n  };\n\n  readBits(4); // vps_video_parameter_set_id\n  const vpsBaseLayerInternalFlag = readBits(1);\n  readBits(1); // vps_base_layer_available_flag\n  const maxLayersPos = bitPos;\n  const maxLayersMinus1 = readBits(6);\n\n  if (maxLayersMinus1 > 0) return vpsData;\n\n  const bits: number[] = [];\n  for (let i = 0; i < vpsData.length; i++) {\n    for (let b = 7; b >= 0; b--) bits.push((vpsData[i]! >> b) & 1);\n  }\n\n  const mlOffset = maxLayersPos + NAL_HEADER_SIZE * 8;\n  for (let i = 0; i < 6; i++) bits[mlOffset + i] = 0;\n  bits[mlOffset + 5] = 1; // vps_max_layers_minus1 = 1\n\n  let lastBit = bits.length - 1;\n  while (lastBit > 0 && bits[lastBit] === 0) lastBit--;\n  if (lastBit <= 1) throw new Error(\"Invalid VPS: no RBSP stop bit\");\n  bits[lastBit - 1] = 1; // vps_extension_flag = 1\n  bits.length = lastBit;\n\n  while (bits.length % 8 !== 0) bits.push(1); // byte-align\n\n  // Minimal VPS extension for FFmpeg's hvcc_parse_vps_extension\n  if (vpsBaseLayerInternalFlag) {\n    for (let i = 0; i < 8; i++) bits.push(0); // general_level_idc\n  }\n  bits.push(0); // splitting_flag\n  for (let i = 0; i < 16; i++) bits.push(i === 3 ? 1 : 0); // scalability_mask: AuxId\n  bits.push(0, 0, 0); // dimension_id_len_minus1 = 0\n  bits.push(0); // vps_nuh_layer_id_present_flag\n  bits.push(1); // dimension_id[1][0] = AUX_ALPHA\n\n  bits.push(1);\n  while (bits.length % 8 !== 0) bits.push(0);\n\n  return packBits(bits);\n}\n\n/**\n * Build alpha_channel_info SEI message (payloadType=165).\n * Layout from x265 SEIAlphaChannelInfo::writeSEI.\n */\nexport function buildAlphaChannelInfoSEI(): Buffer {\n  const payloadType = 165;\n  const payloadSize = 4;\n  const [h0, h1] = encodeNalHeader(NAL_UNIT_PREFIX_SEI, 0, 1);\n\n  const bits: number[] = [];\n  const writeBits = (val: number, n: number) => {\n    for (let i = n - 1; i >= 0; i--) bits.push((val >> i) & 1);\n  };\n\n  writeBits(0, 1); // alpha_channel_cancel_flag\n  writeBits(0, 3); // alpha_channel_use_idc (straight alpha)\n  writeBits(0, 3); // alpha_channel_bit_depth_minus8\n  writeBits(0, 9); // alpha_transparent_value\n  writeBits(255, 9); // alpha_opaque_value\n  writeBits(0, 1); // alpha_channel_incr_flag\n  writeBits(0, 1); // alpha_channel_clip_flag\n  writeBits(1, 1); // byte alignment\n  while (bits.length % 8 !== 0) writeBits(0, 1);\n\n  return Buffer.concat([\n    ANNEX_B_START_CODE,\n    Buffer.from([h0, h1]),\n    Buffer.from([payloadType, payloadSize]),\n    packBits(bits),\n    Buffer.from([0x80]),\n  ]);\n}\n\n/** Interleave base and alpha NALs for a single frame. */\nexport function interleaveAccessUnits(baseNals: NalUnit[], alphaNals: NalUnit[]): Buffer {\n  const chunks: Buffer[] = [];\n  for (const nal of baseNals) {\n    chunks.push(ANNEX_B_START_CODE, nal.data);\n  }\n  for (const nal of alphaNals) {\n    if (nal.type < 32) {\n      chunks.push(ANNEX_B_START_CODE, rewriteNalLayerId(nal.data, 1));\n    }\n  }\n  return Buffer.concat(chunks);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport {\n  Codec,\n  CodecContext,\n  FFmpegError,\n  Frame,\n  HardwareFramesContext,\n  Rational,\n  SoftwareScaleContext,\n  SWS_BILINEAR,\n  type Packet,\n  type Stream,\n} from \"node-av\";\nimport {\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_CUDA,\n  AV_PIX_FMT_YUV420P,\n  AVCOL_RANGE_JPEG,\n  FF_ENCODER_HEVC_NVENC,\n} from \"node-av/constants\";\nimport { buildAlphaChannelInfoSEI, buildUnifiedExtradata, interleaveAccessUnits } from \"./alpha\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { splitNalUnits } from \"./nal\";\nimport { makeFrame, makePacket } from \"./shared\";\nimport type { HwVideoEncoderOptions } from \"./videotoolbox\";\n\ninterface NvencState {\n  baseCtx: CodecContext;\n  alphaCtx: CodecContext;\n  basePkt: Packet;\n  alphaPkt: Packet;\n  stream: Stream;\n  baseSws: SoftwareScaleContext;\n  yuvFrame: Frame;\n  hwFramesCtx: HardwareFramesContext;\n}\n\nexport class NvencDualLayerEncoder implements Disposable {\n  private _s: NvencState;\n  private _seiBuffer: Buffer;\n  private _pts = 0n;\n  private _seiInjected = false;\n  private _alphaBuf?: Buffer;\n  private _alphaFrame?: Frame;\n\n  private constructor(s: NvencState) {\n    this._s = s;\n    this._seiBuffer = buildAlphaChannelInfoSEI();\n  }\n\n  static async create(opts: HwVideoEncoderOptions): Promise<NvencDualLayerEncoder> {\n    const { width, height, fps, bitrate, hw, muxer } = opts;\n\n    const codec = Codec.findEncoderByName(FF_ENCODER_HEVC_NVENC);\n    if (!codec) throw new Error(\"hevc_nvenc encoder not found\");\n\n    const hwFramesCtx = new HardwareFramesContext();\n    hwFramesCtx.alloc(hw.deviceContext);\n    hwFramesCtx.format = AV_PIX_FMT_CUDA;\n    hwFramesCtx.swFormat = AV_PIX_FMT_YUV420P; // NVENC only accepts YUV420P/NV12, not BGRA\n    hwFramesCtx.width = width;\n    hwFramesCtx.height = height;\n    hwFramesCtx.initialPoolSize = 20;\n    FFmpegError.throwIfError(hwFramesCtx.init(), \"hwFramesCtx.init\");\n\n    const makeCtx = async (ctxOpts: { br: number; fullRange?: boolean; cqp?: number }) => {\n      const ctx = new CodecContext();\n      ctx.allocContext3(codec);\n      ctx.codecId = codec.id;\n      ctx.width = width;\n      ctx.height = height;\n      ctx.pixelFormat = AV_PIX_FMT_CUDA;\n      if (ctxOpts.fullRange) ctx.colorRange = AVCOL_RANGE_JPEG;\n      ctx.timeBase = new Rational(1, fps);\n      ctx.framerate = new Rational(fps, 1);\n      ctx.gopSize = fps * 2;\n      ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n      ctx.setOption(\"preset\", \"p4\");\n      ctx.setOption(\"bf\", \"0\"); // no B-frames — keep base+alpha packet output in sync\n      if (ctxOpts.cqp !== undefined) {\n        ctx.setOption(\"rc\", \"constqp\");\n        ctx.setOption(\"qp\", String(ctxOpts.cqp));\n      } else {\n        ctx.bitRate = BigInt(ctxOpts.br);\n      }\n      ctx.hwFramesCtx = hwFramesCtx;\n      FFmpegError.throwIfError(await ctx.open2(codec, null), \"nvenc.open2\");\n      return ctx;\n    };\n\n    const baseCtx = await makeCtx({ br: bitrate });\n    const alphaCtx = await makeCtx({ br: bitrate, fullRange: true, cqp: 1 });\n\n    const basePkt = makePacket();\n    const alphaPkt = makePacket();\n\n    const stream = muxer.addStream(baseCtx, \"hvc1\");\n\n    const baseExtra = baseCtx.extraData;\n    const alphaExtra = alphaCtx.extraData;\n    if (baseExtra && alphaExtra) {\n      stream.codecpar.extradata = buildUnifiedExtradata(baseExtra, alphaExtra);\n    }\n\n    const baseSws = new SoftwareScaleContext();\n    baseSws.getContext(width, height, AV_PIX_FMT_BGRA, width, height, AV_PIX_FMT_YUV420P, SWS_BILINEAR);\n    return new NvencDualLayerEncoder({\n      baseCtx,\n      alphaCtx,\n      basePkt,\n      alphaPkt,\n      stream,\n      baseSws,\n      yuvFrame: makeFrame(width, height, AV_PIX_FMT_YUV420P),\n      hwFramesCtx,\n    });\n  }\n\n  async encode(bgraFrame: Frame, muxer: FormatMuxer): Promise<void> {\n    const { baseCtx, alphaCtx, baseSws, yuvFrame, hwFramesCtx } = this._s;\n    const pts = this._pts++;\n\n    // Base: BGRA → SWS → YUV420P sw frame\n    FFmpegError.throwIfError(yuvFrame.makeWritable(), \"yuv.makeWritable\");\n    FFmpegError.throwIfError(await baseSws.scaleFrame(yuvFrame, bgraFrame), \"sws.base\");\n\n    // Alpha: extract alpha channel → YUV420P sw frame (Buffer.copy pattern from hw-encode.ts)\n    const src = bgraFrame.data?.[0];\n    const srcLs = bgraFrame.linesize?.[0];\n    if (!src || !srcLs) throw new Error(\"encode: missing BGRA data\");\n    const w = bgraFrame.width;\n    const h = bgraFrame.height;\n    const ySize = w * h;\n    const uvSize = (w >> 1) * (h >> 1);\n    if (!this._alphaBuf) this._alphaBuf = Buffer.alloc(ySize + uvSize * 2);\n    const buf = this._alphaBuf;\n    for (let y = 0; y < h; y++) {\n      for (let x = 0; x < w; x++) {\n        buf[y * w + x] = src[y * srcLs + x * 4 + 3]!;\n      }\n    }\n    buf.fill(128, ySize, ySize + uvSize * 2);\n\n    // fromVideoBuffer is the only way to set native frame data on Linux\n    this._alphaFrame?.free();\n    this._alphaFrame = Frame.fromVideoBuffer(buf, { format: AV_PIX_FMT_YUV420P, width: w, height: h });\n\n    // Upload both to GPU + encode\n    const baseHwFrame = new Frame();\n    baseHwFrame.alloc();\n    FFmpegError.throwIfError(hwFramesCtx.getBuffer(baseHwFrame, 0), \"base.getBuffer\");\n    FFmpegError.throwIfError(await hwFramesCtx.transferData(baseHwFrame, yuvFrame, 0), \"base.transfer\");\n    baseHwFrame.pts = pts;\n    baseHwFrame.duration = 1n;\n\n    const alphaHwFrame = new Frame();\n    alphaHwFrame.alloc();\n    FFmpegError.throwIfError(hwFramesCtx.getBuffer(alphaHwFrame, 0), \"alpha.getBuffer\");\n    FFmpegError.throwIfError(await hwFramesCtx.transferData(alphaHwFrame, this._alphaFrame, 0), \"alpha.transfer\");\n    alphaHwFrame.pts = pts;\n    alphaHwFrame.duration = 1n;\n\n    FFmpegError.throwIfError(await baseCtx.sendFrame(baseHwFrame), \"base.sendFrame\");\n    FFmpegError.throwIfError(await alphaCtx.sendFrame(alphaHwFrame), \"alpha.sendFrame\");\n    await this.drainInterleaved(muxer);\n    baseHwFrame.free();\n    alphaHwFrame.free();\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._s.baseCtx.sendFrame(null);\n    await this._s.alphaCtx.sendFrame(null);\n    await this.drainInterleaved(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    const { basePkt, alphaPkt, yuvFrame, baseSws, hwFramesCtx, baseCtx, alphaCtx } = this._s;\n    basePkt.free();\n    alphaPkt.free();\n    yuvFrame[Symbol.dispose]();\n    this._alphaFrame?.free();\n    baseSws[Symbol.dispose]();\n    hwFramesCtx.free();\n    baseCtx.freeContext();\n    alphaCtx.freeContext();\n  }\n\n  private async drainInterleaved(muxer: FormatMuxer): Promise<void> {\n    const { baseCtx, alphaCtx, basePkt, alphaPkt, stream } = this._s;\n    while (true) {\n      const baseR = await baseCtx.receivePacket(basePkt);\n      const alphaR = await alphaCtx.receivePacket(alphaPkt);\n\n      const baseReady = baseR >= 0;\n      const alphaReady = alphaR >= 0;\n      if (!baseReady && !alphaReady) break;\n\n      // Both must produce packets together (bf=0 ensures this)\n      if (baseReady !== alphaReady) {\n        throw new Error(`NVENC desync: base=${baseReady}, alpha=${alphaReady}`);\n      }\n\n      const baseNals = splitNalUnits(basePkt.data!);\n      const alphaNals = splitNalUnits(alphaPkt.data!);\n\n      const chunks: Buffer[] = [];\n      if (!this._seiInjected) {\n        chunks.push(this._seiBuffer);\n        this._seiInjected = true;\n      }\n      chunks.push(interleaveAccessUnits(baseNals, alphaNals));\n\n      // Save timestamps before data replacement (setter may reset them)\n      const pts = basePkt.pts;\n      const dts = basePkt.dts;\n      const duration = basePkt.duration;\n      basePkt.data = Buffer.concat(chunks);\n      basePkt.pts = pts;\n      basePkt.dts = dts;\n      basePkt.duration = duration === 0n ? 1n : duration;\n      basePkt.streamIndex = stream.index;\n      basePkt.rescaleTs(baseCtx.timeBase, stream.timeBase);\n      await muxer.writePacket(basePkt);\n\n      basePkt.unref();\n      alphaPkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { Codec, CodecContext, FFmpegError, Frame, type Packet, Rational, type Stream } from \"node-av\";\nimport { AV_CODEC_FLAG_GLOBAL_HEADER, type AVPixelFormat, type FFVideoEncoder } from \"node-av/constants\";\nimport { drainPackets, makePacket } from \"./shared\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface VideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  codecName: FFVideoEncoder;\n  codecTag?: string;\n  globalHeader: boolean;\n  codecOpts: Record<string, string>;\n  bitrate: number;\n  pixelFormat: AVPixelFormat;\n  muxer: FormatMuxer;\n}\n\nexport class VideoEncoder implements Disposable {\n  private readonly _ctx: CodecContext;\n  private readonly _pkt: Packet;\n  private readonly _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: VideoEncoderOptions): Promise<VideoEncoder> {\n    const { width, height, fps, codecName, codecTag, globalHeader, codecOpts, bitrate, muxer } = opts;\n\n    const codec = Codec.findEncoderByName(codecName);\n    if (!codec) throw new Error(`Video encoder not found: ${codecName}`);\n\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.width = width;\n    ctx.height = height;\n    ctx.pixelFormat = opts.pixelFormat;\n    ctx.timeBase = new Rational(1, fps);\n    ctx.framerate = new Rational(fps, 1);\n    ctx.gopSize = fps * 2;\n    ctx.bitRate = BigInt(bitrate);\n    if (globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    for (const [k, v] of Object.entries(codecOpts)) ctx.setOption(k, v);\n    if (codecTag) ctx.codecTag = codecTag;\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"videoCtx.open2\");\n\n    const stream = muxer.addStream(ctx, codecTag);\n    return new VideoEncoder(ctx, makePacket(), stream);\n  }\n\n  async encode(frame: Frame, muxer: FormatMuxer): Promise<void> {\n    frame.pts = this._pts++;\n    frame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(frame), \"videoCtx.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private drain(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/12.\n\nimport { CodecContext, FFmpegError, Frame, type Packet, Rational, type Stream } from \"node-av\";\nimport type { HardwareContext } from \"node-av/api\";\nimport { AV_CODEC_FLAG_GLOBAL_HEADER, AV_PIX_FMT_BGRA, AVCOL_RANGE_JPEG } from \"node-av/constants\";\nimport { drainPackets, makePacket } from \"./shared\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface HwVideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  hw: HardwareContext;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class VideoToolboxEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _pkt: Packet;\n  private _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: HwVideoEncoderOptions): Promise<VideoToolboxEncoder> {\n    const { width, height, fps, hw, bitrate, muxer } = opts;\n\n    const codec = hw.getEncoderCodec(\"hevc\");\n    if (!codec) throw new Error(\"hevc_videotoolbox encoder not found\");\n\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.width = width;\n    ctx.height = height;\n    ctx.pixelFormat = AV_PIX_FMT_BGRA;\n    ctx.colorRange = AVCOL_RANGE_JPEG;\n    ctx.timeBase = new Rational(1, fps);\n    ctx.framerate = new Rational(fps, 1);\n    ctx.gopSize = fps * 2;\n    ctx.bitRate = BigInt(bitrate);\n    ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    ctx.setOption(\"alpha_quality\", \"1\");\n    ctx.codecTag = \"hvc1\";\n\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"vtEnc.open2\");\n\n    const stream = muxer.addStream(ctx, \"hvc1\");\n    return new VideoToolboxEncoder(ctx, makePacket(), stream);\n  }\n\n  async encode(bgraFrame: Frame, muxer: FormatMuxer): Promise<void> {\n    bgraFrame.pts = this._pts++;\n    bgraFrame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(bgraFrame), \"vtEnc.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private drain(muxer: FormatMuxer): Promise<void> {\n    return drainPackets(this._ctx, this._pkt, this._stream, muxer);\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/13.\n\nimport { HardwareContext } from \"node-av/api\";\nimport {\n  AV_PIX_FMT_YUVA420P,\n  FF_ENCODER_LIBX265,\n  FF_HWDEVICE_TYPE_CUDA,\n  FF_HWDEVICE_TYPE_VIDEOTOOLBOX,\n} from \"node-av/constants\";\n\nimport { logger } from \"../logging\";\nimport { CodecState } from \"./codec\";\nimport type { FormatMuxer } from \"./muxer\";\nimport { NvencDualLayerEncoder } from \"./nvenc\";\nimport { VideoEncoder } from \"./video\";\nimport { VideoToolboxEncoder } from \"./videotoolbox\";\n\nconst TAG = \"[Encoder]\";\n\nexport type HwEncoder = VideoToolboxEncoder | NvencDualLayerEncoder;\n\nexport interface VideoSetup {\n  video?: VideoEncoder;\n  hwVideo?: HwEncoder;\n  codec?: CodecState;\n  hw?: HardwareContext;\n}\n\nexport interface VideoFactoryOptions {\n  width: number;\n  height: number;\n  fps: number;\n  bitrate?: number;\n  disableGpu?: boolean;\n}\n\nexport async function createVideoEncoder(opts: VideoFactoryOptions, muxer: FormatMuxer): Promise<VideoSetup> {\n  const { width, height, fps, bitrate = 8_000_000, disableGpu = false } = opts;\n  const hw = disableGpu ? undefined : (HardwareContext.auto() ?? undefined);\n\n  if (hw?.deviceTypeName === FF_HWDEVICE_TYPE_VIDEOTOOLBOX && hw.getEncoderCodec(\"hevc\")) {\n    logger.debug(TAG, \"using VideoToolbox HEVC alpha encoder\");\n    const hwVideo = await VideoToolboxEncoder.create({ width, height, fps, hw, bitrate, muxer });\n    return { hwVideo, hw };\n  }\n\n  if (hw?.deviceTypeName === FF_HWDEVICE_TYPE_CUDA && hw.getEncoderCodec(\"hevc\")) {\n    logger.debug(TAG, \"using NVENC dual-layer HEVC alpha encoder\");\n    const hwVideo = await NvencDualLayerEncoder.create({ width, height, fps, hw, bitrate, muxer });\n    return { hwVideo, hw };\n  }\n\n  logger.debug(TAG, \"using software libx265 HEVC alpha encoder\");\n  hw?.dispose();\n  const video = await VideoEncoder.create({\n    width,\n    height,\n    fps,\n    codecName: FF_ENCODER_LIBX265,\n    codecTag: \"hvc1\",\n    globalHeader: true,\n    codecOpts: { preset: \"medium\", \"x265-params\": \"log-level=1:bframes=3:pools=+:frame-threads=0\" },\n    bitrate,\n    pixelFormat: AV_PIX_FMT_YUVA420P,\n    muxer,\n  });\n  return { video, codec: await CodecState.create(width, height) };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { FFmpegError, Frame } from \"node-av\";\nimport type { HardwareContext } from \"node-av/api\";\nimport { AV_PIX_FMT_BGRA, AV_SAMPLE_FMT_FLTP, FF_ENCODER_AAC } from \"node-av/constants\";\n\nimport { ok } from \"assert\";\nimport { ConcurrencyLimiter } from \"../limiter\";\nimport { AudioEncoder } from \"./audio\";\nimport { CodecState } from \"./codec\";\nimport { createVideoEncoder, type HwEncoder } from \"./factory\";\nimport { FormatMuxer } from \"./muxer\";\nimport { makeFrame } from \"./shared\";\nimport { VideoEncoder } from \"./video\";\n\nexport interface EncoderPipelineOptions {\n  width: number;\n  height: number;\n  fps: number;\n  outFile: string;\n  withAudio?: boolean;\n  disableGpu?: boolean;\n}\n\ninterface PipelineState {\n  video?: VideoEncoder;\n  hwVideo?: HwEncoder;\n  audio?: AudioEncoder;\n  muxer: FormatMuxer;\n  limiter: ConcurrencyLimiter;\n  outFile: string;\n  codec?: CodecState;\n  hw?: HardwareContext;\n  width: number;\n  height: number;\n}\n\nexport class EncoderPipeline {\n  private _s: PipelineState;\n  private _disposed = false;\n\n  private constructor(s: PipelineState) {\n    this._s = s;\n  }\n\n  static async create(opts: EncoderPipelineOptions): Promise<EncoderPipeline> {\n    const { width, height, outFile, withAudio = false } = opts;\n    const muxer = new FormatMuxer(outFile);\n    const { video, hwVideo, codec, hw } = await createVideoEncoder(opts, muxer);\n\n    let audio: AudioEncoder | undefined;\n    if (withAudio) {\n      audio = await AudioEncoder.create({\n        outSampleRate: 44_100,\n        outSampleFmt: AV_SAMPLE_FMT_FLTP,\n        codecName: FF_ENCODER_AAC,\n        globalHeader: true,\n        bitrate: 128_000,\n        muxer,\n      });\n    }\n\n    await muxer.open();\n    return new EncoderPipeline({\n      video,\n      hwVideo,\n      audio,\n      muxer,\n      limiter: new ConcurrencyLimiter(1),\n      outFile,\n      codec,\n      hw,\n      width,\n      height,\n    });\n  }\n\n  setupAudio(sampleRate: number): void {\n    this._s.audio?.setInputRate(sampleRate);\n  }\n\n  async encodeBGRA(input: Buffer): Promise<void> {\n    await this._s.limiter.schedule(async () => {\n      const { hwVideo, video, codec, muxer } = this._s;\n      if (hwVideo) {\n        using frame = this.bgraFrame(input);\n        await hwVideo.encode(frame, muxer);\n        return;\n      }\n      const { src, dst, sws } = codec!;\n      ok(sws, \"sws not initialized\");\n      FFmpegError.throwIfError(src.makeWritable(), \"bgraSrc.makeWritable\");\n      FFmpegError.throwIfError(src.fromBuffer(input), \"bgraSrc.fromBuffer\");\n      FFmpegError.throwIfError(dst.makeWritable(), \"bgraDst.makeWritable\");\n      FFmpegError.throwIfError(await sws.scaleFrame(dst, src), \"bgraSws.scaleFrame\");\n      return video!.encode(dst, muxer);\n    });\n  }\n\n  async encodePNG(pngData: Buffer): Promise<void> {\n    await this._s.limiter.schedule(async () => {\n      const { hwVideo, video, codec, muxer, width, height } = this._s;\n      const cs = codec ?? (await CodecState.create(width, height));\n      try {\n        const src = await cs.decodePNG(pngData);\n        if (hwVideo) {\n          await hwVideo.encode(src, muxer);\n        } else {\n          FFmpegError.throwIfError(cs.dst.makeWritable(), \"pngDst.makeWritable\");\n          FFmpegError.throwIfError(await cs.sws.scaleFrame(cs.dst, src), \"pngSws.scaleFrame\");\n          await video!.encode(cs.dst, muxer);\n        }\n      } finally {\n        if (!codec) cs[Symbol.dispose]();\n      }\n    });\n  }\n\n  async encodeAudio(pcm: Buffer): Promise<void> {\n    const { audio, limiter, muxer } = this._s;\n    if (audio) await limiter.schedule(() => audio.encode(pcm, muxer));\n  }\n\n  async finish(): Promise<string> {\n    const { video, hwVideo, audio, muxer, limiter } = this._s;\n    try {\n      await using _m = muxer;\n      using _v = video;\n      using _hv = hwVideo;\n      using _a = audio;\n      await limiter.drain();\n      await audio?.flush(muxer);\n      if (hwVideo) {\n        await hwVideo.flush(muxer);\n      } else {\n        await video!.flush(muxer);\n      }\n    } finally {\n      this.free();\n    }\n    return this._s.outFile;\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (this._disposed) return;\n    const { video, hwVideo, audio, muxer, limiter } = this._s;\n    await limiter.drain();\n    video?.[Symbol.dispose]();\n    hwVideo?.[Symbol.dispose]();\n    audio?.[Symbol.dispose]();\n    await muxer[Symbol.asyncDispose]();\n    this.free();\n  }\n\n  private free(): void {\n    if (this._disposed) return;\n    this._disposed = true;\n    using _codec = this._s.codec;\n    this._s.hw?.dispose();\n  }\n\n  private bgraFrame(input: Buffer): Frame {\n    const frame = makeFrame(this._s.width, this._s.height, AV_PIX_FMT_BGRA);\n    FFmpegError.throwIfError(frame.fromBuffer(input), \"bgraFrame.fromBuffer\");\n    return frame;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { HardwareContext } from \"node-av/api\";\nimport { logger } from \"./logging\";\n\nconst TAG = \"[HWAccel]\";\n\nasync function detectGPUDriver() {\n  const hw = HardwareContext.auto();\n  const result = hw !== null;\n  hw?.dispose();\n  return result;\n}\n\nexport const canIUseGPU = detectGPUDriver().then((result) => {\n  logger.debug(TAG, \"gpu:\", result);\n  return result;\n});\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/03.\n\nimport { platform } from \"os\";\nimport { pupLogLevel } from \"./constants\";\nimport { canIUseGPU } from \"./hwaccel\";\n\nexport async function chromiumOptions(disableGpu: boolean) {\n  const opts = [\n    // 容器沙箱\n    \"no-sandbox\",\n    \"disable-dev-shm-usage\",\n    // 跨域/安全\n    \"disable-web-security\",\n    \"disable-site-isolation-trials\",\n    \"ignore-certificate-errors\",\n    // 录制行为\n    \"disable-blink-features=AutomationControlled\",\n    \"mute-audio\",\n    \"autoplay-policy=no-user-gesture-required\",\n    \"disable-extensions\",\n    // 渲染\n    \"force-device-scale-factor=1\",\n    \"force-color-profile=srgb\",\n    \"ignore-gpu-blocklist\",\n    \"use-gl=angle\",\n    \"deterministic-mode\",\n    \"enable-begin-frame-control\",\n    \"disable-new-content-rendering-timeout\",\n    \"run-all-compositor-stages-before-draw\",\n    \"disable-threaded-animation\",\n    \"disable-threaded-scrolling\",\n    \"disable-checker-imaging\",\n    \"disable-image-animation-resync\",\n    \"enable-surface-synchronization\",\n    // https://github.com/puppeteer/puppeteer/issues/2410\n    \"font-render-hinting=none\",\n    // 资源控制\n    \"disable-background-networking\",\n  ];\n\n  if (pupLogLevel < 3) {\n    opts.push(\"log-level=3\");\n  }\n\n  const features = [\"FontationBackend\"];\n  const enableGpu = (await canIUseGPU) && !disableGpu;\n  if (!enableGpu) {\n    opts.push(\"use-angle=swiftshader\", \"enable-unsafe-swiftshader\");\n  } else {\n    opts.push(\"disable-gpu-sandbox\", \"enable-unsafe-webgpu\");\n    const plat = platform();\n    if (plat === \"darwin\") {\n      opts.push(\"use-angle=metal\");\n    } else if (plat === \"win32\") {\n      opts.push(\"use-angle=d3d11\");\n    } else {\n      opts.push(\"use-angle=vulkan\", \"disable-vulkan-surface\");\n      features.push(\"Vulkan\");\n    }\n  }\n\n  opts.push(`enable-features=${features.join(\",\")}`);\n  return opts;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nimport electron, { type Size } from \"electron\";\nimport { platform } from \"os\";\nimport { chromiumOptions } from \"../base/chromium\";\nimport { pupApp } from \"../base/constants\";\nimport { logger } from \"../base/logging\";\nimport { exec, PUP_ARGS_KEY } from \"../base/process\";\n\nexport async function electronOpts(disableGpu: boolean) {\n  return [...(await chromiumOptions(disableGpu)), \"headless=new\"];\n}\n\nconst TAG = \"[Electron]\";\n\nexport async function runElectronApp(size: Size, args: unknown[], ipcSocketPath: string) {\n  const cmdParts: unknown[] = [];\n  const plat = platform();\n  if (plat === \"linux\") {\n    cmdParts.push(`xvfb-run`, `--auto-servernum`, `--server-args=\"-screen 0 ${size.width}x${size.height}x24\"`);\n  }\n  const opts = await electronOpts(args.includes(\"--disable-gpu\"));\n  const electronArgs = opts.map((a) => `--${a}`);\n  const base64Args = Buffer.from(JSON.stringify(args)).toString(\"base64\");\n  electronArgs.push(`${PUP_ARGS_KEY}=${base64Args}`);\n  cmdParts.push(electron, ...electronArgs, pupApp);\n  const cmd = cmdParts.join(\" \");\n  logger.debug(TAG, cmd);\n  return exec(cmd, {\n    stdio: [\"ignore\", \"pipe\", \"pipe\"],\n    shell: plat === \"linux\",\n    env: { ...process.env, RUST_BACKTRACE: \"full\", PUP_IPC_SOCKET: ipcSocketPath },\n  });\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/04/01.\n\nexport const TICK_SYMBOL = \"__pup_tick__\";\n\nexport interface TickInjectorOptions {\n  /**\n   * When true, skips the top-frame guard so the injector runs in the main document.\n   * Required for Puppeteer mode where the page is loaded directly (no stego iframe wrapper).\n   * Default: false (Electron/stego mode — only inject in iframes).\n   */\n  skipFrameGuard?: boolean;\n}\n\n/**\n * Builds the JS injector that hooks all time-related globals in the target frame.\n * In Electron/stego mode (default), guards against running in the top-level frame.\n * In Puppeteer mode (skipFrameGuard: true), injects directly into the main document.\n * Must be injected via Page.addScriptToEvaluateOnNewDocument AND directly into\n * already-loaded frames.\n */\nexport function buildTickInjector(opts?: TickInjectorOptions): string {\n  const frameGuard = opts?.skipFrameGuard ? \"\" : \"if (window.self === window.top) return;\";\n  return `(function() {\n  ${frameGuard}\n  if (typeof ${TICK_SYMBOL} !== 'undefined') return;\n\n  const orig = {\n    Date: Date,\n    dateNow: Date.now.bind(Date),\n    performanceNow: performance.now.bind(performance),\n    raf: requestAnimationFrame.bind(window),\n    caf: cancelAnimationFrame.bind(window),\n    setTimeout: setTimeout.bind(window),\n    clearTimeout: clearTimeout.bind(window),\n    setInterval: setInterval.bind(window),\n    clearInterval: clearInterval.bind(window),\n  };\n\n  let currMs = 0;\n  let rafQueue = [];\n  const timers = {};\n  let nextId = 1;\n  const dateOrigin = new orig.Date();\n  const perfOrigin = orig.performanceNow();\n\n  performance.now = function() { return perfOrigin + currMs; };\n  Date.now = function() { return dateOrigin.getTime() + currMs; };\n  Date = function() {\n    var O = orig.Date;\n    if (arguments.length === 0) return new O(dateOrigin.getTime() + currMs);\n    return new (Function.prototype.bind.apply(O, [null].concat(Array.prototype.slice.call(arguments))))();\n  };\n  Date.now = function() { return dateOrigin.getTime() + currMs; };\n  Date.parse = orig.Date.parse;\n  Date.UTC = orig.Date.UTC;\n  Date.prototype = orig.Date.prototype;\n\n  window.requestAnimationFrame = function(cb) {\n    const id = nextId++;\n    rafQueue.push({ id, cb });\n    return id;\n  };\n  window.cancelAnimationFrame = function(id) {\n    rafQueue = rafQueue.filter((r) => r.id !== id);\n  };\n\n  window.setTimeout = function(cb, delay, ...args) {\n    const id = nextId++;\n    timers[id] = { type: 'timeout', cb, delay: delay || 0, next: currMs + (delay || 0), args };\n    return id;\n  };\n  window.clearTimeout = function(id) { delete timers[id]; };\n\n  window.setInterval = function(cb, delay, ...args) {\n    const id = nextId++;\n    const d = Math.max(delay || 0, 1);\n    timers[id] = { type: 'interval', cb, delay: d, next: currMs + d, args };\n    return id;\n  };\n  window.clearInterval = function(id) { delete timers[id]; };\n\n  function process(timestampMs) {\n    currMs = timestampMs;\n    document.getAnimations().forEach(a => {\n      a.pause();\n      a.currentTime = currMs;\n    });\n    const ids = Object.keys(timers);\n    for (let i = 0; i < ids.length; i++) {\n      const t = timers[ids[i]];\n      if (!t) continue;\n      while (t.next <= currMs) {\n        if (typeof t.cb === 'string') eval(t.cb); else t.cb.apply(undefined, t.args);\n        if (t.type === 'timeout') { delete timers[ids[i]]; break; }\n        t.next += t.delay;\n      }\n    }\n    const rafs = rafQueue.splice(0);\n    for (let j = 0; j < rafs.length; j++) {\n      rafs[j].cb(currMs);\n    }\n  }\n\n  function eject() {\n    Date = orig.Date;\n    performance.now = orig.performanceNow;\n    window.requestAnimationFrame = orig.raf;\n    window.cancelAnimationFrame = orig.caf;\n    window.setTimeout = orig.setTimeout;\n    window.clearTimeout = orig.clearTimeout;\n    window.setInterval = orig.setInterval;\n    window.clearInterval = orig.clearInterval;\n    delete window.${TICK_SYMBOL};\n  }\n\n  window.${TICK_SYMBOL} = { process: process, eject: eject };\n})();`;\n}\n\nexport function doProcess(timestampMs: number): string {\n  return `${TICK_SYMBOL}.process(${timestampMs})`;\n}\n\nexport function doEject(): string {\n  return `if (typeof ${TICK_SYMBOL} !== 'undefined') ${TICK_SYMBOL}.eject()`;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/03.\n\nimport { mkdir } from \"fs/promises\";\nimport { dirname } from \"path\";\nimport puppeteer from \"puppeteer\";\nimport { chromiumOptions } from \"../base/chromium\";\nimport { EncoderPipeline } from \"../base/encoder/pipeline\";\nimport { logger } from \"../base/logging\";\nimport type { IpcDonePayload } from \"./ipc\";\nimport { type RenderOptions } from \"./schema\";\nimport { buildTickInjector, doEject, doProcess } from \"./tick\";\n\nconst TAG = \"[Puppeteer]\";\n\nexport async function doPuppeteer(\n  source: string,\n  options: RenderOptions,\n  onProgress?: (p: number) => void,\n): Promise<IpcDonePayload> {\n  const { fps, width, height, duration, outFile, disableGpu } = options;\n  if (options.withAudio) logger.warn(TAG, \"audio capture is not supported in Puppeteer mode\");\n\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n\n  await mkdir(dirname(outFile), { recursive: true });\n  await using pipeline = await EncoderPipeline.create({ width, height, fps, outFile, disableGpu });\n\n  const browser = await puppeteer.launch({\n    headless: \"shell\",\n    defaultViewport: { width, height },\n    args: (await chromiumOptions(disableGpu)).map((a) => `--${a}`),\n  });\n\n  try {\n    const page = (await browser.pages())[0]!;\n\n    const session = await page.createCDPSession();\n    // Page.addScriptToEvaluateOnNewDocument must use the page's own CDP client.\n    // HeadlessExperimental uses a separate session (see puppeteer-capture).\n    // @ts-expect-error — _client() is a private Puppeteer API not exposed in type declarations\n    const pageClient = page._client() as typeof session;\n\n    const tickScript = buildTickInjector({ skipFrameGuard: true });\n    const { identifier } = await pageClient.send(\"Page.addScriptToEvaluateOnNewDocument\", { source: tickScript });\n\n    try {\n      await page.goto(source, { waitUntil: \"networkidle0\", timeout: 30_000 });\n\n      for (const frame of page.frames()) {\n        await frame.evaluate(tickScript);\n        await frame.evaluate(doProcess(0));\n      }\n\n      await session.send(\"HeadlessExperimental.enable\");\n\n      // Trigger an initial render so any CSS animations start and fire animationStarted events.\n      await session.send(\"HeadlessExperimental.beginFrame\", {\n        frameTimeTicks: 0,\n        interval: frameInterval,\n        noDisplayUpdates: false,\n      });\n\n      let written = 0;\n      let progress = 0;\n      let captureTimestamp = 0;\n      let frameTimeTicks = frameInterval;\n\n      for (let i = 0; i < total; i++) {\n        captureTimestamp += frameInterval;\n\n        await Promise.all(page.frames().map((frame) => frame.evaluate(doProcess(captureTimestamp))));\n\n        const result = await session.send(\"HeadlessExperimental.beginFrame\", {\n          frameTimeTicks,\n          interval: frameInterval,\n          noDisplayUpdates: false,\n          screenshot: { format: \"png\" },\n        });\n        frameTimeTicks += frameInterval;\n\n        if (!result.screenshotData) {\n          logger.warn(TAG, `frame ${i} produced no screenshot`);\n          continue;\n        }\n\n        await pipeline.encodePNG(Buffer.from(result.screenshotData, \"base64\"));\n        written++;\n\n        const newProgress = Math.floor((written / total) * 100);\n        if (Math.abs(newProgress - progress) > 10) {\n          progress = newProgress;\n          onProgress?.(progress);\n        }\n      }\n\n      for (const frame of page.frames()) {\n        if (!frame.detached) await frame.evaluate(doEject());\n      }\n\n      if (written === 0) throw new Error(\"no frames captured\");\n      return { written, jank: 0, outFile };\n    } finally {\n      await session.send(\"HeadlessExperimental.disable\");\n      await pageClient.send(\"Page.removeScriptToEvaluateOnNewDocument\", { identifier });\n      await session.detach();\n    }\n  } finally {\n    await browser.close();\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { ok } from \"assert\";\nimport { randomUUID } from \"crypto\";\nimport { rmSync } from \"fs\";\nimport { mkdir } from \"fs/promises\";\nimport { platform, tmpdir } from \"os\";\nimport { join } from \"path\";\nimport treeKill from \"tree-kill\";\nimport { pupExperimentalPuppeteer } from \"./base/constants\";\nimport { logger } from \"./base/logging\";\nimport { runElectronApp } from \"./renderer/electron\";\nimport { createIpcServer, type IpcDonePayload } from \"./renderer/ipc\";\nimport { doPuppeteer } from \"./renderer/puppeteer\";\nimport { defaultRenderOptions, type RenderOptions, type RenderResult } from \"./renderer/schema\";\n\nconst TAG = \"[pup]\";\n\nexport type PupProgressCallback = (progress: number) => Promise<void> | void;\n\nexport interface PupOptions extends Partial<RenderOptions> {\n  signal?: AbortSignal;\n  onProgress?: PupProgressCallback;\n}\n\nexport interface PupResult extends RenderResult {}\n\ninterface AppOptions extends RenderOptions {\n  signal?: AbortSignal;\n}\n\nasync function runPupApp(source: string, options: AppOptions, socketPath: string) {\n  logger.debug(TAG, `runPupApp`, source, options);\n\n  const args: string[] = [\n    source,\n    `--width`,\n    `${options.width}`,\n    `--height`,\n    `${options.height}`,\n    `--fps`,\n    `${options.fps}`,\n    `--duration`,\n    `${options.duration}`,\n    `--out-file`,\n    `${options.outFile}`,\n  ];\n  if (options.withAudio) args.push(`--with-audio`);\n  if (options.useInnerProxy) args.push(`--use-inner-proxy`);\n  if (options.deterministic) args.push(`--deterministic`);\n  if (options.disableGpu) args.push(`--disable-gpu`);\n\n  return runElectronApp(options, args, socketPath);\n}\n\nconst d = defaultRenderOptions;\n\nexport async function pup(source: string, options: Partial<PupOptions>): Promise<PupResult> {\n  logger.debug(TAG, `pup`, source, options);\n\n  const { signal } = options;\n  if (signal?.aborted) throw signal.reason;\n\n  const outFile = options.outFile ?? d.outFile;\n  const renderOpts: RenderOptions = {\n    width: options.width ?? d.width,\n    height: options.height ?? d.height,\n    fps: options.fps ?? d.fps,\n    duration: options.duration ?? d.duration,\n    withAudio: options.withAudio ?? d.withAudio,\n    useInnerProxy: options.useInnerProxy ?? d.useInnerProxy,\n    deterministic: options.deterministic ?? d.deterministic,\n    disableGpu: options.disableGpu ?? d.disableGpu,\n    outFile,\n  };\n\n  const tmpDir = join(tmpdir(), \"pup\", randomUUID());\n  await mkdir(tmpDir, { recursive: true });\n  const socketPath = join(tmpDir, \"pup.sock\");\n\n  const t0 = performance.now();\n  const tick = (p: number) => (logger.info(TAG, `${source} progress: ${p}%`), options.onProgress?.(p));\n\n  // On Linux + deterministic mode, use Puppeteer inline (no Electron subprocess needed).\n  if (platform() === \"linux\" && renderOpts.deterministic && pupExperimentalPuppeteer) {\n    tick(0);\n    const summary = await doPuppeteer(source, renderOpts, tick);\n    tick(100);\n    logger.info(TAG, `done ${outFile} in ${Math.round(performance.now() - t0)}ms`);\n    return { ...summary, options: renderOpts };\n  }\n\n  const server = await createIpcServer(socketPath);\n  const handle = await runPupApp(source, { ...renderOpts, signal }, socketPath);\n\n  const onAbort = () => {\n    logger.debug(TAG, `aborted`);\n    const pid = handle.process.pid;\n    if (pid) treeKill(pid);\n    else handle.process.kill();\n    rmSync(tmpDir, { recursive: true, force: true });\n  };\n  signal?.addEventListener(\"abort\", onAbort, { once: true });\n\n  try {\n    const result = new Promise<IpcDonePayload>(async (resolve, reject) => {\n      (await server.waitForConnection())\n        .on(\"close\", () => reject(new Error(\"IPC closed without result\")))\n        .on(\"message\", () => signal?.aborted && reject(signal.reason))\n        .on(\"progress\", tick)\n        .on(\"done\", resolve)\n        .on(\"error\", reject);\n    }).finally(() => server.close());\n    tick(0);\n    const summary = await Promise.race([result, handle.wait]);\n    ok(summary, \"no summary received\");\n    tick(100);\n    logger.info(TAG, `done ${outFile} in ${Math.round(performance.now() - t0)}ms`);\n    return { ...summary, options: renderOpts };\n  } catch (e) {\n    if (signal?.aborted) throw signal.reason;\n    throw e;\n  } finally {\n    rmSync(tmpDir, { recursive: true, force: true });\n  }\n}\n"]}