@neoanaloglabkk/lensfun-wasm 0.1.1
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/LICENSE +21 -0
- package/NOTICE.md +10 -0
- package/README.ja.md +318 -0
- package/README.md +320 -0
- package/README.zh-CN.md +318 -0
- package/THIRD_PARTY_LICENSES.md +20 -0
- package/UPSTREAM.md +23 -0
- package/dist/assets/lensfun-core.data +65868 -0
- package/dist/assets/lensfun-core.js +2 -0
- package/dist/assets/lensfun-core.wasm +0 -0
- package/dist/esm/index.js +290 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/types/src/index.d.ts +104 -0
- package/dist/types/src/index.d.ts.map +1 -0
- package/dist/types/tests/api-shape.test.d.ts +2 -0
- package/dist/types/tests/api-shape.test.d.ts.map +1 -0
- package/dist/umd/index.iife.js +313 -0
- package/dist/umd/index.iife.js.map +1 -0
- package/native/CMakeLists.txt +90 -0
- package/native/include/glib/gstdio.h +6 -0
- package/native/include/glib.h +215 -0
- package/native/include/lensfun_wasm_bridge.h +24 -0
- package/native/src/cpuid_stub.cpp +8 -0
- package/native/src/entrypoint.cpp +4 -0
- package/native/src/glib_compat.cpp +799 -0
- package/native/src/lensfun_wasm_bridge.cpp +487 -0
- package/package.json +54 -0
- package/scripts/build-wasm.sh +31 -0
- package/scripts/sync-upstream.sh +25 -0
- package/scripts/verify-release-tag.mjs +41 -0
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var createLensfunCoreModule=(()=>{var _scriptName=globalThis.document?.currentScript?.src;return async function(moduleArg={}){var moduleRtn;var Module=moduleArg;var ENVIRONMENT_IS_WEB=!!globalThis.window;var ENVIRONMENT_IS_WORKER=!!globalThis.WorkerGlobalScope;var ENVIRONMENT_IS_NODE=globalThis.process?.versions?.node&&globalThis.process?.type!="renderer";if(!Module["expectedDataFileDownloads"])Module["expectedDataFileDownloads"]=0;Module["expectedDataFileDownloads"]++;(()=>{var isPthread=typeof ENVIRONMENT_IS_PTHREAD!="undefined"&&ENVIRONMENT_IS_PTHREAD;var isWasmWorker=typeof ENVIRONMENT_IS_WASM_WORKER!="undefined"&&ENVIRONMENT_IS_WASM_WORKER;if(isPthread||isWasmWorker)return;async function loadPackage(metadata){var PACKAGE_PATH="";if(typeof window==="object"){PACKAGE_PATH=window["encodeURIComponent"](window.location.pathname.substring(0,window.location.pathname.lastIndexOf("/"))+"/")}else if(typeof process==="undefined"&&typeof location!=="undefined"){PACKAGE_PATH=encodeURIComponent(location.pathname.substring(0,location.pathname.lastIndexOf("/"))+"/")}var PACKAGE_NAME="lensfun-core.data";var REMOTE_PACKAGE_BASE="lensfun-core.data";var REMOTE_PACKAGE_NAME=Module["locateFile"]?Module["locateFile"](REMOTE_PACKAGE_BASE,""):REMOTE_PACKAGE_BASE;var REMOTE_PACKAGE_SIZE=metadata["remote_package_size"];async function fetchRemotePackage(packageName,packageSize){if(!Module["dataFileDownloads"])Module["dataFileDownloads"]={};try{var response=await fetch(packageName)}catch(e){throw new Error(`Network Error: ${packageName}`,{e})}if(!response.ok){throw new Error(`${response.status}: ${response.url}`)}const chunks=[];const headers=response.headers;const total=Number(headers.get("Content-Length")||packageSize);let loaded=0;Module["setStatus"]&&Module["setStatus"]("Downloading data...");const reader=response.body.getReader();while(1){var{done,value}=await reader.read();if(done)break;chunks.push(value);loaded+=value.length;Module["dataFileDownloads"][packageName]={loaded,total};let totalLoaded=0;let totalSize=0;for(const download of Object.values(Module["dataFileDownloads"])){totalLoaded+=download.loaded;totalSize+=download.total}Module["setStatus"]&&Module["setStatus"](`Downloading data... (${totalLoaded}/${totalSize})`)}const packageData=new Uint8Array(chunks.map(c=>c.length).reduce((a,b)=>a+b,0));let offset=0;for(const chunk of chunks){packageData.set(chunk,offset);offset+=chunk.length}return packageData.buffer}var fetchPromise;var fetched=Module["getPreloadedPackage"]&&Module["getPreloadedPackage"](REMOTE_PACKAGE_NAME,REMOTE_PACKAGE_SIZE);if(!fetched){fetchPromise=fetchRemotePackage(REMOTE_PACKAGE_NAME,REMOTE_PACKAGE_SIZE)}async function runWithFS(Module){function assert(check,msg){if(!check)throw new Error(msg)}Module["FS_createPath"]("/","lensfun-db",true,true);for(var file of metadata["files"]){var name=file["filename"];Module["addRunDependency"](`fp ${name}`)}async function processPackageData(arrayBuffer){assert(arrayBuffer,"Loading data file failed.");assert(arrayBuffer.constructor.name===ArrayBuffer.name,"bad input to processPackageData "+arrayBuffer.constructor.name);var byteArray=new Uint8Array(arrayBuffer);for(var file of metadata["files"]){var name=file["filename"];var data=byteArray.subarray(file["start"],file["end"]);Module["FS_createDataFile"](name,null,data,true,true,true);Module["removeRunDependency"](`fp ${name}`)}Module["removeRunDependency"]("datafile_lensfun-core.data")}Module["addRunDependency"]("datafile_lensfun-core.data");if(!Module["preloadResults"])Module["preloadResults"]={};Module["preloadResults"][PACKAGE_NAME]={fromCache:false};if(!fetched){fetched=await fetchPromise}processPackageData(fetched)}if(Module["calledRun"]){runWithFS(Module)}else{if(!Module["preRun"])Module["preRun"]=[];Module["preRun"].push(runWithFS)}}loadPackage({files:[{filename:"/lensfun-db/6x6.xml",start:0,end:29550},{filename:"/lensfun-db/actioncams.xml",start:29550,end:46738},{filename:"/lensfun-db/compact-canon.xml",start:46738,end:293556},{filename:"/lensfun-db/compact-casio.xml",start:293556,end:300445},{filename:"/lensfun-db/compact-fujifilm.xml",start:300445,end:368399},{filename:"/lensfun-db/compact-kodak.xml",start:368399,end:370490},{filename:"/lensfun-db/compact-konica-minolta.xml",start:370490,end:383839},{filename:"/lensfun-db/compact-leica.xml",start:383839,end:392021},{filename:"/lensfun-db/compact-nikon.xml",start:392021,end:432024},{filename:"/lensfun-db/compact-olympus.xml",start:432024,end:466478},{filename:"/lensfun-db/compact-panasonic.xml",start:466478,end:527373},{filename:"/lensfun-db/compact-pentax.xml",start:527373,end:534062},{filename:"/lensfun-db/compact-ricoh.xml",start:534062,end:551316},{filename:"/lensfun-db/compact-samsung.xml",start:551316,end:565191},{filename:"/lensfun-db/compact-sigma.xml",start:565191,end:567586},{filename:"/lensfun-db/compact-sony.xml",start:567586,end:693661},{filename:"/lensfun-db/contax.xml",start:693661,end:695357},{filename:"/lensfun-db/generic.xml",start:695357,end:700773},{filename:"/lensfun-db/lensfun-database.dtd",start:700773,end:703196},{filename:"/lensfun-db/lensfun-database.xsd",start:703196,end:709391},{filename:"/lensfun-db/mil-canon.xml",start:709391,end:955707},{filename:"/lensfun-db/mil-fujifilm.xml",start:955707,end:1165257},{filename:"/lensfun-db/mil-hasselblad.xml",start:1165257,end:1166305},{filename:"/lensfun-db/mil-leica.xml",start:1166305,end:1177722},{filename:"/lensfun-db/mil-nikon.xml",start:1177722,end:1345310},{filename:"/lensfun-db/mil-olympus.xml",start:1345310,end:1492433},{filename:"/lensfun-db/mil-panasonic.xml",start:1492433,end:1791237},{filename:"/lensfun-db/mil-pentax.xml",start:1791237,end:1792622},{filename:"/lensfun-db/mil-samsung.xml",start:1792622,end:1805629},{filename:"/lensfun-db/mil-samyang.xml",start:1805629,end:1830923},{filename:"/lensfun-db/mil-sigma.xml",start:1830923,end:1940321},{filename:"/lensfun-db/mil-sony.xml",start:1940321,end:2212927},{filename:"/lensfun-db/mil-tamron.xml",start:2212927,end:2299085},{filename:"/lensfun-db/mil-tokina.xml",start:2299085,end:2300099},{filename:"/lensfun-db/mil-zeiss.xml",start:2300099,end:2319270},{filename:"/lensfun-db/misc.xml",start:2319270,end:2486554},{filename:"/lensfun-db/om-system.xml",start:2486554,end:2510852},{filename:"/lensfun-db/rf-leica.xml",start:2510852,end:2517564},{filename:"/lensfun-db/slr-canon.xml",start:2517564,end:3297917},{filename:"/lensfun-db/slr-hasselblad.xml",start:3297917,end:3298559},{filename:"/lensfun-db/slr-konica-minolta.xml",start:3298559,end:3345223},{filename:"/lensfun-db/slr-leica.xml",start:3345223,end:3345655},{filename:"/lensfun-db/slr-nikon.xml",start:3345655,end:3888148},{filename:"/lensfun-db/slr-olympus.xml",start:3888148,end:4004750},{filename:"/lensfun-db/slr-panasonic.xml",start:4004750,end:4005169},{filename:"/lensfun-db/slr-pentax.xml",start:4005169,end:4210033},{filename:"/lensfun-db/slr-ricoh.xml",start:4210033,end:4212902},{filename:"/lensfun-db/slr-samsung.xml",start:4212902,end:4214012},{filename:"/lensfun-db/slr-samyang.xml",start:4214012,end:4230823},{filename:"/lensfun-db/slr-schneider.xml",start:4230823,end:4236713},{filename:"/lensfun-db/slr-sigma.xml",start:4236713,end:4667556},{filename:"/lensfun-db/slr-soligor.xml",start:4667556,end:4668129},{filename:"/lensfun-db/slr-sony.xml",start:4668129,end:4756994},{filename:"/lensfun-db/slr-tamron.xml",start:4756994,end:4954663},{filename:"/lensfun-db/slr-tokina.xml",start:4954663,end:5040890},{filename:"/lensfun-db/slr-ussr.xml",start:5040890,end:5059914},{filename:"/lensfun-db/slr-vivitar.xml",start:5059914,end:5062071},{filename:"/lensfun-db/slr-zeiss.xml",start:5062071,end:5077028},{filename:"/lensfun-db/timestamp.txt",start:5077028,end:5077039}],remote_package_size:5077039})})();var arguments_=[];var thisProgram="./this.program";if(ENVIRONMENT_IS_WORKER){_scriptName=self.location.href}var scriptDirectory="";function locateFile(path){if(Module["locateFile"]){return Module["locateFile"](path,scriptDirectory)}return scriptDirectory+path}var readAsync,readBinary;if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){try{scriptDirectory=new URL(".",_scriptName).href}catch{}{if(ENVIRONMENT_IS_WORKER){readBinary=url=>{var xhr=new XMLHttpRequest;xhr.open("GET",url,false);xhr.responseType="arraybuffer";xhr.send(null);return new Uint8Array(xhr.response)}}readAsync=async url=>{var response=await fetch(url,{credentials:"same-origin"});if(response.ok){return response.arrayBuffer()}throw new Error(response.status+" : "+response.url)}}}else{}var out=console.log.bind(console);var err=console.error.bind(console);var wasmBinary;var ABORT=false;var readyPromiseResolve,readyPromiseReject;var HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;var HEAP64,HEAPU64;var runtimeInitialized=false;function updateMemoryViews(){var b=wasmMemory.buffer;HEAP8=new Int8Array(b);HEAP16=new Int16Array(b);HEAPU8=new Uint8Array(b);HEAPU16=new Uint16Array(b);HEAP32=new Int32Array(b);HEAPU32=new Uint32Array(b);HEAPF32=new Float32Array(b);HEAPF64=new Float64Array(b);HEAP64=new BigInt64Array(b);HEAPU64=new BigUint64Array(b)}function preRun(){if(Module["preRun"]){if(typeof Module["preRun"]=="function")Module["preRun"]=[Module["preRun"]];while(Module["preRun"].length){addOnPreRun(Module["preRun"].shift())}}callRuntimeCallbacks(onPreRuns)}function initRuntime(){runtimeInitialized=true;if(!Module["noFSInit"]&&!FS.initialized)FS.init();TTY.init();wasmExports["p"]();FS.ignorePermissions=false}function postRun(){if(Module["postRun"]){if(typeof Module["postRun"]=="function")Module["postRun"]=[Module["postRun"]];while(Module["postRun"].length){addOnPostRun(Module["postRun"].shift())}}callRuntimeCallbacks(onPostRuns)}function abort(what){Module["onAbort"]?.(what);what="Aborted("+what+")";err(what);ABORT=true;what+=". Build with -sASSERTIONS for more info.";var e=new WebAssembly.RuntimeError(what);readyPromiseReject?.(e);throw e}var wasmBinaryFile;function findWasmBinary(){return locateFile("lensfun-core.wasm")}function getBinarySync(file){if(file==wasmBinaryFile&&wasmBinary){return new Uint8Array(wasmBinary)}if(readBinary){return readBinary(file)}throw"both async and sync fetching of the wasm failed"}async function getWasmBinary(binaryFile){if(!wasmBinary){try{var response=await readAsync(binaryFile);return new Uint8Array(response)}catch{}}return getBinarySync(binaryFile)}async function instantiateArrayBuffer(binaryFile,imports){try{var binary=await getWasmBinary(binaryFile);var instance=await WebAssembly.instantiate(binary,imports);return instance}catch(reason){err(`failed to asynchronously prepare wasm: ${reason}`);abort(reason)}}async function instantiateAsync(binary,binaryFile,imports){if(!binary){try{var response=fetch(binaryFile,{credentials:"same-origin"});var instantiationResult=await WebAssembly.instantiateStreaming(response,imports);return instantiationResult}catch(reason){err(`wasm streaming compile failed: ${reason}`);err("falling back to ArrayBuffer instantiation")}}return instantiateArrayBuffer(binaryFile,imports)}function getWasmImports(){var imports={a:wasmImports};return imports}async function createWasm(){function receiveInstance(instance,module){wasmExports=instance.exports;assignWasmExports(wasmExports);updateMemoryViews();return wasmExports}function receiveInstantiationResult(result){return receiveInstance(result["instance"])}var info=getWasmImports();if(Module["instantiateWasm"]){return new Promise((resolve,reject)=>{Module["instantiateWasm"](info,(inst,mod)=>{resolve(receiveInstance(inst,mod))})})}wasmBinaryFile??=findWasmBinary();var result=await instantiateAsync(wasmBinary,wasmBinaryFile,info);var exports=receiveInstantiationResult(result);return exports}class ExitStatus{name="ExitStatus";constructor(status){this.message=`Program terminated with exit(${status})`;this.status=status}}var callRuntimeCallbacks=callbacks=>{while(callbacks.length>0){callbacks.shift()(Module)}};var onPostRuns=[];var addOnPostRun=cb=>onPostRuns.push(cb);var onPreRuns=[];var addOnPreRun=cb=>onPreRuns.push(cb);var noExitRuntime=true;var stackRestore=val=>__emscripten_stack_restore(val);var stackSave=()=>_emscripten_stack_get_current();class ExceptionInfo{constructor(excPtr){this.excPtr=excPtr;this.ptr=excPtr-24}set_type(type){HEAPU32[this.ptr+4>>2]=type}get_type(){return HEAPU32[this.ptr+4>>2]}set_destructor(destructor){HEAPU32[this.ptr+8>>2]=destructor}get_destructor(){return HEAPU32[this.ptr+8>>2]}set_caught(caught){caught=caught?1:0;HEAP8[this.ptr+12]=caught}get_caught(){return HEAP8[this.ptr+12]!=0}set_rethrown(rethrown){rethrown=rethrown?1:0;HEAP8[this.ptr+13]=rethrown}get_rethrown(){return HEAP8[this.ptr+13]!=0}init(type,destructor){this.set_adjusted_ptr(0);this.set_type(type);this.set_destructor(destructor)}set_adjusted_ptr(adjustedPtr){HEAPU32[this.ptr+16>>2]=adjustedPtr}get_adjusted_ptr(){return HEAPU32[this.ptr+16>>2]}}var exceptionLast=0;var uncaughtExceptionCount=0;var ___cxa_throw=(ptr,type,destructor)=>{var info=new ExceptionInfo(ptr);info.init(type,destructor);exceptionLast=ptr;uncaughtExceptionCount++;throw exceptionLast};var syscallGetVarargI=()=>{var ret=HEAP32[+SYSCALLS.varargs>>2];SYSCALLS.varargs+=4;return ret};var syscallGetVarargP=syscallGetVarargI;var PATH={isAbs:path=>path.charAt(0)==="/",splitPath:filename=>{var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return splitPathRe.exec(filename).slice(1)},normalizeArray:(parts,allowAboveRoot)=>{var up=0;for(var i=parts.length-1;i>=0;i--){var last=parts[i];if(last==="."){parts.splice(i,1)}else if(last===".."){parts.splice(i,1);up++}else if(up){parts.splice(i,1);up--}}if(allowAboveRoot){for(;up;up--){parts.unshift("..")}}return parts},normalize:path=>{var isAbsolute=PATH.isAbs(path),trailingSlash=path.slice(-1)==="/";path=PATH.normalizeArray(path.split("/").filter(p=>!!p),!isAbsolute).join("/");if(!path&&!isAbsolute){path="."}if(path&&trailingSlash){path+="/"}return(isAbsolute?"/":"")+path},dirname:path=>{var result=PATH.splitPath(path),root=result[0],dir=result[1];if(!root&&!dir){return"."}if(dir){dir=dir.slice(0,-1)}return root+dir},basename:path=>path&&path.match(/([^\/]+|\/)\/*$/)[1],join:(...paths)=>PATH.normalize(paths.join("/")),join2:(l,r)=>PATH.normalize(l+"/"+r)};var initRandomFill=()=>view=>crypto.getRandomValues(view);var randomFill=view=>{(randomFill=initRandomFill())(view)};var PATH_FS={resolve:(...args)=>{var resolvedPath="",resolvedAbsolute=false;for(var i=args.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?args[i]:FS.cwd();if(typeof path!="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!path){return""}resolvedPath=path+"/"+resolvedPath;resolvedAbsolute=PATH.isAbs(path)}resolvedPath=PATH.normalizeArray(resolvedPath.split("/").filter(p=>!!p),!resolvedAbsolute).join("/");return(resolvedAbsolute?"/":"")+resolvedPath||"."},relative:(from,to)=>{from=PATH_FS.resolve(from).slice(1);to=PATH_FS.resolve(to).slice(1);function trim(arr){var start=0;for(;start<arr.length;start++){if(arr[start]!=="")break}var end=arr.length-1;for(;end>=0;end--){if(arr[end]!=="")break}if(start>end)return[];return arr.slice(start,end-start+1)}var fromParts=trim(from.split("/"));var toParts=trim(to.split("/"));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i=0;i<length;i++){if(fromParts[i]!==toParts[i]){samePartsLength=i;break}}var outputParts=[];for(var i=samePartsLength;i<fromParts.length;i++){outputParts.push("..")}outputParts=outputParts.concat(toParts.slice(samePartsLength));return outputParts.join("/")}};var UTF8Decoder=globalThis.TextDecoder&&new TextDecoder;var findStringEnd=(heapOrArray,idx,maxBytesToRead,ignoreNul)=>{var maxIdx=idx+maxBytesToRead;if(ignoreNul)return maxIdx;while(heapOrArray[idx]&&!(idx>=maxIdx))++idx;return idx};var UTF8ArrayToString=(heapOrArray,idx=0,maxBytesToRead,ignoreNul)=>{var endPtr=findStringEnd(heapOrArray,idx,maxBytesToRead,ignoreNul);if(endPtr-idx>16&&heapOrArray.buffer&&UTF8Decoder){return UTF8Decoder.decode(heapOrArray.subarray(idx,endPtr))}var str="";while(idx<endPtr){var u0=heapOrArray[idx++];if(!(u0&128)){str+=String.fromCharCode(u0);continue}var u1=heapOrArray[idx++]&63;if((u0&224)==192){str+=String.fromCharCode((u0&31)<<6|u1);continue}var u2=heapOrArray[idx++]&63;if((u0&240)==224){u0=(u0&15)<<12|u1<<6|u2}else{u0=(u0&7)<<18|u1<<12|u2<<6|heapOrArray[idx++]&63}if(u0<65536){str+=String.fromCharCode(u0)}else{var ch=u0-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}}return str};var FS_stdin_getChar_buffer=[];var lengthBytesUTF8=str=>{var len=0;for(var i=0;i<str.length;++i){var c=str.charCodeAt(i);if(c<=127){len++}else if(c<=2047){len+=2}else if(c>=55296&&c<=57343){len+=4;++i}else{len+=3}}return len};var stringToUTF8Array=(str,heap,outIdx,maxBytesToWrite)=>{if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i<str.length;++i){var u=str.codePointAt(i);if(u<=127){if(outIdx>=endIdx)break;heap[outIdx++]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;heap[outIdx++]=192|u>>6;heap[outIdx++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;heap[outIdx++]=224|u>>12;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63}else{if(outIdx+3>=endIdx)break;heap[outIdx++]=240|u>>18;heap[outIdx++]=128|u>>12&63;heap[outIdx++]=128|u>>6&63;heap[outIdx++]=128|u&63;i++}}heap[outIdx]=0;return outIdx-startIdx};var intArrayFromString=(stringy,dontAddNull,length)=>{var len=length>0?length:lengthBytesUTF8(stringy)+1;var u8array=new Array(len);var numBytesWritten=stringToUTF8Array(stringy,u8array,0,u8array.length);if(dontAddNull)u8array.length=numBytesWritten;return u8array};var FS_stdin_getChar=()=>{if(!FS_stdin_getChar_buffer.length){var result=null;if(globalThis.window?.prompt){result=window.prompt("Input: ");if(result!==null){result+="\n"}}else{}if(!result){return null}FS_stdin_getChar_buffer=intArrayFromString(result,true)}return FS_stdin_getChar_buffer.shift()};var TTY={ttys:[],init(){},shutdown(){},register(dev,ops){TTY.ttys[dev]={input:[],output:[],ops};FS.registerDevice(dev,TTY.stream_ops)},stream_ops:{open(stream){var tty=TTY.ttys[stream.node.rdev];if(!tty){throw new FS.ErrnoError(43)}stream.tty=tty;stream.seekable=false},close(stream){stream.tty.ops.fsync(stream.tty)},fsync(stream){stream.tty.ops.fsync(stream.tty)},read(stream,buffer,offset,length,pos){if(!stream.tty||!stream.tty.ops.get_char){throw new FS.ErrnoError(60)}var bytesRead=0;for(var i=0;i<length;i++){var result;try{result=stream.tty.ops.get_char(stream.tty)}catch(e){throw new FS.ErrnoError(29)}if(result===undefined&&bytesRead===0){throw new FS.ErrnoError(6)}if(result===null||result===undefined)break;bytesRead++;buffer[offset+i]=result}if(bytesRead){stream.node.atime=Date.now()}return bytesRead},write(stream,buffer,offset,length,pos){if(!stream.tty||!stream.tty.ops.put_char){throw new FS.ErrnoError(60)}try{for(var i=0;i<length;i++){stream.tty.ops.put_char(stream.tty,buffer[offset+i])}}catch(e){throw new FS.ErrnoError(29)}if(length){stream.node.mtime=stream.node.ctime=Date.now()}return i}},default_tty_ops:{get_char(tty){return FS_stdin_getChar()},put_char(tty,val){if(val===null||val===10){out(UTF8ArrayToString(tty.output));tty.output=[]}else{if(val!=0)tty.output.push(val)}},fsync(tty){if(tty.output?.length>0){out(UTF8ArrayToString(tty.output));tty.output=[]}},ioctl_tcgets(tty){return{c_iflag:25856,c_oflag:5,c_cflag:191,c_lflag:35387,c_cc:[3,28,127,21,4,0,1,0,17,19,26,0,18,15,23,22,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]}},ioctl_tcsets(tty,optional_actions,data){return 0},ioctl_tiocgwinsz(tty){return[24,80]}},default_tty1_ops:{put_char(tty,val){if(val===null||val===10){err(UTF8ArrayToString(tty.output));tty.output=[]}else{if(val!=0)tty.output.push(val)}},fsync(tty){if(tty.output?.length>0){err(UTF8ArrayToString(tty.output));tty.output=[]}}}};var mmapAlloc=size=>{abort()};var MEMFS={ops_table:null,mount(mount){return MEMFS.createNode(null,"/",16895,0)},createNode(parent,name,mode,dev){if(FS.isBlkdev(mode)||FS.isFIFO(mode)){throw new FS.ErrnoError(63)}MEMFS.ops_table||={dir:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,lookup:MEMFS.node_ops.lookup,mknod:MEMFS.node_ops.mknod,rename:MEMFS.node_ops.rename,unlink:MEMFS.node_ops.unlink,rmdir:MEMFS.node_ops.rmdir,readdir:MEMFS.node_ops.readdir,symlink:MEMFS.node_ops.symlink},stream:{llseek:MEMFS.stream_ops.llseek}},file:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:{llseek:MEMFS.stream_ops.llseek,read:MEMFS.stream_ops.read,write:MEMFS.stream_ops.write,mmap:MEMFS.stream_ops.mmap,msync:MEMFS.stream_ops.msync}},link:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,readlink:MEMFS.node_ops.readlink},stream:{}},chrdev:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:FS.chrdev_stream_ops}};var node=FS.createNode(parent,name,mode,dev);if(FS.isDir(node.mode)){node.node_ops=MEMFS.ops_table.dir.node;node.stream_ops=MEMFS.ops_table.dir.stream;node.contents={}}else if(FS.isFile(node.mode)){node.node_ops=MEMFS.ops_table.file.node;node.stream_ops=MEMFS.ops_table.file.stream;node.usedBytes=0;node.contents=null}else if(FS.isLink(node.mode)){node.node_ops=MEMFS.ops_table.link.node;node.stream_ops=MEMFS.ops_table.link.stream}else if(FS.isChrdev(node.mode)){node.node_ops=MEMFS.ops_table.chrdev.node;node.stream_ops=MEMFS.ops_table.chrdev.stream}node.atime=node.mtime=node.ctime=Date.now();if(parent){parent.contents[name]=node;parent.atime=parent.mtime=parent.ctime=node.atime}return node},getFileDataAsTypedArray(node){if(!node.contents)return new Uint8Array(0);if(node.contents.subarray)return node.contents.subarray(0,node.usedBytes);return new Uint8Array(node.contents)},expandFileStorage(node,newCapacity){var prevCapacity=node.contents?node.contents.length:0;if(prevCapacity>=newCapacity)return;var CAPACITY_DOUBLING_MAX=1024*1024;newCapacity=Math.max(newCapacity,prevCapacity*(prevCapacity<CAPACITY_DOUBLING_MAX?2:1.125)>>>0);if(prevCapacity!=0)newCapacity=Math.max(newCapacity,256);var oldContents=node.contents;node.contents=new Uint8Array(newCapacity);if(node.usedBytes>0)node.contents.set(oldContents.subarray(0,node.usedBytes),0)},resizeFileStorage(node,newSize){if(node.usedBytes==newSize)return;if(newSize==0){node.contents=null;node.usedBytes=0}else{var oldContents=node.contents;node.contents=new Uint8Array(newSize);if(oldContents){node.contents.set(oldContents.subarray(0,Math.min(newSize,node.usedBytes)))}node.usedBytes=newSize}},node_ops:{getattr(node){var attr={};attr.dev=FS.isChrdev(node.mode)?node.id:1;attr.ino=node.id;attr.mode=node.mode;attr.nlink=1;attr.uid=0;attr.gid=0;attr.rdev=node.rdev;if(FS.isDir(node.mode)){attr.size=4096}else if(FS.isFile(node.mode)){attr.size=node.usedBytes}else if(FS.isLink(node.mode)){attr.size=node.link.length}else{attr.size=0}attr.atime=new Date(node.atime);attr.mtime=new Date(node.mtime);attr.ctime=new Date(node.ctime);attr.blksize=4096;attr.blocks=Math.ceil(attr.size/attr.blksize);return attr},setattr(node,attr){for(const key of["mode","atime","mtime","ctime"]){if(attr[key]!=null){node[key]=attr[key]}}if(attr.size!==undefined){MEMFS.resizeFileStorage(node,attr.size)}},lookup(parent,name){if(!MEMFS.doesNotExistError){MEMFS.doesNotExistError=new FS.ErrnoError(44);MEMFS.doesNotExistError.stack="<generic error, no stack>"}throw MEMFS.doesNotExistError},mknod(parent,name,mode,dev){return MEMFS.createNode(parent,name,mode,dev)},rename(old_node,new_dir,new_name){var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(new_node){if(FS.isDir(old_node.mode)){for(var i in new_node.contents){throw new FS.ErrnoError(55)}}FS.hashRemoveNode(new_node)}delete old_node.parent.contents[old_node.name];new_dir.contents[new_name]=old_node;old_node.name=new_name;new_dir.ctime=new_dir.mtime=old_node.parent.ctime=old_node.parent.mtime=Date.now()},unlink(parent,name){delete parent.contents[name];parent.ctime=parent.mtime=Date.now()},rmdir(parent,name){var node=FS.lookupNode(parent,name);for(var i in node.contents){throw new FS.ErrnoError(55)}delete parent.contents[name];parent.ctime=parent.mtime=Date.now()},readdir(node){return[".","..",...Object.keys(node.contents)]},symlink(parent,newname,oldpath){var node=MEMFS.createNode(parent,newname,511|40960,0);node.link=oldpath;return node},readlink(node){if(!FS.isLink(node.mode)){throw new FS.ErrnoError(28)}return node.link}},stream_ops:{read(stream,buffer,offset,length,position){var contents=stream.node.contents;if(position>=stream.node.usedBytes)return 0;var size=Math.min(stream.node.usedBytes-position,length);if(size>8&&contents.subarray){buffer.set(contents.subarray(position,position+size),offset)}else{for(var i=0;i<size;i++)buffer[offset+i]=contents[position+i]}return size},write(stream,buffer,offset,length,position,canOwn){if(buffer.buffer===HEAP8.buffer){canOwn=false}if(!length)return 0;var node=stream.node;node.mtime=node.ctime=Date.now();if(buffer.subarray&&(!node.contents||node.contents.subarray)){if(canOwn){node.contents=buffer.subarray(offset,offset+length);node.usedBytes=length;return length}else if(node.usedBytes===0&&position===0){node.contents=buffer.slice(offset,offset+length);node.usedBytes=length;return length}else if(position+length<=node.usedBytes){node.contents.set(buffer.subarray(offset,offset+length),position);return length}}MEMFS.expandFileStorage(node,position+length);if(node.contents.subarray&&buffer.subarray){node.contents.set(buffer.subarray(offset,offset+length),position)}else{for(var i=0;i<length;i++){node.contents[position+i]=buffer[offset+i]}}node.usedBytes=Math.max(node.usedBytes,position+length);return length},llseek(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){position+=stream.node.usedBytes}}if(position<0){throw new FS.ErrnoError(28)}return position},mmap(stream,length,position,prot,flags){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(43)}var ptr;var allocated;var contents=stream.node.contents;if(!(flags&2)&&contents&&contents.buffer===HEAP8.buffer){allocated=false;ptr=contents.byteOffset}else{allocated=true;ptr=mmapAlloc(length);if(!ptr){throw new FS.ErrnoError(48)}if(contents){if(position>0||position+length<contents.length){if(contents.subarray){contents=contents.subarray(position,position+length)}else{contents=Array.prototype.slice.call(contents,position,position+length)}}HEAP8.set(contents,ptr)}}return{ptr,allocated}},msync(stream,buffer,offset,length,mmapFlags){MEMFS.stream_ops.write(stream,buffer,0,length,offset,false);return 0}}};var FS_modeStringToFlags=str=>{var flagModes={r:0,"r+":2,w:512|64|1,"w+":512|64|2,a:1024|64|1,"a+":1024|64|2};var flags=flagModes[str];if(typeof flags=="undefined"){throw new Error(`Unknown file open mode: ${str}`)}return flags};var FS_getMode=(canRead,canWrite)=>{var mode=0;if(canRead)mode|=292|73;if(canWrite)mode|=146;return mode};var asyncLoad=async url=>{var arrayBuffer=await readAsync(url);return new Uint8Array(arrayBuffer)};var FS_createDataFile=(...args)=>FS.createDataFile(...args);var getUniqueRunDependency=id=>id;var runDependencies=0;var dependenciesFulfilled=null;var removeRunDependency=id=>{runDependencies--;Module["monitorRunDependencies"]?.(runDependencies);if(runDependencies==0){if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}};var addRunDependency=id=>{runDependencies++;Module["monitorRunDependencies"]?.(runDependencies)};var preloadPlugins=[];var FS_handledByPreloadPlugin=async(byteArray,fullname)=>{if(typeof Browser!="undefined")Browser.init();for(var plugin of preloadPlugins){if(plugin["canHandle"](fullname)){return plugin["handle"](byteArray,fullname)}}return byteArray};var FS_preloadFile=async(parent,name,url,canRead,canWrite,dontCreateFile,canOwn,preFinish)=>{var fullname=name?PATH_FS.resolve(PATH.join2(parent,name)):parent;var dep=getUniqueRunDependency(`cp ${fullname}`);addRunDependency(dep);try{var byteArray=url;if(typeof url=="string"){byteArray=await asyncLoad(url)}byteArray=await FS_handledByPreloadPlugin(byteArray,fullname);preFinish?.();if(!dontCreateFile){FS_createDataFile(parent,name,byteArray,canRead,canWrite,canOwn)}}finally{removeRunDependency(dep)}};var FS_createPreloadedFile=(parent,name,url,canRead,canWrite,onload,onerror,dontCreateFile,canOwn,preFinish)=>{FS_preloadFile(parent,name,url,canRead,canWrite,dontCreateFile,canOwn,preFinish).then(onload).catch(onerror)};var FS={root:null,mounts:[],devices:{},streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:false,ignorePermissions:true,filesystems:null,syncFSRequests:0,ErrnoError:class{name="ErrnoError";constructor(errno){this.errno=errno}},FSStream:class{shared={};get object(){return this.node}set object(val){this.node=val}get isRead(){return(this.flags&2097155)!==1}get isWrite(){return(this.flags&2097155)!==0}get isAppend(){return this.flags&1024}get flags(){return this.shared.flags}set flags(val){this.shared.flags=val}get position(){return this.shared.position}set position(val){this.shared.position=val}},FSNode:class{node_ops={};stream_ops={};readMode=292|73;writeMode=146;mounted=null;constructor(parent,name,mode,rdev){if(!parent){parent=this}this.parent=parent;this.mount=parent.mount;this.id=FS.nextInode++;this.name=name;this.mode=mode;this.rdev=rdev;this.atime=this.mtime=this.ctime=Date.now()}get read(){return(this.mode&this.readMode)===this.readMode}set read(val){val?this.mode|=this.readMode:this.mode&=~this.readMode}get write(){return(this.mode&this.writeMode)===this.writeMode}set write(val){val?this.mode|=this.writeMode:this.mode&=~this.writeMode}get isFolder(){return FS.isDir(this.mode)}get isDevice(){return FS.isChrdev(this.mode)}},lookupPath(path,opts={}){if(!path){throw new FS.ErrnoError(44)}opts.follow_mount??=true;if(!PATH.isAbs(path)){path=FS.cwd()+"/"+path}linkloop:for(var nlinks=0;nlinks<40;nlinks++){var parts=path.split("/").filter(p=>!!p);var current=FS.root;var current_path="/";for(var i=0;i<parts.length;i++){var islast=i===parts.length-1;if(islast&&opts.parent){break}if(parts[i]==="."){continue}if(parts[i]===".."){current_path=PATH.dirname(current_path);if(FS.isRoot(current)){path=current_path+"/"+parts.slice(i+1).join("/");nlinks--;continue linkloop}else{current=current.parent}continue}current_path=PATH.join2(current_path,parts[i]);try{current=FS.lookupNode(current,parts[i])}catch(e){if(e?.errno===44&&islast&&opts.noent_okay){return{path:current_path}}throw e}if(FS.isMountpoint(current)&&(!islast||opts.follow_mount)){current=current.mounted.root}if(FS.isLink(current.mode)&&(!islast||opts.follow)){if(!current.node_ops.readlink){throw new FS.ErrnoError(52)}var link=current.node_ops.readlink(current);if(!PATH.isAbs(link)){link=PATH.dirname(current_path)+"/"+link}path=link+"/"+parts.slice(i+1).join("/");continue linkloop}}return{path:current_path,node:current}}throw new FS.ErrnoError(32)},getPath(node){var path;while(true){if(FS.isRoot(node)){var mount=node.mount.mountpoint;if(!path)return mount;return mount[mount.length-1]!=="/"?`${mount}/${path}`:mount+path}path=path?`${node.name}/${path}`:node.name;node=node.parent}},hashName(parentid,name){var hash=0;for(var i=0;i<name.length;i++){hash=(hash<<5)-hash+name.charCodeAt(i)|0}return(parentid+hash>>>0)%FS.nameTable.length},hashAddNode(node){var hash=FS.hashName(node.parent.id,node.name);node.name_next=FS.nameTable[hash];FS.nameTable[hash]=node},hashRemoveNode(node){var hash=FS.hashName(node.parent.id,node.name);if(FS.nameTable[hash]===node){FS.nameTable[hash]=node.name_next}else{var current=FS.nameTable[hash];while(current){if(current.name_next===node){current.name_next=node.name_next;break}current=current.name_next}}},lookupNode(parent,name){var errCode=FS.mayLookup(parent);if(errCode){throw new FS.ErrnoError(errCode)}var hash=FS.hashName(parent.id,name);for(var node=FS.nameTable[hash];node;node=node.name_next){var nodeName=node.name;if(node.parent.id===parent.id&&nodeName===name){return node}}return FS.lookup(parent,name)},createNode(parent,name,mode,rdev){var node=new FS.FSNode(parent,name,mode,rdev);FS.hashAddNode(node);return node},destroyNode(node){FS.hashRemoveNode(node)},isRoot(node){return node===node.parent},isMountpoint(node){return!!node.mounted},isFile(mode){return(mode&61440)===32768},isDir(mode){return(mode&61440)===16384},isLink(mode){return(mode&61440)===40960},isChrdev(mode){return(mode&61440)===8192},isBlkdev(mode){return(mode&61440)===24576},isFIFO(mode){return(mode&61440)===4096},isSocket(mode){return(mode&49152)===49152},flagsToPermissionString(flag){var perms=["r","w","rw"][flag&3];if(flag&512){perms+="w"}return perms},nodePermissions(node,perms){if(FS.ignorePermissions){return 0}if(perms.includes("r")&&!(node.mode&292)){return 2}if(perms.includes("w")&&!(node.mode&146)){return 2}if(perms.includes("x")&&!(node.mode&73)){return 2}return 0},mayLookup(dir){if(!FS.isDir(dir.mode))return 54;var errCode=FS.nodePermissions(dir,"x");if(errCode)return errCode;if(!dir.node_ops.lookup)return 2;return 0},mayCreate(dir,name){if(!FS.isDir(dir.mode)){return 54}try{var node=FS.lookupNode(dir,name);return 20}catch(e){}return FS.nodePermissions(dir,"wx")},mayDelete(dir,name,isdir){var node;try{node=FS.lookupNode(dir,name)}catch(e){return e.errno}var errCode=FS.nodePermissions(dir,"wx");if(errCode){return errCode}if(isdir){if(!FS.isDir(node.mode)){return 54}if(FS.isRoot(node)||FS.getPath(node)===FS.cwd()){return 10}}else if(FS.isDir(node.mode)){return 31}return 0},mayOpen(node,flags){if(!node){return 44}if(FS.isLink(node.mode)){return 32}var mode=FS.flagsToPermissionString(flags);if(FS.isDir(node.mode)){if(mode!=="r"||flags&(512|64)){return 31}}return FS.nodePermissions(node,mode)},checkOpExists(op,err){if(!op){throw new FS.ErrnoError(err)}return op},MAX_OPEN_FDS:4096,nextfd(){for(var fd=0;fd<=FS.MAX_OPEN_FDS;fd++){if(!FS.streams[fd]){return fd}}throw new FS.ErrnoError(33)},getStreamChecked(fd){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(8)}return stream},getStream:fd=>FS.streams[fd],createStream(stream,fd=-1){stream=Object.assign(new FS.FSStream,stream);if(fd==-1){fd=FS.nextfd()}stream.fd=fd;FS.streams[fd]=stream;return stream},closeStream(fd){FS.streams[fd]=null},dupStream(origStream,fd=-1){var stream=FS.createStream(origStream,fd);stream.stream_ops?.dup?.(stream);return stream},doSetAttr(stream,node,attr){var setattr=stream?.stream_ops.setattr;var arg=setattr?stream:node;setattr??=node.node_ops.setattr;FS.checkOpExists(setattr,63);setattr(arg,attr)},chrdev_stream_ops:{open(stream){var device=FS.getDevice(stream.node.rdev);stream.stream_ops=device.stream_ops;stream.stream_ops.open?.(stream)},llseek(){throw new FS.ErrnoError(70)}},major:dev=>dev>>8,minor:dev=>dev&255,makedev:(ma,mi)=>ma<<8|mi,registerDevice(dev,ops){FS.devices[dev]={stream_ops:ops}},getDevice:dev=>FS.devices[dev],getMounts(mount){var mounts=[];var check=[mount];while(check.length){var m=check.pop();mounts.push(m);check.push(...m.mounts)}return mounts},syncfs(populate,callback){if(typeof populate=="function"){callback=populate;populate=false}FS.syncFSRequests++;if(FS.syncFSRequests>1){err(`warning: ${FS.syncFSRequests} FS.syncfs operations in flight at once, probably just doing extra work`)}var mounts=FS.getMounts(FS.root.mount);var completed=0;function doCallback(errCode){FS.syncFSRequests--;return callback(errCode)}function done(errCode){if(errCode){if(!done.errored){done.errored=true;return doCallback(errCode)}return}if(++completed>=mounts.length){doCallback(null)}}for(var mount of mounts){if(mount.type.syncfs){mount.type.syncfs(mount,populate,done)}else{done(null)}}},mount(type,opts,mountpoint){var root=mountpoint==="/";var pseudo=!mountpoint;var node;if(root&&FS.root){throw new FS.ErrnoError(10)}else if(!root&&!pseudo){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});mountpoint=lookup.path;node=lookup.node;if(FS.isMountpoint(node)){throw new FS.ErrnoError(10)}if(!FS.isDir(node.mode)){throw new FS.ErrnoError(54)}}var mount={type,opts,mountpoint,mounts:[]};var mountRoot=type.mount(mount);mountRoot.mount=mount;mount.root=mountRoot;if(root){FS.root=mountRoot}else if(node){node.mounted=mount;if(node.mount){node.mount.mounts.push(mount)}}return mountRoot},unmount(mountpoint){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});if(!FS.isMountpoint(lookup.node)){throw new FS.ErrnoError(28)}var node=lookup.node;var mount=node.mounted;var mounts=FS.getMounts(mount);for(var[hash,current]of Object.entries(FS.nameTable)){while(current){var next=current.name_next;if(mounts.includes(current.mount)){FS.destroyNode(current)}current=next}}node.mounted=null;var idx=node.mount.mounts.indexOf(mount);node.mount.mounts.splice(idx,1)},lookup(parent,name){return parent.node_ops.lookup(parent,name)},mknod(path,mode,dev){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);if(!name){throw new FS.ErrnoError(28)}if(name==="."||name===".."){throw new FS.ErrnoError(20)}var errCode=FS.mayCreate(parent,name);if(errCode){throw new FS.ErrnoError(errCode)}if(!parent.node_ops.mknod){throw new FS.ErrnoError(63)}return parent.node_ops.mknod(parent,name,mode,dev)},statfs(path){return FS.statfsNode(FS.lookupPath(path,{follow:true}).node)},statfsStream(stream){return FS.statfsNode(stream.node)},statfsNode(node){var rtn={bsize:4096,frsize:4096,blocks:1e6,bfree:5e5,bavail:5e5,files:FS.nextInode,ffree:FS.nextInode-1,fsid:42,flags:2,namelen:255};if(node.node_ops.statfs){Object.assign(rtn,node.node_ops.statfs(node.mount.opts.root))}return rtn},create(path,mode=438){mode&=4095;mode|=32768;return FS.mknod(path,mode,0)},mkdir(path,mode=511){mode&=511|512;mode|=16384;return FS.mknod(path,mode,0)},mkdirTree(path,mode){var dirs=path.split("/");var d="";for(var dir of dirs){if(!dir)continue;if(d||PATH.isAbs(path))d+="/";d+=dir;try{FS.mkdir(d,mode)}catch(e){if(e.errno!=20)throw e}}},mkdev(path,mode,dev){if(typeof dev=="undefined"){dev=mode;mode=438}mode|=8192;return FS.mknod(path,mode,dev)},symlink(oldpath,newpath){if(!PATH_FS.resolve(oldpath)){throw new FS.ErrnoError(44)}var lookup=FS.lookupPath(newpath,{parent:true});var parent=lookup.node;if(!parent){throw new FS.ErrnoError(44)}var newname=PATH.basename(newpath);var errCode=FS.mayCreate(parent,newname);if(errCode){throw new FS.ErrnoError(errCode)}if(!parent.node_ops.symlink){throw new FS.ErrnoError(63)}return parent.node_ops.symlink(parent,newname,oldpath)},rename(old_path,new_path){var old_dirname=PATH.dirname(old_path);var new_dirname=PATH.dirname(new_path);var old_name=PATH.basename(old_path);var new_name=PATH.basename(new_path);var lookup,old_dir,new_dir;lookup=FS.lookupPath(old_path,{parent:true});old_dir=lookup.node;lookup=FS.lookupPath(new_path,{parent:true});new_dir=lookup.node;if(!old_dir||!new_dir)throw new FS.ErrnoError(44);if(old_dir.mount!==new_dir.mount){throw new FS.ErrnoError(75)}var old_node=FS.lookupNode(old_dir,old_name);var relative=PATH_FS.relative(old_path,new_dirname);if(relative.charAt(0)!=="."){throw new FS.ErrnoError(28)}relative=PATH_FS.relative(new_path,old_dirname);if(relative.charAt(0)!=="."){throw new FS.ErrnoError(55)}var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(old_node===new_node){return}var isdir=FS.isDir(old_node.mode);var errCode=FS.mayDelete(old_dir,old_name,isdir);if(errCode){throw new FS.ErrnoError(errCode)}errCode=new_node?FS.mayDelete(new_dir,new_name,isdir):FS.mayCreate(new_dir,new_name);if(errCode){throw new FS.ErrnoError(errCode)}if(!old_dir.node_ops.rename){throw new FS.ErrnoError(63)}if(FS.isMountpoint(old_node)||new_node&&FS.isMountpoint(new_node)){throw new FS.ErrnoError(10)}if(new_dir!==old_dir){errCode=FS.nodePermissions(old_dir,"w");if(errCode){throw new FS.ErrnoError(errCode)}}FS.hashRemoveNode(old_node);try{old_dir.node_ops.rename(old_node,new_dir,new_name);old_node.parent=new_dir}catch(e){throw e}finally{FS.hashAddNode(old_node)}},rmdir(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var errCode=FS.mayDelete(parent,name,true);if(errCode){throw new FS.ErrnoError(errCode)}if(!parent.node_ops.rmdir){throw new FS.ErrnoError(63)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(10)}parent.node_ops.rmdir(parent,name);FS.destroyNode(node)},readdir(path){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;var readdir=FS.checkOpExists(node.node_ops.readdir,54);return readdir(node)},unlink(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;if(!parent){throw new FS.ErrnoError(44)}var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var errCode=FS.mayDelete(parent,name,false);if(errCode){throw new FS.ErrnoError(errCode)}if(!parent.node_ops.unlink){throw new FS.ErrnoError(63)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(10)}parent.node_ops.unlink(parent,name);FS.destroyNode(node)},readlink(path){var lookup=FS.lookupPath(path);var link=lookup.node;if(!link){throw new FS.ErrnoError(44)}if(!link.node_ops.readlink){throw new FS.ErrnoError(28)}return link.node_ops.readlink(link)},stat(path,dontFollow){var lookup=FS.lookupPath(path,{follow:!dontFollow});var node=lookup.node;var getattr=FS.checkOpExists(node.node_ops.getattr,63);return getattr(node)},fstat(fd){var stream=FS.getStreamChecked(fd);var node=stream.node;var getattr=stream.stream_ops.getattr;var arg=getattr?stream:node;getattr??=node.node_ops.getattr;FS.checkOpExists(getattr,63);return getattr(arg)},lstat(path){return FS.stat(path,true)},doChmod(stream,node,mode,dontFollow){FS.doSetAttr(stream,node,{mode:mode&4095|node.mode&~4095,ctime:Date.now(),dontFollow})},chmod(path,mode,dontFollow){var node;if(typeof path=="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}FS.doChmod(null,node,mode,dontFollow)},lchmod(path,mode){FS.chmod(path,mode,true)},fchmod(fd,mode){var stream=FS.getStreamChecked(fd);FS.doChmod(stream,stream.node,mode,false)},doChown(stream,node,dontFollow){FS.doSetAttr(stream,node,{timestamp:Date.now(),dontFollow})},chown(path,uid,gid,dontFollow){var node;if(typeof path=="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}FS.doChown(null,node,dontFollow)},lchown(path,uid,gid){FS.chown(path,uid,gid,true)},fchown(fd,uid,gid){var stream=FS.getStreamChecked(fd);FS.doChown(stream,stream.node,false)},doTruncate(stream,node,len){if(FS.isDir(node.mode)){throw new FS.ErrnoError(31)}if(!FS.isFile(node.mode)){throw new FS.ErrnoError(28)}var errCode=FS.nodePermissions(node,"w");if(errCode){throw new FS.ErrnoError(errCode)}FS.doSetAttr(stream,node,{size:len,timestamp:Date.now()})},truncate(path,len){if(len<0){throw new FS.ErrnoError(28)}var node;if(typeof path=="string"){var lookup=FS.lookupPath(path,{follow:true});node=lookup.node}else{node=path}FS.doTruncate(null,node,len)},ftruncate(fd,len){var stream=FS.getStreamChecked(fd);if(len<0||(stream.flags&2097155)===0){throw new FS.ErrnoError(28)}FS.doTruncate(stream,stream.node,len)},utime(path,atime,mtime){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;var setattr=FS.checkOpExists(node.node_ops.setattr,63);setattr(node,{atime,mtime})},open(path,flags,mode=438){if(path===""){throw new FS.ErrnoError(44)}flags=typeof flags=="string"?FS_modeStringToFlags(flags):flags;if(flags&64){mode=mode&4095|32768}else{mode=0}var node;var isDirPath;if(typeof path=="object"){node=path}else{isDirPath=path.endsWith("/");var lookup=FS.lookupPath(path,{follow:!(flags&131072),noent_okay:true});node=lookup.node;path=lookup.path}var created=false;if(flags&64){if(node){if(flags&128){throw new FS.ErrnoError(20)}}else if(isDirPath){throw new FS.ErrnoError(31)}else{node=FS.mknod(path,mode|511,0);created=true}}if(!node){throw new FS.ErrnoError(44)}if(FS.isChrdev(node.mode)){flags&=~512}if(flags&65536&&!FS.isDir(node.mode)){throw new FS.ErrnoError(54)}if(!created){var errCode=FS.mayOpen(node,flags);if(errCode){throw new FS.ErrnoError(errCode)}}if(flags&512&&!created){FS.truncate(node,0)}flags&=~(128|512|131072);var stream=FS.createStream({node,path:FS.getPath(node),flags,seekable:true,position:0,stream_ops:node.stream_ops,ungotten:[],error:false});if(stream.stream_ops.open){stream.stream_ops.open(stream)}if(created){FS.chmod(node,mode&511)}return stream},close(stream){if(FS.isClosed(stream)){throw new FS.ErrnoError(8)}if(stream.getdents)stream.getdents=null;try{if(stream.stream_ops.close){stream.stream_ops.close(stream)}}catch(e){throw e}finally{FS.closeStream(stream.fd)}stream.fd=null},isClosed(stream){return stream.fd===null},llseek(stream,offset,whence){if(FS.isClosed(stream)){throw new FS.ErrnoError(8)}if(!stream.seekable||!stream.stream_ops.llseek){throw new FS.ErrnoError(70)}if(whence!=0&&whence!=1&&whence!=2){throw new FS.ErrnoError(28)}stream.position=stream.stream_ops.llseek(stream,offset,whence);stream.ungotten=[];return stream.position},read(stream,buffer,offset,length,position){if(length<0||position<0){throw new FS.ErrnoError(28)}if(FS.isClosed(stream)){throw new FS.ErrnoError(8)}if((stream.flags&2097155)===1){throw new FS.ErrnoError(8)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(31)}if(!stream.stream_ops.read){throw new FS.ErrnoError(28)}var seeking=typeof position!="undefined";if(!seeking){position=stream.position}else if(!stream.seekable){throw new FS.ErrnoError(70)}var bytesRead=stream.stream_ops.read(stream,buffer,offset,length,position);if(!seeking)stream.position+=bytesRead;return bytesRead},write(stream,buffer,offset,length,position,canOwn){if(length<0||position<0){throw new FS.ErrnoError(28)}if(FS.isClosed(stream)){throw new FS.ErrnoError(8)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(8)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(31)}if(!stream.stream_ops.write){throw new FS.ErrnoError(28)}if(stream.seekable&&stream.flags&1024){FS.llseek(stream,0,2)}var seeking=typeof position!="undefined";if(!seeking){position=stream.position}else if(!stream.seekable){throw new FS.ErrnoError(70)}var bytesWritten=stream.stream_ops.write(stream,buffer,offset,length,position,canOwn);if(!seeking)stream.position+=bytesWritten;return bytesWritten},mmap(stream,length,position,prot,flags){if((prot&2)!==0&&(flags&2)===0&&(stream.flags&2097155)!==2){throw new FS.ErrnoError(2)}if((stream.flags&2097155)===1){throw new FS.ErrnoError(2)}if(!stream.stream_ops.mmap){throw new FS.ErrnoError(43)}if(!length){throw new FS.ErrnoError(28)}return stream.stream_ops.mmap(stream,length,position,prot,flags)},msync(stream,buffer,offset,length,mmapFlags){if(!stream.stream_ops.msync){return 0}return stream.stream_ops.msync(stream,buffer,offset,length,mmapFlags)},ioctl(stream,cmd,arg){if(!stream.stream_ops.ioctl){throw new FS.ErrnoError(59)}return stream.stream_ops.ioctl(stream,cmd,arg)},readFile(path,opts={}){opts.flags=opts.flags||0;opts.encoding=opts.encoding||"binary";if(opts.encoding!=="utf8"&&opts.encoding!=="binary"){abort(`Invalid encoding type "${opts.encoding}"`)}var stream=FS.open(path,opts.flags);var stat=FS.stat(path);var length=stat.size;var buf=new Uint8Array(length);FS.read(stream,buf,0,length,0);if(opts.encoding==="utf8"){buf=UTF8ArrayToString(buf)}FS.close(stream);return buf},writeFile(path,data,opts={}){opts.flags=opts.flags||577;var stream=FS.open(path,opts.flags,opts.mode);if(typeof data=="string"){data=new Uint8Array(intArrayFromString(data,true))}if(ArrayBuffer.isView(data)){FS.write(stream,data,0,data.byteLength,undefined,opts.canOwn)}else{abort("Unsupported data type")}FS.close(stream)},cwd:()=>FS.currentPath,chdir(path){var lookup=FS.lookupPath(path,{follow:true});if(lookup.node===null){throw new FS.ErrnoError(44)}if(!FS.isDir(lookup.node.mode)){throw new FS.ErrnoError(54)}var errCode=FS.nodePermissions(lookup.node,"x");if(errCode){throw new FS.ErrnoError(errCode)}FS.currentPath=lookup.path},createDefaultDirectories(){FS.mkdir("/tmp");FS.mkdir("/home");FS.mkdir("/home/web_user")},createDefaultDevices(){FS.mkdir("/dev");FS.registerDevice(FS.makedev(1,3),{read:()=>0,write:(stream,buffer,offset,length,pos)=>length,llseek:()=>0});FS.mkdev("/dev/null",FS.makedev(1,3));TTY.register(FS.makedev(5,0),TTY.default_tty_ops);TTY.register(FS.makedev(6,0),TTY.default_tty1_ops);FS.mkdev("/dev/tty",FS.makedev(5,0));FS.mkdev("/dev/tty1",FS.makedev(6,0));var randomBuffer=new Uint8Array(1024),randomLeft=0;var randomByte=()=>{if(randomLeft===0){randomFill(randomBuffer);randomLeft=randomBuffer.byteLength}return randomBuffer[--randomLeft]};FS.createDevice("/dev","random",randomByte);FS.createDevice("/dev","urandom",randomByte);FS.mkdir("/dev/shm");FS.mkdir("/dev/shm/tmp")},createSpecialDirectories(){FS.mkdir("/proc");var proc_self=FS.mkdir("/proc/self");FS.mkdir("/proc/self/fd");FS.mount({mount(){var node=FS.createNode(proc_self,"fd",16895,73);node.stream_ops={llseek:MEMFS.stream_ops.llseek};node.node_ops={lookup(parent,name){var fd=+name;var stream=FS.getStreamChecked(fd);var ret={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:()=>stream.path},id:fd+1};ret.parent=ret;return ret},readdir(){return Array.from(FS.streams.entries()).filter(([k,v])=>v).map(([k,v])=>k.toString())}};return node}},{},"/proc/self/fd")},createStandardStreams(input,output,error){if(input){FS.createDevice("/dev","stdin",input)}else{FS.symlink("/dev/tty","/dev/stdin")}if(output){FS.createDevice("/dev","stdout",null,output)}else{FS.symlink("/dev/tty","/dev/stdout")}if(error){FS.createDevice("/dev","stderr",null,error)}else{FS.symlink("/dev/tty1","/dev/stderr")}var stdin=FS.open("/dev/stdin",0);var stdout=FS.open("/dev/stdout",1);var stderr=FS.open("/dev/stderr",1)},staticInit(){FS.nameTable=new Array(4096);FS.mount(MEMFS,{},"/");FS.createDefaultDirectories();FS.createDefaultDevices();FS.createSpecialDirectories();FS.filesystems={MEMFS}},init(input,output,error){FS.initialized=true;input??=Module["stdin"];output??=Module["stdout"];error??=Module["stderr"];FS.createStandardStreams(input,output,error)},quit(){FS.initialized=false;for(var stream of FS.streams){if(stream){FS.close(stream)}}},findObject(path,dontResolveLastLink){var ret=FS.analyzePath(path,dontResolveLastLink);if(!ret.exists){return null}return ret.object},analyzePath(path,dontResolveLastLink){try{var lookup=FS.lookupPath(path,{follow:!dontResolveLastLink});path=lookup.path}catch(e){}var ret={isRoot:false,exists:false,error:0,name:null,path:null,object:null,parentExists:false,parentPath:null,parentObject:null};try{var lookup=FS.lookupPath(path,{parent:true});ret.parentExists=true;ret.parentPath=lookup.path;ret.parentObject=lookup.node;ret.name=PATH.basename(path);lookup=FS.lookupPath(path,{follow:!dontResolveLastLink});ret.exists=true;ret.path=lookup.path;ret.object=lookup.node;ret.name=lookup.node.name;ret.isRoot=lookup.path==="/"}catch(e){ret.error=e.errno}return ret},createPath(parent,path,canRead,canWrite){parent=typeof parent=="string"?parent:FS.getPath(parent);var parts=path.split("/").reverse();while(parts.length){var part=parts.pop();if(!part)continue;var current=PATH.join2(parent,part);try{FS.mkdir(current)}catch(e){if(e.errno!=20)throw e}parent=current}return current},createFile(parent,name,properties,canRead,canWrite){var path=PATH.join2(typeof parent=="string"?parent:FS.getPath(parent),name);var mode=FS_getMode(canRead,canWrite);return FS.create(path,mode)},createDataFile(parent,name,data,canRead,canWrite,canOwn){var path=name;if(parent){parent=typeof parent=="string"?parent:FS.getPath(parent);path=name?PATH.join2(parent,name):parent}var mode=FS_getMode(canRead,canWrite);var node=FS.create(path,mode);if(data){if(typeof data=="string"){var arr=new Array(data.length);for(var i=0,len=data.length;i<len;++i)arr[i]=data.charCodeAt(i);data=arr}FS.chmod(node,mode|146);var stream=FS.open(node,577);FS.write(stream,data,0,data.length,0,canOwn);FS.close(stream);FS.chmod(node,mode)}},createDevice(parent,name,input,output){var path=PATH.join2(typeof parent=="string"?parent:FS.getPath(parent),name);var mode=FS_getMode(!!input,!!output);FS.createDevice.major??=64;var dev=FS.makedev(FS.createDevice.major++,0);FS.registerDevice(dev,{open(stream){stream.seekable=false},close(stream){if(output?.buffer?.length){output(10)}},read(stream,buffer,offset,length,pos){var bytesRead=0;for(var i=0;i<length;i++){var result;try{result=input()}catch(e){throw new FS.ErrnoError(29)}if(result===undefined&&bytesRead===0){throw new FS.ErrnoError(6)}if(result===null||result===undefined)break;bytesRead++;buffer[offset+i]=result}if(bytesRead){stream.node.atime=Date.now()}return bytesRead},write(stream,buffer,offset,length,pos){for(var i=0;i<length;i++){try{output(buffer[offset+i])}catch(e){throw new FS.ErrnoError(29)}}if(length){stream.node.mtime=stream.node.ctime=Date.now()}return i}});return FS.mkdev(path,mode,dev)},forceLoadFile(obj){if(obj.isDevice||obj.isFolder||obj.link||obj.contents)return true;if(globalThis.XMLHttpRequest){abort("Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.")}else{try{obj.contents=readBinary(obj.url)}catch(e){throw new FS.ErrnoError(29)}}},createLazyFile(parent,name,url,canRead,canWrite){class LazyUint8Array{lengthKnown=false;chunks=[];get(idx){if(idx>this.length-1||idx<0){return undefined}var chunkOffset=idx%this.chunkSize;var chunkNum=idx/this.chunkSize|0;return this.getter(chunkNum)[chunkOffset]}setDataGetter(getter){this.getter=getter}cacheLength(){var xhr=new XMLHttpRequest;xhr.open("HEAD",url,false);xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))abort("Couldn't load "+url+". Status: "+xhr.status);var datalength=Number(xhr.getResponseHeader("Content-length"));var header;var hasByteServing=(header=xhr.getResponseHeader("Accept-Ranges"))&&header==="bytes";var usesGzip=(header=xhr.getResponseHeader("Content-Encoding"))&&header==="gzip";var chunkSize=1024*1024;if(!hasByteServing)chunkSize=datalength;var doXHR=(from,to)=>{if(from>to)abort("invalid range ("+from+", "+to+") or no bytes requested!");if(to>datalength-1)abort("only "+datalength+" bytes available! programmer error!");var xhr=new XMLHttpRequest;xhr.open("GET",url,false);if(datalength!==chunkSize)xhr.setRequestHeader("Range","bytes="+from+"-"+to);xhr.responseType="arraybuffer";if(xhr.overrideMimeType){xhr.overrideMimeType("text/plain; charset=x-user-defined")}xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))abort("Couldn't load "+url+". Status: "+xhr.status);if(xhr.response!==undefined){return new Uint8Array(xhr.response||[])}return intArrayFromString(xhr.responseText||"",true)};var lazyArray=this;lazyArray.setDataGetter(chunkNum=>{var start=chunkNum*chunkSize;var end=(chunkNum+1)*chunkSize-1;end=Math.min(end,datalength-1);if(typeof lazyArray.chunks[chunkNum]=="undefined"){lazyArray.chunks[chunkNum]=doXHR(start,end)}if(typeof lazyArray.chunks[chunkNum]=="undefined")abort("doXHR failed!");return lazyArray.chunks[chunkNum]});if(usesGzip||!datalength){chunkSize=datalength=1;datalength=this.getter(0).length;chunkSize=datalength;out("LazyFiles on gzip forces download of the whole file when length is accessed")}this._length=datalength;this._chunkSize=chunkSize;this.lengthKnown=true}get length(){if(!this.lengthKnown){this.cacheLength()}return this._length}get chunkSize(){if(!this.lengthKnown){this.cacheLength()}return this._chunkSize}}if(globalThis.XMLHttpRequest){if(!ENVIRONMENT_IS_WORKER)abort("Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc");var lazyArray=new LazyUint8Array;var properties={isDevice:false,contents:lazyArray}}else{var properties={isDevice:false,url}}var node=FS.createFile(parent,name,properties,canRead,canWrite);if(properties.contents){node.contents=properties.contents}else if(properties.url){node.contents=null;node.url=properties.url}Object.defineProperties(node,{usedBytes:{get:function(){return this.contents.length}}});var stream_ops={};for(const[key,fn]of Object.entries(node.stream_ops)){stream_ops[key]=(...args)=>{FS.forceLoadFile(node);return fn(...args)}}function writeChunks(stream,buffer,offset,length,position){var contents=stream.node.contents;if(position>=contents.length)return 0;var size=Math.min(contents.length-position,length);if(contents.slice){for(var i=0;i<size;i++){buffer[offset+i]=contents[position+i]}}else{for(var i=0;i<size;i++){buffer[offset+i]=contents.get(position+i)}}return size}stream_ops.read=(stream,buffer,offset,length,position)=>{FS.forceLoadFile(node);return writeChunks(stream,buffer,offset,length,position)};stream_ops.mmap=(stream,length,position,prot,flags)=>{FS.forceLoadFile(node);var ptr=mmapAlloc(length);if(!ptr){throw new FS.ErrnoError(48)}writeChunks(stream,HEAP8,ptr,length,position);return{ptr,allocated:true}};node.stream_ops=stream_ops;return node}};var UTF8ToString=(ptr,maxBytesToRead,ignoreNul)=>ptr?UTF8ArrayToString(HEAPU8,ptr,maxBytesToRead,ignoreNul):"";var SYSCALLS={calculateAt(dirfd,path,allowEmpty){if(PATH.isAbs(path)){return path}var dir;if(dirfd===-100){dir=FS.cwd()}else{var dirstream=SYSCALLS.getStreamFromFD(dirfd);dir=dirstream.path}if(path.length==0){if(!allowEmpty){throw new FS.ErrnoError(44)}return dir}return dir+"/"+path},writeStat(buf,stat){HEAPU32[buf>>2]=stat.dev;HEAPU32[buf+4>>2]=stat.mode;HEAPU32[buf+8>>2]=stat.nlink;HEAPU32[buf+12>>2]=stat.uid;HEAPU32[buf+16>>2]=stat.gid;HEAPU32[buf+20>>2]=stat.rdev;HEAP64[buf+24>>3]=BigInt(stat.size);HEAP32[buf+32>>2]=4096;HEAP32[buf+36>>2]=stat.blocks;var atime=stat.atime.getTime();var mtime=stat.mtime.getTime();var ctime=stat.ctime.getTime();HEAP64[buf+40>>3]=BigInt(Math.floor(atime/1e3));HEAPU32[buf+48>>2]=atime%1e3*1e3*1e3;HEAP64[buf+56>>3]=BigInt(Math.floor(mtime/1e3));HEAPU32[buf+64>>2]=mtime%1e3*1e3*1e3;HEAP64[buf+72>>3]=BigInt(Math.floor(ctime/1e3));HEAPU32[buf+80>>2]=ctime%1e3*1e3*1e3;HEAP64[buf+88>>3]=BigInt(stat.ino);return 0},writeStatFs(buf,stats){HEAPU32[buf+4>>2]=stats.bsize;HEAPU32[buf+60>>2]=stats.bsize;HEAP64[buf+8>>3]=BigInt(stats.blocks);HEAP64[buf+16>>3]=BigInt(stats.bfree);HEAP64[buf+24>>3]=BigInt(stats.bavail);HEAP64[buf+32>>3]=BigInt(stats.files);HEAP64[buf+40>>3]=BigInt(stats.ffree);HEAPU32[buf+48>>2]=stats.fsid;HEAPU32[buf+64>>2]=stats.flags;HEAPU32[buf+56>>2]=stats.namelen},doMsync(addr,stream,len,flags,offset){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(43)}if(flags&2){return 0}var buffer=HEAPU8.slice(addr,addr+len);FS.msync(stream,buffer,offset,len,flags)},getStreamFromFD(fd){var stream=FS.getStreamChecked(fd);return stream},varargs:undefined,getStr(ptr){var ret=UTF8ToString(ptr);return ret}};function ___syscall_fcntl64(fd,cmd,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(fd);switch(cmd){case 0:{var arg=syscallGetVarargI();if(arg<0){return-28}while(FS.streams[arg]){arg++}var newStream;newStream=FS.dupStream(stream,arg);return newStream.fd}case 1:case 2:return 0;case 3:return stream.flags;case 4:{var arg=syscallGetVarargI();stream.flags|=arg;return 0}case 12:{var arg=syscallGetVarargP();var offset=0;HEAP16[arg+offset>>1]=2;return 0}case 13:case 14:return 0}return-28}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}var stringToUTF8=(str,outPtr,maxBytesToWrite)=>stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrite);function ___syscall_getdents64(fd,dirp,count){try{var stream=SYSCALLS.getStreamFromFD(fd);stream.getdents||=FS.readdir(stream.path);var struct_size=280;var pos=0;var off=FS.llseek(stream,0,1);var startIdx=Math.floor(off/struct_size);var endIdx=Math.min(stream.getdents.length,startIdx+Math.floor(count/struct_size));for(var idx=startIdx;idx<endIdx;idx++){var id;var type;var name=stream.getdents[idx];if(name==="."){id=stream.node.id;type=4}else if(name===".."){var lookup=FS.lookupPath(stream.path,{parent:true});id=lookup.node.id;type=4}else{var child;try{child=FS.lookupNode(stream.node,name)}catch(e){if(e?.errno===28){continue}throw e}id=child.id;type=FS.isChrdev(child.mode)?2:FS.isDir(child.mode)?4:FS.isLink(child.mode)?10:8}HEAP64[dirp+pos>>3]=BigInt(id);HEAP64[dirp+pos+8>>3]=BigInt((idx+1)*struct_size);HEAP16[dirp+pos+16>>1]=280;HEAP8[dirp+pos+18]=type;stringToUTF8(name,dirp+pos+19,256);pos+=struct_size}FS.llseek(stream,idx*struct_size,0);return pos}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}function ___syscall_ioctl(fd,op,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(fd);switch(op){case 21509:{if(!stream.tty)return-59;return 0}case 21505:{if(!stream.tty)return-59;if(stream.tty.ops.ioctl_tcgets){var termios=stream.tty.ops.ioctl_tcgets(stream);var argp=syscallGetVarargP();HEAP32[argp>>2]=termios.c_iflag||0;HEAP32[argp+4>>2]=termios.c_oflag||0;HEAP32[argp+8>>2]=termios.c_cflag||0;HEAP32[argp+12>>2]=termios.c_lflag||0;for(var i=0;i<32;i++){HEAP8[argp+i+17]=termios.c_cc[i]||0}return 0}return 0}case 21510:case 21511:case 21512:{if(!stream.tty)return-59;return 0}case 21506:case 21507:case 21508:{if(!stream.tty)return-59;if(stream.tty.ops.ioctl_tcsets){var argp=syscallGetVarargP();var c_iflag=HEAP32[argp>>2];var c_oflag=HEAP32[argp+4>>2];var c_cflag=HEAP32[argp+8>>2];var c_lflag=HEAP32[argp+12>>2];var c_cc=[];for(var i=0;i<32;i++){c_cc.push(HEAP8[argp+i+17])}return stream.tty.ops.ioctl_tcsets(stream.tty,op,{c_iflag,c_oflag,c_cflag,c_lflag,c_cc})}return 0}case 21519:{if(!stream.tty)return-59;var argp=syscallGetVarargP();HEAP32[argp>>2]=0;return 0}case 21520:{if(!stream.tty)return-59;return-28}case 21537:case 21531:{var argp=syscallGetVarargP();return FS.ioctl(stream,op,argp)}case 21523:{if(!stream.tty)return-59;if(stream.tty.ops.ioctl_tiocgwinsz){var winsize=stream.tty.ops.ioctl_tiocgwinsz(stream.tty);var argp=syscallGetVarargP();HEAP16[argp>>1]=winsize[0];HEAP16[argp+2>>1]=winsize[1]}return 0}case 21524:{if(!stream.tty)return-59;return 0}case 21515:{if(!stream.tty)return-59;return 0}default:return-28}}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}function ___syscall_openat(dirfd,path,flags,varargs){SYSCALLS.varargs=varargs;try{path=SYSCALLS.getStr(path);path=SYSCALLS.calculateAt(dirfd,path);var mode=varargs?syscallGetVarargI():0;return FS.open(path,flags,mode).fd}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}function ___syscall_stat64(path,buf){try{path=SYSCALLS.getStr(path);return SYSCALLS.writeStat(buf,FS.stat(path))}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return-e.errno}}var __abort_js=()=>abort("");var getHeapMax=()=>2147483648;var alignMemory=(size,alignment)=>Math.ceil(size/alignment)*alignment;var growMemory=size=>{var oldHeapSize=wasmMemory.buffer.byteLength;var pages=(size-oldHeapSize+65535)/65536|0;try{wasmMemory.grow(pages);updateMemoryViews();return 1}catch(e){}};var _emscripten_resize_heap=requestedSize=>{var oldSize=HEAPU8.length;requestedSize>>>=0;var maxHeapSize=getHeapMax();if(requestedSize>maxHeapSize){return false}for(var cutDown=1;cutDown<=4;cutDown*=2){var overGrownHeapSize=oldSize*(1+.2/cutDown);overGrownHeapSize=Math.min(overGrownHeapSize,requestedSize+100663296);var newSize=Math.min(maxHeapSize,alignMemory(Math.max(requestedSize,overGrownHeapSize),65536));var replacement=growMemory(newSize);if(replacement){return true}}return false};var ENV={};var getExecutableName=()=>thisProgram||"./this.program";var getEnvStrings=()=>{if(!getEnvStrings.strings){var lang=(globalThis.navigator?.language??"C").replace("-","_")+".UTF-8";var env={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:lang,_:getExecutableName()};for(var x in ENV){if(ENV[x]===undefined)delete env[x];else env[x]=ENV[x]}var strings=[];for(var x in env){strings.push(`${x}=${env[x]}`)}getEnvStrings.strings=strings}return getEnvStrings.strings};var _environ_get=(__environ,environ_buf)=>{var bufSize=0;var envp=0;for(var string of getEnvStrings()){var ptr=environ_buf+bufSize;HEAPU32[__environ+envp>>2]=ptr;bufSize+=stringToUTF8(string,ptr,Infinity)+1;envp+=4}return 0};var _environ_sizes_get=(penviron_count,penviron_buf_size)=>{var strings=getEnvStrings();HEAPU32[penviron_count>>2]=strings.length;var bufSize=0;for(var string of strings){bufSize+=lengthBytesUTF8(string)+1}HEAPU32[penviron_buf_size>>2]=bufSize;return 0};function _fd_close(fd){try{var stream=SYSCALLS.getStreamFromFD(fd);FS.close(stream);return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}var doReadv=(stream,iov,iovcnt,offset)=>{var ret=0;for(var i=0;i<iovcnt;i++){var ptr=HEAPU32[iov>>2];var len=HEAPU32[iov+4>>2];iov+=8;var curr=FS.read(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr<len)break;if(typeof offset!="undefined"){offset+=curr}}return ret};function _fd_read(fd,iov,iovcnt,pnum){try{var stream=SYSCALLS.getStreamFromFD(fd);var num=doReadv(stream,iov,iovcnt);HEAPU32[pnum>>2]=num;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}var INT53_MAX=9007199254740992;var INT53_MIN=-9007199254740992;var bigintToI53Checked=num=>num<INT53_MIN||num>INT53_MAX?NaN:Number(num);function _fd_seek(fd,offset,whence,newOffset){offset=bigintToI53Checked(offset);try{if(isNaN(offset))return 61;var stream=SYSCALLS.getStreamFromFD(fd);FS.llseek(stream,offset,whence);HEAP64[newOffset>>3]=BigInt(stream.position);if(stream.getdents&&offset===0&&whence===0)stream.getdents=null;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}var doWritev=(stream,iov,iovcnt,offset)=>{var ret=0;for(var i=0;i<iovcnt;i++){var ptr=HEAPU32[iov>>2];var len=HEAPU32[iov+4>>2];iov+=8;var curr=FS.write(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr<len){break}if(typeof offset!="undefined"){offset+=curr}}return ret};function _fd_write(fd,iov,iovcnt,pnum){try{var stream=SYSCALLS.getStreamFromFD(fd);var num=doWritev(stream,iov,iovcnt);HEAPU32[pnum>>2]=num;return 0}catch(e){if(typeof FS=="undefined"||!(e.name==="ErrnoError"))throw e;return e.errno}}var getCFunc=ident=>{var func=Module["_"+ident];return func};var writeArrayToMemory=(array,buffer)=>{HEAP8.set(array,buffer)};var stackAlloc=sz=>__emscripten_stack_alloc(sz);var stringToUTF8OnStack=str=>{var size=lengthBytesUTF8(str)+1;var ret=stackAlloc(size);stringToUTF8(str,ret,size);return ret};var ccall=(ident,returnType,argTypes,args,opts)=>{var toC={string:str=>{var ret=0;if(str!==null&&str!==undefined&&str!==0){ret=stringToUTF8OnStack(str)}return ret},array:arr=>{var ret=stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}};function convertReturnValue(ret){if(returnType==="string"){return UTF8ToString(ret)}if(returnType==="boolean")return Boolean(ret);return ret}var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i<args.length;i++){var converter=toC[argTypes[i]];if(converter){if(stack===0)stack=stackSave();cArgs[i]=converter(args[i])}else{cArgs[i]=args[i]}}}var ret=func(...cArgs);function onDone(ret){if(stack!==0)stackRestore(stack);return convertReturnValue(ret)}ret=onDone(ret);return ret};var cwrap=(ident,returnType,argTypes,opts)=>{var numericArgs=!argTypes||argTypes.every(type=>type==="number"||type==="boolean");var numericRet=returnType!=="string";if(numericRet&&numericArgs&&!opts){return getCFunc(ident)}return(...args)=>ccall(ident,returnType,argTypes,args,opts)};var FS_createPath=(...args)=>FS.createPath(...args);var FS_unlink=(...args)=>FS.unlink(...args);var FS_createLazyFile=(...args)=>FS.createLazyFile(...args);var FS_createDevice=(...args)=>FS.createDevice(...args);FS.createPreloadedFile=FS_createPreloadedFile;FS.preloadFile=FS_preloadFile;FS.staticInit();{if(Module["noExitRuntime"])noExitRuntime=Module["noExitRuntime"];if(Module["preloadPlugins"])preloadPlugins=Module["preloadPlugins"];if(Module["print"])out=Module["print"];if(Module["printErr"])err=Module["printErr"];if(Module["wasmBinary"])wasmBinary=Module["wasmBinary"];if(Module["arguments"])arguments_=Module["arguments"];if(Module["thisProgram"])thisProgram=Module["thisProgram"];if(Module["preInit"]){if(typeof Module["preInit"]=="function")Module["preInit"]=[Module["preInit"]];while(Module["preInit"].length>0){Module["preInit"].shift()()}}}Module["addRunDependency"]=addRunDependency;Module["removeRunDependency"]=removeRunDependency;Module["cwrap"]=cwrap;Module["UTF8ToString"]=UTF8ToString;Module["stringToUTF8"]=stringToUTF8;Module["lengthBytesUTF8"]=lengthBytesUTF8;Module["FS_preloadFile"]=FS_preloadFile;Module["FS_unlink"]=FS_unlink;Module["FS_createPath"]=FS_createPath;Module["FS_createDevice"]=FS_createDevice;Module["FS_createDataFile"]=FS_createDataFile;Module["FS_createLazyFile"]=FS_createLazyFile;var _lfw_init,_lfw_dispose,_lfw_find_lenses_json,_lfw_find_cameras_json,_lfw_available_mods,_lfw_build_geometry_map,_lfw_build_tca_map,_lfw_build_vignetting_map,_lfw_free,_malloc,_free,__emscripten_stack_restore,__emscripten_stack_alloc,_emscripten_stack_get_current,memory,__indirect_function_table,wasmMemory;function assignWasmExports(wasmExports){_lfw_init=Module["_lfw_init"]=wasmExports["q"];_lfw_dispose=Module["_lfw_dispose"]=wasmExports["r"];_lfw_find_lenses_json=Module["_lfw_find_lenses_json"]=wasmExports["s"];_lfw_find_cameras_json=Module["_lfw_find_cameras_json"]=wasmExports["t"];_lfw_available_mods=Module["_lfw_available_mods"]=wasmExports["u"];_lfw_build_geometry_map=Module["_lfw_build_geometry_map"]=wasmExports["v"];_lfw_build_tca_map=Module["_lfw_build_tca_map"]=wasmExports["w"];_lfw_build_vignetting_map=Module["_lfw_build_vignetting_map"]=wasmExports["x"];_lfw_free=Module["_lfw_free"]=wasmExports["y"];_malloc=Module["_malloc"]=wasmExports["z"];_free=Module["_free"]=wasmExports["A"];__emscripten_stack_restore=wasmExports["B"];__emscripten_stack_alloc=wasmExports["C"];_emscripten_stack_get_current=wasmExports["D"];memory=wasmMemory=wasmExports["o"];__indirect_function_table=wasmExports["__indirect_function_table"]}var wasmImports={a:___cxa_throw,e:___syscall_fcntl64,k:___syscall_getdents64,m:___syscall_ioctl,c:___syscall_openat,h:___syscall_stat64,i:__abort_js,n:_emscripten_resize_heap,f:_environ_get,g:_environ_sizes_get,b:_fd_close,l:_fd_read,j:_fd_seek,d:_fd_write};function run(){if(runDependencies>0){dependenciesFulfilled=run;return}preRun();if(runDependencies>0){dependenciesFulfilled=run;return}function doRun(){Module["calledRun"]=true;if(ABORT)return;initRuntime();readyPromiseResolve?.(Module);Module["onRuntimeInitialized"]?.();postRun()}if(Module["setStatus"]){Module["setStatus"]("Running...");setTimeout(()=>{setTimeout(()=>Module["setStatus"](""),1);doRun()},1)}else{doRun()}}var wasmExports;wasmExports=await (createWasm());run();if(runtimeInitialized){moduleRtn=Module}else{moduleRtn=new Promise((resolve,reject)=>{readyPromiseResolve=resolve;readyPromiseReject=reject})}
|
|
2
|
+
;return moduleRtn}})();if(typeof exports==="object"&&typeof module==="object"){module.exports=createLensfunCoreModule;module.exports.default=createLensfunCoreModule}else if(typeof define==="function"&&define["amd"])define([],()=>createLensfunCoreModule);
|
|
Binary file
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
// src/index.ts
|
|
2
|
+
var LF_SEARCH_LOOSE = 1;
|
|
3
|
+
var LF_SEARCH_SORT_AND_UNIQUIFY = 2;
|
|
4
|
+
var LF_MODIFY_TCA = 1;
|
|
5
|
+
var LF_MODIFY_VIGNETTING = 2;
|
|
6
|
+
var LF_MODIFY_DISTORTION = 8;
|
|
7
|
+
var LF_MODIFY_GEOMETRY = 16;
|
|
8
|
+
var LF_MODIFY_SCALE = 32;
|
|
9
|
+
var LF_MODIFY_PERSPECTIVE = 64;
|
|
10
|
+
var globalScope = globalThis;
|
|
11
|
+
function requiredString(value, field) {
|
|
12
|
+
if (!value || value.trim().length === 0) {
|
|
13
|
+
throw new Error(`[lensfun-wasm] ${field} is required`);
|
|
14
|
+
}
|
|
15
|
+
return value;
|
|
16
|
+
}
|
|
17
|
+
function toFlag(value) {
|
|
18
|
+
return value ? 1 : 0;
|
|
19
|
+
}
|
|
20
|
+
function toGrid(size, step) {
|
|
21
|
+
return Math.floor((size - 1) / step) + 1;
|
|
22
|
+
}
|
|
23
|
+
function requirePositiveInt(value, field) {
|
|
24
|
+
if (!Number.isInteger(value) || value <= 0) {
|
|
25
|
+
throw new Error(`[lensfun-wasm] ${field} must be a positive integer`);
|
|
26
|
+
}
|
|
27
|
+
return value;
|
|
28
|
+
}
|
|
29
|
+
async function loadScript(url) {
|
|
30
|
+
if (typeof document === "undefined") {
|
|
31
|
+
throw new Error("[lensfun-wasm] moduleJsUrl in non-browser runtime requires moduleFactory instead");
|
|
32
|
+
}
|
|
33
|
+
await new Promise((resolve, reject) => {
|
|
34
|
+
const script = document.createElement("script");
|
|
35
|
+
script.src = url;
|
|
36
|
+
script.async = true;
|
|
37
|
+
script.onload = () => resolve();
|
|
38
|
+
script.onerror = () => reject(new Error(`[lensfun-wasm] failed to load ${url}`));
|
|
39
|
+
document.head.appendChild(script);
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
async function resolveFactory(options) {
|
|
43
|
+
if (options.moduleFactory) {
|
|
44
|
+
return options.moduleFactory;
|
|
45
|
+
}
|
|
46
|
+
const existing = globalScope.createLensfunCoreModule;
|
|
47
|
+
if (typeof existing === "function") {
|
|
48
|
+
return existing;
|
|
49
|
+
}
|
|
50
|
+
if (options.moduleJsUrl) {
|
|
51
|
+
if (typeof document !== "undefined") {
|
|
52
|
+
await loadScript(options.moduleJsUrl);
|
|
53
|
+
const globalFactory = globalScope.createLensfunCoreModule;
|
|
54
|
+
if (typeof globalFactory === "function") {
|
|
55
|
+
return globalFactory;
|
|
56
|
+
}
|
|
57
|
+
} else {
|
|
58
|
+
const imported = await import(
|
|
59
|
+
/* @vite-ignore */
|
|
60
|
+
options.moduleJsUrl
|
|
61
|
+
);
|
|
62
|
+
const loaded = imported.default ?? imported.createLensfunCoreModule;
|
|
63
|
+
if (typeof loaded === "function") {
|
|
64
|
+
return loaded;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
throw new Error(
|
|
69
|
+
"[lensfun-wasm] module factory not found. Provide moduleFactory or preload dist/assets/lensfun-core.js (global createLensfunCoreModule)."
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
function makeLocateFile(options) {
|
|
73
|
+
return (path, prefix) => {
|
|
74
|
+
if (options.locateFile) {
|
|
75
|
+
return options.locateFile(path, prefix);
|
|
76
|
+
}
|
|
77
|
+
if (path.endsWith(".wasm") && options.wasmUrl) {
|
|
78
|
+
return options.wasmUrl;
|
|
79
|
+
}
|
|
80
|
+
if (path.endsWith(".data") && options.dataUrl) {
|
|
81
|
+
return options.dataUrl;
|
|
82
|
+
}
|
|
83
|
+
return `${prefix}${path}`;
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
function parseJsonPtr(module, freePtr, ptr) {
|
|
87
|
+
if (!ptr) {
|
|
88
|
+
return [];
|
|
89
|
+
}
|
|
90
|
+
const raw = module.UTF8ToString(ptr);
|
|
91
|
+
freePtr(ptr);
|
|
92
|
+
if (!raw) {
|
|
93
|
+
return [];
|
|
94
|
+
}
|
|
95
|
+
return JSON.parse(raw);
|
|
96
|
+
}
|
|
97
|
+
function bindFns(module) {
|
|
98
|
+
return {
|
|
99
|
+
init: module.cwrap("lfw_init", "number", ["string"]),
|
|
100
|
+
dispose: module.cwrap("lfw_dispose", null, []),
|
|
101
|
+
findLensesJson: module.cwrap("lfw_find_lenses_json", "number", ["string", "string", "string", "string", "number"]),
|
|
102
|
+
findCamerasJson: module.cwrap("lfw_find_cameras_json", "number", ["string", "string", "number"]),
|
|
103
|
+
availableMods: module.cwrap("lfw_available_mods", "number", ["number", "number"]),
|
|
104
|
+
buildGeometryMap: module.cwrap("lfw_build_geometry_map", "number", [
|
|
105
|
+
"number",
|
|
106
|
+
"number",
|
|
107
|
+
"number",
|
|
108
|
+
"number",
|
|
109
|
+
"number",
|
|
110
|
+
"number",
|
|
111
|
+
"number",
|
|
112
|
+
"number",
|
|
113
|
+
"number"
|
|
114
|
+
]),
|
|
115
|
+
buildTcaMap: module.cwrap("lfw_build_tca_map", "number", [
|
|
116
|
+
"number",
|
|
117
|
+
"number",
|
|
118
|
+
"number",
|
|
119
|
+
"number",
|
|
120
|
+
"number",
|
|
121
|
+
"number",
|
|
122
|
+
"number",
|
|
123
|
+
"number",
|
|
124
|
+
"number"
|
|
125
|
+
]),
|
|
126
|
+
buildVignettingMap: module.cwrap("lfw_build_vignetting_map", "number", [
|
|
127
|
+
"number",
|
|
128
|
+
"number",
|
|
129
|
+
"number",
|
|
130
|
+
"number",
|
|
131
|
+
"number",
|
|
132
|
+
"number",
|
|
133
|
+
"number",
|
|
134
|
+
"number",
|
|
135
|
+
"number",
|
|
136
|
+
"number",
|
|
137
|
+
"number"
|
|
138
|
+
]),
|
|
139
|
+
freePtr: module.cwrap("lfw_free", null, ["number"])
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
var LensfunClient = class {
|
|
143
|
+
constructor(module, fns) {
|
|
144
|
+
this.disposed = false;
|
|
145
|
+
this.module = module;
|
|
146
|
+
this.fns = fns;
|
|
147
|
+
}
|
|
148
|
+
dispose() {
|
|
149
|
+
if (this.disposed) {
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
this.fns.dispose();
|
|
153
|
+
this.disposed = true;
|
|
154
|
+
}
|
|
155
|
+
searchLenses(input) {
|
|
156
|
+
this.ensureAlive();
|
|
157
|
+
const lensModel = requiredString(input.lensModel, "lensModel");
|
|
158
|
+
const ptr = this.fns.findLensesJson(
|
|
159
|
+
input.cameraMaker ?? "",
|
|
160
|
+
input.cameraModel ?? "",
|
|
161
|
+
input.lensMaker ?? "",
|
|
162
|
+
lensModel,
|
|
163
|
+
input.searchFlags ?? LF_SEARCH_SORT_AND_UNIQUIFY
|
|
164
|
+
);
|
|
165
|
+
return parseJsonPtr(this.module, this.fns.freePtr, ptr);
|
|
166
|
+
}
|
|
167
|
+
searchCameras(input) {
|
|
168
|
+
this.ensureAlive();
|
|
169
|
+
const ptr = this.fns.findCamerasJson(
|
|
170
|
+
input.maker ?? "",
|
|
171
|
+
input.model ?? "",
|
|
172
|
+
input.searchFlags ?? 0
|
|
173
|
+
);
|
|
174
|
+
return parseJsonPtr(this.module, this.fns.freePtr, ptr);
|
|
175
|
+
}
|
|
176
|
+
getAvailableModifications(lensHandle, crop) {
|
|
177
|
+
this.ensureAlive();
|
|
178
|
+
return this.fns.availableMods(lensHandle, crop);
|
|
179
|
+
}
|
|
180
|
+
buildCorrectionMaps(input) {
|
|
181
|
+
this.ensureAlive();
|
|
182
|
+
const width = requirePositiveInt(input.width, "width");
|
|
183
|
+
const height = requirePositiveInt(input.height, "height");
|
|
184
|
+
const step = requirePositiveInt(input.step ?? 1, "step");
|
|
185
|
+
const gridWidth = toGrid(width, step);
|
|
186
|
+
const gridHeight = toGrid(height, step);
|
|
187
|
+
const geometry = this.runFloatMap(
|
|
188
|
+
gridWidth * gridHeight * 2,
|
|
189
|
+
this.fns.buildGeometryMap,
|
|
190
|
+
input.lensHandle,
|
|
191
|
+
input.focal,
|
|
192
|
+
input.crop,
|
|
193
|
+
width,
|
|
194
|
+
height,
|
|
195
|
+
toFlag(input.reverse),
|
|
196
|
+
step
|
|
197
|
+
);
|
|
198
|
+
const result = {
|
|
199
|
+
gridWidth,
|
|
200
|
+
gridHeight,
|
|
201
|
+
step,
|
|
202
|
+
geometry
|
|
203
|
+
};
|
|
204
|
+
if (input.includeTca) {
|
|
205
|
+
result.tca = this.runFloatMap(
|
|
206
|
+
gridWidth * gridHeight * 6,
|
|
207
|
+
this.fns.buildTcaMap,
|
|
208
|
+
input.lensHandle,
|
|
209
|
+
input.focal,
|
|
210
|
+
input.crop,
|
|
211
|
+
width,
|
|
212
|
+
height,
|
|
213
|
+
toFlag(input.reverse),
|
|
214
|
+
step
|
|
215
|
+
);
|
|
216
|
+
}
|
|
217
|
+
if (input.includeVignetting) {
|
|
218
|
+
if (typeof input.aperture !== "number") {
|
|
219
|
+
throw new Error("[lensfun-wasm] aperture is required for vignetting map");
|
|
220
|
+
}
|
|
221
|
+
result.vignetting = this.runFloatMap(
|
|
222
|
+
gridWidth * gridHeight * 3,
|
|
223
|
+
this.fns.buildVignettingMap,
|
|
224
|
+
input.lensHandle,
|
|
225
|
+
input.focal,
|
|
226
|
+
input.crop,
|
|
227
|
+
input.aperture,
|
|
228
|
+
input.distance ?? 1e3,
|
|
229
|
+
width,
|
|
230
|
+
height,
|
|
231
|
+
toFlag(input.reverse),
|
|
232
|
+
step
|
|
233
|
+
);
|
|
234
|
+
}
|
|
235
|
+
return result;
|
|
236
|
+
}
|
|
237
|
+
runFloatMap(size, fn, ...args) {
|
|
238
|
+
const bytes = size * 4;
|
|
239
|
+
const ptr = this.module._malloc(bytes);
|
|
240
|
+
try {
|
|
241
|
+
const rc = fn(...args, ptr, size);
|
|
242
|
+
if (rc !== 0) {
|
|
243
|
+
throw new Error(`[lensfun-wasm] native map builder failed with code ${rc}`);
|
|
244
|
+
}
|
|
245
|
+
const start = ptr >> 2;
|
|
246
|
+
const end = start + size;
|
|
247
|
+
const out = new Float32Array(size);
|
|
248
|
+
out.set(this.module.HEAPF32.subarray(start, end));
|
|
249
|
+
return out;
|
|
250
|
+
} finally {
|
|
251
|
+
this.module._free(ptr);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
ensureAlive() {
|
|
255
|
+
if (this.disposed) {
|
|
256
|
+
throw new Error("[lensfun-wasm] LensfunClient is disposed");
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
};
|
|
260
|
+
async function createLensfun(options = {}) {
|
|
261
|
+
const factory = await resolveFactory(options);
|
|
262
|
+
if (!factory) {
|
|
263
|
+
throw new Error("[lensfun-wasm] failed to resolve module factory");
|
|
264
|
+
}
|
|
265
|
+
const module = await factory({
|
|
266
|
+
locateFile: makeLocateFile(options)
|
|
267
|
+
});
|
|
268
|
+
const fns = bindFns(module);
|
|
269
|
+
if (options.autoInitDb ?? true) {
|
|
270
|
+
const dbPath = options.dbPath ?? "/lensfun-db";
|
|
271
|
+
const rc = fns.init(dbPath);
|
|
272
|
+
if (rc !== 0) {
|
|
273
|
+
throw new Error(`[lensfun-wasm] lfw_init failed with code ${rc} for ${dbPath}`);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
return new LensfunClient(module, fns);
|
|
277
|
+
}
|
|
278
|
+
export {
|
|
279
|
+
LF_MODIFY_DISTORTION,
|
|
280
|
+
LF_MODIFY_GEOMETRY,
|
|
281
|
+
LF_MODIFY_PERSPECTIVE,
|
|
282
|
+
LF_MODIFY_SCALE,
|
|
283
|
+
LF_MODIFY_TCA,
|
|
284
|
+
LF_MODIFY_VIGNETTING,
|
|
285
|
+
LF_SEARCH_LOOSE,
|
|
286
|
+
LF_SEARCH_SORT_AND_UNIQUIFY,
|
|
287
|
+
LensfunClient,
|
|
288
|
+
createLensfun
|
|
289
|
+
};
|
|
290
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["export const LF_SEARCH_LOOSE = 1;\nexport const LF_SEARCH_SORT_AND_UNIQUIFY = 2;\n\nexport const LF_MODIFY_TCA = 0x00000001;\nexport const LF_MODIFY_VIGNETTING = 0x00000002;\nexport const LF_MODIFY_DISTORTION = 0x00000008;\nexport const LF_MODIFY_GEOMETRY = 0x00000010;\nexport const LF_MODIFY_SCALE = 0x00000020;\nexport const LF_MODIFY_PERSPECTIVE = 0x00000040;\n\nexport interface LensfunModule {\n cwrap: (ident: string, returnType: string | null, argTypes: string[]) => (...args: unknown[]) => unknown;\n UTF8ToString: (ptr: number) => string;\n _malloc: (size: number) => number;\n _free: (ptr: number) => void;\n HEAPF32: Float32Array;\n}\n\nexport interface LensfunInitOptions {\n moduleFactory?: (options?: Record<string, unknown>) => Promise<LensfunModule>;\n moduleJsUrl?: string;\n wasmUrl?: string;\n dataUrl?: string;\n locateFile?: (path: string, prefix: string) => string;\n dbPath?: string;\n autoInitDb?: boolean;\n}\n\nexport interface LensMatch {\n handle: number;\n maker: string;\n model: string;\n score: number;\n minFocal: number;\n maxFocal: number;\n minAperture: number;\n maxAperture: number;\n cropFactor: number;\n}\n\nexport interface CameraMatch {\n maker: string;\n model: string;\n variant: string;\n mount: string;\n cropFactor: number;\n score: number;\n}\n\nexport interface SearchLensesInput {\n lensMaker?: string;\n lensModel: string;\n cameraMaker?: string;\n cameraModel?: string;\n searchFlags?: number;\n}\n\nexport interface SearchCamerasInput {\n maker?: string;\n model?: string;\n searchFlags?: number;\n}\n\nexport interface CorrectionInput {\n lensHandle: number;\n width: number;\n height: number;\n focal: number;\n crop: number;\n step?: number;\n reverse?: boolean;\n includeTca?: boolean;\n includeVignetting?: boolean;\n aperture?: number;\n distance?: number;\n}\n\nexport interface CorrectionMaps {\n gridWidth: number;\n gridHeight: number;\n step: number;\n geometry: Float32Array;\n tca?: Float32Array;\n vignetting?: Float32Array;\n}\n\ntype CFn = (...args: unknown[]) => unknown;\n\ninterface NativeFns {\n init: CFn;\n dispose: CFn;\n findLensesJson: CFn;\n findCamerasJson: CFn;\n availableMods: CFn;\n buildGeometryMap: CFn;\n buildTcaMap: CFn;\n buildVignettingMap: CFn;\n freePtr: CFn;\n}\n\nconst globalScope = globalThis as Record<string, unknown>;\n\nfunction requiredString(value: string | undefined, field: string): string {\n if (!value || value.trim().length === 0) {\n throw new Error(`[lensfun-wasm] ${field} is required`);\n }\n return value;\n}\n\nfunction toFlag(value: boolean | undefined): number {\n return value ? 1 : 0;\n}\n\nfunction toGrid(size: number, step: number): number {\n return Math.floor((size - 1) / step) + 1;\n}\n\nfunction requirePositiveInt(value: number, field: string): number {\n if (!Number.isInteger(value) || value <= 0) {\n throw new Error(`[lensfun-wasm] ${field} must be a positive integer`);\n }\n return value;\n}\n\nasync function loadScript(url: string): Promise<void> {\n if (typeof document === 'undefined') {\n throw new Error('[lensfun-wasm] moduleJsUrl in non-browser runtime requires moduleFactory instead');\n }\n\n await new Promise<void>((resolve, reject) => {\n const script = document.createElement('script');\n script.src = url;\n script.async = true;\n script.onload = () => resolve();\n script.onerror = () => reject(new Error(`[lensfun-wasm] failed to load ${url}`));\n document.head.appendChild(script);\n });\n}\n\nasync function resolveFactory(options: LensfunInitOptions): Promise<LensfunInitOptions['moduleFactory']> {\n if (options.moduleFactory) {\n return options.moduleFactory;\n }\n\n const existing = globalScope.createLensfunCoreModule;\n if (typeof existing === 'function') {\n return existing as LensfunInitOptions['moduleFactory'];\n }\n\n if (options.moduleJsUrl) {\n if (typeof document !== 'undefined') {\n await loadScript(options.moduleJsUrl);\n const globalFactory = globalScope.createLensfunCoreModule;\n if (typeof globalFactory === 'function') {\n return globalFactory as LensfunInitOptions['moduleFactory'];\n }\n } else {\n const imported = await import(/* @vite-ignore */ options.moduleJsUrl);\n const loaded =\n (imported as Record<string, unknown>).default ??\n (imported as Record<string, unknown>).createLensfunCoreModule;\n if (typeof loaded === 'function') {\n return loaded as LensfunInitOptions['moduleFactory'];\n }\n }\n }\n\n throw new Error(\n '[lensfun-wasm] module factory not found. Provide moduleFactory or preload dist/assets/lensfun-core.js (global createLensfunCoreModule).'\n );\n}\n\nfunction makeLocateFile(options: LensfunInitOptions): (path: string, prefix: string) => string {\n return (path: string, prefix: string) => {\n if (options.locateFile) {\n return options.locateFile(path, prefix);\n }\n\n if (path.endsWith('.wasm') && options.wasmUrl) {\n return options.wasmUrl;\n }\n\n if (path.endsWith('.data') && options.dataUrl) {\n return options.dataUrl;\n }\n\n return `${prefix}${path}`;\n };\n}\n\nfunction parseJsonPtr<T>(module: LensfunModule, freePtr: CFn, ptr: number): T[] {\n if (!ptr) {\n return [];\n }\n\n const raw = module.UTF8ToString(ptr);\n freePtr(ptr);\n if (!raw) {\n return [];\n }\n return JSON.parse(raw) as T[];\n}\n\nfunction bindFns(module: LensfunModule): NativeFns {\n return {\n init: module.cwrap('lfw_init', 'number', ['string']),\n dispose: module.cwrap('lfw_dispose', null, []),\n findLensesJson: module.cwrap('lfw_find_lenses_json', 'number', ['string', 'string', 'string', 'string', 'number']),\n findCamerasJson: module.cwrap('lfw_find_cameras_json', 'number', ['string', 'string', 'number']),\n availableMods: module.cwrap('lfw_available_mods', 'number', ['number', 'number']),\n buildGeometryMap: module.cwrap('lfw_build_geometry_map', 'number', [\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number'\n ]),\n buildTcaMap: module.cwrap('lfw_build_tca_map', 'number', [\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number'\n ]),\n buildVignettingMap: module.cwrap('lfw_build_vignetting_map', 'number', [\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number',\n 'number'\n ]),\n freePtr: module.cwrap('lfw_free', null, ['number'])\n };\n}\n\nexport class LensfunClient {\n private readonly module: LensfunModule;\n private readonly fns: NativeFns;\n private disposed = false;\n\n constructor(module: LensfunModule, fns: NativeFns) {\n this.module = module;\n this.fns = fns;\n }\n\n dispose(): void {\n if (this.disposed) {\n return;\n }\n this.fns.dispose();\n this.disposed = true;\n }\n\n searchLenses(input: SearchLensesInput): LensMatch[] {\n this.ensureAlive();\n const lensModel = requiredString(input.lensModel, 'lensModel');\n const ptr = this.fns.findLensesJson(\n input.cameraMaker ?? '',\n input.cameraModel ?? '',\n input.lensMaker ?? '',\n lensModel,\n input.searchFlags ?? LF_SEARCH_SORT_AND_UNIQUIFY\n ) as number;\n return parseJsonPtr<LensMatch>(this.module, this.fns.freePtr, ptr);\n }\n\n searchCameras(input: SearchCamerasInput): CameraMatch[] {\n this.ensureAlive();\n const ptr = this.fns.findCamerasJson(\n input.maker ?? '',\n input.model ?? '',\n input.searchFlags ?? 0\n ) as number;\n return parseJsonPtr<CameraMatch>(this.module, this.fns.freePtr, ptr);\n }\n\n getAvailableModifications(lensHandle: number, crop: number): number {\n this.ensureAlive();\n return this.fns.availableMods(lensHandle, crop) as number;\n }\n\n buildCorrectionMaps(input: CorrectionInput): CorrectionMaps {\n this.ensureAlive();\n\n const width = requirePositiveInt(input.width, 'width');\n const height = requirePositiveInt(input.height, 'height');\n const step = requirePositiveInt(input.step ?? 1, 'step');\n\n const gridWidth = toGrid(width, step);\n const gridHeight = toGrid(height, step);\n\n const geometry = this.runFloatMap(\n gridWidth * gridHeight * 2,\n this.fns.buildGeometryMap,\n input.lensHandle,\n input.focal,\n input.crop,\n width,\n height,\n toFlag(input.reverse),\n step\n );\n\n const result: CorrectionMaps = {\n gridWidth,\n gridHeight,\n step,\n geometry\n };\n\n if (input.includeTca) {\n result.tca = this.runFloatMap(\n gridWidth * gridHeight * 6,\n this.fns.buildTcaMap,\n input.lensHandle,\n input.focal,\n input.crop,\n width,\n height,\n toFlag(input.reverse),\n step\n );\n }\n\n if (input.includeVignetting) {\n if (typeof input.aperture !== 'number') {\n throw new Error('[lensfun-wasm] aperture is required for vignetting map');\n }\n result.vignetting = this.runFloatMap(\n gridWidth * gridHeight * 3,\n this.fns.buildVignettingMap,\n input.lensHandle,\n input.focal,\n input.crop,\n input.aperture,\n input.distance ?? 1000,\n width,\n height,\n toFlag(input.reverse),\n step\n );\n }\n\n return result;\n }\n\n private runFloatMap(size: number, fn: CFn, ...args: number[]): Float32Array {\n const bytes = size * 4;\n const ptr = this.module._malloc(bytes);\n try {\n const rc = fn(...args, ptr, size) as number;\n if (rc !== 0) {\n throw new Error(`[lensfun-wasm] native map builder failed with code ${rc}`);\n }\n\n const start = ptr >> 2;\n const end = start + size;\n const out = new Float32Array(size);\n out.set(this.module.HEAPF32.subarray(start, end));\n return out;\n } finally {\n this.module._free(ptr);\n }\n }\n\n private ensureAlive(): void {\n if (this.disposed) {\n throw new Error('[lensfun-wasm] LensfunClient is disposed');\n }\n }\n}\n\nexport async function createLensfun(options: LensfunInitOptions = {}): Promise<LensfunClient> {\n const factory = await resolveFactory(options);\n if (!factory) {\n throw new Error('[lensfun-wasm] failed to resolve module factory');\n }\n\n const module = await factory({\n locateFile: makeLocateFile(options)\n });\n\n const fns = bindFns(module);\n\n if (options.autoInitDb ?? true) {\n const dbPath = options.dbPath ?? '/lensfun-db';\n const rc = fns.init(dbPath) as number;\n if (rc !== 0) {\n throw new Error(`[lensfun-wasm] lfw_init failed with code ${rc} for ${dbPath}`);\n }\n }\n\n return new LensfunClient(module, fns);\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
export declare const LF_SEARCH_LOOSE = 1;
|
|
2
|
+
export declare const LF_SEARCH_SORT_AND_UNIQUIFY = 2;
|
|
3
|
+
export declare const LF_MODIFY_TCA = 1;
|
|
4
|
+
export declare const LF_MODIFY_VIGNETTING = 2;
|
|
5
|
+
export declare const LF_MODIFY_DISTORTION = 8;
|
|
6
|
+
export declare const LF_MODIFY_GEOMETRY = 16;
|
|
7
|
+
export declare const LF_MODIFY_SCALE = 32;
|
|
8
|
+
export declare const LF_MODIFY_PERSPECTIVE = 64;
|
|
9
|
+
export interface LensfunModule {
|
|
10
|
+
cwrap: (ident: string, returnType: string | null, argTypes: string[]) => (...args: unknown[]) => unknown;
|
|
11
|
+
UTF8ToString: (ptr: number) => string;
|
|
12
|
+
_malloc: (size: number) => number;
|
|
13
|
+
_free: (ptr: number) => void;
|
|
14
|
+
HEAPF32: Float32Array;
|
|
15
|
+
}
|
|
16
|
+
export interface LensfunInitOptions {
|
|
17
|
+
moduleFactory?: (options?: Record<string, unknown>) => Promise<LensfunModule>;
|
|
18
|
+
moduleJsUrl?: string;
|
|
19
|
+
wasmUrl?: string;
|
|
20
|
+
dataUrl?: string;
|
|
21
|
+
locateFile?: (path: string, prefix: string) => string;
|
|
22
|
+
dbPath?: string;
|
|
23
|
+
autoInitDb?: boolean;
|
|
24
|
+
}
|
|
25
|
+
export interface LensMatch {
|
|
26
|
+
handle: number;
|
|
27
|
+
maker: string;
|
|
28
|
+
model: string;
|
|
29
|
+
score: number;
|
|
30
|
+
minFocal: number;
|
|
31
|
+
maxFocal: number;
|
|
32
|
+
minAperture: number;
|
|
33
|
+
maxAperture: number;
|
|
34
|
+
cropFactor: number;
|
|
35
|
+
}
|
|
36
|
+
export interface CameraMatch {
|
|
37
|
+
maker: string;
|
|
38
|
+
model: string;
|
|
39
|
+
variant: string;
|
|
40
|
+
mount: string;
|
|
41
|
+
cropFactor: number;
|
|
42
|
+
score: number;
|
|
43
|
+
}
|
|
44
|
+
export interface SearchLensesInput {
|
|
45
|
+
lensMaker?: string;
|
|
46
|
+
lensModel: string;
|
|
47
|
+
cameraMaker?: string;
|
|
48
|
+
cameraModel?: string;
|
|
49
|
+
searchFlags?: number;
|
|
50
|
+
}
|
|
51
|
+
export interface SearchCamerasInput {
|
|
52
|
+
maker?: string;
|
|
53
|
+
model?: string;
|
|
54
|
+
searchFlags?: number;
|
|
55
|
+
}
|
|
56
|
+
export interface CorrectionInput {
|
|
57
|
+
lensHandle: number;
|
|
58
|
+
width: number;
|
|
59
|
+
height: number;
|
|
60
|
+
focal: number;
|
|
61
|
+
crop: number;
|
|
62
|
+
step?: number;
|
|
63
|
+
reverse?: boolean;
|
|
64
|
+
includeTca?: boolean;
|
|
65
|
+
includeVignetting?: boolean;
|
|
66
|
+
aperture?: number;
|
|
67
|
+
distance?: number;
|
|
68
|
+
}
|
|
69
|
+
export interface CorrectionMaps {
|
|
70
|
+
gridWidth: number;
|
|
71
|
+
gridHeight: number;
|
|
72
|
+
step: number;
|
|
73
|
+
geometry: Float32Array;
|
|
74
|
+
tca?: Float32Array;
|
|
75
|
+
vignetting?: Float32Array;
|
|
76
|
+
}
|
|
77
|
+
type CFn = (...args: unknown[]) => unknown;
|
|
78
|
+
interface NativeFns {
|
|
79
|
+
init: CFn;
|
|
80
|
+
dispose: CFn;
|
|
81
|
+
findLensesJson: CFn;
|
|
82
|
+
findCamerasJson: CFn;
|
|
83
|
+
availableMods: CFn;
|
|
84
|
+
buildGeometryMap: CFn;
|
|
85
|
+
buildTcaMap: CFn;
|
|
86
|
+
buildVignettingMap: CFn;
|
|
87
|
+
freePtr: CFn;
|
|
88
|
+
}
|
|
89
|
+
export declare class LensfunClient {
|
|
90
|
+
private readonly module;
|
|
91
|
+
private readonly fns;
|
|
92
|
+
private disposed;
|
|
93
|
+
constructor(module: LensfunModule, fns: NativeFns);
|
|
94
|
+
dispose(): void;
|
|
95
|
+
searchLenses(input: SearchLensesInput): LensMatch[];
|
|
96
|
+
searchCameras(input: SearchCamerasInput): CameraMatch[];
|
|
97
|
+
getAvailableModifications(lensHandle: number, crop: number): number;
|
|
98
|
+
buildCorrectionMaps(input: CorrectionInput): CorrectionMaps;
|
|
99
|
+
private runFloatMap;
|
|
100
|
+
private ensureAlive;
|
|
101
|
+
}
|
|
102
|
+
export declare function createLensfun(options?: LensfunInitOptions): Promise<LensfunClient>;
|
|
103
|
+
export {};
|
|
104
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-shape.test.d.ts","sourceRoot":"","sources":["../../../tests/api-shape.test.ts"],"names":[],"mappings":""}
|