pup-recorder 0.2.7 → 0.2.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build.ts +0 -3
- package/dist/_tsup-dts-rollup.d.ts +46 -10
- package/dist/app.cjs +26 -14
- package/dist/chunk-BG7244QU.js +92 -0
- package/dist/cli.js +2 -2
- package/dist/index.d.ts +1 -0
- package/dist/index.js +2 -2
- package/package.json +3 -2
- package/dist/chunk-3POZKRKH.js +0 -2
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import'source-map-support/register.js';import {a,b as b$1}from'./chunk-3POZKRKH.js';export{v as DEFAULT_DURATION,u as DEFAULT_FPS,t as DEFAULT_HEIGHT,w as DEFAULT_OUT_FILE,s as DEFAULT_WIDTH,m as Logger,p as PUP_ARGS_KEY,x as RenderSchema,y as defaultRenderOptions,r as exec,n as logger,o as noerr,q as pargs,d as parseNumber,e as parseString,c as penv,z as pup,k as pupApp,i as pupDeterministic,h as pupDisableGPU,l as pupIpcSocket,f as pupLogLevel,j as pupPkgRoot,g as pupUseInnerProxy}from'./chunk-3POZKRKH.js';import {setTimeout as setTimeout$1}from'timers/promises';import {cpus}from'os';import {FormatContext,FFmpegError,Frame,SoftwareScaleContext,Codec,CodecContext,Rational,Packet,FilterGraph,Filter,FilterInOut}from'node-av';import {AV_PIX_FMT_YUVA420P,FF_ENCODER_LIBX265,FF_ENCODER_AAC,AV_SAMPLE_FMT_FLTP,AV_PIX_FMT_BGRA,SWS_BILINEAR,FF_THREAD_SLICE,AV_CODEC_FLAG_GLOBAL_HEADER,AVERROR_EAGAIN,AVERROR_EOF,AV_CHANNEL_LAYOUT_STEREO,AV_SAMPLE_FMT_FLT}from'node-av/constants';var C=class{constructor(e){this.makeValue=e;}get value(){return this._initialized||(this._value=this.makeValue(),this._initialized=true),this._value}get initialized(){return this._initialized}_initialized=false;_value};var b=class{constructor(e){this.maxConcurrency=e;}_active=0;_queue=[];_ended=false;get active(){return this._active}get pending(){return this._queue.length}get stats(){return `active: ${this.active}, pending: ${this.pending}`}async schedule(e){if(this._ended)throw new Error("ended");return new Promise((t,r)=>{let i=()=>{this._active++,e().then(a=>{this._active--,t(a),this.next();}).catch(a=>{this._active--,r(a),this.next();});};this._queue.push(i),this.next();})}async end(){if(!this._ended)for(this._ended=true;this._active>0||this.pending>0;)await new Promise(e=>setTimeout(e,50));}next(){this._active<this.maxConcurrency&&this._queue.shift()?.();}};function k(n){return new Promise(e=>setTimeout(e,n))}function Ge(n,e){let t,r=false;async function i(a){await n(a),!r&&(t=setTimeout(()=>i(a+1),e));}return t=setTimeout(()=>i(0),e),()=>{r=true,clearTimeout(t);}}function Xe({fn:n,maxAttempts:e=3,timeout:t}){let r=new Error(`timeout over ${t}ms`);return async function(...i){let a=0;for(;;)try{let s=[n(...i)];return t&&s.push(setTimeout$1(t).then(()=>{throw r})),await Promise.race(s)}catch(s){if(a++,a>=e)throw s;await k(Math.pow(2,a)*100+Math.random()*100);}}}var Q={[AV_SAMPLE_FMT_FLT]:"flt",[AV_SAMPLE_FMT_FLTP]:"fltp"},y=class n{_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=new Packet,this._pkt.alloc(),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 n(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 a=Filter.getByName("abuffersink"),s=t.createFilter(a,"sink");if(!s)throw new Error("Failed to create abuffersink");let d=`aformat=sample_fmts=${Q[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}]),c=FilterInOut.createList([{name:"out",filterCtx:s,padIdx:0}]);FFmpegError.throwIfError(t.parsePtr(d,c,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 c=0;c<r.length;c++)isFinite(r[c])||(r[c]=0);let i=r.length>>1;let a$1=a(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(a$1),"buffersrcAddFrame");await this.drain(t);}catch(m){var d=m,u=true;}finally{b$1(s,d,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);}}async drainCodec(e){for(;;){let t=await this._ctx.receivePacket(this._pkt);if(t===AVERROR_EAGAIN||t===AVERROR_EOF)break;FFmpegError.throwIfError(t,"audio.receivePacket"),this._pkt.streamIndex=this._stream.index,this._pkt.rescaleTs(this._ctx.timeBase,this._stream.timeBase),await e.writePacket(this._pkt),this._pkt.unref();}}};var E=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);}};var g=class n{_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:a,codecTag:s,globalHeader:m,codecOpts:d,bitrate:u,threadCount:c,muxer:f}=e,_=Codec.findEncoderByName(a);if(!_)throw new Error(`Video encoder not found: ${a}`);let o=new CodecContext;o.allocContext3(_),o.codecId=_.id,o.width=t,o.height=r,o.pixelFormat=e.pixelFormat,o.timeBase=new Rational(1,i),o.framerate=new Rational(i,1),o.gopSize=i*2,o.bitRate=BigInt(u),c&&(o.threadCount=c,o.threadType=FF_THREAD_SLICE),m&&o.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);for(let[$,z]of Object.entries(d))o.setOption($,z);s&&(o.codecTag=s),FFmpegError.throwIfError(await o.open2(_,null),"videoCtx.open2");let P=new Packet;P.alloc();let G=f.addStream(o,s);return new n(o,P,G)}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();}async drain(e){let t=this._pkt;for(;;){let r=await this._ctx.receivePacket(t);if(r===AVERROR_EAGAIN||r===AVERROR_EOF)break;FFmpegError.throwIfError(r,"video.receivePacket"),t.streamIndex=this._stream.index,t.duration===0n&&(t.duration=1n),t.rescaleTs(this._ctx.timeBase,this._stream.timeBase),await e.writePacket(t),t.unref();}}};var H=class n{constructor(e,t,r,i,a,s,m,d){this._video=e;this._audio=t;this._muxer=r;this._limiter=i;this._outFile=a;this._sws=s;this._srcFrame=m;this._dstFrame=d;}_disposed=false;static async create(e){let{width:t,height:r,fps:i,outFile:a,withAudio:s=false}=e,m=new E(a),d=await g.create({width:t,height:r,fps:i,codecName:FF_ENCODER_LIBX265,codecTag:"hvc1",globalHeader:true,codecOpts:{preset:"ultrafast","x265-params":"log-level=1:bframes=0"},bitrate:8e6,pixelFormat:AV_PIX_FMT_YUVA420P,threadCount:cpus().length,muxer:m}),u;s&&(u=await y.create({outSampleRate:44100,outSampleFmt:AV_SAMPLE_FMT_FLTP,codecName:FF_ENCODER_AAC,globalHeader:true,bitrate:128e3,muxer:m})),await m.open();let c=new b(1),f=new Frame;f.alloc(),f.format=AV_PIX_FMT_BGRA,f.width=t,f.height=r,FFmpegError.throwIfError(f.getBuffer(0),"srcFrame.getBuffer");let _=new SoftwareScaleContext;_.getContext(t,r,AV_PIX_FMT_BGRA,t,r,AV_PIX_FMT_YUVA420P,SWS_BILINEAR);let o=new Frame;return o.alloc(),o.format=AV_PIX_FMT_YUVA420P,o.width=t,o.height=r,FFmpegError.throwIfError(o.getBuffer(0),"dstFrame.getBuffer"),new n(d,u,m,c,a,_,f,o)}setupAudio(e){this._audio?.setInputRate(e);}async encodeFrame(e){await this._limiter.schedule(async()=>(FFmpegError.throwIfError(this._srcFrame.makeWritable(),"srcFrame.makeWritable"),FFmpegError.throwIfError(this._srcFrame.fromBuffer(e),"srcFrame.fromBuffer"),FFmpegError.throwIfError(await this._sws.scaleFrame(this._dstFrame,this._srcFrame),"sws.scaleFrame"),FFmpegError.throwIfError(this._dstFrame.makeWritable(),"dstFrame.makeWritable"),this._video.encode(this._dstFrame,this._muxer)));}async encodeAudio(e){this._audio&&await this._limiter.schedule(()=>this._audio.encode(e,this._muxer));}async finish(){try{var e=[];try{let s=a(e,this._muxer,!0);let m=a(e,this._video);let d=a(e,this._audio);await this._limiter.end();await this._audio?.flush(this._muxer);await this._video.flush(this._muxer);}catch(t){var r=t,i=!0;}finally{var a$1=b$1(e,r,i);a$1&&await a$1;}}finally{this.free();}return this._outFile}async[Symbol.asyncDispose](){this._disposed||(await this._limiter.end(),this._video[Symbol.dispose](),this._audio?.[Symbol.dispose](),await this._muxer[Symbol.asyncDispose](),this.free());}free(){this._disposed||(this._disposed=true,this._srcFrame.free(),this._dstFrame.free(),this._sws[Symbol.dispose]());}};export{b as ConcurrencyLimiter,H as EncoderPipeline,E as FormatMuxer,C as Lazy,Ge as periodical,k as sleep,Xe as useRetry};//# sourceMappingURL=index.js.map
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/base/lazy.ts","../src/base/limiter.ts","../src/base/timing.ts","../src/base/retry.ts","../src/base/encoder/audio.ts","../src/base/encoder/muxer.ts","../src/base/encoder/video.ts","../src/base/encoder/encoder.ts"],"names":["Lazy","makeValue","ConcurrencyLimiter","maxConcurrency","fn","resolve","reject","run","v","e","r","sleep","ms","periodical","callback","token","closed","tick","count","useRetry","maxAttempts","timeout","timeoutError","args","attempt","promises","setTimeout","SAMPLE_FMT_NAME","AV_SAMPLE_FMT_FLT","AV_SAMPLE_FMT_FLTP","AudioEncoder","_AudioEncoder","ctx","stream","outFmt","Packet","Frame","opts","codec","Codec","CodecContext","AV_CHANNEL_LAYOUT_STEREO","Rational","AV_CODEC_FLAG_GLOBAL_HEADER","FFmpegError","inSampleRate","graph","FilterGraph","abuffer","Filter","bufSrc","abuffersink","bufSink","filterDesc","outputs","FilterInOut","inputs","pcm","muxer","_stack","src","i","nSamples","frame","__using","_","_error","_hasError","__callDispose","AVERROR_EAGAIN","AVERROR_EOF","FormatMuxer","outPath","formatName","FormatContext","codecCtx","codecTag","pkt","VideoEncoder","_VideoEncoder","width","height","fps","codecName","globalHeader","codecOpts","bitrate","threadCount","FF_THREAD_SLICE","k","EncoderPipeline","_EncoderPipeline","_video","_audio","_muxer","_limiter","_outFile","_sws","_srcFrame","_dstFrame","outFile","withAudio","video","FF_ENCODER_LIBX265","AV_PIX_FMT_YUVA420P","cpus","audio","FF_ENCODER_AAC","limiter","srcFrame","AV_PIX_FMT_BGRA","sws","SoftwareScaleContext","SWS_BILINEAR","dstFrame","sampleRate","input","_m","_v","_a","_promise"],"mappings":"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","file":"index.js","sourcesContent":["// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nexport class Lazy<T> {\n  constructor(readonly makeValue: () => T) {}\n\n  get value(): T {\n    if (!this._initialized) {\n      this._value = this.makeValue();\n      this._initialized = true;\n    }\n    return this._value!;\n  }\n\n  get initialized(): boolean {\n    return this._initialized;\n  }\n\n  private _initialized = false;\n  private _value: T | undefined;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nexport class ConcurrencyLimiter {\n  private _active = 0;\n  private _queue: VoidFunction[] = [];\n  private _ended = false;\n\n  constructor(readonly maxConcurrency: number) {}\n\n  get active(): number {\n    return this._active;\n  }\n\n  get pending(): number {\n    return this._queue.length;\n  }\n\n  get stats(): string {\n    return `active: ${this.active}, pending: ${this.pending}`;\n  }\n\n  async schedule<T>(fn: () => Promise<T>): Promise<T> {\n    if (this._ended) {\n      throw new Error(\"ended\");\n    }\n    return new Promise<T>((resolve, reject) => {\n      const run = () => {\n        this._active++;\n        fn()\n          .then((v) => {\n            this._active--;\n            resolve(v);\n            this.next();\n          })\n          .catch((e) => {\n            this._active--;\n            reject(e);\n            this.next();\n          });\n      };\n      this._queue.push(run);\n      this.next();\n    });\n  }\n\n  async end() {\n    if (this._ended) {\n      return;\n    }\n    this._ended = true;\n    while (this._active > 0 || this.pending > 0) {\n      await new Promise((r) => setTimeout(r, 50));\n    }\n  }\n\n  private next() {\n    if (this._active < this.maxConcurrency) {\n      this._queue.shift()?.();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nexport function sleep(ms: number) {\n  return new Promise<void>((resolve) => setTimeout(resolve, ms));\n}\n\nexport function periodical(callback: (count: number) => Promise<void> | void, ms: number) {\n  let token: NodeJS.Timeout;\n  let closed = false;\n  async function tick(count: number) {\n    await callback(count);\n    if (closed) return;\n    token = setTimeout(() => tick(count + 1), ms);\n  }\n  token = setTimeout(() => tick(0), ms);\n  return () => {\n    closed = true;\n    clearTimeout(token);\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/05.\n\nimport { setTimeout } from \"timers/promises\";\nimport { sleep } from \"./timing\";\n\nexport interface RetryOptions<Args extends any[], Ret> {\n  fn: (...args: Args) => Promise<Ret>;\n  maxAttempts?: number;\n  timeout?: number;\n}\n\nexport function useRetry<Args extends any[], Ret>({ fn, maxAttempts = 3, timeout }: RetryOptions<Args, Ret>) {\n  const timeoutError = new Error(`timeout over ${timeout}ms`);\n  return async function (...args: Args) {\n    let attempt = 0;\n    while (true) {\n      try {\n        const promises = [fn(...args)];\n        if (timeout) {\n          promises.push(\n            setTimeout(timeout).then(() => {\n              throw timeoutError;\n            }),\n          );\n        }\n        return await Promise.race(promises);\n      } catch (e) {\n        attempt++;\n        if (attempt >= maxAttempts) {\n          throw e;\n        }\n        await sleep(Math.pow(2, attempt) * 100 + Math.random() * 100);\n      }\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { Codec, CodecContext, FFmpegError, Filter, FilterGraph, FilterInOut, Frame, Packet, Rational } from \"node-av\";\nimport {\n  AV_CHANNEL_LAYOUT_STEREO,\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AV_SAMPLE_FMT_FLT,\n  AV_SAMPLE_FMT_FLTP,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  type FFAudioEncoder,\n} from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\n\nconst SAMPLE_FMT_NAME: Partial<Record<number, string>> = { [AV_SAMPLE_FMT_FLT]: \"flt\", [AV_SAMPLE_FMT_FLTP]: \"fltp\" };\ntype Stream = ReturnType<import(\"node-av\").FormatContext[\"newStream\"]>;\n\nexport interface AudioEncoderOptions {\n  outSampleRate: number;\n  outSampleFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  codecName: FFAudioEncoder;\n  globalHeader: boolean;\n  bitrate: number;\n  muxer: FormatMuxer;\n}\n\nexport class AudioEncoder implements Disposable {\n  private _ctx: CodecContext;\n  private _stream: Stream;\n  private _pkt: Packet;\n  private _outRate: number;\n  private _outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP;\n  private _frameSize: number;\n  private _filterFrame: Frame;\n  private _graph?: FilterGraph;\n  private _bufSrc?: any;\n  private _bufSink?: any;\n  private _inRate?: number;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, stream: Stream, outFmt: typeof AV_SAMPLE_FMT_FLT | typeof AV_SAMPLE_FMT_FLTP) {\n    this._ctx = ctx;\n    this._stream = stream;\n    this._outRate = ctx.sampleRate;\n    this._outFmt = outFmt;\n    this._frameSize = ctx.frameSize;\n    this._pkt = new Packet();\n    this._pkt.alloc();\n    this._filterFrame = new Frame();\n    this._filterFrame.alloc();\n  }\n\n  static async create(opts: AudioEncoderOptions): Promise<AudioEncoder> {\n    const codec = Codec.findEncoderByName(opts.codecName);\n    if (!codec) throw new Error(`Audio encoder not found: ${opts.codecName}`);\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.sampleFormat = opts.outSampleFmt;\n    ctx.sampleRate = opts.outSampleRate;\n    ctx.channelLayout = AV_CHANNEL_LAYOUT_STEREO;\n    ctx.timeBase = new Rational(1, opts.outSampleRate);\n    ctx.bitRate = BigInt(opts.bitrate);\n    if (opts.globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"audioCtx.open2\");\n    const stream = opts.muxer.addStream(ctx);\n    return new AudioEncoder(ctx, stream, opts.outSampleFmt);\n  }\n\n  setInputRate(inSampleRate: number): void {\n    this._graph?.[Symbol.dispose]();\n    this._inRate = inSampleRate;\n    const graph = new FilterGraph();\n    graph.alloc();\n    const abuffer = Filter.getByName(\"abuffer\")!;\n    const bufSrc = graph.createFilter(\n      abuffer,\n      \"src\",\n      `sample_rate=${inSampleRate}:sample_fmt=flt:channel_layout=stereo:time_base=1/${inSampleRate}`,\n    );\n    if (!bufSrc) throw new Error(\"Failed to create abuffer\");\n    const abuffersink = Filter.getByName(\"abuffersink\")!;\n    const bufSink = graph.createFilter(abuffersink, \"sink\");\n    if (!bufSink) throw new Error(\"Failed to create abuffersink\");\n    const fmtName = SAMPLE_FMT_NAME[this._outFmt] ?? \"flt\";\n    const filterDesc = `aformat=sample_fmts=${fmtName}:sample_rates=${this._outRate}:channel_layouts=stereo,asetnsamples=n=${this._frameSize}:p=1`;\n    const outputs = FilterInOut.createList([{ name: \"in\", filterCtx: bufSrc, padIdx: 0 }]);\n    const inputs = FilterInOut.createList([{ name: \"out\", filterCtx: bufSink, padIdx: 0 }]);\n    FFmpegError.throwIfError(graph.parsePtr(filterDesc, inputs, outputs), \"graph.parsePtr\");\n    FFmpegError.throwIfError(graph.configSync(), \"graph.config\");\n    this._graph = graph;\n    this._bufSrc = bufSrc;\n    this._bufSink = bufSink;\n  }\n\n  async encode(pcm: Buffer, muxer: FormatMuxer): Promise<void> {\n    if (!this._bufSrc || !this._inRate) return;\n    const src = new Float32Array(pcm.buffer, pcm.byteOffset, pcm.byteLength / 4);\n    for (let i = 0; i < src.length; i++) if (!isFinite(src[i]!)) src[i] = 0;\n    const nSamples = src.length >> 1;\n    using frame = Frame.fromAudioBuffer(Buffer.from(src.buffer, src.byteOffset, src.byteLength), {\n      nbSamples: nSamples,\n      format: AV_SAMPLE_FMT_FLT,\n      sampleRate: this._inRate,\n      channelLayout: AV_CHANNEL_LAYOUT_STEREO,\n      pts: this._pts,\n      timeBase: { num: 1, den: this._inRate },\n    });\n    this._pts += BigInt(nSamples);\n    FFmpegError.throwIfError(await this._bufSrc.buffersrcAddFrame(frame), \"buffersrcAddFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    if (this._bufSrc) {\n      await this._bufSrc.buffersrcAddFrame(null);\n      await this.drain(muxer);\n    }\n    await this._ctx.sendFrame(null);\n    await this.drainCodec(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._filterFrame.free();\n    this._graph?.[Symbol.dispose]();\n    this._ctx.freeContext();\n  }\n\n  private async drain(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._bufSink!.buffersinkGetFrame(this._filterFrame);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"buffersinkGetFrame\");\n      FFmpegError.throwIfError(await this._ctx.sendFrame(this._filterFrame), \"audioCtx.sendFrame\");\n      this._filterFrame.unref();\n      await this.drainCodec(muxer);\n    }\n  }\n\n  private async drainCodec(muxer: FormatMuxer): Promise<void> {\n    while (true) {\n      const r = await this._ctx.receivePacket(this._pkt);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"audio.receivePacket\");\n      this._pkt.streamIndex = this._stream.index;\n      this._pkt.rescaleTs(this._ctx.timeBase, this._stream.timeBase);\n      await muxer.writePacket(this._pkt);\n      this._pkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { CodecContext, FFmpegError, FormatContext, Packet } from \"node-av\";\n\nexport class FormatMuxer {\n  private readonly _ctx: FormatContext;\n  private _opened = false;\n\n  constructor(outPath: string, formatName?: string) {\n    this._ctx = new FormatContext();\n    FFmpegError.throwIfError(this._ctx.allocOutputContext2(null, formatName ?? null, outPath), \"allocOutputContext2\");\n  }\n\n  addStream(codecCtx: CodecContext, codecTag?: string): ReturnType<FormatContext[\"newStream\"]> {\n    const stream = this._ctx.newStream(null);\n    stream.timeBase = codecCtx.timeBase;\n    FFmpegError.throwIfError(stream.codecpar.fromContext(codecCtx), \"codecpar.fromContext\");\n    if (codecTag) stream.codecpar.codecTag = codecTag;\n    return stream;\n  }\n\n  async open(): Promise<void> {\n    if (this._opened) return;\n    FFmpegError.throwIfError(await this._ctx.openOutput(), \"openOutput\");\n    FFmpegError.throwIfError(await this._ctx.writeHeader(null), \"writeHeader\");\n    this._opened = true;\n  }\n\n  async writePacket(pkt: Packet): Promise<void> {\n    FFmpegError.throwIfError(await this._ctx.interleavedWriteFrame(pkt), \"interleavedWriteFrame\");\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (!this._opened) return;\n    await this._ctx.writeTrailer();\n    await this._ctx.closeOutput();\n    await this._ctx[Symbol.asyncDispose]();\n    this._opened = false;\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/21.\n\nimport { Codec, CodecContext, FFmpegError, Frame, Packet, Rational } from \"node-av\";\nimport {\n  AV_CODEC_FLAG_GLOBAL_HEADER,\n  AVERROR_EAGAIN,\n  AVERROR_EOF,\n  FF_THREAD_SLICE,\n  type AVPixelFormat,\n  type FFVideoEncoder,\n} from \"node-av/constants\";\nimport type { FormatMuxer } from \"./muxer\";\n\nexport interface VideoEncoderOptions {\n  width: number;\n  height: number;\n  fps: number;\n  codecName: FFVideoEncoder;\n  codecTag?: string;\n  globalHeader: boolean;\n  codecOpts: Record<string, string>;\n  bitrate: number;\n  pixelFormat: AVPixelFormat;\n  threadCount?: number;\n  muxer: FormatMuxer;\n}\n\ntype Stream = ReturnType<import(\"node-av\").FormatContext[\"newStream\"]>;\n\nexport class VideoEncoder implements Disposable {\n  private readonly _ctx: CodecContext;\n  private readonly _pkt: Packet;\n  private readonly _stream: Stream;\n  private _pts = 0n;\n\n  private constructor(ctx: CodecContext, pkt: Packet, stream: Stream) {\n    this._ctx = ctx;\n    this._pkt = pkt;\n    this._stream = stream;\n  }\n\n  static async create(opts: VideoEncoderOptions): Promise<VideoEncoder> {\n    const { width, height, fps, codecName, codecTag, globalHeader, codecOpts, bitrate, threadCount, muxer } = opts;\n\n    const codec = Codec.findEncoderByName(codecName);\n    if (!codec) throw new Error(`Video encoder not found: ${codecName}`);\n\n    const ctx = new CodecContext();\n    ctx.allocContext3(codec);\n    ctx.codecId = codec.id;\n    ctx.width = width;\n    ctx.height = height;\n    ctx.pixelFormat = opts.pixelFormat;\n    ctx.timeBase = new Rational(1, fps);\n    ctx.framerate = new Rational(fps, 1);\n    ctx.gopSize = fps * 2;\n    ctx.bitRate = BigInt(bitrate);\n    if (threadCount) {\n      ctx.threadCount = threadCount;\n      ctx.threadType = FF_THREAD_SLICE;\n    }\n    if (globalHeader) ctx.setFlags(AV_CODEC_FLAG_GLOBAL_HEADER);\n    for (const [k, v] of Object.entries(codecOpts)) ctx.setOption(k, v);\n    if (codecTag) ctx.codecTag = codecTag;\n    FFmpegError.throwIfError(await ctx.open2(codec, null), \"videoCtx.open2\");\n\n    const pkt = new Packet();\n    pkt.alloc();\n\n    const stream = muxer.addStream(ctx, codecTag);\n    return new VideoEncoder(ctx, pkt, stream);\n  }\n\n  async encode(frame: Frame, muxer: FormatMuxer): Promise<void> {\n    frame.pts = this._pts++;\n    frame.duration = 1n;\n    FFmpegError.throwIfError(await this._ctx.sendFrame(frame), \"videoCtx.sendFrame\");\n    await this.drain(muxer);\n  }\n\n  async flush(muxer: FormatMuxer): Promise<void> {\n    await this._ctx.sendFrame(null);\n    await this.drain(muxer);\n  }\n\n  [Symbol.dispose](): void {\n    this._pkt.free();\n    this._ctx.freeContext();\n  }\n\n  private async drain(muxer: FormatMuxer): Promise<void> {\n    const pkt = this._pkt;\n    while (true) {\n      const r = await this._ctx.receivePacket(pkt);\n      if (r === AVERROR_EAGAIN || r === AVERROR_EOF) break;\n      FFmpegError.throwIfError(r, \"video.receivePacket\");\n      pkt.streamIndex = this._stream.index;\n      if (pkt.duration === 0n) pkt.duration = 1n;\n      pkt.rescaleTs(this._ctx.timeBase, this._stream.timeBase);\n      await muxer.writePacket(pkt);\n      pkt.unref();\n    }\n  }\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/04/01.\n\nimport { cpus } from \"os\";\nimport { FFmpegError, Frame, SoftwareScaleContext } from \"node-av\";\nimport {\n  AV_PIX_FMT_BGRA,\n  AV_PIX_FMT_YUVA420P,\n  AV_SAMPLE_FMT_FLTP,\n  FF_ENCODER_AAC,\n  FF_ENCODER_LIBX265,\n  SWS_BILINEAR,\n} from \"node-av/constants\";\n\nimport { ConcurrencyLimiter } from \"../limiter\";\nimport { AudioEncoder } from \"./audio\";\nimport { FormatMuxer } from \"./muxer\";\nimport { VideoEncoder } from \"./video\";\n\nexport interface EncoderPipelineOptions {\n  width: number;\n  height: number;\n  fps: number;\n  outFile: string;\n  withAudio?: boolean;\n}\n\nexport class EncoderPipeline {\n  private _disposed = false;\n\n  private constructor(\n    private _video: VideoEncoder,\n    private _audio: AudioEncoder | undefined,\n    private _muxer: FormatMuxer,\n    private _limiter: ConcurrencyLimiter,\n    private _outFile: string,\n    private _sws: SoftwareScaleContext,\n    private _srcFrame: Frame,\n    private _dstFrame: Frame,\n  ) {}\n\n  static async create(opts: EncoderPipelineOptions): Promise<EncoderPipeline> {\n    const { width, height, fps, outFile, withAudio = false } = opts;\n    const muxer = new FormatMuxer(outFile);\n\n    const video = await VideoEncoder.create({\n      width,\n      height,\n      fps,\n      codecName: FF_ENCODER_LIBX265,\n      codecTag: \"hvc1\",\n      globalHeader: true,\n      codecOpts: { preset: \"ultrafast\", \"x265-params\": \"log-level=1:bframes=0\" },\n      bitrate: 8_000_000,\n      pixelFormat: AV_PIX_FMT_YUVA420P,\n      threadCount: cpus().length,\n      muxer,\n    });\n\n    let audio: AudioEncoder | undefined;\n    if (withAudio) {\n      audio = await AudioEncoder.create({\n        outSampleRate: 44_100,\n        outSampleFmt: AV_SAMPLE_FMT_FLTP,\n        codecName: FF_ENCODER_AAC,\n        globalHeader: true,\n        bitrate: 128_000,\n        muxer,\n      });\n    }\n\n    await muxer.open();\n    const limiter = new ConcurrencyLimiter(1);\n\n    const srcFrame = new Frame();\n    srcFrame.alloc();\n    srcFrame.format = AV_PIX_FMT_BGRA;\n    srcFrame.width = width;\n    srcFrame.height = height;\n    FFmpegError.throwIfError(srcFrame.getBuffer(0), \"srcFrame.getBuffer\");\n\n    const sws = new SoftwareScaleContext();\n    sws.getContext(width, height, AV_PIX_FMT_BGRA, width, height, AV_PIX_FMT_YUVA420P, SWS_BILINEAR);\n    const dstFrame = new Frame();\n    dstFrame.alloc();\n    dstFrame.format = AV_PIX_FMT_YUVA420P;\n    dstFrame.width = width;\n    dstFrame.height = height;\n    FFmpegError.throwIfError(dstFrame.getBuffer(0), \"dstFrame.getBuffer\");\n\n    return new EncoderPipeline(video, audio, muxer, limiter, outFile, sws, srcFrame, dstFrame);\n  }\n\n  setupAudio(sampleRate: number): void {\n    this._audio?.setInputRate(sampleRate);\n  }\n\n  async encodeFrame(input: Buffer): Promise<void> {\n    await this._limiter.schedule(async () => {\n      FFmpegError.throwIfError(this._srcFrame.makeWritable(), \"srcFrame.makeWritable\");\n      FFmpegError.throwIfError(this._srcFrame.fromBuffer(input), \"srcFrame.fromBuffer\");\n      FFmpegError.throwIfError(await this._sws.scaleFrame(this._dstFrame, this._srcFrame), \"sws.scaleFrame\");\n      FFmpegError.throwIfError(this._dstFrame.makeWritable(), \"dstFrame.makeWritable\");\n      return this._video.encode(this._dstFrame, this._muxer);\n    });\n  }\n\n  async encodeAudio(pcm: Buffer): Promise<void> {\n    if (this._audio) await this._limiter.schedule(() => this._audio!.encode(pcm, this._muxer));\n  }\n\n  async finish(): Promise<string> {\n    try {\n      await using _m = this._muxer;\n      using _v = this._video;\n      using _a = this._audio;\n      await this._limiter.end();\n      await this._audio?.flush(this._muxer);\n      await this._video.flush(this._muxer);\n    } finally {\n      this.free();\n    }\n    return this._outFile;\n  }\n\n  async [Symbol.asyncDispose](): Promise<void> {\n    if (this._disposed) return;\n    await this._limiter.end();\n    this._video[Symbol.dispose]();\n    this._audio?.[Symbol.dispose]();\n    await this._muxer[Symbol.asyncDispose]();\n    this.free();\n  }\n\n  private free(): void {\n    if (this._disposed) return;\n    this._disposed = true;\n    this._srcFrame.free();\n    this._dstFrame.free();\n    this._sws[Symbol.dispose]();\n  }\n}\n"]}
|
|
1
|
+
import'source-map-support/register.js';export{y as ConcurrencyLimiter,u as DEFAULT_DURATION,t as DEFAULT_FPS,s as DEFAULT_HEIGHT,v as DEFAULT_OUT_FILE,r as DEFAULT_WIDTH,A as EncoderPipeline,z as FormatMuxer,l as Logger,o as PUP_ARGS_KEY,w as RenderSchema,x as defaultRenderOptions,q as exec,m as logger,n as noerr,p as pargs,b as parseNumber,c as parseString,a as penv,B as pup,i as pupApp,g as pupDeterministic,f as pupDisableGPU,k as pupExperimentalPuppeteer,j as pupIpcSocket,d as pupLogLevel,h as pupPkgRoot,e as pupUseInnerProxy}from'./chunk-BG7244QU.js';import {setTimeout as setTimeout$1}from'timers/promises';var u=class{constructor(e){this.makeValue=e;}makeValue;get value(){return this._initialized||(this._value=this.makeValue(),this._initialized=true),this._value}get initialized(){return this._initialized}_initialized=false;_value};function p(r){return new Promise(e=>setTimeout(e,r))}function F(r,e){let t,i=false;async function n(o){await r(o),!i&&(t=setTimeout(()=>n(o+1),e));}return t=setTimeout(()=>n(0),e),()=>{i=true,clearTimeout(t);}}function Q({fn:r,maxAttempts:e=3,timeout:t}){let i=new Error(`timeout over ${t}ms`);return async function(...n){let o=0;for(;;)try{let m=[r(...n)];return t&&m.push(setTimeout$1(t).then(()=>{throw i})),await Promise.race(m)}catch(m){if(o++,o>=e)throw m;await p(Math.pow(2,o)*100+Math.random()*100);}}}export{u as Lazy,F as periodical,p as sleep,Q as useRetry};//# sourceMappingURL=index.js.map
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9iYXNlL2xhenkudHMiLCIuLi9zcmMvYmFzZS90aW1pbmcudHMiLCIuLi9zcmMvYmFzZS9yZXRyeS50cyJdLCJuYW1lcyI6WyJMYXp5IiwibWFrZVZhbHVlIiwic2xlZXAiLCJtcyIsInJlc29sdmUiLCJwZXJpb2RpY2FsIiwiY2FsbGJhY2siLCJ0b2tlbiIsImNsb3NlZCIsInRpY2siLCJjb3VudCIsInVzZVJldHJ5IiwiZm4iLCJtYXhBdHRlbXB0cyIsInRpbWVvdXQiLCJ0aW1lb3V0RXJyb3IiLCJhcmdzIiwiYXR0ZW1wdCIsInByb21pc2VzIiwic2V0VGltZW91dCIsImUiXSwibWFwcGluZ3MiOiIwbUJBRU8sSUFBTUEsRUFBTixLQUFjLENBQ25CLFlBQXFCQyxDQUFBQSxDQUFvQixDQUFwQixlQUFBQSxFQUFxQixDQUFyQixVQUVyQixJQUFJLEtBQUEsRUFBVyxDQUNiLE9BQUssSUFBQSxDQUFLLGVBQ1IsSUFBQSxDQUFLLE1BQUEsQ0FBUyxLQUFLLFNBQUEsRUFBVSxDQUM3QixLQUFLLFlBQUEsQ0FBZSxJQUFBLENBQUEsQ0FFZixLQUFLLE1BQ2QsQ0FFQSxJQUFJLFdBQUEsRUFBdUIsQ0FDekIsT0FBTyxJQUFBLENBQUssWUFDZCxDQUVRLFlBQUEsQ0FBZSxLQUFBLENBQ2YsTUFDVixFQ2pCTyxTQUFTQyxDQUFBQSxDQUFNQyxDQUFBQSxDQUFZLENBQ2hDLE9BQU8sSUFBSSxPQUFBLENBQWVDLENBQUFBLEVBQVksV0FBV0EsQ0FBQUEsQ0FBU0QsQ0FBRSxDQUFDLENBQy9ELENBRU8sU0FBU0UsQ0FBQUEsQ0FBV0MsQ0FBQUEsQ0FBbURILEVBQVksQ0FDeEYsSUFBSUksRUFDQUMsQ0FBQUEsQ0FBUyxLQUFBLENBQ2IsZUFBZUMsQ0FBQUEsQ0FBS0MsQ0FBQUEsQ0FBZSxDQUNqQyxNQUFNSixDQUFBQSxDQUFTSSxDQUFLLENBQUEsQ0FDaEIsQ0FBQUYsSUFDSkQsQ0FBQUEsQ0FBUSxVQUFBLENBQVcsSUFBTUUsQ0FBQUEsQ0FBS0MsQ0FBQUEsQ0FBUSxDQUFDLENBQUEsQ0FBR1AsQ0FBRSxHQUM5QyxDQUNBLE9BQUFJLEVBQVEsVUFBQSxDQUFXLElBQU1FLEVBQUssQ0FBQyxDQUFBLENBQUdOLENBQUUsQ0FBQSxDQUM3QixJQUFNLENBQ1hLLENBQUFBLENBQVMsS0FDVCxZQUFBLENBQWFELENBQUssRUFDcEIsQ0FDRixDQ1JPLFNBQVNJLENBQUFBLENBQWtDLENBQUUsR0FBQUMsQ0FBQUEsQ0FBSSxXQUFBLENBQUFDLEVBQWMsQ0FBQSxDQUFHLE9BQUEsQ0FBQUMsQ0FBUSxDQUFBLENBQTRCLENBQzNHLElBQU1DLENBQUFBLENBQWUsSUFBSSxNQUFNLENBQUEsYUFBQSxFQUFnQkQsQ0FBTyxJQUFJLENBQUEsQ0FDMUQsT0FBTyxrQkFBbUJFLENBQUFBLENBQVksQ0FDcEMsSUFBSUMsQ0FBQUEsQ0FBVSxDQUFBLENBQ2QsT0FDRSxHQUFJLENBQ0YsSUFBTUMsQ0FBQUEsQ0FBVyxDQUFDTixFQUFHLEdBQUdJLENBQUksQ0FBQyxDQUFBLENBQzdCLE9BQUlGLENBQUFBLEVBQ0ZJLENBQUFBLENBQVMsS0FDUEMsWUFBQUEsQ0FBV0wsQ0FBTyxFQUFFLElBQUEsQ0FBSyxJQUFNLENBQzdCLE1BQU1DLENBQ1IsQ0FBQyxDQUNILENBQUEsQ0FFSyxNQUFNLE9BQUEsQ0FBUSxJQUFBLENBQUtHLENBQVEsQ0FDcEMsQ0FBQSxNQUFTRSxFQUFHLENBRVYsR0FEQUgsSUFDSUEsQ0FBQUEsRUFBV0osQ0FBQUEsQ0FDYixNQUFNTyxDQUFBQSxDQUVSLE1BQU1sQixFQUFNLElBQUEsQ0FBSyxHQUFBLENBQUksRUFBR2UsQ0FBTyxDQUFBLENBQUksSUFBTSxJQUFBLENBQUssTUFBQSxHQUFXLEdBQUcsRUFDOUQsQ0FFSixDQUNGIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ3JlYXRlZCBieSBBdXRva2FrYSAocXExOTA5Njk4NDk0QGdtYWlsLmNvbSkgb24gMjAyNi8wMS8zMC5cblxuZXhwb3J0IGNsYXNzIExhenk8VD4ge1xuICBjb25zdHJ1Y3RvcihyZWFkb25seSBtYWtlVmFsdWU6ICgpID0+IFQpIHt9XG5cbiAgZ2V0IHZhbHVlKCk6IFQge1xuICAgIGlmICghdGhpcy5faW5pdGlhbGl6ZWQpIHtcbiAgICAgIHRoaXMuX3ZhbHVlID0gdGhpcy5tYWtlVmFsdWUoKTtcbiAgICAgIHRoaXMuX2luaXRpYWxpemVkID0gdHJ1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuX3ZhbHVlITtcbiAgfVxuXG4gIGdldCBpbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5faW5pdGlhbGl6ZWQ7XG4gIH1cblxuICBwcml2YXRlIF9pbml0aWFsaXplZCA9IGZhbHNlO1xuICBwcml2YXRlIF92YWx1ZTogVCB8IHVuZGVmaW5lZDtcbn1cbiIsIi8vIENyZWF0ZWQgYnkgQXV0b2tha2EgKHFxMTkwOTY5ODQ5NEBnbWFpbC5jb20pIG9uIDIwMjYvMDIvMDkuXG5cbmV4cG9ydCBmdW5jdGlvbiBzbGVlcChtczogbnVtYmVyKSB7XG4gIHJldHVybiBuZXcgUHJvbWlzZTx2b2lkPigocmVzb2x2ZSkgPT4gc2V0VGltZW91dChyZXNvbHZlLCBtcykpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGVyaW9kaWNhbChjYWxsYmFjazogKGNvdW50OiBudW1iZXIpID0+IFByb21pc2U8dm9pZD4gfCB2b2lkLCBtczogbnVtYmVyKSB7XG4gIGxldCB0b2tlbjogTm9kZUpTLlRpbWVvdXQ7XG4gIGxldCBjbG9zZWQgPSBmYWxzZTtcbiAgYXN5bmMgZnVuY3Rpb24gdGljayhjb3VudDogbnVtYmVyKSB7XG4gICAgYXdhaXQgY2FsbGJhY2soY291bnQpO1xuICAgIGlmIChjbG9zZWQpIHJldHVybjtcbiAgICB0b2tlbiA9IHNldFRpbWVvdXQoKCkgPT4gdGljayhjb3VudCArIDEpLCBtcyk7XG4gIH1cbiAgdG9rZW4gPSBzZXRUaW1lb3V0KCgpID0+IHRpY2soMCksIG1zKTtcbiAgcmV0dXJuICgpID0+IHtcbiAgICBjbG9zZWQgPSB0cnVlO1xuICAgIGNsZWFyVGltZW91dCh0b2tlbik7XG4gIH07XG59XG4iLCIvLyBDcmVhdGVkIGJ5IEF1dG9rYWthIChxcTE5MDk2OTg0OTRAZ21haWwuY29tKSBvbiAyMDI2LzAyLzA1LlxuXG5pbXBvcnQgeyBzZXRUaW1lb3V0IH0gZnJvbSBcInRpbWVycy9wcm9taXNlc1wiO1xuaW1wb3J0IHsgc2xlZXAgfSBmcm9tIFwiLi90aW1pbmdcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSZXRyeU9wdGlvbnM8QXJncyBleHRlbmRzIGFueVtdLCBSZXQ+IHtcbiAgZm46ICguLi5hcmdzOiBBcmdzKSA9PiBQcm9taXNlPFJldD47XG4gIG1heEF0dGVtcHRzPzogbnVtYmVyO1xuICB0aW1lb3V0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlUmV0cnk8QXJncyBleHRlbmRzIGFueVtdLCBSZXQ+KHsgZm4sIG1heEF0dGVtcHRzID0gMywgdGltZW91dCB9OiBSZXRyeU9wdGlvbnM8QXJncywgUmV0Pikge1xuICBjb25zdCB0aW1lb3V0RXJyb3IgPSBuZXcgRXJyb3IoYHRpbWVvdXQgb3ZlciAke3RpbWVvdXR9bXNgKTtcbiAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uICguLi5hcmdzOiBBcmdzKSB7XG4gICAgbGV0IGF0dGVtcHQgPSAwO1xuICAgIHdoaWxlICh0cnVlKSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCBwcm9taXNlcyA9IFtmbiguLi5hcmdzKV07XG4gICAgICAgIGlmICh0aW1lb3V0KSB7XG4gICAgICAgICAgcHJvbWlzZXMucHVzaChcbiAgICAgICAgICAgIHNldFRpbWVvdXQodGltZW91dCkudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAgIHRocm93IHRpbWVvdXRFcnJvcjtcbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGF3YWl0IFByb21pc2UucmFjZShwcm9taXNlcyk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGF0dGVtcHQrKztcbiAgICAgICAgaWYgKGF0dGVtcHQgPj0gbWF4QXR0ZW1wdHMpIHtcbiAgICAgICAgICB0aHJvdyBlO1xuICAgICAgICB9XG4gICAgICAgIGF3YWl0IHNsZWVwKE1hdGgucG93KDIsIGF0dGVtcHQpICogMTAwICsgTWF0aC5yYW5kb20oKSAqIDEwMCk7XG4gICAgICB9XG4gICAgfVxuICB9O1xufVxuIl19
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "pup-recorder",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.8",
|
|
4
4
|
"description": "Record web pages as video",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -36,7 +36,8 @@
|
|
|
36
36
|
"tree-kill": "latest",
|
|
37
37
|
"source-map-support": "latest",
|
|
38
38
|
"systeminformation": "latest",
|
|
39
|
-
"zod": "latest"
|
|
39
|
+
"zod": "latest",
|
|
40
|
+
"puppeteer": "latest"
|
|
40
41
|
},
|
|
41
42
|
"devDependencies": {
|
|
42
43
|
"@microsoft/api-extractor": "latest",
|
package/dist/chunk-3POZKRKH.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import'source-map-support/register.js';import {createRequire}from'module';import {dirname,join}from'path';import {Log}from'node-av';import {AV_LOG_ERROR,AV_LOG_WARNING}from'node-av/constants';import {spawn}from'child_process';import w from'zod';import {ok}from'assert';import {randomUUID}from'crypto';import {rmSync}from'fs';import {readdir,mkdir,stat}from'fs/promises';import {platform,tmpdir}from'os';import ir from'tree-kill';import qe from'electron';import {fileURLToPath}from'url';import {graphics}from'systeminformation';import {EventEmitter}from'events';import {createServer}from'net';var xe=Object.create;var C=Object.defineProperty;var _e=Object.getOwnPropertyDescriptor;var O=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),k=t=>{throw TypeError(t)};var X=(t,e,r)=>e in t?C(t,e,{enumerable:true,configurable:true,writable:true,value:r}):t[e]=r;var Z=t=>[,,,xe(null)],Q=["class","method","getter","setter","accessor","field","value","get","set"],S=t=>t!==void 0&&typeof t!="function"?k("Function expected"):t,Ee=(t,e,r,n,o)=>({kind:Q[t],name:e,metadata:n,addInitializer:s=>r._?k("Already initialized"):o.push(S(s||null))}),G=(t,e)=>X(e,O("metadata"),t[3]),ee=(t,e,r,n)=>{for(var o=0,s=t[e>>1],i=s&&s.length;o<i;o++)s[o].call(r);return n},_=(t,e,r,n,o,s)=>{var c,p,u,E,a=e&7,R=false,d=false,v=2,x=Q[a+5],ye=t[v]||(t[v]=[]),m=((o=o.prototype),_e(o,r));for(var D=n.length-1;D>=0;D--)u=Ee(a,r,p={},t[3],ye),(u.static=R,u.private=d,E=u.access={has:f=>r in f},(E.get=f=>f[r]),a>2),c=(0, n[D])(m[x],u),p._=1,S(c)&&(m[x]=c);return m&&C(o,r,m),o},re=(t,e,r)=>X(t,e+"",r);var cr=(t,e,r)=>{if(e!=null){typeof e!="object"&&typeof e!="function"&&k("Object expected");var n,o;r&&(n=e[O("asyncDispose")]),n===void 0&&(n=e[O("dispose")],r&&(o=n)),typeof n!="function"&&k("Object not disposable"),o&&(n=function(){try{o.call(this);}catch(s){return Promise.reject(s)}}),t.push([r,n,e]);}else r&&t.push([r]);return e},pr=(t,e,r)=>{var n=typeof SuppressedError=="function"?SuppressedError:function(i,c,p,u){return u=Error(p),u.name="SuppressedError",u.error=i,u.suppressed=c,u},o=i=>e=r?new n(i,e,"An error was suppressed during disposal"):(r=true,i),s=i=>{for(;i=t.pop();)try{var c=i[1]&&i[1].call(i[2]);if(i[0])return Promise.resolve(c).then(s,p=>(o(p),s()))}catch(p){o(p);}if(r)throw e};return s()};function te(t,e,r){try{return e(process.env[t])}catch{return r}}function ne(t){if(typeof t=="number")return t;let e=Number(t);if(Number.isNaN(e))throw new Error(`Value ${t} is not a valid number`);return e}function fr(t){return typeof t=="string"?t:String(t)}var Te=createRequire(import.meta.url),T=process.env,U=te("PUP_LOG_LEVEL",ne,2),oe=T.PUP_USE_INNER_PROXY==="1",se=T.PUP_DISABLE_GPU==="1",ie=T.PUP_DETERMINISTIC==="1",Ue=dirname(Te.resolve("pup-recorder/package.json")),$=join(Ue,"dist","app.cjs"),Pr=T.PUP_IPC_SOCKET;var B="<pup@debug>",W="<pup@info>",M="<pup@warn>",j="<pup@error>",V="<pup@fatal>";function I(t,e){return function(...r){let n=r.map(o=>o instanceof Error?o.stack??String(o):o);return t.call(this,...n)}}var ae,ce,pe,ue,le,y;le=[I],ue=[I],pe=[I],ce=[I],ae=[I];var b=class{constructor(e=U){this._level=e;ee(y,5,this);re(this,"_impl");this.impl=console;}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 r=e.debug??console.debug,n=e.info??console.info,o=e.warn??console.warn,s=e.error??console.error,i=this._level;this._impl={debug:i>=3?r:void 0,info:i>=2?n:void 0,warn:i>=1?o:void 0,error:i>=0?s:void 0};}debug(...e){this.impl?.debug?.(B,...e);}info(...e){this.impl?.info?.(W,...e);}warn(...e){this.impl?.warn?.(M,...e);}error(...e){this.impl?.error?.(j,...e);}fatal(...e){this.impl?.error?.(V,...e),process.exit(1);}dispatch(e){let r=e.trimEnd();r.startsWith(B)?this.debug(r.slice(B.length+1)):r.startsWith(W)?this.info(r.slice(W.length+1)):r.startsWith(M)?this.warn(r.slice(M.length+1)):r.startsWith(j)?this.error(r.slice(j.length+1)):this.info(r);}attach(e,r){return new Promise((n,o)=>{this.debug(`${r}.attach`);let s="",i=c=>{let p=c.toString();p.startsWith(V)?s+=p.slice(V.length+1):this.dispatch(p);};e.stderr?.on("data",i),e.stdout?.on("data",i),e.on("message",i).on("error",c=>{s+=c.message,e.kill();}).once("close",(c,p)=>{c||p||s?(s||=`command failed: ${e.spawnargs.join(" ")}`,this.debug(`${r}.close`,{code:c,signal:p,fatal:s}),o(new Error(s))):(this.debug(`${r}.close`),n());}).on("unhandledRejection",c=>{this.error(`${r}.unhandled`,c);}).on("uncaughtExceptionMonitor",c=>{this.error(`${r}.unhandled`,c);});})}};y=Z(),_(y,1,"debug",le,b),_(y,1,"info",ue,b),_(y,1,"warn",pe,b),_(y,1,"error",ce,b),_(y,1,"fatal",ae,b),G(y,b);var l=new b;Log.setCallback((t,e)=>{let r=e.trimEnd();r&&(t<=AV_LOG_ERROR?l.error(r):t<=AV_LOG_WARNING&&l.warn(r));});function Ar(t,e){return (...r)=>{try{let n=t(...r);return n instanceof Promise?n.catch(()=>e):n}catch{return e}}}var H="--pup-priv-args";function Dr(){let t=process.argv,e=t.find(n=>n.startsWith(H));if(!e)return l.debug("procargv",t),process.argv;let r=["exec",...t.slice(-1)];return e=Buffer.from(e.split("=")[1],"base64").toString(),r.push(...JSON.parse(e)),l.debug("pupargs",r),r}function de(t,e){let r=t.split(" ").filter(i=>i.length),[n,...o]=r;if(!n)throw new Error("empty command");let s=spawn(n,o,{stdio:"inherit",...e});return {process:s,wait:l.attach(s,n)}}var Ge=1920,Ne=1080,$e=30,Be=5,We="output.mov",$r=w.object({duration:w.number().describe("Duration in seconds"),width:w.number().describe("Video width"),height:w.number().describe("Video height"),fps:w.number().describe("Frames per second"),withAudio:w.boolean().describe("Capture and encode audio"),outFile:w.string().describe("Output mp4 file path"),useInnerProxy:w.boolean().describe("Use bilibili inner proxy for resource access"),deterministic:w.boolean().describe("Render by frame rather than recording")}),fe={width:Ge,height:Ne,fps:$e,duration:Be,outFile:We,withAudio:false,useInnerProxy:oe,deterministic:ie};var me="[HWAccel]",He=["microsoft","vmware","virtualbox","llvmpipe","softpipe","swiftshader"];function ze(t){let e=t.toLowerCase();return He.some(r=>e.includes(r))}async function Ke(){let{controllers:t}=await graphics();if(platform()==="linux")try{return (await readdir("/dev/dri")).some(r=>r.startsWith("renderD"))}catch{return false}return l.debug(me,"GPU controllers:",t),t.some(e=>e.vendor.length>0&&!ze(e.vendor))}var he=Ke().then(t=>(l.debug(me,"gpu:",t),t));async function Xe(){let t=["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","headless=new","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","disable-background-networking"];if(U<3&&t.push("log-level=3"),!(await he&&!se))return t.push("use-angle=swiftshader","enable-unsafe-swiftshader"),t;t.push("disable-gpu-sandbox","enable-unsafe-webgpu");let r=platform();return r==="darwin"?t.push("use-angle=metal"):r==="win32"?t.push("use-angle=d3d11"):t.push("use-angle=vulkan","enable-features=Vulkan","disable-vulkan-surface"),t}var Ze="[Electron]";async function Qe(){let[t,e]=await Promise.all([stat($),stat(fileURLToPath(import.meta.url))]);ok(t.mtimeMs>=e.mtimeMs,"app.cjs is stale, run `bun run build`");}async function we(t,e,r){await Qe();let n=[],o=platform();o==="linux"&&n.push("xvfb-run","--auto-servernum",`--server-args="-screen 0 ${t.width}x${t.height}x24"`);let i=(await Xe()).map(u=>`--${u}`),c=Buffer.from(JSON.stringify(e)).toString("base64");i.push(`${H}=${c}`),n.push(qe,...i,$);let p=n.join(" ");return l.debug(Ze,p),de(p,{stdio:["ignore","pipe","pipe"],shell:o==="linux",env:{...process.env,RUST_BACKTRACE:"full",PUP_IPC_SOCKET:r}})}var L=8;var z=class extends EventEmitter{constructor(r){super();this._socket=r;this._socket.on("data",n=>this.onData(n)),this._socket.on("error",n=>this.emit("error",n)),this._socket.on("close",()=>this.emit("close"));}_chunks=[];_buffered=0;onData(r){this._chunks.push(r),this._buffered+=r.byteLength,this.flush();}flush(){for(;;){if(this._buffered<L)return;let r=this.peek(L),n=r.readUInt32LE(0),o=r.readUInt32LE(4);if(this._buffered<L+o)return;this.consume(L);let s=this.consume(o);switch(this.emit("message",n,s),n){case 1:{this.emit("progress",Number(s.toString()));break}case 2:{this.emit("done",JSON.parse(s.toString()));break}case 3:{this.emit("error",new Error(s.toString()));break}}}}peek(r){return this._chunks[0]&&this._chunks[0].byteLength>=r?this._chunks[0]:Buffer.concat(this._chunks).subarray(0,r)}consume(r){let n=Buffer.allocUnsafe(r),o=0;for(;o<r;){let s=this._chunks[0],i=Math.min(s.byteLength,r-o);s.copy(n,o,0,i),i===s.byteLength?this._chunks.shift():this._chunks[0]=s.subarray(i),o+=i;}return this._buffered-=r,n}};function ve(t){return new Promise((e,r)=>{let n=createServer();n.once("error",r),n.listen(t,()=>{e({waitForConnection(){return new Promise((o,s)=>{n.once("connection",i=>o(new z(i))),n.once("error",s);})},close(){n.close();}});});})}var A="[pup]";async function ar(t,e,r){l.debug(A,"runPupApp",t,e);let n=[t,"--width",`${e.width}`,"--height",`${e.height}`,"--fps",`${e.fps}`,"--duration",`${e.duration}`,"--out-file",`${e.outFile}`];return e.withAudio&&n.push("--with-audio"),e.useInnerProxy&&n.push("--use-inner-proxy"),e.deterministic&&n.push("--deterministic"),we(e,n,r)}var P=fe;async function kt(t,e){l.debug(A,"pup",t,e);let{signal:r}=e;if(r?.aborted)throw r.reason;let n=e.outFile??P.outFile,o={width:e.width??P.width,height:e.height??P.height,fps:e.fps??P.fps,duration:e.duration??P.duration,withAudio:e.withAudio??P.withAudio,useInnerProxy:e.useInnerProxy??P.useInnerProxy,deterministic:e.deterministic??P.deterministic,outFile:n},s=join(tmpdir(),"pup",randomUUID());await mkdir(s,{recursive:true});let i=join(s,"pup.sock"),c=performance.now(),p=await ve(i),u=await ar(t,{...o,signal:r},i),E=()=>{l.debug(A,"aborted");let a=u.process.pid;a?ir(a):u.process.kill(),rmSync(s,{recursive:true,force:true});};r?.addEventListener("abort",E,{once:true});try{let a=v=>(l.info(A,`${t} progress: ${v}%`),e.onProgress?.(v)),R=new Promise(async(v,x)=>{(await p.waitForConnection()).on("close",()=>x(new Error("IPC closed without result"))).on("message",()=>r?.aborted&&x(r.reason)).on("progress",a).on("done",v).on("error",x);}).finally(()=>p.close());a(0);let d=await Promise.race([R,u.wait]);return ok(d,"no summary received"),a(100),l.info(A,`done ${n} in ${Math.round(performance.now()-c)}ms`),{...d,options:o}}catch(a){throw r?.aborted?r.reason:a}finally{rmSync(s,{recursive:true,force:true});}}export{cr as a,pr as b,te as c,ne as d,fr as e,U as f,oe as g,se as h,ie as i,Ue as j,$ as k,Pr as l,b as m,l as n,Ar as o,H as p,Dr as q,de as r,Ge as s,Ne as t,$e as u,Be as v,We as w,$r as x,fe as y,kt as z};//# sourceMappingURL=chunk-3POZKRKH.js.map
|
|
2
|
-
//# 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/hwaccel.ts","../src/renderer/electron.ts","../src/renderer/ipc.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","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","s","command","spawn","DEFAULT_WIDTH","DEFAULT_HEIGHT","DEFAULT_FPS","DEFAULT_DURATION","DEFAULT_OUT_FILE","RenderSchema","z","defaultRenderOptions","TAG","softwareVendors","isSoftwareRenderer","vendor","lower","v","detectGPUDriver","controllers","graphics","platform","readdir","f","c","canIUseGPU","result","electronOpts","opts","plat","assertAppFresh","appStat","selfStat","stat","fileURLToPath","ok","runElectronApp","size","ipcSocketPath","cmdParts","electronArgs","a","base64Args","electron","HEADER_SIZE","IpcReader","EventEmitter","_socket","header","type","len","payload","n","out","offset","chunk","take","createIpcServer","socketPath","server","createServer","no","socket","runPupApp","source","d","pup","outFile","renderOpts","tmpDir","tmpdir","randomUUID","mkdir","t0","handle","onAbort","pid","treeKill","rmSync","tick","p","summary","e"],"mappings":"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","file":"chunk-3POZKRKH.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","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport { ChildProcess, type Serializable } from \"child_process\";\nimport { Log } from \"node-av\";\nimport { AV_LOG_ERROR, AV_LOG_WARNING } from \"node-av/constants\";\nimport { pupLogLevel } from \"./constants\";\n\nexport interface LoggerLike {\n  debug?(this: void, ...messages: unknown[]): void;\n\n  info?(this: void, ...messages: unknown[]): void;\n\n  warn?(this: void, ...messages: unknown[]): void;\n\n  error?(this: void, ...messages: unknown[]): void;\n}\n\nconst DEBUG = \"<pup@debug>\";\nconst INFO = \"<pup@info>\";\nconst WARN = \"<pup@warn>\";\nconst ERROR = \"<pup@error>\";\nconst FATAL = \"<pup@fatal>\";\n\nfunction stackHook(target: Function, _context: ClassMethodDecoratorContext) {\n  return function (this: Logger, ...messages: unknown[]) {\n    const processed = messages.map((msg) => {\n      return msg instanceof Error ? (msg.stack ?? String(msg)) : msg;\n    });\n    return target.call(this, ...processed);\n  };\n}\n\nexport class Logger implements LoggerLike {\n  private _impl?: LoggerLike;\n\n  get level(): number {\n    return this._level;\n  }\n\n  set level(value: number) {\n    this._level = value;\n    this.impl = this._impl ?? console;\n  }\n\n  get impl(): LoggerLike | undefined {\n    return this._impl;\n  }\n\n  set impl(value: LoggerLike) {\n    const debug = value.debug ?? console.debug;\n    const info = value.info ?? console.info;\n    const warn = value.warn ?? console.warn;\n    const error = value.error ?? console.error;\n    const lv = this._level;\n    this._impl = {\n      debug: lv >= 3 ? debug : undefined,\n      info: lv >= 2 ? info : undefined,\n      warn: lv >= 1 ? warn : undefined,\n      error: lv >= 0 ? error : undefined,\n    };\n  }\n\n  constructor(private _level: number = pupLogLevel) {\n    this.impl = console;\n  }\n\n  @stackHook\n  debug(...messages: unknown[]): void {\n    this.impl?.debug?.(DEBUG, ...messages);\n  }\n\n  @stackHook\n  info(...messages: unknown[]): void {\n    this.impl?.info?.(INFO, ...messages);\n  }\n\n  @stackHook\n  warn(...messages: unknown[]): void {\n    this.impl?.warn?.(WARN, ...messages);\n  }\n\n  @stackHook\n  error(...messages: unknown[]): void {\n    this.impl?.error?.(ERROR, ...messages);\n  }\n\n  @stackHook\n  fatal(...messages: unknown[]): void {\n    this.impl?.error?.(FATAL, ...messages);\n    process.exit(1);\n  }\n\n  private dispatch(message: string) {\n    const msg = message.trimEnd();\n    if (msg.startsWith(DEBUG)) {\n      this.debug(msg.slice(DEBUG.length + 1));\n    } else if (msg.startsWith(INFO)) {\n      this.info(msg.slice(INFO.length + 1));\n    } else if (msg.startsWith(WARN)) {\n      this.warn(msg.slice(WARN.length + 1));\n    } else if (msg.startsWith(ERROR)) {\n      this.error(msg.slice(ERROR.length + 1));\n    } else {\n      this.info(msg);\n    }\n  }\n\n  attach(proc: ChildProcess, name: string) {\n    return new Promise<void>((resolve, reject) => {\n      this.debug(`${name}.attach`);\n      let fatal: string = \"\";\n      const dispatch = (data: Buffer | Serializable) => {\n        const message = data.toString();\n        if (message.startsWith(FATAL)) {\n          fatal += message.slice(FATAL.length + 1);\n        } else {\n          this.dispatch(message);\n        }\n      };\n      proc.stderr?.on(\"data\", dispatch);\n      proc.stdout?.on(\"data\", dispatch);\n      proc\n        .on(\"message\", dispatch)\n        .on(\"error\", (err) => {\n          fatal += err.message;\n          proc.kill();\n        })\n        .once(\"close\", (code, signal) => {\n          if (code || signal || fatal) {\n            fatal ||= `command failed: ${proc.spawnargs.join(\" \")}`;\n            this.debug(`${name}.close`, { code, signal, fatal });\n            reject(new Error(fatal));\n          } else {\n            this.debug(`${name}.close`);\n            resolve();\n          }\n        })\n        .on(\"unhandledRejection\", (reason) => {\n          this.error(`${name}.unhandled`, reason);\n        })\n        .on(\"uncaughtExceptionMonitor\", (err) => {\n          this.error(`${name}.unhandled`, err);\n        });\n    });\n  }\n}\n\nconst logger = new Logger();\n\n// Route ffmpeg native logs through pup's logger.\nLog.setCallback((level, message) => {\n  const msg = message.trimEnd();\n  if (!msg) return;\n  if (level <= AV_LOG_ERROR) logger.error(msg);\n  else if (level <= AV_LOG_WARNING) logger.warn(msg);\n});\n\nexport { logger };\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/24.\n\nexport function noerr<Fn extends (...args: any[]) => any, D>(\n  fn: Fn,\n  defaultValue: D,\n): (...args: Parameters<Fn>) => ReturnType<Fn> | D {\n  return (...args) => {\n    try {\n      const ret = fn(...args);\n      if (ret instanceof Promise) {\n        return ret.catch(() => defaultValue);\n      }\n      return ret;\n    } catch {\n      return defaultValue;\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { spawn, type ChildProcess, type SpawnOptions } from \"child_process\";\nimport { logger } from \"./logging\";\n\nexport const PUP_ARGS_KEY = \"--pup-priv-args\";\n\nexport function pargs() {\n  const argv = process.argv;\n  let priv = argv.find((arg) => arg.startsWith(PUP_ARGS_KEY));\n  if (!priv) {\n    logger.debug(\"procargv\", argv);\n    return process.argv;\n  }\n  const args = [\"exec\", ...argv.slice(-1)];\n  priv = Buffer.from(priv.split(\"=\")[1]!, \"base64\").toString();\n  args.push(...JSON.parse(priv));\n  logger.debug(\"pupargs\", args);\n  return args;\n}\n\nexport interface ProcessHandle {\n  process: ChildProcess;\n  wait: Promise<void>;\n}\n\nexport function exec(cmd: string, options?: SpawnOptions): ProcessHandle {\n  const parts = cmd.split(\" \").filter((s) => s.length);\n  const [command, ...args] = parts;\n  if (!command) throw new Error(\"empty command\");\n  const proc = spawn(command, args, {\n    stdio: \"inherit\",\n    ...options,\n  });\n  return { process: proc, wait: logger.attach(proc, command) };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport z from \"zod\";\nimport { pupDeterministic, pupUseInnerProxy } from \"../base/constants\";\n\nexport const DEFAULT_WIDTH = 1920;\nexport const DEFAULT_HEIGHT = 1080;\nexport const DEFAULT_FPS = 30;\nexport const DEFAULT_DURATION = 5;\nexport const DEFAULT_OUT_FILE = \"output.mov\";\n\nexport const RenderSchema = z.object({\n  duration: z.number().describe(\"Duration in seconds\"),\n  width: z.number().describe(\"Video width\"),\n  height: z.number().describe(\"Video height\"),\n  fps: z.number().describe(\"Frames per second\"),\n  withAudio: z.boolean().describe(\"Capture and encode audio\"),\n  outFile: z.string().describe(\"Output mp4 file path\"),\n  useInnerProxy: z.boolean().describe(\"Use bilibili inner proxy for resource access\"),\n  deterministic: z.boolean().describe(\"Render by frame rather than recording\"),\n});\n\nexport type RenderOptions = z.infer<typeof RenderSchema>;\n\nexport interface RenderResult {\n  options: RenderOptions;\n  written: number;\n  jank: number;\n  outFile: string;\n}\n\nexport const defaultRenderOptions: RenderOptions = {\n  width: DEFAULT_WIDTH,\n  height: DEFAULT_HEIGHT,\n  fps: DEFAULT_FPS,\n  duration: DEFAULT_DURATION,\n  outFile: DEFAULT_OUT_FILE,\n  withAudio: false,\n  useInnerProxy: pupUseInnerProxy,\n  deterministic: pupDeterministic,\n};\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { readdir } from \"fs/promises\";\nimport { platform } from \"os\";\nimport { graphics } from \"systeminformation\";\nimport { logger } from \"./logging\";\n\nconst TAG = \"[HWAccel]\";\n\nconst softwareVendors = [\"microsoft\", \"vmware\", \"virtualbox\", \"llvmpipe\", \"softpipe\", \"swiftshader\"];\n\nfunction isSoftwareRenderer(vendor: string) {\n  const lower = vendor.toLowerCase();\n  return softwareVendors.some((v) => lower.includes(v));\n}\n\nasync function detectGPUDriver() {\n  const { controllers } = await graphics();\n  if (platform() === \"linux\") {\n    try {\n      const files = await readdir(\"/dev/dri\");\n      return files.some((f) => f.startsWith(\"renderD\"));\n    } catch {\n      return false;\n    }\n  }\n  logger.debug(TAG, \"GPU controllers:\", controllers);\n  return controllers.some((c) => c.vendor.length > 0 && !isSoftwareRenderer(c.vendor));\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/02/25.\n\nimport { ok } from \"assert\";\nimport electron, { type Size } from \"electron\";\nimport { stat } from \"fs/promises\";\nimport { platform } from \"os\";\nimport { fileURLToPath } from \"url\";\nimport { pupApp, pupDisableGPU, pupLogLevel } from \"../base/constants\";\nimport { canIUseGPU } from \"../base/hwaccel\";\nimport { logger } from \"../base/logging\";\nimport { exec, PUP_ARGS_KEY } from \"../base/process\";\n\nexport async function electronOpts() {\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    \"headless=new\",\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    // 资源控制\n    \"disable-background-networking\",\n  ];\n  if (pupLogLevel < 3) {\n    opts.push(\"log-level=3\");\n  }\n\n  const enableGpu = (await canIUseGPU) && !pupDisableGPU;\n  if (!enableGpu) {\n    opts.push(\"use-angle=swiftshader\", \"enable-unsafe-swiftshader\");\n    return opts;\n  }\n\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\", \"enable-features=Vulkan\", \"disable-vulkan-surface\");\n  }\n  return opts;\n}\n\nconst TAG = \"[Electron]\";\n\nasync function assertAppFresh() {\n  const [appStat, selfStat] = await Promise.all([stat(pupApp), stat(fileURLToPath(import.meta.url))]);\n  ok(appStat.mtimeMs >= selfStat.mtimeMs, `app.cjs is stale, run \\`bun run build\\``);\n}\n\nexport async function runElectronApp(size: Size, args: unknown[], ipcSocketPath: string) {\n  await assertAppFresh();\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();\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/02/09.\n\nimport { ok } from \"assert\";\nimport { randomUUID } from \"crypto\";\nimport { rmSync } from \"fs\";\nimport { mkdir } from \"fs/promises\";\nimport { tmpdir } from \"os\";\nimport { join } from \"path\";\nimport treeKill from \"tree-kill\";\nimport { logger } from \"./base/logging\";\nimport { runElectronApp } from \"./renderer/electron\";\nimport { createIpcServer, type IpcDonePayload } from \"./renderer/ipc\";\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\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    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 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 tick = (p: number) => (logger.info(TAG, `${source} progress: ${p}%`), options.onProgress?.(p));\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"]}
|