pup-recorder 0.0.23 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -7,7 +7,7 @@ pup-recorder - record web pages as video
7
7
  ## SYNOPSIS
8
8
 
9
9
  ```
10
- pup <source> [-w width] [-h height] [-f fps] [-t duration] [-o dir] [-a]
10
+ pup <source> [-w width] [-h height] [-f fps] [-t duration] [-o dir] [-a] [-s]
11
11
  ```
12
12
 
13
13
  ## DESCRIPTION
@@ -25,6 +25,7 @@ by default; with `-a` outputs WebM (VP9) and MOV (HEVC alpha).
25
25
  -t, --duration <n> seconds, default 5
26
26
  -o, --out-dir <path> default "out"
27
27
  -a, --with-alpha-channel
28
+ -s, --with-audio
28
29
  --use-inner-proxy bilibili internal proxy
29
30
  ```
30
31
 
@@ -44,7 +45,7 @@ import { pup } from "pup-recorder";
44
45
  const { mp4, webm, mov, cover, width, height, fps, duration } =
45
46
  await pup("https://example.com", {
46
47
  width: 1920, height: 1080, fps: 30, duration: 5,
47
- withAlphaChannel: false, outDir: "out", useInnerProxy: false,
48
+ withAlphaChannel: false, withAudio: false, outDir: "out", useInnerProxy: false,
48
49
  cancelQuery: () => boolean,
49
50
  onProgress: (pct: number) => void,
50
51
  });
@@ -66,6 +67,7 @@ x265/* x265 binaries
66
67
  ```sh
67
68
  pup https://example.com -t 5
68
69
  pup file:///path/to/page.html -a
70
+ pup https://example.com -s -t 10
69
71
  pup https://example.com -w 1280 -h 720 -f 60 -t 10 -o /tmp/out
70
72
  ```
71
73
 
package/dist/cjs/app.cjs CHANGED
@@ -1,4 +1,76 @@
1
- 'use strict';require('source-map-support/register.js');var electron=require('electron'),fs=require('fs'),path=require('path'),url=require('url'),promises=require('fs/promises'),promises$1=require('timers/promises'),commander=require('commander'),T=require('zod');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var T__default=/*#__PURE__*/_interopDefault(T);var Ke=Object.create;var V=Object.defineProperty;var qe=Object.getOwnPropertyDescriptor;var le=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),F=t=>{throw TypeError(t)};var me=(t,e,r)=>e in t?V(t,e,{enumerable:true,configurable:true,writable:true,value:r}):t[e]=r;var fe=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var he=t=>[,,,Ke(null)],ge=["class","method","getter","setter","accessor","field","value","get","set"],D=t=>t!==void 0&&typeof t!="function"?F("Function expected"):t,Ve=(t,e,r,o,i)=>({kind:ge[t],name:e,metadata:o,addInitializer:n=>r._?F("Already initialized"):i.push(D(n||null))}),Y=(t,e)=>me(e,le("metadata"),t[3]),we=(t,e,r,o)=>{for(var i=0,n=t[e>>1],c=n&&n.length;i<c;i++)n[i].call(r);return o},C=(t,e,r,o,i,n)=>{var a,l,g,f,s=e&7,w=false,d=false,m=2,x=ge[s+5],_=t[m]||(t[m]=[]),h=((i=i.prototype),qe(i,r));for(var I=o.length-1;I>=0;I--)g=Ve(s,r,l={},t[3],_),(g.static=w,g.private=d,f=g.access={has:u=>r in u},(f.get=u=>u[r]),s>2),a=(0, o[I])(h[x],g),l._=1,D(a)&&(h[x]=a);return h&&V(i,r,h),i},be=(t,e,r)=>me(t,e+"",r);var Xe=()=>typeof document>"u"?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.tagName.toUpperCase()==="SCRIPT"?document.currentScript.src:new URL("main.js",document.baseURI).href,p=Xe();var y=path.dirname(url.fileURLToPath(p));function xe(t,e,r){try{return e(process.env[t])}catch{return r}}function v(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}var tt=[path.join(y,"cjs/app.cjs"),path.join(y,"app.cjs"),path.join(y,"../../cjs/app.cjs")];tt.find(fs.existsSync);var Re=process.env,$=xe("PUP_LOG_LEVEL",v,2),Q=Re.PUP_USE_INNER_PROXY==="1";Re.FFMPEG_BIN??"ffmpeg";var Z="<pup@debug>",ee="<pup@info>",te="<pup@warn>",re="<pup@error>",oe="<pup@fatal>";function L(t,e){return function(...r){let o=r.map(i=>i instanceof Error?i.stack??String(i):i);return t.call(this,...o)}}var _e,Te,ye,ve,Ee,E;Ee=[L],ve=[L],ye=[L],Te=[L],_e=[L];var R=class{constructor(){we(E,5,this);be(this,"_impl");this.impl=console;}get impl(){return this._impl}set impl(e){let r=e.debug??console.debug,o=e.info??console.info,i=e.warn??console.warn,n=e.error??console.error;this._impl={debug:$>=3?r:void 0,info:$>=2?o:void 0,warn:$>=1?i:void 0,error:$>=0?n:void 0};}debug(...e){this.impl?.debug?.(Z,...e);}info(...e){this.impl?.info?.(ee,...e);}warn(...e){this.impl?.warn?.(te,...e);}error(...e){this.impl?.error?.(re,...e);}fatal(...e){this.impl?.error?.(oe,...e),process.exit(1);}dispatch(e){e.startsWith(Z)?this.debug(e.slice(Z.length+1)):e.startsWith(ee)?this.info(e.slice(ee.length+1)):e.startsWith(te)?this.warn(e.slice(te.length+1)):e.startsWith(re)?this.error(e.slice(re.length+1)):this.info(e);}attach(e,r){return new Promise((o,i)=>{this.debug(`${r}.attach`);let n="",c=a=>{let l=a.toString();l.startsWith(oe)?n+=l.slice(oe.length+1):this.dispatch(l);};e.stderr?.on("data",c),e.stdout?.on("data",c),e.on("message",c).on("error",a=>{n+=a.message,e.kill();}).once("close",(a,l)=>{a||l||n?(n||=`command failed: ${e.spawnargs.join(" ")}`,this.debug(`${r}.close`,{code:a,signal:l,fatal:n}),i(new Error(n))):(this.debug(`${r}.close`),o());}).on("unhandledRejection",a=>{this.error(`${r}.unhandled`,a);}).on("uncaughtExceptionMonitor",a=>{this.error(`${r}.unhandled`,a);});})}};E=he(),C(E,1,"debug",Ee,R),C(E,1,"info",ve,R),C(E,1,"warn",ye,R),C(E,1,"error",Te,R),C(E,1,"fatal",_e,R),Y(E,R);var b=new R;var rt="__PUP_ARGS__";function Pe(){let t=process.env[rt];if(t){let e=["exec",...process.argv.slice(-1)];return e.push(...JSON.parse(t)),b.debug("pupargs",e),e}return b.debug("procargv",process.argv),process.argv}var Ie=["no-sandbox","disable-setuid-sandbox","disable-gpu","disable-dev-shm-usage","disable-software-rasterizer","disable-web-security","disable-site-isolation-trials","disable-features=IsolateOrigins,site-per-process","allow-insecure-localhost","ignore-certificate-errors","disable-blink-features=AutomationControlled","mute-audio","disable-extensions","disable-background-networking","address-family=ipv4","disable-async-dns","force-device-scale-factor=1","trace-warnings","force-color-profile=srgb","disable-color-correct-rendering","log-level=3"];var{platform:nt,arch:it}=process,Ae=`rust/${nt}-${it}.node`,st=[path.join(y,`../../${Ae}`),path.join(y,`../${Ae}`)],at=fe(st.find(fs.existsSync)),Ce=at.FixedBufferWriter;function De(t,e){let{width:r,height:o}=e;return `<!DOCTYPE html>
1
+ 'use strict';require('source-map-support/register.js');var electron=require('electron'),fs=require('fs'),path=require('path'),url=require('url'),systeminformation=require('systeminformation'),promises=require('fs/promises'),crypto=require('crypto'),os=require('os'),promises$1=require('timers/promises'),commander=require('commander'),x=require('zod');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var x__default=/*#__PURE__*/_interopDefault(x);var ot=Object.create;var J=Object.defineProperty;var nt=Object.getOwnPropertyDescriptor;var xe=(t,e)=>(e=Symbol[t])?e:Symbol.for("Symbol."+t),L=t=>{throw TypeError(t)};var _e=(t,e,r)=>e in t?J(t,e,{enumerable:true,configurable:true,writable:true,value:r}):t[e]=r;var ye=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var Re=t=>[,,,ot(null)],Ae=["class","method","getter","setter","accessor","field","value","get","set"],D=t=>t!==void 0&&typeof t!="function"?L("Function expected"):t,it=(t,e,r,o,i)=>({kind:Ae[t],name:e,metadata:o,addInitializer:n=>r._?L("Already initialized"):i.push(D(n||null))}),X=(t,e)=>_e(e,xe("metadata"),t[3]),Pe=(t,e,r,o)=>{for(var i=0,n=t[e>>1],c=n&&n.length;i<c;i++)n[i].call(r);return o},S=(t,e,r,o,i,n)=>{var s,l,h,u,a=e&7,T=false,w=false,_=2,$=Ae[a+5],g=t[_]||(t[_]=[]),m=((i=i.prototype),nt(i,r));for(var y=o.length-1;y>=0;y--)h=it(a,r,l={},t[3],g),(h.static=T,h.private=w,u=h.access={has:d=>r in d},(u.get=d=>d[r]),a>2),s=(0, o[y])(m[$],h),l._=1,D(s)&&(m[$]=s);return m&&J(i,r,m),i},Te=(t,e,r)=>_e(t,e+"",r);var ct=()=>typeof document>"u"?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.tagName.toUpperCase()==="SCRIPT"?document.currentScript.src:new URL("main.js",document.baseURI).href,p=ct();var R=path.dirname(url.fileURLToPath(p));function Ee(t,e,r){try{return e(process.env[t])}catch{return r}}function A(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}var lt=[path.join(R,"cjs/app.cjs"),path.join(R,"app.cjs"),path.join(R,"../../cjs/app.cjs")];lt.find(fs.existsSync);var ee=process.env,F=Ee("PUP_LOG_LEVEL",A,2),te=ee.PUP_USE_INNER_PROXY==="1";ee.FFMPEG_BIN??"ffmpeg";var ve=ee.PUP_DISABLE_GPU==="1";var re="<pup@debug>",oe="<pup@info>",ne="<pup@warn>",ie="<pup@error>",se="<pup@fatal>";function U(t,e){return function(...r){let o=r.map(i=>i instanceof Error?i.stack??String(i):i);return t.call(this,...o)}}var Ce,Se,Ie,ke,De,P;De=[U],ke=[U],Ie=[U],Se=[U],Ce=[U];var b=class{constructor(){Pe(P,5,this);Te(this,"_impl");this.impl=console;}get impl(){return this._impl}set impl(e){let r=e.debug??console.debug,o=e.info??console.info,i=e.warn??console.warn,n=e.error??console.error;this._impl={debug:F>=3?r:void 0,info:F>=2?o:void 0,warn:F>=1?i:void 0,error:F>=0?n:void 0};}debug(...e){this.impl?.debug?.(re,...e);}info(...e){this.impl?.info?.(oe,...e);}warn(...e){this.impl?.warn?.(ne,...e);}error(...e){this.impl?.error?.(ie,...e);}fatal(...e){this.impl?.error?.(se,...e),process.exit(1);}dispatch(e){e.startsWith(re)?this.debug(e.slice(re.length+1)):e.startsWith(oe)?this.info(e.slice(oe.length+1)):e.startsWith(ne)?this.warn(e.slice(ne.length+1)):e.startsWith(ie)?this.error(e.slice(ie.length+1)):this.info(e);}attach(e,r){return new Promise((o,i)=>{this.debug(`${r}.attach`);let n="",c=s=>{let l=s.toString();l.startsWith(se)?n+=l.slice(se.length+1):this.dispatch(l);};e.stderr?.on("data",c),e.stdout?.on("data",c),e.on("message",c).on("error",s=>{n+=s.message,e.kill();}).once("close",(s,l)=>{s||l||n?(n||=`command failed: ${e.spawnargs.join(" ")}`,this.debug(`${r}.close`,{code:s,signal:l,fatal:n}),i(new Error(n))):(this.debug(`${r}.close`),o());}).on("unhandledRejection",s=>{this.error(`${r}.unhandled`,s);}).on("uncaughtExceptionMonitor",s=>{this.error(`${r}.unhandled`,s);});})}};P=Re(),S(P,1,"debug",De,b),S(P,1,"info",ke,b),S(P,1,"warn",Ie,b),S(P,1,"error",Se,b),S(P,1,"fatal",Ce,b),X(P,b);var f=new b;var ft="[HWAccel]";async function ht(){let{controllers:t}=await systeminformation.graphics();return t.some(e=>e.vendor.length)}var Le=ht().then(t=>(f.debug(ft,"GPU detected:",t),t));var Fe="--pup-priv-args";function Ue(){let t=process.argv,e=t.find(o=>o.startsWith(Fe));if(!e)return f.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)),f.debug("pupargs",r),r}async function Oe(){let t=["no-sandbox","disable-setuid-sandbox","disable-dev-shm-usage","disable-web-security","disable-site-isolation-trials","disable-features=IsolateOrigins,site-per-process","allow-insecure-localhost","ignore-certificate-errors","disable-blink-features=AutomationControlled","mute-audio","autoplay-policy=no-user-gesture-required","disable-extensions","disable-background-networking","address-family=ipv4","disable-async-dns","force-device-scale-factor=1","trace-warnings","force-color-profile=srgb","disable-color-correct-rendering","log-level=3","ignore-gpu-blocklist","gpu-shader-disk-cache-size-kb=524288"];return await Le&&!ve?t.push("in-process-gpu","use-gl=angle",process.platform==="darwin"?"use-angle=metal":process.platform==="win32"?"use-angle=d3d11":"use-angle=vulkan"):t.push("use-gl=angle","use-angle=swiftshader","enable-unsafe-swiftshader"),t}var{platform:gt,arch:bt}=process,We=`rust/${gt}-${bt}.node`,xt=[path.join(R,`../../${We}`),path.join(R,`../${We}`)],_t=ye(xt.find(fs.existsSync)),M=_t.FixedBufferWriter;var Et=`
2
+ (function() {
3
+ if (window.__pup_audio_capturing__) return;
4
+ window.__pup_audio_capturing__ = true;
5
+
6
+ const { ipcRenderer } = require('electron');
7
+ const capturedContexts = new WeakSet();
8
+ const sourcedElements = new WeakSet();
9
+ let metaSent = false;
10
+
11
+ const origCreateMES = AudioContext.prototype.createMediaElementSource;
12
+ AudioContext.prototype.createMediaElementSource = function(el) {
13
+ sourcedElements.add(el);
14
+ return origCreateMES.call(this, el);
15
+ };
16
+
17
+ const origConnect = AudioNode.prototype.connect;
18
+ AudioNode.prototype.connect = function(dest, outIdx, inIdx) {
19
+ const captureNode = dest?.context?.__pup_captureNode__;
20
+ if (captureNode && dest === dest.context.destination && this !== captureNode) {
21
+ origConnect.call(this, captureNode, outIdx, inIdx);
22
+ }
23
+ return origConnect.call(this, dest, outIdx, inIdx);
24
+ };
25
+
26
+ const OrigAC = window.AudioContext || window.webkitAudioContext;
27
+ if (!OrigAC) return;
28
+
29
+ function PatchedAC() {
30
+ const ctx = new OrigAC(...arguments);
31
+ if (!capturedContexts.has(ctx)) {
32
+ capturedContexts.add(ctx);
33
+ if (!metaSent) {
34
+ metaSent = true;
35
+ ipcRenderer.send('audio-meta', { sampleRate: ctx.sampleRate });
36
+ }
37
+ const node = ctx.createScriptProcessor(4096, 2, 2);
38
+ node.onaudioprocess = (e) => {
39
+ const L = e.inputBuffer.getChannelData(0);
40
+ const R = e.inputBuffer.getChannelData(1);
41
+ const out = new Float32Array(L.length * 2);
42
+ for (let i = 0; i < L.length; i++) {
43
+ out[i * 2] = L[i];
44
+ out[i * 2 + 1] = R[i];
45
+ }
46
+ ipcRenderer.send('audio-chunk', Buffer.from(out.buffer));
47
+ };
48
+ node.connect(ctx.destination);
49
+ ctx.__pup_captureNode__ = node;
50
+ }
51
+ return ctx;
52
+ }
53
+ PatchedAC.prototype = OrigAC.prototype;
54
+ Object.setPrototypeOf(PatchedAC, OrigAC);
55
+ window.AudioContext = PatchedAC;
56
+ if ('webkitAudioContext' in window) window.webkitAudioContext = PatchedAC;
57
+
58
+ const origPlay = HTMLMediaElement.prototype.play;
59
+ HTMLMediaElement.prototype.play = function() {
60
+ if (!this.__pup_captured__) {
61
+ this.__pup_captured__ = true;
62
+ const el = this;
63
+ Promise.resolve().then(() => {
64
+ if (!sourcedElements.has(el)) {
65
+ const ctx = new PatchedAC();
66
+ ctx.createMediaElementSource(el).connect(ctx.destination);
67
+ }
68
+ });
69
+ }
70
+ return origPlay.call(this);
71
+ };
72
+ })();
73
+ `;async function Ne(t){let e=path.join(os.tmpdir(),`pup_audio_preload_${crypto.randomUUID()}.js`);await promises.writeFile(e,Et),electron.session.defaultSession.registerPreloadScript({type:"frame",id:"pup-audio",filePath:e});let r=new M(t,4096*2*4),o={sampleRate:void 0,async teardown(){electron.ipcMain.removeAllListeners("audio-chunk"),electron.ipcMain.removeAllListeners("audio-meta"),await r.close(),electron.session.defaultSession.unregisterPreloadScript("pup-audio"),await promises.rm(e,{force:true});}};return electron.ipcMain.once("audio-meta",(i,n)=>{o.sampleRate=n.sampleRate;}),electron.ipcMain.on("audio-chunk",(i,n)=>{r.write(n);}),o}function Be(t,e){let{width:r,height:o}=e;return `<!DOCTYPE html>
2
74
  <html>
3
75
  <head>
4
76
  <meta charset="UTF-8">
@@ -86,6 +158,6 @@
86
158
  })();
87
159
  </script>
88
160
  </body>
89
- </html>`}function Fe(t,e){let{width:r,height:o}=e;if(r<32||o<2)return;let i=o-1,n=0;for(let c=0;c<32;c++){let a=(i*r+c)*4,g=(t[a]??0)>127?1:0;n=n<<1|g;}if(n=n>>>0,!(!Number.isFinite(n)||n<0||n>1e7))return n}function $e(t){return t.sendCommand("Runtime.evaluate",{expression:"window.__pup_start_recording__()"})}function Le(t){return t.sendCommand("Runtime.evaluate",{expression:"window.__pup_stop_recording__()"})}var ne=["file:","http:","https:","data:"],ct=/^(file:|https?:|data:)/;function ke(t){if(ct.test(t))return;let e=t.split(":")[0]+":",r=ne.includes(e)?`unsupported protocol: ${e}, expected ${ne.join(", ")}`:`invalid source format, expected ${ne.join(", ")}`;throw new Error(r)}function Ue(t){let e=t.getSize();return e.width===0||e.height===0?true:t.isEmpty()}var dt="[Proxy]";function ie(t){if(!t.startsWith("http"))return t;let e=t.match(/^https:\/\/([^-]+)-boss\.hdslb\.com(.*)$/);if(e){let[,r,o]=e;return `http://${r}-boss.bilibili.co${o}`}return t}function Oe(){electron.session.defaultSession.webRequest.onBeforeRequest((t,e)=>{let r=t.url,o=ie(r);if(o===r)return e({cancel:false});b.debug(dt,`${r} -> ${o}`),e({cancel:false,redirectURL:o});});}function Ne(t){return new Promise(e=>setTimeout(e,t))}function Me({fn:t,maxAttempts:e=3,timeout:r}){let o=new Error(`timeout over ${r}ms`);return async function(...i){let n=0;for(;;)try{let c=[t(...i)];return r&&c.push(promises$1.setTimeout(r).then(()=>{throw o})),await Promise.race(c)}catch(c){if(n++,n>=e)throw c;await Ne(Math.pow(2,n)*100+Math.random()*100);}}}var M="[Record]";async function gt(t,e){ke(t);let{width:r,height:o,useInnerProxy:i}=e;electron.session.defaultSession.webRequest.onHeadersReceived((f,s)=>{let w={...f.responseHeaders};delete w["x-frame-options"],delete w["X-Frame-Options"],delete w["content-security-policy"],delete w["Content-Security-Policy"],s({cancel:false,responseHeaders:w});});let n=t;i&&(n=ie(t),Oe());let c=new electron.BrowserWindow({width:r,height:o+1,show:false,transparent:true,backgroundColor:void 0,webPreferences:{offscreen:true,backgroundThrottling:false,nodeIntegration:true,contextIsolation:false,webSecurity:false,allowRunningInsecureContent:true,experimentalFeatures:true}});c.webContents.on("console-message",f=>{f.level==="error"&&b.error(M,"console:",f.message);});let a=De(n,{width:r,height:o}),l=`data:text/html;charset=utf-8,${encodeURIComponent(a)}`,g;return await new Promise((f,s)=>{g=setTimeout(()=>{s(new Error("load window timeout"));},20*1e3),c.webContents.once("did-finish-load",f),c.webContents.once("did-fail-load",(w,d,m,x)=>{s(new Error(`failed to load ${x}: [${d}] ${m}`));}),c.webContents.once("render-process-gone",(w,d)=>{let{exitCode:m,reason:x}=d;s(new Error(`renderer crashed: ${m}, ${x}`));}),c.loadURL(l);}),clearTimeout(g),c}async function He(t,e){b.info(M,"progress: 0%");let{outDir:r,fps:o,width:i,height:n,duration:c}=e,a=await Me({fn:gt,maxAttempts:2})(t,e);await promises.mkdir(r,{recursive:true});let l=a.webContents.debugger;l.attach("1.3"),a.webContents.setFrameRate(o),a.webContents.isPainting()||a.webContents.startPainting();let g=path.join(r,"output.bgra"),f=Math.ceil(o*c),s=1e3/o,w=i*n*4,d=new Ce(g,w,o),m=0,x,P=0,_,h,I,u=A=>{m++;try{d.write(A);}catch(O){_??=O;}},S=(A,O,G)=>{if(_){I?.(_);return}if(m>=f){h?.();return}if(Ue(G))return;let se=G.toBitmap(),N=Fe(se,G.getSize());if(N===void 0){_??=new Error(`no timestamp @ ${m}`);return}let je=i*4,K=se.subarray(0,n*je);if(x===void 0){u(K),x=N;return}let q=N-x;if(q<s*.8)return;if(q<=s*1.2)u(K);else {let Ge=Math.round(q/s);for(let ce=0;ce<Ge&&m<f;ce++)u(K);}x=N;let ae=Math.floor(m/f*100);Math.abs(ae-P)>10&&(P=ae,b.info(M,`progress: ${Math.round(P)}%`));};a.webContents.on("paint",S),await $e(l);try{await new Promise((A,O)=>[h,I]=[A,O]);}finally{await Le(l),a.webContents.off("paint",S),await d.close();}if(_||m===0)throw _??new Error("no frames captured");try{let A={options:e,written:m,bgraPath:g};await promises.writeFile(path.join(r,"record.json"),JSON.stringify(A)),b.info(M,`progress: 100%, ${m} frames written`);}finally{a.close();}}function k(t,e){return (...r)=>{try{let o=t(...r);return o instanceof Promise?o.catch(()=>e):o}catch{return e}}}var W=1920,H=1080,B=30,z=5,j="out";T__default.default.object({duration:T__default.default.number().optional().default(z).describe("Recording duration in seconds"),width:T__default.default.number().optional().default(W).describe("Video width"),height:T__default.default.number().optional().default(H).describe("Video height"),fps:T__default.default.number().optional().default(B).describe("Frames per second"),withAlphaChannel:T__default.default.boolean().optional().default(false).describe("Output with alpha channel"),outDir:T__default.default.string().optional().default(j).describe("Output directory"),useInnerProxy:T__default.default.boolean().optional().default(false).describe("Use bilibili inner proxy for resource access")});function ze(t,e){commander.program.name(t).argument("<source>","file://, http(s)://, \u6216 data: URI").option("-w, --width <number>","\u89C6\u9891\u5BBD\u5EA6",`${W}`).option("-h, --height <number>","\u89C6\u9891\u9AD8\u5EA6",`${H}`).option("-f, --fps <number>","\u5E27\u7387",`${B}`).option("-t, --duration <number>","\u5F55\u5236\u65F6\u957F\uFF08\u79D2\uFF09",`${z}`).option("-o, --out-dir <path>","\u8F93\u51FA\u76EE\u5F55",`${j}`).option("-a, --with-alpha-channel","\u8F93\u51FA\u5305\u542B alpha \u901A\u9053\u7684\u89C6\u9891",false).option("--use-inner-proxy","\u4F7F\u7528 B \u7AD9\u5185\u7F51\u4EE3\u7406\u52A0\u901F\u8D44\u6E90\u8BBF\u95EE",Q).action(async(r,o)=>{try{await e(r,{width:k(v,W)(o.width),height:k(v,H)(o.height),fps:k(v,B)(o.fps),duration:k(v,z)(o.duration),outDir:o.outDir??j,withAlphaChannel:o.withAlphaChannel??!1,useInnerProxy:o.useInnerProxy??Q});}catch(i){b.fatal(i);}}),commander.program.parse(Pe());}process.once("exit",()=>electron.app.quit());ze("app",async(t,e)=>{try{Ie.forEach(r=>electron.app.commandLine.appendSwitch(r)),electron.app.dock?.hide(),await electron.app.whenReady(),await He(t,e);}finally{electron.app.quit();}});
161
+ </html>`}function He(t,e){let{width:r,height:o}=e;if(r<32||o<2)return;let i=o-1,n=0;for(let c=0;c<32;c++){let s=(i*r+c)*4,h=(t[s]??0)>127?1:0;n=n<<1|h;}if(n=n>>>0,!(!Number.isFinite(n)||n<0||n>1e7))return n}function je(t){return t.sendCommand("Runtime.evaluate",{expression:"window.__pup_start_recording__()"})}function ze(t){return t.sendCommand("Runtime.evaluate",{expression:"window.__pup_stop_recording__()"})}function Ge(t){let e=t.getSize();return e.width===0||e.height===0?true:t.isEmpty()}var ae=["file:","http:","https:","data:"],vt=/^(file:|https?:|data:)/;function qe(t){if(vt.test(t))return;let e=t.split(":")[0]+":",r=ae.includes(e)?`unsupported protocol: ${e}, expected ${ae.join(", ")}`:`invalid source format, expected ${ae.join(", ")}`;throw new Error(r)}var It="[Proxy]",kt=new Map([["jssz-boss.hdslb.com","jssz-boss.bilibili.co"],["boss.hdslb.com","shjd-boss.bilibili.co"]]);function ce(t){if(!t.startsWith("http"))return t;let e=new url.URL(t),r=kt.get(e.hostname);return r?(e.hostname=r,e.protocol="http:",e.toString()):t}function Ke(){electron.session.defaultSession.webRequest.onBeforeRequest((t,e)=>{let r=t.url,o=ce(r);if(o===r)return e({cancel:false});f.debug(It,`${r} -> ${o}`),e({cancel:false,redirectURL:o});});}function Ve(t){return new Promise(e=>setTimeout(e,t))}function Ye({fn:t,maxAttempts:e=3,timeout:r}){let o=new Error(`timeout over ${r}ms`);return async function(...i){let n=0;for(;;)try{let c=[t(...i)];return r&&c.push(promises$1.setTimeout(r).then(()=>{throw o})),await Promise.race(c)}catch(c){if(n++,n>=e)throw c;await Ve(Math.pow(2,n)*100+Math.random()*100);}}}var Ut="[Window]";function Je(t,e){return new Promise((r,o)=>{let i=setTimeout(()=>o(new Error("load window timeout")),2e4),n=c=>{clearTimeout(i),c?o(c):r();};t.webContents.once("did-finish-load",()=>n()),t.webContents.once("did-fail-load",(c,s,l,h)=>n(new Error(`failed to load ${h}: [${s}] ${l}`))),t.webContents.once("render-process-gone",(c,{exitCode:s,reason:l})=>n(new Error(`renderer crashed: ${s}, ${l}`))),e();})}async function Ot(t,e,r){qe(e);let{width:o,height:i,useInnerProxy:n}=r;electron.session.defaultSession.webRequest.onHeadersReceived(({responseHeaders:u},a)=>{delete u?.["x-frame-options"],delete u?.["X-Frame-Options"],delete u?.["content-security-policy"],delete u?.["Content-Security-Policy"],a({cancel:false,responseHeaders:u});});let c=e;n&&(c=ce(e),Ke());let s=new electron.BrowserWindow({width:o,height:i+1,show:false,transparent:true,backgroundColor:void 0,webPreferences:{offscreen:true,backgroundThrottling:false,nodeIntegration:true,nodeIntegrationInSubFrames:true,contextIsolation:false,webSecurity:false,allowRunningInsecureContent:true,experimentalFeatures:true}});t.splice(0).forEach(u=>u.destroy()),t.push(s),s.webContents.on("console-message",({level:u,message:a})=>{u==="error"&&f.error(Ut,"console:",a);});let l=Be(c,{width:o,height:i}),h=`data:text/html;charset=utf-8,${encodeURIComponent(l)}`;return await Je(s,()=>s.loadURL(h)),s}async function Xe(t,e){let r=[],o=await Ye({fn:Ot,maxAttempts:2})(r,t,e);return await Je(o,()=>o.reload()),o}var ue="[Record]";async function Qe(t,e){f.info(ue,"progress: 0%");let{outDir:r,fps:o,width:i,height:n,duration:c,withAudio:s}=e;await promises.mkdir(r,{recursive:true});let l=path.join(r,"output.pcm"),h=s?await Ne(l):void 0,u=await Xe(t,e),a=u.webContents.debugger;a.attach("1.3"),u.webContents.setFrameRate(o),u.webContents.isPainting()||u.webContents.startPainting();let T=path.join(r,"output.bgra"),w=Math.ceil(o*c),_=1e3/o,$=i*n*4,k=new M(T,$,o),g=0,m,y=0,d,E,de,q=v=>{g++;try{k.write(v);}catch(C){d??=C;}},le=(v,C,K)=>{if(d){de?.(d);return}if(g>=w){E?.();return}if(Ge(K))return;let me=K.toBitmap(),W=He(me,K.getSize());if(W===void 0){d??=new Error(`no timestamp @ ${g}`);return}let tt=i*4,V=me.subarray(0,n*tt);if(m===void 0){q(V),m=W;return}let Y=W-m;if(Y<_*.8)return;if(Y<=_*1.2)q(V);else {let rt=Math.round(Y/_);for(let he=0;he<rt&&g<w;he++)q(V);}m=W;let fe=Math.floor(g/w*100);Math.abs(fe-y)>10&&(y=fe,f.info(ue,`progress: ${Math.round(y)}%`));};u.webContents.on("paint",le),await je(a);try{await new Promise((v,C)=>[E,de]=[v,C]);}finally{await ze(a),u.webContents.off("paint",le),await k.close(),await h?.teardown();}if(d||g===0)throw d??new Error("no frames captured");try{let v=h?.sampleRate?{pcmPath:l,sampleRate:h.sampleRate}:void 0,C={options:e,written:g,bgra:T,audio:v};await promises.writeFile(path.join(r,"record.json"),JSON.stringify(C)),f.info(ue,`progress: 100%, ${g} frames written`);}finally{u.close();}}function O(t,e){return (...r)=>{try{let o=t(...r);return o instanceof Promise?o.catch(()=>e):o}catch{return e}}}var B=1920,H=1080,j=30,z=5,G="out";x__default.default.object({duration:x__default.default.number().optional().default(z).describe("Recording duration in seconds"),width:x__default.default.number().optional().default(B).describe("Video width"),height:x__default.default.number().optional().default(H).describe("Video height"),fps:x__default.default.number().optional().default(j).describe("Frames per second"),withAlphaChannel:x__default.default.boolean().optional().default(false).describe("Output with alpha channel"),withAudio:x__default.default.boolean().optional().default(false).describe("Capture and encode audio"),outDir:x__default.default.string().optional().default(G).describe("Output directory"),useInnerProxy:x__default.default.boolean().optional().default(false).describe("Use bilibili inner proxy for resource access")});function et(t,e){commander.program.name(t).argument("<source>","file://, http(s)://, \u6216 data: URI").option("-w, --width <number>","\u89C6\u9891\u5BBD\u5EA6",`${B}`).option("-h, --height <number>","\u89C6\u9891\u9AD8\u5EA6",`${H}`).option("-f, --fps <number>","\u5E27\u7387",`${j}`).option("-t, --duration <number>","\u5F55\u5236\u65F6\u957F\uFF08\u79D2\uFF09",`${z}`).option("-o, --out-dir <path>","\u8F93\u51FA\u76EE\u5F55",`${G}`).option("-a, --with-alpha-channel","\u8F93\u51FA\u5305\u542B alpha \u901A\u9053\u7684\u89C6\u9891",false).option("-s, --with-audio","\u6355\u83B7\u5E76\u6DF7\u5165\u97F3\u9891",false).option("--use-inner-proxy","\u4F7F\u7528 B \u7AD9\u5185\u7F51\u4EE3\u7406\u52A0\u901F\u8D44\u6E90\u8BBF\u95EE",te).action(async(r,o)=>{try{await e(r,{width:O(A,B)(o.width),height:O(A,H)(o.height),fps:O(A,j)(o.fps),duration:O(A,z)(o.duration),outDir:o.outDir??G,withAlphaChannel:o.withAlphaChannel??!1,withAudio:o.withAudio??!1,useInnerProxy:o.useInnerProxy??te});}catch(i){f.fatal(i);}}),commander.program.parse(Ue());}process.once("exit",()=>electron.app.quit());et("app",async(t,e)=>{try{(await Oe()).forEach(o=>{let i=o.indexOf("=");if(i<0)electron.app.commandLine.appendSwitch(o);else {let n=o.slice(0,i),c=o.slice(i+1);electron.app.commandLine.appendSwitch(n,c);}}),electron.app.dock?.hide(),await electron.app.whenReady(),await Qe(t,e);}finally{electron.app.quit();}});
90
162
  //# sourceMappingURL=app.cjs.map
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../node_modules/.bun/tsup@8.5.1+3f29b90437d001ad/node_modules/tsup/assets/cjs_shims.js","../../src/base/basedir.ts","../../src/base/env.ts","../../src/base/parser.ts","../../src/base/constants.ts","../../src/base/logging.ts","../../src/base/process.ts","../../src/base/electron.ts","../../src/rust/lib.ts","../../src/base/frame_sync.ts","../../src/base/html_check.ts","../../src/base/image.ts","../../src/base/proxy.ts","../../src/base/timing.ts","../../src/base/retry.ts","../../src/base/record.ts","../../src/base/noerr.ts","../../src/base/schema.ts","../../src/common.ts","../../src/app.ts"],"names":["getImportMetaUrl","importMetaUrl","basedir","dirname","fileURLToPath","penv","name","parser","defaultValue","parseNumber","value","num","pupAppSearchPaths","join","existsSync","env","pupLogLevel","pupUseInnerProxy","DEBUG","INFO","WARN","ERROR","FATAL","stackHook","target","_context","messages","processed","msg","_fatal_dec","_error_dec","_warn_dec","_info_dec","_debug_dec","_init","Logger","__runInitializers","__publicField","debug","info","warn","error","message","proc","resolve","reject","fatal","dispatch","data","err","code","signal","reason","__decoratorStart","__decorateElement","__decoratorMetadata","logger","PUP_ARGS_ENV_KEY","pargs","pupArgs","args","ELECTRON_OPTS","platform","arch","rustPath","nativeSearchPaths","mod","__require","FixedBufferWriter","buildWrapperHTML","targetURL","size","width","height","decodeTimestamp","bitmap","markerRow","timestamp","i","pixelIdx","bit","startSync","cdp","stopSync","SUPPORTED_PROTOCOLS","SOURCE_PATTERN","checkHTML","source","protocol","isEmpty","image","TAG","proxiedUrl","url","match","prefix","path","enableProxy","session","details","callback","proxied","sleep","ms","useRetry","fn","maxAttempts","timeout","timeoutError","attempt","promises","setTimeout","e","loadWindow","options","useInnerProxy","responseHeaders","src","win","BrowserWindow","event","wrapperHTML","dataURL","token","_event","desc","exitCode","record","outDir","fps","duration","mkdir","bgraPath","total","frameInterval","bufferSize","writer","written","lastWrittenTime","progress","frameError","resolver","rejecter","scheduleWrite","buffer","paint","_e","_r","currentTime","bytesPerRow","cropped","timeSinceLastFrame","framesToInsert","newProgress","r","j","result","writeFile","noerr","ret","DEFAULT_WIDTH","DEFAULT_HEIGHT","DEFAULT_FPS","DEFAULT_DURATION","DEFAULT_OUT_DIR","z","makeCLI","program","opts","app","o"],"mappings":"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","file":"app.cjs","sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n  typeof document === \"undefined\" \n    ? new URL(`file:${__filename}`).href \n    : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n      ? document.currentScript.src \n      : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nimport { dirname } from \"path\";\nimport { fileURLToPath } from \"url\";\n\nexport const basedir = dirname(fileURLToPath(import.meta.url));\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nexport type EnvParser<T> = (value: unknown) => T;\n\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue: T): T;\nexport function penv<T>(\n  name: string,\n  parser: EnvParser<T>,\n  defaultValue?: T,\n): T | undefined;\nexport function penv<T>(\n  name: string,\n  parser: EnvParser<T>,\n  defaultValue?: T,\n): 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(value: unknown): number {\n  if (typeof value === \"number\") {\n    return value;\n  }\n  const num = Number(value);\n  if (Number.isNaN(num)) {\n    throw new Error(`Value ${value} is not a valid number`);\n  }\n  return num;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { existsSync } from \"fs\";\nimport { join } from \"path\";\nimport { basedir } from \"./basedir\";\nimport { penv } from \"./env\";\nimport { parseNumber } from \"./parser\";\n\nconst pupAppSearchPaths = [\n  join(basedir, \"cjs/app.cjs\"), // process from dist\n  join(basedir, \"app.cjs\"), // process from dist/cjs\n  join(basedir, \"../../cjs/app.cjs\"), // process from src\n];\nexport const pupAppPath = pupAppSearchPaths.find(existsSync)!;\n\nconst env = process.env;\nexport const pupLogLevel = penv(\"PUP_LOG_LEVEL\", parseNumber, 2);\nexport const pupUseInnerProxy = env[\"PUP_USE_INNER_PROXY\"] === \"1\";\nexport const pupFFmpegPath = env[\"FFMPEG_BIN\"] ?? `ffmpeg`;\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport { ChildProcess, type Serializable } from \"child_process\";\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\nclass Logger implements LoggerLike {\n  private _impl?: LoggerLike;\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    this._impl = {\n      debug: pupLogLevel >= 3 ? debug : undefined,\n      info: pupLogLevel >= 2 ? info : undefined,\n      warn: pupLogLevel >= 1 ? warn : undefined,\n      error: pupLogLevel >= 0 ? error : undefined,\n    };\n  }\n\n  constructor() {\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    if (message.startsWith(DEBUG)) {\n      this.debug(message.slice(DEBUG.length + 1));\n    } else if (message.startsWith(INFO)) {\n      this.info(message.slice(INFO.length + 1));\n    } else if (message.startsWith(WARN)) {\n      this.warn(message.slice(WARN.length + 1));\n    } else if (message.startsWith(ERROR)) {\n      this.error(message.slice(ERROR.length + 1));\n    } else {\n      this.info(message);\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\nexport { logger };\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_ENV_KEY = \"__PUP_ARGS__\";\n\nexport function pargs() {\n  const pupArgs = process.env[PUP_ARGS_ENV_KEY];\n  if (pupArgs) {\n    const args = [\"exec\", ...process.argv.slice(-1)];\n    args.push(...JSON.parse(pupArgs));\n    logger.debug(\"pupargs\", args);\n    return args;\n  }\n\n  logger.debug(\"procargv\", process.argv);\n  return process.argv;\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/25.\n\nimport electron, { type Size } from \"electron\";\nimport { exec } from \"./process\";\n\nexport const ELECTRON_OPTS = [\n  \"no-sandbox\",\n  \"disable-setuid-sandbox\",\n  \"disable-gpu\",\n  \"disable-dev-shm-usage\",\n  \"disable-software-rasterizer\",\n  \"disable-web-security\",\n  \"disable-site-isolation-trials\",\n  \"disable-features=IsolateOrigins,site-per-process\",\n  \"allow-insecure-localhost\",\n  \"ignore-certificate-errors\",\n  \"disable-blink-features=AutomationControlled\",\n  \"mute-audio\",\n  \"disable-extensions\",\n  \"disable-background-networking\",\n  \"address-family=ipv4\",\n  \"disable-async-dns\",\n  \"force-device-scale-factor=1\",\n  \"trace-warnings\",\n  \"force-color-profile=srgb\",\n  \"disable-color-correct-rendering\",\n  \"log-level=3\",\n];\n\nexport function runElectronApp(size: Size, app: unknown, args: unknown[]) {\n  const electronArgs = ELECTRON_OPTS.map((a) => `--${a}`);\n  const cmdParts = [];\n  if (process.platform === \"linux\") {\n    cmdParts.push(\n      \"xvfb-run\",\n      \"--auto-servernum\",\n      `--server-args='-screen 0 ${size.width}x${size.height}x24'`,\n    );\n  }\n  cmdParts.push(electron, ...electronArgs, app);\n  return exec(cmdParts.join(\" \"), {\n    stdio: [\"ignore\", \"pipe\", \"pipe\"],\n    shell: true,\n    env: {\n      ...process.env,\n      ELECTRON_DISABLE_DBUS: \"1\",\n      RUST_BACKTRACE: \"full\",\n      __PUP_ARGS__: JSON.stringify(args),\n    },\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/10.\n\nimport { existsSync } from \"fs\";\nimport { join } from \"path\";\nimport { basedir } from \"../base/basedir\";\n\nconst { platform, arch } = process;\n\nconst rustPath = `rust/${platform}-${arch}.node`;\n\nconst nativeSearchPaths = [\n  join(basedir, `../../${rustPath}`), // process start from src\n  join(basedir, `../${rustPath}`), // process start from dist\n];\nconst mod = require(nativeSearchPaths.find(existsSync)!);\n\nexport interface FixedBufferWriter {\n  new (\n    path: string,\n    bufferSize: number,\n    queueDepth?: number,\n  ): FixedBufferWriter;\n\n  write(buffer: Buffer): void;\n\n  close(): Promise<void>;\n}\n\nexport const FixedBufferWriter = mod.FixedBufferWriter as FixedBufferWriter;\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport type { Debugger, Size } from \"electron\";\n\nexport const FRAME_SYNC_MARKER_WIDTH = 32;\nexport const FRAME_SYNC_MARKER_HEIGHT = 1;\n\nexport function buildWrapperHTML(targetURL: string, size: Size): string {\n  const { width, height } = size;\n  return `<!DOCTYPE html>\n<html>\n<head>\n  <meta charset=\"UTF-8\">\n  <style>\n    * { margin: 0; padding: 0; box-sizing: border-box; }\n    html, body { width: ${width}px; height: ${height + 1}px; overflow: hidden; }\n    #target { \n      position: absolute; \n      top: 0; \n      left: 0; \n      width: ${width}px; \n      height: ${height}px; \n      border: none; \n      display: block;\n    }\n    #stego { \n      position: absolute; \n      top: ${height}px; \n      left: 0; \n      width: ${width}px; \n      height: 1px; \n      display: block;\n      image-rendering: pixelated;\n    }\n  </style>\n</head>\n<body>\n  <iframe id=\"target\" src=\"${targetURL}\"></iframe>\n  <canvas id=\"stego\" width=\"${width}\" height=\"1\"></canvas>\n  <script>\n    (function() {\n      const WIDTH = ${width};\n      const MARKER_WIDTH = ${FRAME_SYNC_MARKER_WIDTH};\n      const canvas = document.getElementById('stego');\n      const ctx = canvas.getContext('2d', { willReadFrequently: true });\n      let startTime = null;\n      let rafId = null;\n\n      function encodeTimestamp(timestampMs) {\n        const imageData = ctx.createImageData(WIDTH, 1);\n        const data = imageData.data;\n        \n        const timestampInt = Math.floor(timestampMs) >>> 0;\n        \n        for (let i = 0; i < MARKER_WIDTH; i++) {\n          const bit = (timestampInt >>> (MARKER_WIDTH - 1 - i)) & 1;\n          const value = bit ? 255 : 0;\n          const idx = i * 4;\n          data[idx] = value;\n          data[idx + 1] = value;\n          data[idx + 2] = value;\n          data[idx + 3] = 255;\n        }\n        \n        for (let i = MARKER_WIDTH; i < WIDTH; i++) {\n          const idx = i * 4;\n          data[idx] = 0;\n          data[idx + 1] = 0;\n          data[idx + 2] = 0;\n          data[idx + 3] = 255;\n        }\n        \n        ctx.putImageData(imageData, 0, 0);\n      }\n\n      function updateLoop() {\n        if (startTime === null) return;\n        const elapsed = performance.now() - startTime;\n        encodeTimestamp(elapsed);\n        rafId = requestAnimationFrame(updateLoop);\n      }\n\n      window.__pup_start_recording__ = () => {\n        startTime = performance.now();\n        encodeTimestamp(0);\n        requestAnimationFrame(updateLoop);\n      };\n\n      window.__pup_stop_recording__ = () => {\n        if (rafId !== null) {\n          cancelAnimationFrame(rafId);\n          rafId = null;\n        }\n      };\n    })();\n  </script>\n</body>\n</html>`;\n}\n\nexport function decodeTimestamp(\n  bitmap: Buffer,\n  size: Size,\n): number | undefined {\n  const { width, height } = size;\n  if (width < FRAME_SYNC_MARKER_WIDTH || height < 2) {\n    return undefined;\n  }\n\n  const markerRow = height - 1;\n\n  let timestamp = 0;\n  for (let i = 0; i < FRAME_SYNC_MARKER_WIDTH; i++) {\n    const pixelIdx = (markerRow * width + i) * 4;\n    const r = bitmap[pixelIdx] ?? 0;\n    const bit = r > 127 ? 1 : 0;\n    timestamp = (timestamp << 1) | bit;\n  }\n\n  timestamp = timestamp >>> 0;\n\n  if (!Number.isFinite(timestamp) || timestamp < 0 || timestamp > 1e7) {\n    return undefined;\n  }\n\n  return timestamp;\n}\n\nexport function startSync(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_start_recording__()`,\n  });\n}\n\nexport function stopSync(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_stop_recording__()`,\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nconst SUPPORTED_PROTOCOLS = [\"file:\", \"http:\", \"https:\", \"data:\"];\nconst SOURCE_PATTERN = /^(file:|https?:|data:)/;\n\nexport function checkHTML(source: string): void {\n  if (SOURCE_PATTERN.test(source)) {\n    return;\n  }\n\n  const protocol = source.split(\":\")[0] + \":\";\n  const message = SUPPORTED_PROTOCOLS.includes(protocol)\n    ? `unsupported protocol: ${protocol}, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`\n    : `invalid source format, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`;\n\n  throw new Error(message);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport type { NativeImage } from \"electron\";\n\nexport function isEmpty(image: NativeImage) {\n  const size = image.getSize();\n  if (size.width === 0 || size.height === 0) return true;\n  return image.isEmpty();\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { session } from \"electron\";\nimport { logger } from \"./logging\";\n\nconst TAG = \"[Proxy]\";\n\nexport function proxiedUrl(url: string) {\n  if (!url.startsWith(\"http\")) {\n    return url;\n  }\n  // Redirect boss.hdslb.com to boss.bilibili.co\n  const match = url.match(/^https:\\/\\/([^-]+)-boss\\.hdslb\\.com(.*)$/);\n  if (match) {\n    const [, prefix, path] = match;\n    return `http://${prefix}-boss.bilibili.co${path}`;\n  }\n  return url;\n}\n\nexport function enableProxy() {\n  // Redirect boss.hdslb.com to boss.bilibili.co\n  session.defaultSession.webRequest.onBeforeRequest((details, callback) => {\n    const url = details.url;\n    const proxied = proxiedUrl(url);\n    if (proxied === url) {\n      return callback({ cancel: false });\n    } else {\n      logger.debug(TAG, `${url} -> ${proxied}`);\n      callback({ cancel: false, redirectURL: proxied });\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(\n  callback: (count: number) => Promise<void> | void,\n  ms: number,\n) {\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>({\n  fn,\n  maxAttempts = 3,\n  timeout,\n}: RetryOptions<Args, Ret>) {\n  const timeoutError = new Error(`timeout over ${timeout}ms`);\n  return async function (...args: Args) {\n    let attempt = 0;\n    while (true) {\n      try {\n        const promises = [fn(...args)];\n        if (timeout) {\n          promises.push(\n            setTimeout(timeout).then(() => {\n              throw timeoutError;\n            }),\n          );\n        }\n        return await Promise.race(promises);\n      } catch (e) {\n        attempt++;\n        if (attempt >= maxAttempts) {\n          throw e;\n        }\n        await sleep(Math.pow(2, attempt) * 100 + Math.random() * 100);\n      }\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { BrowserWindow, session, type NativeImage } from \"electron\";\nimport { mkdir, writeFile } from \"fs/promises\";\nimport { join } from \"path\";\nimport { FixedBufferWriter } from \"../rust/lib\";\nimport {\n  buildWrapperHTML,\n  decodeTimestamp,\n  startSync,\n  stopSync,\n} from \"./frame_sync\";\nimport { checkHTML } from \"./html_check\";\nimport { isEmpty } from \"./image\";\nimport { logger } from \"./logging\";\nimport { enableProxy, proxiedUrl } from \"./proxy\";\nimport { useRetry } from \"./retry\";\nimport type { RecordOptions, RecordResult } from \"./schema\";\n\nconst TAG = \"[Record]\";\n\nasync function loadWindow(source: string, options: RecordOptions) {\n  checkHTML(source);\n\n  const { width, height, useInnerProxy } = options;\n\n  // Remove X-Frame-Options and CSP headers to allow iframe loading\n  // Note: Electron's onHeadersReceived uses REPLACE behavior (not append).\n  // Only the last attached listener is used, so no cleanup needed.\n  // Ref: https://www.electronjs.org/docs/latest/api/web-request\n  session.defaultSession.webRequest.onHeadersReceived((details, callback) => {\n    const responseHeaders = { ...details.responseHeaders };\n    delete responseHeaders[\"x-frame-options\"];\n    delete responseHeaders[\"X-Frame-Options\"];\n    delete responseHeaders[\"content-security-policy\"];\n    delete responseHeaders[\"Content-Security-Policy\"];\n    callback({ cancel: false, responseHeaders });\n  });\n\n  let src = source;\n  if (useInnerProxy) {\n    src = proxiedUrl(source);\n    enableProxy();\n  }\n\n  const win = new BrowserWindow({\n    width: width,\n    height: height + 1,\n    show: false,\n    transparent: true,\n    backgroundColor: undefined,\n    webPreferences: {\n      offscreen: true,\n      backgroundThrottling: false,\n      nodeIntegration: true,\n      contextIsolation: false,\n      webSecurity: false,\n      allowRunningInsecureContent: true,\n      experimentalFeatures: true,\n    },\n  });\n\n  win.webContents.on(\"console-message\", (event) => {\n    if (event.level === \"error\") {\n      logger.error(TAG, \"console:\", event.message);\n    }\n  });\n\n  const wrapperHTML = buildWrapperHTML(src, { width, height });\n  const dataURL = `data:text/html;charset=utf-8,${encodeURIComponent(wrapperHTML)}`;\n  let token: NodeJS.Timeout | undefined;\n\n  await new Promise<void>((resolve, reject) => {\n    token = setTimeout(() => {\n      reject(new Error(\"load window timeout\"));\n    }, 20 * 1000);\n\n    win.webContents.once(\"did-finish-load\", resolve);\n\n    win.webContents.once(\"did-fail-load\", (_event, code, desc, url) => {\n      reject(new Error(`failed to load ${url}: [${code}] ${desc}`));\n    });\n\n    win.webContents.once(\"render-process-gone\", (_event, details) => {\n      const { exitCode, reason } = details;\n      reject(new Error(`renderer crashed: ${exitCode}, ${reason}`));\n    });\n\n    win.loadURL(dataURL);\n  });\n  clearTimeout(token);\n  return win;\n}\n\nexport async function record(\n  source: string,\n  options: RecordOptions,\n): Promise<void> {\n  logger.info(TAG, `progress: 0%`);\n  const { outDir, fps, width, height, duration } = options;\n\n  const win = await useRetry({ fn: loadWindow, maxAttempts: 2 })(\n    source,\n    options,\n  );\n\n  await mkdir(outDir, { recursive: true });\n\n  const cdp = win.webContents.debugger;\n  cdp.attach(\"1.3\");\n\n  win.webContents.setFrameRate(fps);\n  if (!win.webContents.isPainting()) {\n    win.webContents.startPainting();\n  }\n\n  const bgraPath = join(outDir, \"output.bgra\");\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n  const bufferSize = width * height * 4;\n\n  const writer = new FixedBufferWriter(bgraPath, bufferSize, fps);\n\n  let written = 0;\n  let lastWrittenTime: number | undefined;\n  let progress = 0;\n  let frameError: Error | undefined;\n  let resolver: (() => void) | undefined;\n  let rejecter: ((reason?: unknown) => void) | undefined;\n\n  const scheduleWrite = (buffer: Buffer) => {\n    written++;\n    try {\n      writer.write(buffer);\n    } catch (error) {\n      frameError ??= error as Error;\n    }\n  };\n\n  const paint = (_e: unknown, _r: unknown, image: NativeImage) => {\n    if (frameError) {\n      rejecter?.(frameError);\n      return;\n    }\n\n    if (written >= total) {\n      resolver?.();\n      return;\n    }\n\n    if (isEmpty(image)) return;\n\n    const bitmap = image.toBitmap();\n    const currentTime = decodeTimestamp(bitmap, image.getSize());\n    if (currentTime === undefined) {\n      frameError ??= new Error(`no timestamp @ ${written}`);\n      return;\n    }\n\n    const bytesPerRow = width * 4;\n    const cropped = bitmap.subarray(0, height * bytesPerRow);\n\n    if (lastWrittenTime === undefined) {\n      scheduleWrite(cropped);\n      lastWrittenTime = currentTime;\n      return;\n    }\n\n    const timeSinceLastFrame = currentTime - lastWrittenTime;\n    if (timeSinceLastFrame < frameInterval * 0.8) {\n      return;\n    }\n\n    if (timeSinceLastFrame <= frameInterval * 1.2) {\n      scheduleWrite(cropped);\n    } else {\n      const framesToInsert = Math.round(timeSinceLastFrame / frameInterval);\n      for (let i = 0; i < framesToInsert && written < total; i++) {\n        scheduleWrite(cropped);\n      }\n    }\n    lastWrittenTime = currentTime;\n\n    const newProgress = Math.floor((written / total) * 100);\n    if (Math.abs(newProgress - progress) > 10) {\n      progress = newProgress;\n      logger.info(TAG, `progress: ${Math.round(progress)}%`);\n    }\n  };\n\n  win.webContents.on(\"paint\", paint);\n  await startSync(cdp);\n  try {\n    await new Promise<void>((r, j) => ([resolver, rejecter] = [r, j]));\n  } finally {\n    await stopSync(cdp);\n    win.webContents.off(\"paint\", paint);\n    await writer.close();\n  }\n\n  if (frameError || written === 0) {\n    throw frameError ?? new Error(\"no frames captured\");\n  }\n\n  try {\n    const result: RecordResult = { options, written, bgraPath };\n    await writeFile(join(outDir, \"record.json\"), JSON.stringify(result));\n    logger.info(TAG, `progress: 100%, ${written} frames written`);\n  } finally {\n    win.close();\n  }\n}\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/02/06.\n\nimport type { Size } from \"electron\";\nimport z from \"zod\";\n\nexport interface VideoSpec {\n  fps: number;\n  frames: number;\n  size: Size;\n}\n\nexport interface VideoFiles {\n  mp4?: string;\n  webm?: string;\n  mov?: string;\n}\n\nexport interface VideoFilesWithCover extends VideoFiles {\n  cover: string;\n}\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_DIR = \"out\";\n\nexport const RecordSchema = z.object({\n  duration: z\n    .number()\n    .optional()\n    .default(DEFAULT_DURATION)\n    .describe(\"Recording duration in seconds\"),\n  width: z.number().optional().default(DEFAULT_WIDTH).describe(\"Video width\"),\n  height: z\n    .number()\n    .optional()\n    .default(DEFAULT_HEIGHT)\n    .describe(\"Video height\"),\n  fps: z.number().optional().default(DEFAULT_FPS).describe(\"Frames per second\"),\n  withAlphaChannel: z\n    .boolean()\n    .optional()\n    .default(false)\n    .describe(\"Output with alpha channel\"),\n  outDir: z\n    .string()\n    .optional()\n    .default(DEFAULT_OUT_DIR)\n    .describe(\"Output directory\"),\n  useInnerProxy: z\n    .boolean()\n    .optional()\n    .default(false)\n    .describe(\"Use bilibili inner proxy for resource access\"),\n});\n\nexport interface RecordOptions {\n  duration: number;\n  width: number;\n  height: number;\n  fps: number;\n  withAlphaChannel: boolean;\n  outDir: string;\n  useInnerProxy: boolean;\n}\n\nexport interface RecordResult {\n  options: RecordOptions;\n  written: number;\n  bgraPath: string;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { program } from \"commander\";\nimport { pupUseInnerProxy } from \"./base/constants\";\nimport { logger } from \"./base/logging\";\nimport { noerr } from \"./base/noerr\";\nimport { parseNumber } from \"./base/parser\";\nimport { pargs } from \"./base/process\";\nimport {\n  DEFAULT_DURATION,\n  DEFAULT_FPS,\n  DEFAULT_HEIGHT,\n  DEFAULT_OUT_DIR,\n  DEFAULT_WIDTH,\n  type RecordOptions,\n} from \"./base/schema\";\n\nexport type CLICallback = (\n  source: string,\n  options: RecordOptions,\n) => Promise<unknown>;\n\nexport function makeCLI(name: string, callback: CLICallback) {\n  program\n    .name(name)\n    .argument(\"<source>\", \"file://, http(s)://, 或 data: URI\")\n    .option(\"-w, --width <number>\", \"视频宽度\", `${DEFAULT_WIDTH}`)\n    .option(\"-h, --height <number>\", \"视频高度\", `${DEFAULT_HEIGHT}`)\n    .option(\"-f, --fps <number>\", \"帧率\", `${DEFAULT_FPS}`)\n    .option(\"-t, --duration <number>\", \"录制时长（秒）\", `${DEFAULT_DURATION}`)\n    .option(\"-o, --out-dir <path>\", \"输出目录\", `${DEFAULT_OUT_DIR}`)\n    .option(\"-a, --with-alpha-channel\", \"输出包含 alpha 通道的视频\", false)\n    .option(\n      \"--use-inner-proxy\",\n      \"使用 B 站内网代理加速资源访问\",\n      pupUseInnerProxy,\n    )\n    .action(async (source: string, opts) => {\n      try {\n        await callback(source, {\n          width: noerr(parseNumber, DEFAULT_WIDTH)(opts.width),\n          height: noerr(parseNumber, DEFAULT_HEIGHT)(opts.height),\n          fps: noerr(parseNumber, DEFAULT_FPS)(opts.fps),\n          duration: noerr(parseNumber, DEFAULT_DURATION)(opts.duration),\n          outDir: opts.outDir ?? DEFAULT_OUT_DIR,\n          withAlphaChannel: opts.withAlphaChannel ?? false,\n          useInnerProxy: opts.useInnerProxy ?? pupUseInnerProxy,\n        });\n      } catch (e) {\n        logger.fatal(e);\n      }\n    });\n  program.parse(pargs());\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { app } from \"electron\";\nimport { ELECTRON_OPTS } from \"./base/electron\";\nimport { record } from \"./base/record\";\nimport { makeCLI } from \"./common\";\n\nprocess.once(\"exit\", () => app.quit());\n\nmakeCLI(\"app\", async (source, options) => {\n  try {\n    ELECTRON_OPTS.forEach((o) => app.commandLine.appendSwitch(o));\n    app.dock?.hide();\n    await app.whenReady();\n    await record(source, options);\n  } finally {\n    app.quit();\n  }\n});\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../node_modules/.bun/tsup@8.5.1+3f29b90437d001ad/node_modules/tsup/assets/cjs_shims.js","../../src/base/basedir.ts","../../src/base/env.ts","../../src/base/parser.ts","../../src/base/constants.ts","../../src/base/logging.ts","../../src/base/hwaccel.ts","../../src/base/process.ts","../../src/base/electron.ts","../../src/rust/lib.ts","../../src/base/audio_capture.ts","../../src/base/frame_sync.ts","../../src/base/image.ts","../../src/base/html_check.ts","../../src/base/proxy.ts","../../src/base/timing.ts","../../src/base/retry.ts","../../src/base/window.ts","../../src/base/record.ts","../../src/base/noerr.ts","../../src/base/schema.ts","../../src/common.ts","../../src/app.ts"],"names":["getImportMetaUrl","importMetaUrl","basedir","dirname","fileURLToPath","penv","name","parser","defaultValue","parseNumber","value","num","pupAppSearchPaths","join","existsSync","env","pupLogLevel","pupUseInnerProxy","pupDisableGPU","DEBUG","INFO","WARN","ERROR","FATAL","stackHook","target","_context","messages","processed","msg","_fatal_dec","_error_dec","_warn_dec","_info_dec","_debug_dec","_init","Logger","__runInitializers","__publicField","debug","info","warn","error","message","proc","resolve","reject","fatal","dispatch","data","err","code","signal","reason","__decoratorStart","__decorateElement","__decoratorMetadata","logger","TAG","detect","controllers","graphics","c","hasGpu","gpu","PUP_ARGS_KEY","pargs","argv","priv","arg","args","electronOpts","opts","platform","arch","rustPath","nativeSearchPaths","mod","__require","FixedBufferWriter","AUDIO_CAPTURE_SCRIPT","setupAudioCapture","pcmPath","preloadPath","tmpdir","randomUUID","writeFile","session","writer","capture","ipcMain","rm","_e","buffer","buildWrapperHTML","targetURL","size","width","height","decodeTimestamp","bitmap","markerRow","timestamp","i","pixelIdx","bit","startSync","cdp","stopSync","isEmpty","image","SUPPORTED_PROTOCOLS","SOURCE_PATTERN","checkHTML","source","protocol","map","proxiedUrl","url","parsed","URL","enableProxy","details","callback","proxied","sleep","ms","useRetry","fn","maxAttempts","timeout","timeoutError","attempt","promises","setTimeout","e","waitForFinish","win","action","done","desc","exitCode","openWindow","wins","options","useInnerProxy","responseHeaders","src","BrowserWindow","w","level","wrapperHTML","dataURL","loadWindow","record","outDir","fps","duration","withAudio","mkdir","audioCapture","bgra","total","frameInterval","bufferSize","written","lastWrittenTime","progress","frameError","resolver","rejecter","scheduleWrite","paint","_r","currentTime","bytesPerRow","cropped","timeSinceLastFrame","framesToInsert","newProgress","r","j","audio","result","noerr","ret","DEFAULT_WIDTH","DEFAULT_HEIGHT","DEFAULT_FPS","DEFAULT_DURATION","DEFAULT_OUT_DIR","z","makeCLI","program","app","eq","key"],"mappings":"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","file":"app.cjs","sourcesContent":["// Shim globals in cjs bundle\n// There's a weird bug that esbuild will always inject importMetaUrl\n// if we export it as `const importMetaUrl = ... __filename ...`\n// But using a function will not cause this issue\n\nconst getImportMetaUrl = () => \n  typeof document === \"undefined\" \n    ? new URL(`file:${__filename}`).href \n    : (document.currentScript && document.currentScript.tagName.toUpperCase() === 'SCRIPT') \n      ? document.currentScript.src \n      : new URL(\"main.js\", document.baseURI).href;\n\nexport const importMetaUrl = /* @__PURE__ */ getImportMetaUrl()\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nimport { dirname } from \"path\";\nimport { fileURLToPath } from \"url\";\n\nexport const basedir = dirname(fileURLToPath(import.meta.url));\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/25.\n\nexport type EnvParser<T> = (value: unknown) => T;\n\nexport function penv<T>(name: string, parser: EnvParser<T>, defaultValue: T): T;\nexport function penv<T>(\n  name: string,\n  parser: EnvParser<T>,\n  defaultValue?: T,\n): T | undefined;\nexport function penv<T>(\n  name: string,\n  parser: EnvParser<T>,\n  defaultValue?: T,\n): 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(value: unknown): number {\n  if (typeof value === \"number\") {\n    return value;\n  }\n  const num = Number(value);\n  if (Number.isNaN(num)) {\n    throw new Error(`Value ${value} is not a valid number`);\n  }\n  return num;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { existsSync } from \"fs\";\nimport { join } from \"path\";\nimport { basedir } from \"./basedir\";\nimport { penv } from \"./env\";\nimport { parseNumber } from \"./parser\";\n\nconst pupAppSearchPaths = [\n  join(basedir, \"cjs/app.cjs\"), // process from dist\n  join(basedir, \"app.cjs\"), // process from dist/cjs\n  join(basedir, \"../../cjs/app.cjs\"), // process from src\n];\nexport const pupAppPath = pupAppSearchPaths.find(existsSync)!;\n\nconst env = process.env;\nexport const pupLogLevel = penv(\"PUP_LOG_LEVEL\", parseNumber, 2);\nexport const pupUseInnerProxy = env[\"PUP_USE_INNER_PROXY\"] === \"1\";\nexport const pupFFmpegPath = env[\"FFMPEG_BIN\"] ?? `ffmpeg`;\nexport const pupDisableGPU = env[\"PUP_DISABLE_GPU\"] === \"1\";\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport { ChildProcess, type Serializable } from \"child_process\";\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\nclass Logger implements LoggerLike {\n  private _impl?: LoggerLike;\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    this._impl = {\n      debug: pupLogLevel >= 3 ? debug : undefined,\n      info: pupLogLevel >= 2 ? info : undefined,\n      warn: pupLogLevel >= 1 ? warn : undefined,\n      error: pupLogLevel >= 0 ? error : undefined,\n    };\n  }\n\n  constructor() {\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    if (message.startsWith(DEBUG)) {\n      this.debug(message.slice(DEBUG.length + 1));\n    } else if (message.startsWith(INFO)) {\n      this.info(message.slice(INFO.length + 1));\n    } else if (message.startsWith(WARN)) {\n      this.warn(message.slice(WARN.length + 1));\n    } else if (message.startsWith(ERROR)) {\n      this.error(message.slice(ERROR.length + 1));\n    } else {\n      this.info(message);\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\nexport { logger };\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { graphics } from \"systeminformation\";\nimport { logger } from \"./logging\";\n\nconst TAG = \"[HWAccel]\";\n\nasync function detect() {\n  const { controllers } = await graphics();\n  return controllers.some((c) => c.vendor.length);\n}\n\nexport const hasGpu = detect().then((gpu) => {\n  logger.debug(TAG, \"GPU detected:\", gpu);\n  return gpu;\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/25.\n\nimport electron, { type Size } from \"electron\";\nimport { platform } from \"process\";\nimport { pupDisableGPU } from \"./constants\";\nimport { hasGpu } from \"./hwaccel\";\nimport { logger } from \"./logging\";\nimport { exec, PUP_ARGS_KEY } from \"./process\";\n\nexport async function electronOpts() {\n  const opts = [\n    \"no-sandbox\",\n    \"disable-setuid-sandbox\",\n    \"disable-dev-shm-usage\",\n    \"disable-web-security\",\n    \"disable-site-isolation-trials\",\n    \"disable-features=IsolateOrigins,site-per-process\",\n    \"allow-insecure-localhost\",\n    \"ignore-certificate-errors\",\n    \"disable-blink-features=AutomationControlled\",\n    \"mute-audio\", // do not leak audio on capture\n    \"autoplay-policy=no-user-gesture-required\",\n    \"disable-extensions\",\n    \"disable-background-networking\",\n    \"address-family=ipv4\",\n    \"disable-async-dns\",\n    \"force-device-scale-factor=1\",\n    \"trace-warnings\",\n    \"force-color-profile=srgb\",\n    \"disable-color-correct-rendering\",\n    \"log-level=3\",\n    \"ignore-gpu-blocklist\",\n    \"gpu-shader-disk-cache-size-kb=524288\",\n  ];\n  const enableGpu = (await hasGpu) && !pupDisableGPU;\n  if (enableGpu) {\n    opts.push(\n      \"in-process-gpu\",\n      \"use-gl=angle\",\n      process.platform === \"darwin\"\n        ? \"use-angle=metal\"\n        : process.platform === \"win32\"\n          ? \"use-angle=d3d11\"\n          : \"use-angle=vulkan\",\n    );\n  } else {\n    opts.push(\n      \"use-gl=angle\",\n      \"use-angle=swiftshader\",\n      \"enable-unsafe-swiftshader\",\n    );\n  }\n  return opts;\n}\n\nexport interface ElectronAppOptions {\n  size: Size;\n  app: unknown;\n  args: unknown[];\n}\n\nconst TAG = \"[Electron]\";\n\nexport async function runElectronApp(options: ElectronAppOptions) {\n  const { size, app, args } = options;\n  const cmdParts = [];\n  if (platform === \"linux\") {\n    cmdParts.push(\n      \"xvfb-run\",\n      \"--auto-servernum\",\n      `--server-args='-screen 0 ${size.width}x${size.height}x24'`,\n    );\n  }\n  const opts = await electronOpts();\n  logger.debug(TAG, \"opts\", opts);\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, app);\n  return exec(cmdParts.join(\" \"), {\n    stdio: [\"ignore\", \"pipe\", \"pipe\"],\n    shell: platform === \"linux\",\n    env: { ...process.env, ELECTRON_DISABLE_DBUS: \"1\", RUST_BACKTRACE: \"full\" },\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/10.\n\nimport { existsSync } from \"fs\";\nimport { join } from \"path\";\nimport { basedir } from \"../base/basedir\";\n\nconst { platform, arch } = process;\n\nconst rustPath = `rust/${platform}-${arch}.node`;\n\nconst nativeSearchPaths = [\n  join(basedir, `../../${rustPath}`), // process start from src\n  join(basedir, `../${rustPath}`), // process start from dist\n];\nconst mod = require(nativeSearchPaths.find(existsSync)!);\n\nexport interface FixedBufferWriter {\n  new (\n    path: string,\n    bufferSize: number,\n    queueDepth?: number,\n  ): FixedBufferWriter;\n\n  write(buffer: Buffer): void;\n\n  close(): Promise<void>;\n}\n\nexport const FixedBufferWriter = mod.FixedBufferWriter as FixedBufferWriter;\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/03/02.\n\nimport { randomUUID } from \"crypto\";\nimport { ipcMain, session } from \"electron\";\nimport { rm, writeFile } from \"fs/promises\";\nimport { tmpdir } from \"os\";\nimport { join } from \"path\";\nimport { FixedBufferWriter } from \"../rust/lib\";\n\nconst AUDIO_CAPTURE_SCRIPT = `\n(function() {\n  if (window.__pup_audio_capturing__) return;\n  window.__pup_audio_capturing__ = true;\n\n  const { ipcRenderer } = require('electron');\n  const capturedContexts = new WeakSet();\n  const sourcedElements = new WeakSet();\n  let metaSent = false;\n\n  const origCreateMES = AudioContext.prototype.createMediaElementSource;\n  AudioContext.prototype.createMediaElementSource = function(el) {\n    sourcedElements.add(el);\n    return origCreateMES.call(this, el);\n  };\n\n  const origConnect = AudioNode.prototype.connect;\n  AudioNode.prototype.connect = function(dest, outIdx, inIdx) {\n    const captureNode = dest?.context?.__pup_captureNode__;\n    if (captureNode && dest === dest.context.destination && this !== captureNode) {\n      origConnect.call(this, captureNode, outIdx, inIdx);\n    }\n    return origConnect.call(this, dest, outIdx, inIdx);\n  };\n\n  const OrigAC = window.AudioContext || window.webkitAudioContext;\n  if (!OrigAC) return;\n\n  function PatchedAC() {\n    const ctx = new OrigAC(...arguments);\n    if (!capturedContexts.has(ctx)) {\n      capturedContexts.add(ctx);\n      if (!metaSent) {\n        metaSent = true;\n        ipcRenderer.send('audio-meta', { sampleRate: ctx.sampleRate });\n      }\n      const node = ctx.createScriptProcessor(4096, 2, 2);\n      node.onaudioprocess = (e) => {\n        const L = e.inputBuffer.getChannelData(0);\n        const R = e.inputBuffer.getChannelData(1);\n        const out = new Float32Array(L.length * 2);\n        for (let i = 0; i < L.length; i++) {\n          out[i * 2] = L[i];\n          out[i * 2 + 1] = R[i];\n        }\n        ipcRenderer.send('audio-chunk', Buffer.from(out.buffer));\n      };\n      node.connect(ctx.destination);\n      ctx.__pup_captureNode__ = node;\n    }\n    return ctx;\n  }\n  PatchedAC.prototype = OrigAC.prototype;\n  Object.setPrototypeOf(PatchedAC, OrigAC);\n  window.AudioContext = PatchedAC;\n  if ('webkitAudioContext' in window) window.webkitAudioContext = PatchedAC;\n\n  const origPlay = HTMLMediaElement.prototype.play;\n  HTMLMediaElement.prototype.play = function() {\n    if (!this.__pup_captured__) {\n      this.__pup_captured__ = true;\n      const el = this;\n      Promise.resolve().then(() => {\n        if (!sourcedElements.has(el)) {\n          const ctx = new PatchedAC();\n          ctx.createMediaElementSource(el).connect(ctx.destination);\n        }\n      });\n    }\n    return origPlay.call(this);\n  };\n})();\n`;\n\nexport interface AudioCapture {\n  sampleRate?: number;\n  teardown(): Promise<void>;\n}\n\nexport async function setupAudioCapture(\n  pcmPath: string,\n): Promise<AudioCapture> {\n  const preloadPath = join(tmpdir(), `pup_audio_preload_${randomUUID()}.js`);\n  await writeFile(preloadPath, AUDIO_CAPTURE_SCRIPT);\n  session.defaultSession.registerPreloadScript({\n    type: \"frame\",\n    id: \"pup-audio\",\n    filePath: preloadPath,\n  });\n\n  const writer = new FixedBufferWriter(pcmPath, 4096 * 2 * 4);\n  const capture: AudioCapture = {\n    sampleRate: undefined,\n    async teardown() {\n      ipcMain.removeAllListeners(\"audio-chunk\");\n      ipcMain.removeAllListeners(\"audio-meta\");\n      await writer.close();\n      session.defaultSession.unregisterPreloadScript(\"pup-audio\");\n      await rm(preloadPath, { force: true });\n    },\n  };\n\n  ipcMain.once(\"audio-meta\", (_e, data: { sampleRate: number }) => {\n    capture.sampleRate = data.sampleRate;\n  });\n  ipcMain.on(\"audio-chunk\", (_e, buffer: Buffer) => {\n    writer.write(buffer);\n  });\n  return capture;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport type { Debugger, Size } from \"electron\";\n\nexport const FRAME_SYNC_MARKER_WIDTH = 32;\nexport const FRAME_SYNC_MARKER_HEIGHT = 1;\n\nexport function buildWrapperHTML(targetURL: string, size: Size): string {\n  const { width, height } = size;\n  return `<!DOCTYPE html>\n<html>\n<head>\n  <meta charset=\"UTF-8\">\n  <style>\n    * { margin: 0; padding: 0; box-sizing: border-box; }\n    html, body { width: ${width}px; height: ${height + 1}px; overflow: hidden; }\n    #target { \n      position: absolute; \n      top: 0; \n      left: 0; \n      width: ${width}px; \n      height: ${height}px; \n      border: none; \n      display: block;\n    }\n    #stego { \n      position: absolute; \n      top: ${height}px; \n      left: 0; \n      width: ${width}px; \n      height: 1px; \n      display: block;\n      image-rendering: pixelated;\n    }\n  </style>\n</head>\n<body>\n  <iframe id=\"target\" src=\"${targetURL}\"></iframe>\n  <canvas id=\"stego\" width=\"${width}\" height=\"1\"></canvas>\n  <script>\n    (function() {\n      const WIDTH = ${width};\n      const MARKER_WIDTH = ${FRAME_SYNC_MARKER_WIDTH};\n      const canvas = document.getElementById('stego');\n      const ctx = canvas.getContext('2d', { willReadFrequently: true });\n      let startTime = null;\n      let rafId = null;\n\n      function encodeTimestamp(timestampMs) {\n        const imageData = ctx.createImageData(WIDTH, 1);\n        const data = imageData.data;\n        \n        const timestampInt = Math.floor(timestampMs) >>> 0;\n        \n        for (let i = 0; i < MARKER_WIDTH; i++) {\n          const bit = (timestampInt >>> (MARKER_WIDTH - 1 - i)) & 1;\n          const value = bit ? 255 : 0;\n          const idx = i * 4;\n          data[idx] = value;\n          data[idx + 1] = value;\n          data[idx + 2] = value;\n          data[idx + 3] = 255;\n        }\n        \n        for (let i = MARKER_WIDTH; i < WIDTH; i++) {\n          const idx = i * 4;\n          data[idx] = 0;\n          data[idx + 1] = 0;\n          data[idx + 2] = 0;\n          data[idx + 3] = 255;\n        }\n        \n        ctx.putImageData(imageData, 0, 0);\n      }\n\n      function updateLoop() {\n        if (startTime === null) return;\n        const elapsed = performance.now() - startTime;\n        encodeTimestamp(elapsed);\n        rafId = requestAnimationFrame(updateLoop);\n      }\n\n      window.__pup_start_recording__ = () => {\n        startTime = performance.now();\n        encodeTimestamp(0);\n        requestAnimationFrame(updateLoop);\n      };\n\n      window.__pup_stop_recording__ = () => {\n        if (rafId !== null) {\n          cancelAnimationFrame(rafId);\n          rafId = null;\n        }\n      };\n    })();\n  </script>\n</body>\n</html>`;\n}\n\nexport function decodeTimestamp(\n  bitmap: Buffer,\n  size: Size,\n): number | undefined {\n  const { width, height } = size;\n  if (width < FRAME_SYNC_MARKER_WIDTH || height < 2) {\n    return undefined;\n  }\n\n  const markerRow = height - 1;\n\n  let timestamp = 0;\n  for (let i = 0; i < FRAME_SYNC_MARKER_WIDTH; i++) {\n    const pixelIdx = (markerRow * width + i) * 4;\n    const r = bitmap[pixelIdx] ?? 0;\n    const bit = r > 127 ? 1 : 0;\n    timestamp = (timestamp << 1) | bit;\n  }\n\n  timestamp = timestamp >>> 0;\n\n  if (!Number.isFinite(timestamp) || timestamp < 0 || timestamp > 1e7) {\n    return undefined;\n  }\n\n  return timestamp;\n}\n\nexport function startSync(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_start_recording__()`,\n  });\n}\n\nexport function stopSync(cdp: Debugger) {\n  return cdp.sendCommand(\"Runtime.evaluate\", {\n    expression: `window.__pup_stop_recording__()`,\n  });\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/06.\n\nimport type { NativeImage } from \"electron\";\n\nexport function isEmpty(image: NativeImage) {\n  const size = image.getSize();\n  if (size.width === 0 || size.height === 0) return true;\n  return image.isEmpty();\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nconst SUPPORTED_PROTOCOLS = [\"file:\", \"http:\", \"https:\", \"data:\"];\nconst SOURCE_PATTERN = /^(file:|https?:|data:)/;\n\nexport function checkHTML(source: string): void {\n  if (SOURCE_PATTERN.test(source)) {\n    return;\n  }\n\n  const protocol = source.split(\":\")[0] + \":\";\n  const message = SUPPORTED_PROTOCOLS.includes(protocol)\n    ? `unsupported protocol: ${protocol}, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`\n    : `invalid source format, expected ${SUPPORTED_PROTOCOLS.join(\", \")}`;\n\n  throw new Error(message);\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { session } from \"electron\";\nimport { URL } from \"url\";\nimport { logger } from \"./logging\";\n\nconst TAG = \"[Proxy]\";\n\nconst map = new Map([\n  [`jssz-boss.hdslb.com`, `jssz-boss.bilibili.co`], //\n  [`boss.hdslb.com`, `shjd-boss.bilibili.co`],\n]);\n\nexport function proxiedUrl(url: string) {\n  if (!url.startsWith(\"http\")) {\n    return url;\n  }\n  const parsed = new URL(url);\n  const target = map.get(parsed.hostname);\n  if (!target) {\n    return url;\n  }\n  parsed.hostname = target;\n  parsed.protocol = \"http:\";\n  return parsed.toString();\n}\n\nexport function enableProxy() {\n  session.defaultSession.webRequest.onBeforeRequest((details, callback) => {\n    const url = details.url;\n    const proxied = proxiedUrl(url);\n    if (proxied === url) {\n      return callback({ cancel: false });\n    } else {\n      logger.debug(TAG, `${url} -> ${proxied}`);\n      callback({ cancel: false, redirectURL: proxied });\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(\n  callback: (count: number) => Promise<void> | void,\n  ms: number,\n) {\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>({\n  fn,\n  maxAttempts = 3,\n  timeout,\n}: RetryOptions<Args, Ret>) {\n  const timeoutError = new Error(`timeout over ${timeout}ms`);\n  return async function (...args: Args) {\n    let attempt = 0;\n    while (true) {\n      try {\n        const promises = [fn(...args)];\n        if (timeout) {\n          promises.push(\n            setTimeout(timeout).then(() => {\n              throw timeoutError;\n            }),\n          );\n        }\n        return await Promise.race(promises);\n      } catch (e) {\n        attempt++;\n        if (attempt >= maxAttempts) {\n          throw e;\n        }\n        await sleep(Math.pow(2, attempt) * 100 + Math.random() * 100);\n      }\n    }\n  };\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/27.\n\nimport { BrowserWindow, session } from \"electron\";\nimport { buildWrapperHTML } from \"./frame_sync\";\nimport { checkHTML } from \"./html_check\";\nimport { logger } from \"./logging\";\nimport { enableProxy, proxiedUrl } from \"./proxy\";\nimport { useRetry } from \"./retry\";\nimport type { RecordOptions } from \"./schema\";\n\nconst TAG = \"[Window]\";\n\nfunction waitForFinish(win: BrowserWindow, action: () => void) {\n  return new Promise<void>((resolve, reject) => {\n    const timeout = setTimeout(\n      () => reject(new Error(\"load window timeout\")),\n      20_000,\n    );\n    const done = (err?: Error) => {\n      clearTimeout(timeout);\n      err ? reject(err) : resolve();\n    };\n    win.webContents.once(\"did-finish-load\", () => done());\n    win.webContents.once(\"did-fail-load\", (_e, code, desc, url) =>\n      done(new Error(`failed to load ${url}: [${code}] ${desc}`)),\n    );\n    win.webContents.once(\"render-process-gone\", (_e, { exitCode, reason }) =>\n      done(new Error(`renderer crashed: ${exitCode}, ${reason}`)),\n    );\n    action();\n  });\n}\n\nasync function openWindow(\n  wins: BrowserWindow[],\n  source: string,\n  options: RecordOptions,\n): Promise<BrowserWindow> {\n  checkHTML(source);\n\n  const { width, height, useInnerProxy } = options;\n\n  session.defaultSession.webRequest.onHeadersReceived(\n    ({ responseHeaders }, callback) => {\n      delete responseHeaders?.[\"x-frame-options\"];\n      delete responseHeaders?.[\"X-Frame-Options\"];\n      delete responseHeaders?.[\"content-security-policy\"];\n      delete responseHeaders?.[\"Content-Security-Policy\"];\n      callback({ cancel: false, responseHeaders });\n    },\n  );\n\n  let src = source;\n  if (useInnerProxy) {\n    src = proxiedUrl(source);\n    enableProxy();\n  }\n\n  const win = new BrowserWindow({\n    width,\n    height: height + 1,\n    show: false,\n    transparent: true,\n    backgroundColor: undefined,\n    webPreferences: {\n      offscreen: true,\n      backgroundThrottling: false,\n      nodeIntegration: true,\n      nodeIntegrationInSubFrames: true,\n      contextIsolation: false,\n      webSecurity: false,\n      allowRunningInsecureContent: true,\n      experimentalFeatures: true,\n    },\n  });\n  wins.splice(0).forEach((w) => w.destroy());\n  wins.push(win);\n\n  win.webContents.on(\"console-message\", ({ level, message }) => {\n    if (level === \"error\") logger.error(TAG, \"console:\", message);\n  });\n\n  const wrapperHTML = buildWrapperHTML(src, { width, height });\n  const dataURL = `data:text/html;charset=utf-8,${encodeURIComponent(wrapperHTML)}`;\n  await waitForFinish(win, () => win.loadURL(dataURL));\n\n  return win;\n}\n\nexport async function loadWindow(\n  source: string,\n  options: RecordOptions,\n): Promise<BrowserWindow> {\n  const wins: BrowserWindow[] = [];\n  const win = await useRetry({ fn: openWindow, maxAttempts: 2 })(\n    wins,\n    source,\n    options,\n  );\n  await waitForFinish(win, () => win.reload());\n  return win;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { type NativeImage } from \"electron\";\nimport { mkdir, writeFile } from \"fs/promises\";\nimport { join } from \"path\";\nimport { FixedBufferWriter } from \"../rust/lib\";\nimport { setupAudioCapture } from \"./audio_capture\";\nimport { decodeTimestamp, startSync, stopSync } from \"./frame_sync\";\nimport { isEmpty } from \"./image\";\nimport { logger } from \"./logging\";\nimport type { RecordOptions, RecordResult } from \"./schema\";\nimport { loadWindow } from \"./window\";\n\nconst TAG = \"[Record]\";\n\nexport async function record(\n  source: string,\n  options: RecordOptions,\n): Promise<void> {\n  logger.info(TAG, `progress: 0%`);\n  const { outDir, fps, width, height, duration, withAudio } = options;\n\n  await mkdir(outDir, { recursive: true });\n\n  const pcmPath = join(outDir, \"output.pcm\");\n  const audioCapture = withAudio ? await setupAudioCapture(pcmPath) : undefined;\n\n  const win = await loadWindow(source, options);\n\n  const cdp = win.webContents.debugger;\n  cdp.attach(\"1.3\");\n\n  win.webContents.setFrameRate(fps);\n  if (!win.webContents.isPainting()) {\n    win.webContents.startPainting();\n  }\n\n  const bgra = join(outDir, \"output.bgra\");\n  const total = Math.ceil(fps * duration);\n  const frameInterval = 1000 / fps;\n  const bufferSize = width * height * 4;\n\n  const writer = new FixedBufferWriter(bgra, bufferSize, fps);\n\n  let written = 0;\n  let lastWrittenTime: number | undefined;\n  let progress = 0;\n  let frameError: Error | undefined;\n  let resolver: (() => void) | undefined;\n  let rejecter: ((reason?: unknown) => void) | undefined;\n\n  const scheduleWrite = (buffer: Buffer) => {\n    written++;\n    try {\n      writer.write(buffer);\n    } catch (error) {\n      frameError ??= error as Error;\n    }\n  };\n\n  const paint = (_e: unknown, _r: unknown, image: NativeImage) => {\n    if (frameError) {\n      rejecter?.(frameError);\n      return;\n    }\n\n    if (written >= total) {\n      resolver?.();\n      return;\n    }\n\n    if (isEmpty(image)) return;\n\n    const bitmap = image.toBitmap();\n    const currentTime = decodeTimestamp(bitmap, image.getSize());\n    if (currentTime === undefined) {\n      frameError ??= new Error(`no timestamp @ ${written}`);\n      return;\n    }\n\n    const bytesPerRow = width * 4;\n    const cropped = bitmap.subarray(0, height * bytesPerRow);\n\n    if (lastWrittenTime === undefined) {\n      scheduleWrite(cropped);\n      lastWrittenTime = currentTime;\n      return;\n    }\n\n    const timeSinceLastFrame = currentTime - lastWrittenTime;\n    if (timeSinceLastFrame < frameInterval * 0.8) {\n      return;\n    }\n\n    if (timeSinceLastFrame <= frameInterval * 1.2) {\n      scheduleWrite(cropped);\n    } else {\n      const framesToInsert = Math.round(timeSinceLastFrame / frameInterval);\n      for (let i = 0; i < framesToInsert && written < total; i++) {\n        scheduleWrite(cropped);\n      }\n    }\n    lastWrittenTime = currentTime;\n\n    const newProgress = Math.floor((written / total) * 100);\n    if (Math.abs(newProgress - progress) > 10) {\n      progress = newProgress;\n      logger.info(TAG, `progress: ${Math.round(progress)}%`);\n    }\n  };\n\n  win.webContents.on(\"paint\", paint);\n  await startSync(cdp);\n  try {\n    await new Promise<void>((r, j) => ([resolver, rejecter] = [r, j]));\n  } finally {\n    await stopSync(cdp);\n    win.webContents.off(\"paint\", paint);\n    await writer.close();\n    await audioCapture?.teardown();\n  }\n\n  if (frameError || written === 0) {\n    throw frameError ?? new Error(\"no frames captured\");\n  }\n\n  try {\n    const audio = audioCapture?.sampleRate\n      ? { pcmPath, sampleRate: audioCapture.sampleRate }\n      : undefined;\n    const result: RecordResult = { options, written, bgra, audio };\n    await writeFile(join(outDir, \"record.json\"), JSON.stringify(result));\n    logger.info(TAG, `progress: 100%, ${written} frames written`);\n  } finally {\n    win.close();\n  }\n}\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/02/06.\n\nimport type { Size } from \"electron\";\nimport z from \"zod\";\n\nexport interface VideoSpec {\n  fps: number;\n  frames: number;\n  size: Size;\n}\n\nexport interface VideoFiles {\n  mp4?: string;\n  webm?: string;\n  mov?: string;\n}\n\nexport interface VideoFilesWithCover extends VideoFiles {\n  cover: string;\n}\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_DIR = \"out\";\n\nexport const RecordSchema = z.object({\n  duration: z\n    .number()\n    .optional()\n    .default(DEFAULT_DURATION)\n    .describe(\"Recording duration in seconds\"),\n  width: z.number().optional().default(DEFAULT_WIDTH).describe(\"Video width\"),\n  height: z\n    .number()\n    .optional()\n    .default(DEFAULT_HEIGHT)\n    .describe(\"Video height\"),\n  fps: z.number().optional().default(DEFAULT_FPS).describe(\"Frames per second\"),\n  withAlphaChannel: z\n    .boolean()\n    .optional()\n    .default(false)\n    .describe(\"Output with alpha channel\"),\n  withAudio: z\n    .boolean()\n    .optional()\n    .default(false)\n    .describe(\"Capture and encode audio\"),\n  outDir: z\n    .string()\n    .optional()\n    .default(DEFAULT_OUT_DIR)\n    .describe(\"Output directory\"),\n  useInnerProxy: z\n    .boolean()\n    .optional()\n    .default(false)\n    .describe(\"Use bilibili inner proxy for resource access\"),\n});\n\nexport interface RecordOptions {\n  duration: number;\n  width: number;\n  height: number;\n  fps: number;\n  withAlphaChannel: boolean;\n  withAudio: boolean;\n  outDir: string;\n  useInnerProxy: boolean;\n}\n\nexport interface AudioSpec {\n  pcmPath: string;\n  sampleRate: number;\n}\n\nexport interface RecordResult {\n  options: RecordOptions;\n  written: number;\n  bgra: string;\n  audio?: AudioSpec;\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/02/09.\n\nimport { program } from \"commander\";\nimport { pupUseInnerProxy } from \"./base/constants\";\nimport { logger } from \"./base/logging\";\nimport { noerr } from \"./base/noerr\";\nimport { parseNumber } from \"./base/parser\";\nimport { pargs } from \"./base/process\";\nimport {\n  DEFAULT_DURATION,\n  DEFAULT_FPS,\n  DEFAULT_HEIGHT,\n  DEFAULT_OUT_DIR,\n  DEFAULT_WIDTH,\n  type RecordOptions,\n} from \"./base/schema\";\n\nexport type CLICallback = (\n  source: string,\n  options: RecordOptions,\n) => Promise<unknown>;\n\nexport function makeCLI(name: string, callback: CLICallback) {\n  program\n    .name(name)\n    .argument(\"<source>\", \"file://, http(s)://, 或 data: URI\")\n    .option(\"-w, --width <number>\", \"视频宽度\", `${DEFAULT_WIDTH}`)\n    .option(\"-h, --height <number>\", \"视频高度\", `${DEFAULT_HEIGHT}`)\n    .option(\"-f, --fps <number>\", \"帧率\", `${DEFAULT_FPS}`)\n    .option(\"-t, --duration <number>\", \"录制时长（秒）\", `${DEFAULT_DURATION}`)\n    .option(\"-o, --out-dir <path>\", \"输出目录\", `${DEFAULT_OUT_DIR}`)\n    .option(\"-a, --with-alpha-channel\", \"输出包含 alpha 通道的视频\", false)\n    .option(\"-s, --with-audio\", \"捕获并混入音频\", false)\n    .option(\n      \"--use-inner-proxy\",\n      \"使用 B 站内网代理加速资源访问\",\n      pupUseInnerProxy,\n    )\n    .action(async (source: string, opts) => {\n      try {\n        await callback(source, {\n          width: noerr(parseNumber, DEFAULT_WIDTH)(opts.width),\n          height: noerr(parseNumber, DEFAULT_HEIGHT)(opts.height),\n          fps: noerr(parseNumber, DEFAULT_FPS)(opts.fps),\n          duration: noerr(parseNumber, DEFAULT_DURATION)(opts.duration),\n          outDir: opts.outDir ?? DEFAULT_OUT_DIR,\n          withAlphaChannel: opts.withAlphaChannel ?? false,\n          withAudio: opts.withAudio ?? false,\n          useInnerProxy: opts.useInnerProxy ?? pupUseInnerProxy,\n        });\n      } catch (e) {\n        logger.fatal(e);\n      }\n    });\n  program.parse(pargs());\n}\n","// Created by Autokaka (qq1909698494@gmail.com) on 2026/01/30.\n\nimport { app } from \"electron\";\nimport { electronOpts } from \"./base/electron\";\nimport { record } from \"./base/record\";\nimport { makeCLI } from \"./common\";\n\nprocess.once(\"exit\", () => app.quit());\n\nmakeCLI(\"app\", async (source, options) => {\n  try {\n    const opts = await electronOpts();\n    opts.forEach((o) => {\n      const eq = o.indexOf(\"=\");\n      if (eq < 0) {\n        app.commandLine.appendSwitch(o);\n      } else {\n        const key = o.slice(0, eq);\n        const value = o.slice(eq + 1);\n        app.commandLine.appendSwitch(key, value);\n      }\n    });\n    app.dock?.hide();\n    await app.whenReady();\n    await record(source, options);\n  } finally {\n    app.quit();\n  }\n});\n"]}