@visulima/task-runner 1.0.0-alpha.19 → 1.0.0-alpha.20

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/CHANGELOG.md CHANGED
@@ -1,3 +1,9 @@
1
+ ## @visulima/task-runner [1.0.0-alpha.20](https://github.com/visulima/visulima/compare/@visulima/task-runner@1.0.0-alpha.19...@visulima/task-runner@1.0.0-alpha.20) (2026-06-06)
2
+
3
+ ### Bug Fixes
4
+
5
+ * **task-runner:** output-cache data loss + path-safety bugs ([aaa4007](https://github.com/visulima/visulima/commit/aaa4007ed3daea0151588c2ce42bc80eaceb40fd))
6
+
1
7
  ## @visulima/task-runner [1.0.0-alpha.19](https://github.com/visulima/visulima/compare/@visulima/task-runner@1.0.0-alpha.18...@visulima/task-runner@1.0.0-alpha.19) (2026-06-04)
2
8
 
3
9
  ### Bug Fixes
package/dist/index.d.ts CHANGED
@@ -2191,7 +2191,7 @@ declare class Cache {
2191
2191
  * Removes old cache entries that exceed the maximum age,
2192
2192
  * and enforces the maximum cache size by evicting oldest entries.
2193
2193
  *
2194
- * NOTE: `maxCacheSize` only bounds the *legacy* `<hash>/` entry
2194
+ * NOTE: `maxCacheSize` only bounds the *legacy* `&lt;hash>/` entry
2195
2195
  * layout. The v2 CAS subtree (rooted at {@link V2_ROOT}) is skipped
2196
2196
  * here — it manages its own lifetime via blob-level touch + reference
2197
2197
  * accounting (see `cas/store.ts`) and is deliberately excluded from
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- import{buildForwardDependencyMap as o,buildReverseDependencyMap as t,expandAffected as a,filterAffectedTasks as s,getAffectedProjects as p,getChangedFiles as n}from"./packem_shared/buildForwardDependencyMap-DudUDFze.js";import{createRemoteCacheBackend as i,resolveCacheMode as c,resolveTurboEnvCompat as f}from"./packem_shared/resolveCacheMode--4y60ODd.js";import{actionDigestForTaskHash as x,containsByTaskHash as h,retrieveByTaskHash as d,storeByTaskHash as u}from"./packem_shared/actionDigestForTaskHash-BOL4fZ9v.js";import{HttpRemoteCache as T}from"./packem_shared/HttpRemoteCache-CpPl6lzE.js";import{ReapiRemoteCache as g}from"./packem_shared/ReapiRemoteCache-BXJip5wH.js";import{Cache as R,DEFAULT_CACHE_DIRECTORY_NAME as v,formatCacheSize as F,parseCacheSize as B}from"./packem_shared/Cache-BVrj9bd4.js";import{digestBuffer as E,digestFile as P}from"./packem_shared/digestBuffer-g11aCaDx.js";import{V2_AC as I,V2_CAS as L,V2_INDEX as H,V2_ROOT as A,V2_TMP as w,acEntryPath as D,casBlobPath as _,taskHashIndexPath as M}from"./packem_shared/V2_ROOT-injxWBrl.js";import{containsBlob as N,fetchBlobToFile as O,putBlobFromBytes as U,putBlobFromFile as V,touchBlob as W,verifyBlob as j}from"./packem_shared/containsBlob-DAU8R7GH.js";import{toChromeTrace as Y,writeChromeTrace as q}from"./packem_shared/toChromeTrace-DxN5NQIU.js";import{parseCommands as K}from"./packem_shared/parseCommands-BHsXoUCd.js";import{runConcurrently as X}from"./packem_shared/runConcurrently-D1Ytsjaj.js";import{runConcurrentFallback as $}from"./packem_shared/runConcurrentFallback-BhJCT2LA.js";import{defaultTaskRunner as re}from"./packem_shared/defaultTaskRunner-RJnuLoJz.js";import{detectScriptShell as te}from"./packem_shared/detectScriptShell-CaTDk5cW.js";import{FileAccessTracker as se,generatePreloadScript as pe}from"./packem_shared/FileAccessTracker-DBz_w4wl.js";import{FingerprintManager as me}from"./packem_shared/FingerprintManager-CYW2EwLc.js";import{detectFrameworks as ce,getFrameworkEnvVariables as fe,inferFrameworkEnvPatterns as le}from"./packem_shared/detectFrameworks-WVZJOPgN.js";import{projectGraphToDot as he,toGraphAscii as de,toGraphHtml as ue,toGraphJson as ke,toGraphvizDot as Te}from"./packem_shared/projectGraphToDot-FN6oHDGH.js";import{IncrementalFileHasher as ge}from"./packem_shared/IncrementalFileHasher-B-V3i2x-.js";import{CompositeLifeCycle as Re,ConsoleLifeCycle as ve,EmptyLifeCycle as Fe}from"./packem_shared/CompositeLifeCycle-C6aee9GK.js";import{LockfileHasher as be,extractPackageName as Ee,parseNpmLockfile as Pe,parsePnpmLockfile as Se,parseYarnLockfile as Ie}from"./packem_shared/extractPackageName-BeL6Gc3a.js";import{LogReporter as He,createLogReporter as Ae}from"./packem_shared/LogReporter-3R3oWj-Q.js";import{isNativeAvailable as De,loadNativeBindings as _e}from"./packem_shared/isNativeAvailable-CkTjxb7P.js";import{resolveOutputs as Ge}from"./packem_shared/resolveOutputs-BBjdaraf.js";import{INPUT_URI_SCHEMES as Oe,InvalidInputUriError as Ue,looksLikeInputUri as Ve,parseInputUri as We}from"./packem_shared/INPUT_URI_SCHEMES-Csrd0tlg.js";import{buildEnhancedPath as ze,collectNodeModulesBinDirs as Ye,withEnhancedPath as qe}from"./packem_shared/collectNodeModulesBinDirs-CD-eDrtO.js";import{enforceProjectConstraints as Ke}from"./packem_shared/enforceProjectConstraints-dNc1SwRi.js";import{generateRunSummary as Xe,getLastRunSummaryPath as Ze,readLastRunSummary as $e,writeLastRunSummary as er,writeRunSummary as rr}from"./packem_shared/generateRunSummary-L9Z2NfWn.js";import{createTaskGraph as tr,getTaskId as ar,parseTaskId as sr}from"./packem_shared/createTaskGraph-BBG8Rosl.js";import{findCycle as nr,findCycles as mr,getDependentTasks as ir,getLeafTasks as cr,getTransitiveDependencies as fr,makeAcyclic as lr,reverseTaskGraph as xr,walkTaskGraph as hr}from"./packem_shared/findCycle-BY8-jmzB.js";import{InProcessTaskHasher as ur,computeTaskHash as kr}from"./packem_shared/computeTaskHash-CaPdG1BA.js";import{TaskOrchestrator as Cr}from"./packem_shared/TaskOrchestrator-CYj5MLwz.js";import{TaskScheduler as yr,parsePartition as Rr}from"./packem_shared/parsePartition-Bt1jBjZH.js";import{TerminalBuffer as Fr}from"./packem_shared/TerminalBuffer-BtZy7TpT.js";import{T as br}from"./packem_shared/tracked-executor-B90U4Um3.js";import{d as Pr,j as Sr,T as Ir,b as Lr,E as Hr,v as Ar,h as wr,O as Dr}from"./packem_shared/utils-BH2W5Wml.js";import{evaluateWhen as Mr,explainWhen as Gr,getCurrentBranch as Nr,resetBranchCache as Or}from"./packem_shared/getCurrentBranch-D-qoZByx.js";import{getMainWorktreeRoot as Vr,isLinkedWorktree as Wr,resetWorktreeCache as jr}from"./packem_shared/getMainWorktreeRoot-DB9P2wDL.js";import{createInputHandler as Yr}from"./packem_shared/createInputHandler-CkDCpPYy.js";import{expandArguments as Jr}from"./packem_shared/expandArguments-D7qvc6Rp.js";import{expandShortcut as Qr}from"./packem_shared/expandShortcut-BErNHNXZ.js";import{expandTokens as Zr,expandTokensInString as $r}from"./packem_shared/expandTokensInString-DVSFEdWu.js";import{expandWildcard as ro}from"./packem_shared/expandWildcard-DE0dOOZF.js";import{formatTimingTable as to,logTimings as ao}from"./packem_shared/formatTimingTable-CP3rsDwf.js";import{runTeardown as po}from"./packem_shared/runTeardown-DAn1xFWJ.js";import{stripQuotes as mo}from"./packem_shared/stripQuotes-jkZb0CL9.js";import{withRestart as co}from"./packem_shared/withRestart-DKtEGsQA.js";export{R as Cache,Re as CompositeLifeCycle,ve as ConsoleLifeCycle,v as DEFAULT_CACHE_DIRECTORY_NAME,Fe as EmptyLifeCycle,se as FileAccessTracker,me as FingerprintManager,T as HttpRemoteCache,Oe as INPUT_URI_SCHEMES,ur as InProcessTaskHasher,ge as IncrementalFileHasher,Ue as InvalidInputUriError,be as LockfileHasher,He as LogReporter,g as ReapiRemoteCache,Cr as TaskOrchestrator,yr as TaskScheduler,Fr as TerminalBuffer,br as TrackedTaskExecutor,I as V2_AC,L as V2_CAS,H as V2_INDEX,A as V2_ROOT,w as V2_TMP,D as acEntryPath,x as actionDigestForTaskHash,ze as buildEnhancedPath,o as buildForwardDependencyMap,t as buildReverseDependencyMap,_ as casBlobPath,Pr as collectFiles,Ye as collectNodeModulesBinDirs,kr as computeTaskHash,N as containsBlob,h as containsByTaskHash,Sr as createFailureResult,Yr as createInputHandler,Ae as createLogReporter,i as createRemoteCacheBackend,tr as createTaskGraph,re as defaultTaskRunner,ce as detectFrameworks,te as detectScriptShell,E as digestBuffer,P as digestFile,Ke as enforceProjectConstraints,Mr as evaluateWhen,a as expandAffected,Jr as expandArguments,Qr as expandShortcut,Zr as expandTokens,$r as expandTokensInString,ro as expandWildcard,Gr as explainWhen,Ee as extractPackageName,O as fetchBlobToFile,s as filterAffectedTasks,nr as findCycle,mr as findCycles,F as formatCacheSize,to as formatTimingTable,pe as generatePreloadScript,Xe as generateRunSummary,p as getAffectedProjects,n as getChangedFiles,Nr as getCurrentBranch,ir as getDependentTasks,fe as getFrameworkEnvVariables,Ze as getLastRunSummaryPath,cr as getLeafTasks,Vr as getMainWorktreeRoot,ar as getTaskId,fr as getTransitiveDependencies,Ir as hashFile,Lr as hashStrings,le as inferFrameworkEnvPatterns,Wr as isLinkedWorktree,De as isNativeAvailable,_e as loadNativeBindings,ao as logTimings,Ve as looksLikeInputUri,lr as makeAcyclic,B as parseCacheSize,K as parseCommands,We as parseInputUri,Pe as parseNpmLockfile,Rr as parsePartition,Se as parsePnpmLockfile,sr as parseTaskId,Ie as parseYarnLockfile,he as projectGraphToDot,U as putBlobFromBytes,V as putBlobFromFile,$e as readLastRunSummary,Hr as readPackageDeps,Or as resetBranchCache,jr as resetWorktreeCache,c as resolveCacheMode,Ge as resolveOutputs,Ar as resolveTaskCwd,f as resolveTurboEnvCompat,d as retrieveByTaskHash,xr as reverseTaskGraph,$ as runConcurrentFallback,X as runConcurrently,po as runTeardown,wr as sortObjectKeys,u as storeByTaskHash,mo as stripQuotes,M as taskHashIndexPath,Y as toChromeTrace,de as toGraphAscii,ue as toGraphHtml,ke as toGraphJson,Te as toGraphvizDot,W as touchBlob,Dr as uniqueId,j as verifyBlob,hr as walkTaskGraph,qe as withEnhancedPath,co as withRestart,q as writeChromeTrace,er as writeLastRunSummary,rr as writeRunSummary};
1
+ import{buildForwardDependencyMap as o,buildReverseDependencyMap as t,expandAffected as a,filterAffectedTasks as s,getAffectedProjects as p,getChangedFiles as n}from"./packem_shared/buildForwardDependencyMap-DudUDFze.js";import{createRemoteCacheBackend as i,resolveCacheMode as c,resolveTurboEnvCompat as f}from"./packem_shared/resolveCacheMode--4y60ODd.js";import{actionDigestForTaskHash as x,containsByTaskHash as h,retrieveByTaskHash as d,storeByTaskHash as u}from"./packem_shared/actionDigestForTaskHash-BOL4fZ9v.js";import{HttpRemoteCache as T}from"./packem_shared/HttpRemoteCache-CpPl6lzE.js";import{ReapiRemoteCache as g}from"./packem_shared/ReapiRemoteCache-BXJip5wH.js";import{Cache as R,DEFAULT_CACHE_DIRECTORY_NAME as v,formatCacheSize as F,parseCacheSize as B}from"./packem_shared/Cache-C8FfeXpg.js";import{digestBuffer as E,digestFile as P}from"./packem_shared/digestBuffer-g11aCaDx.js";import{V2_AC as I,V2_CAS as L,V2_INDEX as H,V2_ROOT as A,V2_TMP as w,acEntryPath as D,casBlobPath as _,taskHashIndexPath as M}from"./packem_shared/V2_ROOT-injxWBrl.js";import{containsBlob as N,fetchBlobToFile as O,putBlobFromBytes as U,putBlobFromFile as V,touchBlob as W,verifyBlob as j}from"./packem_shared/containsBlob-DAU8R7GH.js";import{toChromeTrace as Y,writeChromeTrace as q}from"./packem_shared/toChromeTrace-DxN5NQIU.js";import{parseCommands as K}from"./packem_shared/parseCommands-BHsXoUCd.js";import{runConcurrently as X}from"./packem_shared/runConcurrently-D1Ytsjaj.js";import{runConcurrentFallback as $}from"./packem_shared/runConcurrentFallback-BhJCT2LA.js";import{defaultTaskRunner as re}from"./packem_shared/defaultTaskRunner-DMHpavzm.js";import{detectScriptShell as te}from"./packem_shared/detectScriptShell-CaTDk5cW.js";import{FileAccessTracker as se,generatePreloadScript as pe}from"./packem_shared/FileAccessTracker-DBz_w4wl.js";import{FingerprintManager as me}from"./packem_shared/FingerprintManager-CYW2EwLc.js";import{detectFrameworks as ce,getFrameworkEnvVariables as fe,inferFrameworkEnvPatterns as le}from"./packem_shared/detectFrameworks-WVZJOPgN.js";import{projectGraphToDot as he,toGraphAscii as de,toGraphHtml as ue,toGraphJson as ke,toGraphvizDot as Te}from"./packem_shared/projectGraphToDot-FN6oHDGH.js";import{IncrementalFileHasher as ge}from"./packem_shared/IncrementalFileHasher-B-V3i2x-.js";import{CompositeLifeCycle as Re,ConsoleLifeCycle as ve,EmptyLifeCycle as Fe}from"./packem_shared/CompositeLifeCycle-C6aee9GK.js";import{LockfileHasher as be,extractPackageName as Ee,parseNpmLockfile as Pe,parsePnpmLockfile as Se,parseYarnLockfile as Ie}from"./packem_shared/extractPackageName-BeL6Gc3a.js";import{LogReporter as He,createLogReporter as Ae}from"./packem_shared/LogReporter-3R3oWj-Q.js";import{isNativeAvailable as De,loadNativeBindings as _e}from"./packem_shared/isNativeAvailable-CkTjxb7P.js";import{resolveOutputs as Ge}from"./packem_shared/resolveOutputs-CzGGEbcP.js";import{INPUT_URI_SCHEMES as Oe,InvalidInputUriError as Ue,looksLikeInputUri as Ve,parseInputUri as We}from"./packem_shared/INPUT_URI_SCHEMES-Csrd0tlg.js";import{buildEnhancedPath as ze,collectNodeModulesBinDirs as Ye,withEnhancedPath as qe}from"./packem_shared/collectNodeModulesBinDirs-CD-eDrtO.js";import{enforceProjectConstraints as Ke}from"./packem_shared/enforceProjectConstraints-dNc1SwRi.js";import{generateRunSummary as Xe,getLastRunSummaryPath as Ze,readLastRunSummary as $e,writeLastRunSummary as er,writeRunSummary as rr}from"./packem_shared/generateRunSummary-L9Z2NfWn.js";import{createTaskGraph as tr,getTaskId as ar,parseTaskId as sr}from"./packem_shared/createTaskGraph-D8Jn_Dn9.js";import{findCycle as nr,findCycles as mr,getDependentTasks as ir,getLeafTasks as cr,getTransitiveDependencies as fr,makeAcyclic as lr,reverseTaskGraph as xr,walkTaskGraph as hr}from"./packem_shared/findCycle-BY8-jmzB.js";import{InProcessTaskHasher as ur,computeTaskHash as kr}from"./packem_shared/computeTaskHash-CaPdG1BA.js";import{TaskOrchestrator as Cr}from"./packem_shared/TaskOrchestrator-CYj5MLwz.js";import{TaskScheduler as yr,parsePartition as Rr}from"./packem_shared/parsePartition-Bt1jBjZH.js";import{TerminalBuffer as Fr}from"./packem_shared/TerminalBuffer-BtZy7TpT.js";import{T as br}from"./packem_shared/tracked-executor-B90U4Um3.js";import{d as Pr,j as Sr,T as Ir,b as Lr,E as Hr,v as Ar,h as wr,O as Dr}from"./packem_shared/utils-BH2W5Wml.js";import{evaluateWhen as Mr,explainWhen as Gr,getCurrentBranch as Nr,resetBranchCache as Or}from"./packem_shared/getCurrentBranch-D-qoZByx.js";import{getMainWorktreeRoot as Vr,isLinkedWorktree as Wr,resetWorktreeCache as jr}from"./packem_shared/getMainWorktreeRoot-DB9P2wDL.js";import{createInputHandler as Yr}from"./packem_shared/createInputHandler-CkDCpPYy.js";import{expandArguments as Jr}from"./packem_shared/expandArguments-D7qvc6Rp.js";import{expandShortcut as Qr}from"./packem_shared/expandShortcut-BErNHNXZ.js";import{expandTokens as Zr,expandTokensInString as $r}from"./packem_shared/expandTokensInString-DVSFEdWu.js";import{expandWildcard as ro}from"./packem_shared/expandWildcard-DE0dOOZF.js";import{formatTimingTable as to,logTimings as ao}from"./packem_shared/formatTimingTable-CP3rsDwf.js";import{runTeardown as po}from"./packem_shared/runTeardown-DAn1xFWJ.js";import{stripQuotes as mo}from"./packem_shared/stripQuotes-jkZb0CL9.js";import{withRestart as co}from"./packem_shared/withRestart-DKtEGsQA.js";export{R as Cache,Re as CompositeLifeCycle,ve as ConsoleLifeCycle,v as DEFAULT_CACHE_DIRECTORY_NAME,Fe as EmptyLifeCycle,se as FileAccessTracker,me as FingerprintManager,T as HttpRemoteCache,Oe as INPUT_URI_SCHEMES,ur as InProcessTaskHasher,ge as IncrementalFileHasher,Ue as InvalidInputUriError,be as LockfileHasher,He as LogReporter,g as ReapiRemoteCache,Cr as TaskOrchestrator,yr as TaskScheduler,Fr as TerminalBuffer,br as TrackedTaskExecutor,I as V2_AC,L as V2_CAS,H as V2_INDEX,A as V2_ROOT,w as V2_TMP,D as acEntryPath,x as actionDigestForTaskHash,ze as buildEnhancedPath,o as buildForwardDependencyMap,t as buildReverseDependencyMap,_ as casBlobPath,Pr as collectFiles,Ye as collectNodeModulesBinDirs,kr as computeTaskHash,N as containsBlob,h as containsByTaskHash,Sr as createFailureResult,Yr as createInputHandler,Ae as createLogReporter,i as createRemoteCacheBackend,tr as createTaskGraph,re as defaultTaskRunner,ce as detectFrameworks,te as detectScriptShell,E as digestBuffer,P as digestFile,Ke as enforceProjectConstraints,Mr as evaluateWhen,a as expandAffected,Jr as expandArguments,Qr as expandShortcut,Zr as expandTokens,$r as expandTokensInString,ro as expandWildcard,Gr as explainWhen,Ee as extractPackageName,O as fetchBlobToFile,s as filterAffectedTasks,nr as findCycle,mr as findCycles,F as formatCacheSize,to as formatTimingTable,pe as generatePreloadScript,Xe as generateRunSummary,p as getAffectedProjects,n as getChangedFiles,Nr as getCurrentBranch,ir as getDependentTasks,fe as getFrameworkEnvVariables,Ze as getLastRunSummaryPath,cr as getLeafTasks,Vr as getMainWorktreeRoot,ar as getTaskId,fr as getTransitiveDependencies,Ir as hashFile,Lr as hashStrings,le as inferFrameworkEnvPatterns,Wr as isLinkedWorktree,De as isNativeAvailable,_e as loadNativeBindings,ao as logTimings,Ve as looksLikeInputUri,lr as makeAcyclic,B as parseCacheSize,K as parseCommands,We as parseInputUri,Pe as parseNpmLockfile,Rr as parsePartition,Se as parsePnpmLockfile,sr as parseTaskId,Ie as parseYarnLockfile,he as projectGraphToDot,U as putBlobFromBytes,V as putBlobFromFile,$e as readLastRunSummary,Hr as readPackageDeps,Or as resetBranchCache,jr as resetWorktreeCache,c as resolveCacheMode,Ge as resolveOutputs,Ar as resolveTaskCwd,f as resolveTurboEnvCompat,d as retrieveByTaskHash,xr as reverseTaskGraph,$ as runConcurrentFallback,X as runConcurrently,po as runTeardown,wr as sortObjectKeys,u as storeByTaskHash,mo as stripQuotes,M as taskHashIndexPath,Y as toChromeTrace,de as toGraphAscii,ue as toGraphHtml,ke as toGraphJson,Te as toGraphvizDot,W as touchBlob,Dr as uniqueId,j as verifyBlob,hr as walkTaskGraph,qe as withEnhancedPath,co as withRestart,q as writeChromeTrace,er as writeLastRunSummary,rr as writeRunSummary};
@@ -0,0 +1,2 @@
1
+ var J=Object.defineProperty;var O=(s,t)=>J(s,"name",{value:t,configurable:!0});import{createRequire as R}from"node:module";import{parseBytes as G,formatBytes as K}from"@visulima/humanizer";import{dirname as k,join as u,resolve as b,relative as L}from"@visulima/path";import{a as U,b as Y}from"./archive-CDfGy5Lm.js";import{O as m}from"./utils-BH2W5Wml.js";import{acEntryPath as A,tmpDirectory as j,taskHashIndexPath as z,V2_ROOT as x}from"./V2_ROOT-injxWBrl.js";import{fetchBlobToFile as Z,containsBlob as Q,putBlobFromFile as tt}from"./containsBlob-DAU8R7GH.js";import{resolveOutputs as et}from"./resolveOutputs-CzGGEbcP.js";const H=R(import.meta.url),N=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,C=O(s=>{if(typeof N<"u"&&N.versions&&N.versions.node){const[t,e]=N.versions.node.split(".").map(Number);if(t>22||t===22&&e>=3||t===20&&e>=16)return N.getBuiltinModule(s)}return H(s)},"__cjs_getBuiltinModule"),{createWriteStream:q}=C("node:fs"),{mkdir:p,writeFile:v,rename:w,rm:f,readFile:g,utimes:W,open:V,stat:S,readdir:_,cp:D}=C("node:fs/promises"),{pipeline:X}=C("node:stream/promises");var at=Object.defineProperty,E=O((s,t)=>at(s,"name",{value:t,configurable:!0}),"s");const rt=E(async(s,t,e)=>{const r=A(s,t),a=j(s),i=`${a}/${m()}`;await p(a,{recursive:!0}),await p(k(r),{recursive:!0});const n=`${JSON.stringify(e,null,2)}
2
+ `;await v(i,n);try{await w(i,r)}catch(c){throw await f(i,{force:!0}).catch(()=>{}),c}},"writeActionEntry"),st=E(async(s,t)=>{const e=A(s,t);try{const r=await g(e,"utf8"),a=JSON.parse(r),i=new Date;return await W(e,i,i).catch(()=>{}),a}catch{return null}},"readActionEntry"),it=E(async(s,t,e)=>{const r=z(s,t),a=j(s),i=`${a}/${m()}`;await p(a,{recursive:!0}),await p(k(r),{recursive:!0}),await v(i,e);try{await w(i,r)}catch(n){throw await f(i,{force:!0}).catch(()=>{}),n}},"writeTaskHashIndex"),ct=E(async(s,t)=>{try{const e=(await g(z(s,t),"utf8")).trim();return e.length>0?e:null}catch{return null}},"readTaskHashIndex");var nt=Object.defineProperty,y=O((s,t)=>nt(s,"name",{value:t,configurable:!0}),"d");const ot=10080*60*1e3,ut=".task-runner-cache",ht=y(s=>{if(s.includes("\0"))throw new Error("cacheNamespace: null bytes are not allowed.");if(s.includes("/")||s.includes("\\"))throw new Error(`cacheNamespace: path separators are not allowed (received ${JSON.stringify(s)}).`);if(s==="."||s==="..")throw new Error(`cacheNamespace: "${s}" would escape the cache subtree.`)},"assertSafeNamespace"),P=y(async s=>{try{await f(s,{force:!0,recursive:!0})}catch{}},"removeEntry"),B=y(async s=>{let t=0;try{const e=await _(s,{withFileTypes:!0});for(const r of e){const a=u(s,r.name);if(r.isDirectory())t+=await B(a);else if(r.isFile()){const i=await S(a);t+=i.size}}}catch{}return t},"getDirectorySize"),lt=y(s=>{const t=G(s.trim());if(Number.isNaN(t))throw new TypeError(`Invalid cache size format: "${s}". Expected format like "500MB" or "1GB".`);return t},"parseCacheSize"),Nt=y(s=>K(s,{decimals:1,space:!1}),"formatCacheSize");class St{static{O(this,"et")}static{y(this,"Cache")}#e;#t;#r;#a;#s=Promise.resolve();constructor(t){this.#e=t.workspaceRoot;const e=t.cacheDirectory??u(t.workspaceRoot,ut);t.cacheNamespace!==void 0&&t.cacheNamespace.length>0&&ht(t.cacheNamespace),this.#t=t.cacheNamespace&&t.cacheNamespace.length>0?u(e,"ns",t.cacheNamespace):e,this.#r=t.maxCacheAge??ot,this.#a=t.maxCacheSize?lt(t.maxCacheSize):void 0}get cacheDirectory(){return this.#t}get casRoot(){return this.#t}async getActionResult(t){return st(this.#t,t.hash)}async resolveActionDigestForTaskHash(t){return ct(this.#t,t)}async putActionResult(t,e,r,a){await this.#i(a),await rt(this.#t,e.hash,r),await it(this.#t,t,e.hash)}async materializeOutputs(t,e){for(const r of t.outputFiles){const a=b(e,r.path),i=L(e,a);if(i.length===0||i.startsWith("..")||!await Z(this.#t,r.digest,a))return!1}return!0}async#i(t){for(const e of t){if(await Q(this.#t,e.digest))continue;const r=u(this.#t,x,"tmp",`.put-${m()}`);await p(k(r),{recursive:!0});const a=await e.open();await X(a,q(r)),await tt(this.#t,e.digest,r),await f(r,{force:!0}).catch(()=>{})}}async get(t){const e=u(this.#t,t);try{await g(u(e,".commit"));const r=await g(u(e,"code"),"utf8"),a=Number.parseInt(r.trim(),10);if(Number.isNaN(a))return;let i="";try{i=await g(u(e,"terminalOutput"),"utf8")}catch{}let n;try{const c=await g(u(e,"fingerprint.json"),"utf8");n=JSON.parse(c)}catch{}return{code:a,fingerprint:n,hash:t,terminalOutput:i}}catch{return}}async put(t,e,r,a,i,n){const c=u(this.#t,t),h=u(this.#t,`.tmp-${t}-${m()}`);try{await p(h,{recursive:!0});const o=[v(u(h,"code"),String(a)),v(u(h,"terminalOutput"),e),this.#o(h,r,n)];i&&o.push(v(u(h,"fingerprint.json"),JSON.stringify(i))),await Promise.all(o),await v(u(h,".commit"),"");const l=`${c}.trash-${m()}`;let d=!1;try{await w(c,l),d=!0}catch{}try{await w(h,c)}catch(F){throw d&&await w(l,c).catch(()=>{}),F}d&&P(l).catch(()=>{})}catch{await P(h)}}async restoreOutputs(t,e,r){const a=u(this.#t,t);return wt(a,this.#e,r)}async getByTaskId(t){const e=u(this.#t,".task-index.json");try{const r=await g(e,"utf8"),a=JSON.parse(r)[t];return a?this.get(a):void 0}catch{return}}async setTaskIndex(t,e){const r=this.#s.then(()=>this.#c(t,e));return this.#s=r.catch(()=>{}),r}async#c(t,e){const r=u(this.#t,".task-index.json"),a=u(this.#t,`.task-index-${m()}.tmp`);await p(this.#t,{recursive:!0}),await this.#n(async()=>{let i={};try{const n=await g(r,"utf8");i=JSON.parse(n)}catch{}i[t]=e,await v(a,JSON.stringify(i));try{await w(a,r)}catch{await v(r,JSON.stringify(i)),await f(a,{force:!0})}})}async#n(t){const e=u(this.#t,".task-index.lock"),r=3e4,a=1e4,i=Date.now();for(;;){let n;try{n=await V(e,"wx")}catch(c){if(c.code!=="EEXIST")throw c;const h=await S(e).catch(()=>{});if(h&&Date.now()-h.mtimeMs>r){await f(e,{force:!0}).catch(()=>{});continue}if(Date.now()-i>a)throw new Error(`Timed out waiting for task-index lock at ${e}`,{cause:c});await new Promise(o=>{setTimeout(o,50)});continue}try{return await t()}finally{await n.close().catch(()=>{}),await f(e,{force:!0}).catch(()=>{})}}}async removeOldEntries(){try{const t=await _(this.#t),e=Date.now(),r=[];for(const a of t){if(a.startsWith(".")||a===x)continue;const i=u(this.#t,a);try{const n=await S(i);if(e-n.mtimeMs>this.#r)await P(i);else{const c=await B(i);r.push({mtimeMs:n.mtimeMs,name:a,path:i,size:c})}}catch{}}if(this.#a!==void 0){const a=r.toSorted((n,c)=>n.mtimeMs-c.mtimeMs);let i=0;for(const n of a)i+=n.size;for(const n of a){if(i<=this.#a)break;await P(n.path),i-=n.size}}}catch{}}async clear(){const t=b(this.#t);if(!(t===b(this.#e)||k(t)===t))try{await f(this.#t,{force:!0,recursive:!0})}catch{}}async#o(t,e,r){await ft(this.#e,t,e,r)}}const I="outputs.tar.br",M="outputs-manifest.json",ft=y(async(s,t,e,r)=>{if(e.length===0)return;const a=await et(s,e,r);if(a.length===0)return;const i=u(t,`.outputs-stage-${m()}`),n=u(t,I);try{await p(i,{recursive:!0});const c=await $(T,a,async o=>{const l=b(s,o),d=u(i,o);try{return await p(k(d),{recursive:!0}),await D(l,d,{preserveTimestamps:!0,recursive:!0}),!0}catch{return!1}}),h=a.filter((o,l)=>c[l]);if(h.length===0)return;await Y(i,n),await v(u(t,M),JSON.stringify(h))}finally{await f(i,{force:!0,recursive:!0}).catch(()=>{})}},"archiveOutputsCompressed"),T=16,$=y(async(s,t,e)=>{const r=Array.from({length:t.length});let a=0;const i=y(async()=>{for(;a<t.length;){const c=a;a+=1,r[c]=await e(t[c],c)}},"worker"),n=Array.from({length:Math.min(s,t.length)},()=>i());return await Promise.all(n),r},"runBounded"),wt=y(async(s,t,e)=>{const r=u(s,I);try{await S(r)}catch{return!0}const a=u(s,`.restore-${m()}`),i=e?.preserveMtime??!0,n=[];try{await p(a,{recursive:!0}),await U(r,a,e);let c;try{c=JSON.parse(await g(u(s,M),"utf8"))}catch{return!1}const h=m();for(const o of[...c].sort()){const l=b(t,o);if(o.length===0||l===b(t))return!1;n.push({absoluteOutput:l,backupCreated:!1,backupPath:`${l}.old-${h}`,entry:o,installed:!1,prePositioned:`${l}.restoring-${h}`})}return await $(T,n,async o=>{const l=u(a,o.entry);await p(k(o.absoluteOutput),{recursive:!0}),await f(o.prePositioned,{force:!0,recursive:!0}).catch(()=>{});try{await w(l,o.prePositioned)}catch(d){if(d.code==="EXDEV")await D(l,o.prePositioned,{preserveTimestamps:i,recursive:!0});else throw d}}),await $(T,n,async o=>{try{await S(o.absoluteOutput)}catch{return}await w(o.absoluteOutput,o.backupPath),o.backupCreated=!0}),await $(T,n,async o=>{await w(o.prePositioned,o.absoluteOutput),o.installed=!0}),await Promise.all(n.filter(o=>o.backupCreated).map(({backupPath:o})=>f(o,{force:!0,recursive:!0}).catch(()=>{}))),!0}catch{for(const c of n)if(c.installed){const h=`${c.absoluteOutput}.failed-${m()}`;await w(c.absoluteOutput,h).catch(()=>{}),c.backupCreated&&await w(c.backupPath,c.absoluteOutput).catch(()=>{}),c.installed=!1,await f(h,{force:!0,recursive:!0}).catch(()=>{})}else c.backupCreated&&await w(c.backupPath,c.absoluteOutput).catch(()=>{});return!1}finally{await f(a,{force:!0,recursive:!0}).catch(()=>{});for(const c of n)await f(c.prePositioned,{force:!0,recursive:!0}).catch(()=>{}),!(c.backupCreated&&!c.installed)&&await f(c.backupPath,{force:!0,recursive:!0}).catch(()=>{})}},"restoreOutputsCompressed");export{St as Cache,ut as DEFAULT_CACHE_DIRECTORY_NAME,Nt as formatCacheSize,lt as parseCacheSize};
@@ -0,0 +1 @@
1
+ var C=Object.defineProperty;var j=(t,e)=>C(t,"name",{value:e,configurable:!0});import{findCycle as P}from"./findCycle-BY8-jmzB.js";var T=Object.defineProperty,d=j((t,e)=>T(t,"name",{value:e,configurable:!0}),"g");const m=d(t=>{const e=[t.project,t.target];return t.configuration&&e.push(t.configuration),e.join(":")},"getTaskId"),A=d(t=>{const e=t.split(":");if(e.length<2)throw new Error(`Invalid task ID: ${t}`);return{configuration:e[2],project:e[0],target:e[1]}},"parseTaskId"),k=d(t=>{if(t===void 0)return;const e=typeof t=="string"?[t]:t;return e.length===0?void 0:e},"normalizeWarningPattern"),v=d((t,e,o,c)=>{const a=o.projects[t],r=a?.targets?.[e],p=c?.[e],i=r?.outputs??p?.outputs??[],g=a?.root&&a.root.length>0?a.root:".";return i.map(s=>typeof s=="string"?s.replaceAll("{projectRoot}",g).replaceAll("{projectName}",t):s)},"getTaskOutputs"),f=d((t,e,o,c,a)=>{const r=c.projects[t];if(!r)return[];if(!(r.targets?.[e]!==void 0||a?.[e]!==void 0))return[];const p={project:t,target:e};return[{always:r.targets?.[e]?.always??a?.[e]?.always,cache:r.targets?.[e]?.cache??a?.[e]?.cache,cacheOnWarning:r.targets?.[e]?.cacheOnWarning??a?.[e]?.cacheOnWarning,cacheRestore:r.targets?.[e]?.cacheRestore??a?.[e]?.cacheRestore,concurrencyGroup:r.targets?.[e]?.concurrencyGroup??a?.[e]?.concurrencyGroup,concurrencyWeight:r.targets?.[e]?.concurrencyWeight??a?.[e]?.concurrencyWeight,hashMode:r.targets?.[e]?.hashMode??a?.[e]?.hashMode,id:m(p),maxConcurrent:r.targets?.[e]?.maxConcurrent??a?.[e]?.maxConcurrent,outputs:v(t,e,c,a),overrides:o,parallelism:r.targets?.[e]?.parallelism??a?.[e]?.parallelism,projectRoot:r.root,pty:r.targets?.[e]?.pty??a?.[e]?.pty,target:p,warningPattern:k(r.targets?.[e]?.warningPattern??a?.[e]?.warningPattern),when:r.targets?.[e]?.when??a?.[e]?.when}]},"getSameProjectTask"),W=d((t,e,o,c,a,r)=>{const p=[],i=a.dependencies[t]??[];for(const g of i){if(g.target===t||g.type==="peerDependency")continue;const s=c.projects[g.target];if(s&&(s.targets?.[e]!==void 0||r?.[e]!==void 0)){const u={project:g.target,target:e};p.push({soft:g.type==="devDependency",task:{always:s.targets?.[e]?.always??r?.[e]?.always,cache:s.targets?.[e]?.cache??r?.[e]?.cache,cacheOnWarning:s.targets?.[e]?.cacheOnWarning??r?.[e]?.cacheOnWarning,cacheRestore:s.targets?.[e]?.cacheRestore??r?.[e]?.cacheRestore,concurrencyGroup:s.targets?.[e]?.concurrencyGroup??r?.[e]?.concurrencyGroup,concurrencyWeight:s.targets?.[e]?.concurrencyWeight??r?.[e]?.concurrencyWeight,hashMode:s.targets?.[e]?.hashMode??r?.[e]?.hashMode,id:m(u),maxConcurrent:s.targets?.[e]?.maxConcurrent??r?.[e]?.maxConcurrent,outputs:v(g.target,e,c,r),overrides:o,parallelism:s.targets?.[e]?.parallelism??r?.[e]?.parallelism,projectRoot:s.root,pty:s.targets?.[e]?.pty??r?.[e]?.pty,target:u,warningPattern:k(s.targets?.[e]?.warningPattern??r?.[e]?.warningPattern),when:s.targets?.[e]?.when??r?.[e]?.when}})}}return p},"getDependencyProjectTasks"),y=d(t=>t.map(e=>({soft:!1,task:e})),"asHardDependencies"),D=d((t,e,o,c,a)=>{if(e.startsWith("^")){const r=e.slice(1);return W(t.target.project,r,{},o,c,a)}return y(f(t.target.project,e,{},o,a))},"resolveStringDependency"),G=d((t,e,o,c,a)=>{const r=[];if(e.dependencies)r.push(...W(t.target.project,e.target,e.params==="forward"?t.overrides:{},o,c,a));else if(e.projects){const p=Array.isArray(e.projects)?e.projects:[e.projects];for(const i of p)r.push(...y(f(i,e.target,e.params==="forward"?t.overrides:{},o,a)))}else r.push(...y(f(t.target.project,e.target,e.params==="forward"?t.overrides:{},o,a)));return r},"resolveConfigDependency"),R=d((t,e,o,c,a)=>typeof e=="string"?D(t,e,o,c,a):G(t,e,o,c,a),"resolveDependency"),S=d((t,e)=>{const{projectGraph:o,targetDefaults:c,workspace:a}=e,r=a.projects[t.target.project];if(!r)return[];const p=r.targets?.[t.target.target],i=c?.[t.target.target],g=p?.dependsOn??i?.dependsOn??[],s=[];for(const u of g){const n=R(t,u,a,o,c);s.push(...n)}return s},"resolveTaskDependencies"),b="\0",w=d((t,e)=>`${t}${b}${e}`,"edgeKey"),x=d((t,e,o,c,a)=>{if(o.size===0)return;const r=d((p,i)=>{const g=w(p,i);return o.has(g)&&!c.has(g)},"isSoftEdge");for(let p=o.size;p>=0;p-=1){const i=P({dependencies:e,roots:[],tasks:t});if(!i||i.length<2)return;let g=!0;for(let n=0;n<i.length-1;n+=1)if(!r(i[n],i[n+1])){g=!1;break}if(!g)return;const s=i.at(-2),u=i.at(-1);e[s]=(e[s]??[]).filter(n=>n!==u),o.delete(w(s,u)),a?.(i)}},"breakSoftOnlyCycles"),$=d((t,e)=>{const o={},c={},a=new Set,r=new Set,p=new Set,i=new Set(t.map(n=>n.id)),g=[...t];for(;g.length>0;){const n=g.shift();if(!n)break;if(p.has(n.id))continue;p.add(n.id),o[n.id]=n,c[n.id]=[];const l=S(n,e);for(const{soft:O,task:h}of l)c[n.id]?.push(h.id),(O?a:r).add(w(n.id,h.id)),!p.has(h.id)&&!i.has(h.id)&&(g.push(h),i.add(h.id))}x(o,c,a,r,e.onCycleBroken);const s=new Set;for(const n of Object.values(c))for(const l of n)s.add(l);const u=Object.keys(o).filter(n=>!s.has(n));return{dependencies:c,roots:u,tasks:o}},"createTaskGraph");export{$ as createTaskGraph,m as getTaskId,A as parseTaskId};
@@ -1,2 +1,2 @@
1
- var v=Object.defineProperty;var I=(e,a)=>v(e,"name",{value:a,configurable:!0});import{X as w}from"./utils-BH2W5Wml.js";import{createRemoteCacheBackend as N}from"./resolveCacheMode--4y60ODd.js";import{Cache as A}from"./Cache-BVrj9bd4.js";import{inferFrameworkEnvPatterns as y}from"./detectFrameworks-WVZJOPgN.js";import{IncrementalFileHasher as L}from"./IncrementalFileHasher-B-V3i2x-.js";import{InProcessTaskHasher as P}from"./computeTaskHash-CaPdG1BA.js";import{TaskOrchestrator as b}from"./TaskOrchestrator-CYj5MLwz.js";import{TaskScheduler as H}from"./parsePartition-Bt1jBjZH.js";var G=Object.defineProperty,m=I((e,a)=>G(e,"name",{value:a,configurable:!0}),"i");const U=m(e=>{const a=[],o={};for(const[t,s]of Object.entries(e.tasks))s.always?a.push(s):o[t]=s;if(a.length===0)return{alwaysTasks:[],graph:e};const i=new Set(a.map(t=>t.id)),c={};for(const[t,s]of Object.entries(e.dependencies))i.has(t)||(c[t]=s.filter(n=>!i.has(n)));return{alwaysTasks:a,graph:{dependencies:c,roots:e.roots.filter(t=>!i.has(t)),tasks:o}}},"partitionAlwaysTasks"),B=m(e=>{if(!e||e.length===0)return;const a=[...e].sort().map(o=>`${o}=${process.env[o]??""}`).join(`
2
- `);return w(Buffer.from(a)).slice(0,16)},"computeGlobalEnvNamespace"),Y=["GITHUB_*","RUNNER_*","ACTIONS_*","GH_*","CI_*","BUILDKITE_*","CIRCLECI_*","CIRCLE_*","GITLAB_*","VERCEL_GIT_*","NETLIFY_BUILD_*","COREPACK_*","VOLTA_*","NPM_CONFIG_*","YARN_*","PNPM_*","NODE_OPTIONS","NODE_PATH","NODE_REPL_HISTORY","NODE_EXTRA_CA_CERTS","LD_PRELOAD","LD_LIBRARY_PATH","DYLD_INSERT_LIBRARIES","DYLD_LIBRARY_PATH","DISPLAY","XAUTHORITY","DBUS_SESSION_BUS_ADDRESS","SSH_AUTH_SOCK","SSH_AGENT_PID","TMUX","TMUX_PANE","STY","WINDOWID","TERM_SESSION_ID","PROCESSOR_*","USERDNSDOMAIN","LOGONSERVER","USERDOMAIN_*"],j=m(e=>typeof e=="number"?Math.max(1,e):e===!1?1:3,"resolveParallel"),Z=m(async(e,a,o)=>{const{lifeCycle:i,projectGraph:c,taskExecutor:t,taskGraph:s,workspaceRoot:n}=o,R=a.namespaceByGlobalEnv?B(a.globalEnv):void 0,_=new A({cacheDirectory:a.cacheDirectory,cacheNamespace:R,maxCacheAge:a.maxCacheAge,maxCacheSize:a.maxCacheSize,workspaceRoot:n});_.removeOldEntries().catch(()=>{});const p={};for(const[r,f]of Object.entries(c.nodes))p[r]=f.data;const l=a.incrementalFileHashing?new L({workspaceRoot:n}):void 0;l&&await l.load();const d=new P({autoEnvVars:a.autoEnvVars,envVars:a.envVars,frameworkInference:a.frameworkInference,globalEnv:a.globalEnv,globalInputs:a.globalInputs,incrementalHasher:l,namedInputs:a.namedInputs,onFingerprint:a.onFingerprint,projects:p,smartLockfileHashing:a.smartLockfileHashing,targetDefaults:a.targetDefaults,workspaceRoot:n}),{alwaysTasks:k,graph:u}=U(s),g=j(a.parallel),S=new H(u,c,g,a.concurrencyGroups),D=Object.values(u.tasks).some(r=>r.hashMode==="trace"),T=m(r=>{const f=c.nodes[r.target.project]?.data.targets?.[r.target.target],O=a.targetDefaults?.[r.target.target];return f?.command??O?.command},"resolveCommand"),h=a.remoteCache?N(a.remoteCache):void 0;let E=a.fingerprintEnvPatterns??[];if(a.frameworkInference&&(a.autoFingerprint||D)){const r=await y(n,p);E=[...new Set([...E,...r])]}const C=new b({alwaysTasks:k,autoFingerprint:a.autoFingerprint,bail:a.bail,cache:_,cacheDiagnostics:a.cacheDiagnostics,captureOutput:!0,dataDirectory:a.dataDirectory,dryRun:a.dryRun,fingerprintEnvPatterns:E,lifeCycle:i,onRemoteUploadError:a.remoteCache?.onUploadError,remoteCache:h,resolveCommand:T,scheduler:S,skipCache:a.skipNxCache,summarize:a.summarize,taskExecutor:t,taskGraph:u,taskHasher:d,untrackedEnvVars:[...Y,...a.untrackedEnvVars??[]],workspaceRoot:n});try{const r=await C.run();return l&&await l.save().catch(()=>{}),r}finally{h&&await h.close().catch(()=>{})}},"defaultTaskRunner");export{Z as defaultTaskRunner};
1
+ var v=Object.defineProperty;var I=(e,a)=>v(e,"name",{value:a,configurable:!0});import{X as w}from"./utils-BH2W5Wml.js";import{createRemoteCacheBackend as N}from"./resolveCacheMode--4y60ODd.js";import{Cache as A}from"./Cache-C8FfeXpg.js";import{inferFrameworkEnvPatterns as y}from"./detectFrameworks-WVZJOPgN.js";import{IncrementalFileHasher as L}from"./IncrementalFileHasher-B-V3i2x-.js";import{InProcessTaskHasher as P}from"./computeTaskHash-CaPdG1BA.js";import{TaskOrchestrator as b}from"./TaskOrchestrator-CYj5MLwz.js";import{TaskScheduler as H}from"./parsePartition-Bt1jBjZH.js";var G=Object.defineProperty,m=I((e,a)=>G(e,"name",{value:a,configurable:!0}),"i");const U=m(e=>{const a=[],o={};for(const[t,s]of Object.entries(e.tasks))s.always?a.push(s):o[t]=s;if(a.length===0)return{alwaysTasks:[],graph:e};const i=new Set(a.map(t=>t.id)),c={};for(const[t,s]of Object.entries(e.dependencies))i.has(t)||(c[t]=s.filter(n=>!i.has(n)));return{alwaysTasks:a,graph:{dependencies:c,roots:e.roots.filter(t=>!i.has(t)),tasks:o}}},"partitionAlwaysTasks"),B=m(e=>{if(!e||e.length===0)return;const a=[...e].sort().map(o=>`${o}=${process.env[o]??""}`).join(`
2
+ `);return w(Buffer.from(a)).slice(0,16)},"computeGlobalEnvNamespace"),Y=["GITHUB_*","RUNNER_*","ACTIONS_*","GH_*","CI_*","BUILDKITE_*","CIRCLECI_*","CIRCLE_*","GITLAB_*","VERCEL_GIT_*","NETLIFY_BUILD_*","COREPACK_*","VOLTA_*","NPM_CONFIG_*","YARN_*","PNPM_*","NODE_OPTIONS","NODE_PATH","NODE_REPL_HISTORY","NODE_EXTRA_CA_CERTS","LD_PRELOAD","LD_LIBRARY_PATH","DYLD_INSERT_LIBRARIES","DYLD_LIBRARY_PATH","DISPLAY","XAUTHORITY","DBUS_SESSION_BUS_ADDRESS","SSH_AUTH_SOCK","SSH_AGENT_PID","TMUX","TMUX_PANE","STY","WINDOWID","TERM_SESSION_ID","PROCESSOR_*","USERDNSDOMAIN","LOGONSERVER","USERDOMAIN_*"],j=m(e=>typeof e=="number"?Math.max(1,e):e===!1?1:3,"resolveParallel"),q=m(async(e,a,o)=>{const{lifeCycle:i,projectGraph:c,taskExecutor:t,taskGraph:s,workspaceRoot:n}=o,R=a.namespaceByGlobalEnv?B(a.globalEnv):void 0,_=new A({cacheDirectory:a.cacheDirectory,cacheNamespace:R,maxCacheAge:a.maxCacheAge,maxCacheSize:a.maxCacheSize,workspaceRoot:n});_.removeOldEntries().catch(()=>{});const p={};for(const[r,f]of Object.entries(c.nodes))p[r]=f.data;const l=a.incrementalFileHashing?new L({workspaceRoot:n}):void 0;l&&await l.load();const d=new P({autoEnvVars:a.autoEnvVars,envVars:a.envVars,frameworkInference:a.frameworkInference,globalEnv:a.globalEnv,globalInputs:a.globalInputs,incrementalHasher:l,namedInputs:a.namedInputs,onFingerprint:a.onFingerprint,projects:p,smartLockfileHashing:a.smartLockfileHashing,targetDefaults:a.targetDefaults,workspaceRoot:n}),{alwaysTasks:k,graph:u}=U(s),g=j(a.parallel),S=new H(u,c,g,a.concurrencyGroups),D=Object.values(u.tasks).some(r=>r.hashMode==="trace"),T=m(r=>{const f=c.nodes[r.target.project]?.data.targets?.[r.target.target],O=a.targetDefaults?.[r.target.target];return f?.command??O?.command},"resolveCommand"),h=a.remoteCache?N(a.remoteCache):void 0;let E=a.fingerprintEnvPatterns??[];if(a.frameworkInference&&(a.autoFingerprint||D)){const r=await y(n,p);E=[...new Set([...E,...r])]}const C=new b({alwaysTasks:k,autoFingerprint:a.autoFingerprint,bail:a.bail,cache:_,cacheDiagnostics:a.cacheDiagnostics,captureOutput:!0,dataDirectory:a.dataDirectory,dryRun:a.dryRun,fingerprintEnvPatterns:E,lifeCycle:i,onRemoteUploadError:a.remoteCache?.onUploadError,remoteCache:h,resolveCommand:T,scheduler:S,skipCache:a.skipNxCache,summarize:a.summarize,taskExecutor:t,taskGraph:u,taskHasher:d,untrackedEnvVars:[...Y,...a.untrackedEnvVars??[]],workspaceRoot:n});try{const r=await C.run();return l&&await l.save().catch(()=>{}),r}finally{h&&await h.close().catch(()=>{})}},"defaultTaskRunner");export{q as defaultTaskRunner};
@@ -0,0 +1 @@
1
+ var y=Object.defineProperty;var f=(t,e)=>y(t,"name",{value:e,configurable:!0});import{createRequire as b}from"node:module";import{isAbsolute as O,resolve as g,relative as T,join as q}from"@visulima/path";const j=b(import.meta.url),a=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,m=f(t=>{if(typeof a<"u"&&a.versions&&a.versions.node){const[e,s]=a.versions.node.split(".").map(Number);if(e>22||e===22&&s>=3||e===20&&s>=16)return a.getBuiltinModule(t)}return j(t)},"__cjs_getBuiltinModule"),{stat:w,glob:P}=m("node:fs/promises"),{matchesGlob:F}=m("node:path");var R=Object.defineProperty,u=f((t,e)=>R(t,"name",{value:e,configurable:!0}),"c");const W=/[*?[\]{}]/,p=u((t,e)=>{const s=T(t,e);if(!(s.length===0||s.startsWith("..")))return s},"toWorkspaceRelative"),A=u(async(t,e,s)=>{if(!e||e.length===0)return[];const n=[],r=[];let c=!1;for(const o of e){if(typeof o!="string"){o.auto&&(c=!0);continue}if(o.length!==0){if(o.startsWith("!")){const i=o.slice(1);i.length>0&&r.push(i);continue}n.push(o)}}const l=new Set;if(c&&s)for(const o of s){const i=O(o)?o:g(t,o),d=p(t,i);d&&l.add(d)}const _=r.length>0,v=await Promise.all(n.map(o=>x(t,o,_)));for(const o of v)for(const i of o)l.add(i);return r.length===0?[...l].sort():[...l].filter(o=>!r.some(i=>F(o,i))).sort()},"resolveOutputs"),h=u(async(t,e)=>{const s=[];for await(const n of P(e,{cwd:t,withFileTypes:!0})){if(!n.isFile())continue;const r=p(t,q(n.parentPath,n.name));r&&s.push(r)}return s},"collectFiles"),x=u(async(t,e,s)=>{if(!W.test(e)){const n=g(t,e),r=p(t,n);if(!r)return[];let c;try{c=await w(n)}catch{return[]}return s&&c.isDirectory()?h(t,`${e}/**`):[r]}return h(t,e)},"expandPattern");export{A as resolveOutputs};
package/index.js CHANGED
@@ -81,8 +81,8 @@ function requireNative() {
81
81
  try {
82
82
  const binding = require('@visulima/task-runner-binding-android-arm64')
83
83
  const bindingPackageVersion = require('@visulima/task-runner-binding-android-arm64/package.json').version
84
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
85
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
84
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
85
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
86
86
  }
87
87
  return binding
88
88
  } catch (e) {
@@ -97,8 +97,8 @@ function requireNative() {
97
97
  try {
98
98
  const binding = require('@visulima/task-runner-binding-android-arm-eabi')
99
99
  const bindingPackageVersion = require('@visulima/task-runner-binding-android-arm-eabi/package.json').version
100
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
101
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
100
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
101
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
102
102
  }
103
103
  return binding
104
104
  } catch (e) {
@@ -118,8 +118,8 @@ function requireNative() {
118
118
  try {
119
119
  const binding = require('@visulima/task-runner-binding-win32-x64-gnu')
120
120
  const bindingPackageVersion = require('@visulima/task-runner-binding-win32-x64-gnu/package.json').version
121
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
122
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
121
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
122
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
123
123
  }
124
124
  return binding
125
125
  } catch (e) {
@@ -134,8 +134,8 @@ function requireNative() {
134
134
  try {
135
135
  const binding = require('@visulima/task-runner-binding-win32-x64-msvc')
136
136
  const bindingPackageVersion = require('@visulima/task-runner-binding-win32-x64-msvc/package.json').version
137
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
138
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
137
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
138
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
139
139
  }
140
140
  return binding
141
141
  } catch (e) {
@@ -151,8 +151,8 @@ function requireNative() {
151
151
  try {
152
152
  const binding = require('@visulima/task-runner-binding-win32-ia32-msvc')
153
153
  const bindingPackageVersion = require('@visulima/task-runner-binding-win32-ia32-msvc/package.json').version
154
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
155
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
154
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
155
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
156
156
  }
157
157
  return binding
158
158
  } catch (e) {
@@ -167,8 +167,8 @@ function requireNative() {
167
167
  try {
168
168
  const binding = require('@visulima/task-runner-binding-win32-arm64-msvc')
169
169
  const bindingPackageVersion = require('@visulima/task-runner-binding-win32-arm64-msvc/package.json').version
170
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
171
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
170
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
171
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
172
172
  }
173
173
  return binding
174
174
  } catch (e) {
@@ -186,8 +186,8 @@ function requireNative() {
186
186
  try {
187
187
  const binding = require('@visulima/task-runner-binding-darwin-universal')
188
188
  const bindingPackageVersion = require('@visulima/task-runner-binding-darwin-universal/package.json').version
189
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
190
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
189
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
190
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
191
191
  }
192
192
  return binding
193
193
  } catch (e) {
@@ -202,8 +202,8 @@ function requireNative() {
202
202
  try {
203
203
  const binding = require('@visulima/task-runner-binding-darwin-x64')
204
204
  const bindingPackageVersion = require('@visulima/task-runner-binding-darwin-x64/package.json').version
205
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
206
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
205
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
206
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
207
207
  }
208
208
  return binding
209
209
  } catch (e) {
@@ -218,8 +218,8 @@ function requireNative() {
218
218
  try {
219
219
  const binding = require('@visulima/task-runner-binding-darwin-arm64')
220
220
  const bindingPackageVersion = require('@visulima/task-runner-binding-darwin-arm64/package.json').version
221
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
222
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
221
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
222
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
223
223
  }
224
224
  return binding
225
225
  } catch (e) {
@@ -238,8 +238,8 @@ function requireNative() {
238
238
  try {
239
239
  const binding = require('@visulima/task-runner-binding-freebsd-x64')
240
240
  const bindingPackageVersion = require('@visulima/task-runner-binding-freebsd-x64/package.json').version
241
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
242
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
241
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
242
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
243
243
  }
244
244
  return binding
245
245
  } catch (e) {
@@ -254,8 +254,8 @@ function requireNative() {
254
254
  try {
255
255
  const binding = require('@visulima/task-runner-binding-freebsd-arm64')
256
256
  const bindingPackageVersion = require('@visulima/task-runner-binding-freebsd-arm64/package.json').version
257
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
258
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
257
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
258
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
259
259
  }
260
260
  return binding
261
261
  } catch (e) {
@@ -275,8 +275,8 @@ function requireNative() {
275
275
  try {
276
276
  const binding = require('@visulima/task-runner-binding-linux-x64-musl')
277
277
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-x64-musl/package.json').version
278
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
279
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
278
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
279
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
280
280
  }
281
281
  return binding
282
282
  } catch (e) {
@@ -291,8 +291,8 @@ function requireNative() {
291
291
  try {
292
292
  const binding = require('@visulima/task-runner-binding-linux-x64-gnu')
293
293
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-x64-gnu/package.json').version
294
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
295
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
294
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
295
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
296
296
  }
297
297
  return binding
298
298
  } catch (e) {
@@ -309,8 +309,8 @@ function requireNative() {
309
309
  try {
310
310
  const binding = require('@visulima/task-runner-binding-linux-arm64-musl')
311
311
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-arm64-musl/package.json').version
312
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
313
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
312
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
313
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
314
314
  }
315
315
  return binding
316
316
  } catch (e) {
@@ -325,8 +325,8 @@ function requireNative() {
325
325
  try {
326
326
  const binding = require('@visulima/task-runner-binding-linux-arm64-gnu')
327
327
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-arm64-gnu/package.json').version
328
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
329
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
328
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
329
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
330
330
  }
331
331
  return binding
332
332
  } catch (e) {
@@ -343,8 +343,8 @@ function requireNative() {
343
343
  try {
344
344
  const binding = require('@visulima/task-runner-binding-linux-arm-musleabihf')
345
345
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-arm-musleabihf/package.json').version
346
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
347
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
346
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
347
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
348
348
  }
349
349
  return binding
350
350
  } catch (e) {
@@ -359,8 +359,8 @@ function requireNative() {
359
359
  try {
360
360
  const binding = require('@visulima/task-runner-binding-linux-arm-gnueabihf')
361
361
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-arm-gnueabihf/package.json').version
362
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
363
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
362
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
363
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
364
364
  }
365
365
  return binding
366
366
  } catch (e) {
@@ -377,8 +377,8 @@ function requireNative() {
377
377
  try {
378
378
  const binding = require('@visulima/task-runner-binding-linux-loong64-musl')
379
379
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-loong64-musl/package.json').version
380
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
381
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
380
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
381
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
382
382
  }
383
383
  return binding
384
384
  } catch (e) {
@@ -393,8 +393,8 @@ function requireNative() {
393
393
  try {
394
394
  const binding = require('@visulima/task-runner-binding-linux-loong64-gnu')
395
395
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-loong64-gnu/package.json').version
396
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
397
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
396
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
397
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
398
398
  }
399
399
  return binding
400
400
  } catch (e) {
@@ -411,8 +411,8 @@ function requireNative() {
411
411
  try {
412
412
  const binding = require('@visulima/task-runner-binding-linux-riscv64-musl')
413
413
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-riscv64-musl/package.json').version
414
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
415
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
414
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
415
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
416
416
  }
417
417
  return binding
418
418
  } catch (e) {
@@ -427,8 +427,8 @@ function requireNative() {
427
427
  try {
428
428
  const binding = require('@visulima/task-runner-binding-linux-riscv64-gnu')
429
429
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-riscv64-gnu/package.json').version
430
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
431
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
430
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
431
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
432
432
  }
433
433
  return binding
434
434
  } catch (e) {
@@ -444,8 +444,8 @@ function requireNative() {
444
444
  try {
445
445
  const binding = require('@visulima/task-runner-binding-linux-ppc64-gnu')
446
446
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-ppc64-gnu/package.json').version
447
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
448
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
447
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
448
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
449
449
  }
450
450
  return binding
451
451
  } catch (e) {
@@ -460,8 +460,8 @@ function requireNative() {
460
460
  try {
461
461
  const binding = require('@visulima/task-runner-binding-linux-s390x-gnu')
462
462
  const bindingPackageVersion = require('@visulima/task-runner-binding-linux-s390x-gnu/package.json').version
463
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
464
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
463
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
464
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
465
465
  }
466
466
  return binding
467
467
  } catch (e) {
@@ -480,8 +480,8 @@ function requireNative() {
480
480
  try {
481
481
  const binding = require('@visulima/task-runner-binding-openharmony-arm64')
482
482
  const bindingPackageVersion = require('@visulima/task-runner-binding-openharmony-arm64/package.json').version
483
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
484
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
483
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
484
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
485
485
  }
486
486
  return binding
487
487
  } catch (e) {
@@ -496,8 +496,8 @@ function requireNative() {
496
496
  try {
497
497
  const binding = require('@visulima/task-runner-binding-openharmony-x64')
498
498
  const bindingPackageVersion = require('@visulima/task-runner-binding-openharmony-x64/package.json').version
499
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
500
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
499
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
500
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
501
501
  }
502
502
  return binding
503
503
  } catch (e) {
@@ -512,8 +512,8 @@ function requireNative() {
512
512
  try {
513
513
  const binding = require('@visulima/task-runner-binding-openharmony-arm')
514
514
  const bindingPackageVersion = require('@visulima/task-runner-binding-openharmony-arm/package.json').version
515
- if (bindingPackageVersion !== '1.0.0-alpha.18' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
516
- throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.19 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
515
+ if (bindingPackageVersion !== '1.0.0-alpha.19' && process.env.NAPI_RS_ENFORCE_VERSION_CHECK && process.env.NAPI_RS_ENFORCE_VERSION_CHECK !== '0') {
516
+ throw new Error(`Native binding package version mismatch, expected 1.0.0-alpha.20 but got ${bindingPackageVersion}. You can reinstall dependencies to fix this issue.`)
517
517
  }
518
518
  return binding
519
519
  } catch (e) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visulima/task-runner",
3
- "version": "1.0.0-alpha.19",
3
+ "version": "1.0.0-alpha.20",
4
4
  "description": "A task runner with caching support for monorepo workspaces",
5
5
  "keywords": [
6
6
  "cache",
@@ -68,14 +68,14 @@
68
68
  }
69
69
  },
70
70
  "optionalDependencies": {
71
- "@visulima/task-runner-binding-darwin-arm64": "1.0.0-alpha.19",
72
- "@visulima/task-runner-binding-darwin-x64": "1.0.0-alpha.19",
73
- "@visulima/task-runner-binding-linux-arm64-gnu": "1.0.0-alpha.19",
74
- "@visulima/task-runner-binding-linux-arm64-musl": "1.0.0-alpha.19",
75
- "@visulima/task-runner-binding-linux-x64-gnu": "1.0.0-alpha.19",
76
- "@visulima/task-runner-binding-win32-arm64-msvc": "1.0.0-alpha.19",
77
- "@visulima/task-runner-binding-linux-x64-musl": "1.0.0-alpha.19",
78
- "@visulima/task-runner-binding-win32-x64-msvc": "1.0.0-alpha.19"
71
+ "@visulima/task-runner-binding-linux-arm64-gnu": "1.0.0-alpha.20",
72
+ "@visulima/task-runner-binding-darwin-arm64": "1.0.0-alpha.20",
73
+ "@visulima/task-runner-binding-linux-arm64-musl": "1.0.0-alpha.20",
74
+ "@visulima/task-runner-binding-darwin-x64": "1.0.0-alpha.20",
75
+ "@visulima/task-runner-binding-linux-x64-gnu": "1.0.0-alpha.20",
76
+ "@visulima/task-runner-binding-linux-x64-musl": "1.0.0-alpha.20",
77
+ "@visulima/task-runner-binding-win32-x64-msvc": "1.0.0-alpha.20",
78
+ "@visulima/task-runner-binding-win32-arm64-msvc": "1.0.0-alpha.20"
79
79
  },
80
80
  "engines": {
81
81
  "node": "^22.14.0 || >=24.10.0"
@@ -1,2 +0,0 @@
1
- var I=Object.defineProperty;var b=(s,t)=>I(s,"name",{value:t,configurable:!0});import{createRequire as R}from"node:module";import{parseBytes as X,formatBytes as Y}from"@visulima/humanizer";import{dirname as N,join as u,resolve as x}from"@visulima/path";import{a as G,b as K}from"./archive-CDfGy5Lm.js";import{O as m}from"./utils-BH2W5Wml.js";import{acEntryPath as A,tmpDirectory as B,taskHashIndexPath as z,V2_ROOT as _}from"./V2_ROOT-injxWBrl.js";import{fetchBlobToFile as L,containsBlob as U,putBlobFromFile as Z}from"./containsBlob-DAU8R7GH.js";import{resolveOutputs as Q}from"./resolveOutputs-BBjdaraf.js";const J=R(import.meta.url),k=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,E=b(s=>{if(typeof k<"u"&&k.versions&&k.versions.node){const[t,e]=k.versions.node.split(".").map(Number);if(t>22||t===22&&e>=3||t===20&&e>=16)return k.getBuiltinModule(s)}return J(s)},"__cjs_getBuiltinModule"),{createWriteStream:H}=E("node:fs"),{mkdir:f,writeFile:d,rename:w,rm:l,readFile:v,utimes:q,open:V,stat:O,readdir:S,cp:D}=E("node:fs/promises"),{pipeline:W}=E("node:stream/promises");var tt=Object.defineProperty,C=b((s,t)=>tt(s,"name",{value:t,configurable:!0}),"s");const et=C(async(s,t,e)=>{const r=A(s,t),a=B(s),i=`${a}/${m()}`;await f(a,{recursive:!0}),await f(N(r),{recursive:!0});const n=`${JSON.stringify(e,null,2)}
2
- `;await d(i,n);try{await w(i,r)}catch(c){throw await l(i,{force:!0}).catch(()=>{}),c}},"writeActionEntry"),at=C(async(s,t)=>{const e=A(s,t);try{const r=await v(e,"utf8"),a=JSON.parse(r),i=new Date;return await q(e,i,i).catch(()=>{}),a}catch{return null}},"readActionEntry"),rt=C(async(s,t,e)=>{const r=z(s,t),a=B(s),i=`${a}/${m()}`;await f(a,{recursive:!0}),await f(N(r),{recursive:!0}),await d(i,e);try{await w(i,r)}catch(n){throw await l(i,{force:!0}).catch(()=>{}),n}},"writeTaskHashIndex"),st=C(async(s,t)=>{try{const e=(await v(z(s,t),"utf8")).trim();return e.length>0?e:null}catch{return null}},"readTaskHashIndex");var it=Object.defineProperty,y=b((s,t)=>it(s,"name",{value:t,configurable:!0}),"d");const ct=10080*60*1e3,nt=".task-runner-cache",ot=y(s=>{if(s.includes("\0"))throw new Error("cacheNamespace: null bytes are not allowed.");if(s.includes("/")||s.includes("\\"))throw new Error(`cacheNamespace: path separators are not allowed (received ${JSON.stringify(s)}).`);if(s==="."||s==="..")throw new Error(`cacheNamespace: "${s}" would escape the cache subtree.`)},"assertSafeNamespace"),$=y(async s=>{try{await l(s,{force:!0,recursive:!0})}catch{}},"removeEntry"),j=y(async s=>{let t=0;try{const e=await S(s,{withFileTypes:!0});for(const r of e){const a=u(s,r.name);if(r.isDirectory())t+=await j(a);else if(r.isFile()){const i=await O(a);t+=i.size}}}catch{}return t},"getDirectorySize"),ut=y(s=>{const t=X(s.trim());if(Number.isNaN(t))throw new TypeError(`Invalid cache size format: "${s}". Expected format like "500MB" or "1GB".`);return t},"parseCacheSize"),kt=y(s=>Y(s,{decimals:1,space:!1}),"formatCacheSize");class Ot{static{b(this,"Z")}static{y(this,"Cache")}#e;#t;#r;#a;#s=Promise.resolve();constructor(t){this.#e=t.workspaceRoot;const e=t.cacheDirectory??u(t.workspaceRoot,nt);t.cacheNamespace!==void 0&&t.cacheNamespace.length>0&&ot(t.cacheNamespace),this.#t=t.cacheNamespace&&t.cacheNamespace.length>0?u(e,"ns",t.cacheNamespace):e,this.#r=t.maxCacheAge??ct,this.#a=t.maxCacheSize?ut(t.maxCacheSize):void 0}get cacheDirectory(){return this.#t}get casRoot(){return this.#t}async getActionResult(t){return at(this.#t,t.hash)}async resolveActionDigestForTaskHash(t){return st(this.#t,t)}async putActionResult(t,e,r,a){await this.#i(a),await et(this.#t,e.hash,r),await rt(this.#t,t,e.hash)}async materializeOutputs(t,e){for(const r of t.outputFiles){const a=x(e,r.path);if(!await L(this.#t,r.digest,a))return!1}return!0}async#i(t){for(const e of t){if(await U(this.#t,e.digest))continue;const r=u(this.#t,_,"tmp",`.put-${m()}`);await f(N(r),{recursive:!0});const a=await e.open();await W(a,H(r)),await Z(this.#t,e.digest,r),await l(r,{force:!0}).catch(()=>{})}}async get(t){const e=u(this.#t,t);try{await v(u(e,".commit"));const r=await v(u(e,"code"),"utf8"),a=Number.parseInt(r.trim(),10);if(Number.isNaN(a))return;let i="";try{i=await v(u(e,"terminalOutput"),"utf8")}catch{}let n;try{const c=await v(u(e,"fingerprint.json"),"utf8");n=JSON.parse(c)}catch{}return{code:a,fingerprint:n,hash:t,terminalOutput:i}}catch{return}}async put(t,e,r,a,i,n){const c=u(this.#t,t),h=u(this.#t,`.tmp-${t}-${m()}`);try{await f(h,{recursive:!0});const o=[d(u(h,"code"),String(a)),d(u(h,"terminalOutput"),e),this.#o(h,r,n)];i&&o.push(d(u(h,"fingerprint.json"),JSON.stringify(i))),await Promise.all(o),await d(u(h,".commit"),"");const p=`${c}.trash-${m()}`;let g=!1;try{await w(c,p),g=!0}catch{}try{await w(h,c)}catch(F){throw g&&await w(p,c).catch(()=>{}),F}g&&$(p).catch(()=>{})}catch{await $(h)}}async restoreOutputs(t,e,r){const a=u(this.#t,t);return lt(a,this.#e,r)}async getByTaskId(t){const e=u(this.#t,".task-index.json");try{const r=await v(e,"utf8"),a=JSON.parse(r)[t];return a?this.get(a):void 0}catch{return}}async setTaskIndex(t,e){const r=this.#s.then(()=>this.#c(t,e));return this.#s=r.catch(()=>{}),r}async#c(t,e){const r=u(this.#t,".task-index.json"),a=u(this.#t,`.task-index-${m()}.tmp`);await f(this.#t,{recursive:!0}),await this.#n(async()=>{let i={};try{const n=await v(r,"utf8");i=JSON.parse(n)}catch{}i[t]=e,await d(a,JSON.stringify(i));try{await w(a,r)}catch{await d(r,JSON.stringify(i)),await l(a,{force:!0})}})}async#n(t){const e=u(this.#t,".task-index.lock"),r=3e4,a=1e4,i=Date.now();for(;;){let n;try{n=await V(e,"wx")}catch(c){if(c.code!=="EEXIST")throw c;const h=await O(e).catch(()=>{});if(h&&Date.now()-h.mtimeMs>r){await l(e,{force:!0}).catch(()=>{});continue}if(Date.now()-i>a)throw new Error(`Timed out waiting for task-index lock at ${e}`,{cause:c});await new Promise(o=>{setTimeout(o,50)});continue}try{return await t()}finally{await n.close().catch(()=>{}),await l(e,{force:!0}).catch(()=>{})}}}async removeOldEntries(){try{const t=await S(this.#t),e=Date.now(),r=[];for(const a of t){if(a.startsWith(".")||a===_)continue;const i=u(this.#t,a);try{const n=await O(i);if(e-n.mtimeMs>this.#r)await $(i);else{const c=await j(i);r.push({mtimeMs:n.mtimeMs,name:a,path:i,size:c})}}catch{}}if(this.#a!==void 0){const a=r.toSorted((n,c)=>n.mtimeMs-c.mtimeMs);let i=0;for(const n of a)i+=n.size;for(const n of a){if(i<=this.#a)break;await $(n.path),i-=n.size}}}catch{}}async clear(){try{await l(this.#t,{force:!0,recursive:!0})}catch{}}async#o(t,e,r){await ht(this.#e,t,e,r)}}const M="outputs.tar.br",ht=y(async(s,t,e,r)=>{if(e.length===0)return;const a=await Q(s,e,r);if(a.length===0)return;const i=u(t,`.outputs-stage-${m()}`),n=u(t,M);try{if(await f(i,{recursive:!0}),(await T(P,a,async c=>{const h=x(s,c),o=u(i,c);try{return await f(N(o),{recursive:!0}),await D(h,o,{preserveTimestamps:!0,recursive:!0}),!0}catch{return!1}})).filter(Boolean).length===0)return;await K(i,n)}finally{await l(i,{force:!0,recursive:!0}).catch(()=>{})}},"archiveOutputsCompressed"),P=16,T=y(async(s,t,e)=>{const r=Array.from({length:t.length});let a=0;const i=y(async()=>{for(;a<t.length;){const c=a;a+=1,r[c]=await e(t[c],c)}},"worker"),n=Array.from({length:Math.min(s,t.length)},()=>i());return await Promise.all(n),r},"runBounded"),lt=y(async(s,t,e)=>{const r=u(s,M);try{await O(r)}catch{return!0}const a=u(s,`.restore-${m()}`),i=e?.preserveMtime??!0,n=[];try{await f(a,{recursive:!0}),await G(r,a,e);const c=(await S(a)).sort(),h=m();for(const o of c){const p=x(t,o);n.push({absoluteOutput:p,backupCreated:!1,backupPath:`${p}.old-${h}`,entry:o,installed:!1,prePositioned:`${p}.restoring-${h}`})}return await T(P,n,async o=>{const p=u(a,o.entry);await f(N(o.absoluteOutput),{recursive:!0}),await l(o.prePositioned,{force:!0,recursive:!0}).catch(()=>{});try{await w(p,o.prePositioned)}catch(g){if(g.code==="EXDEV")await D(p,o.prePositioned,{preserveTimestamps:i,recursive:!0});else throw g}}),await T(P,n,async o=>{try{await O(o.absoluteOutput)}catch{return}await w(o.absoluteOutput,o.backupPath),o.backupCreated=!0}),await T(P,n,async o=>{await w(o.prePositioned,o.absoluteOutput),o.installed=!0}),await Promise.all(n.filter(o=>o.backupCreated).map(({backupPath:o})=>l(o,{force:!0,recursive:!0}).catch(()=>{}))),!0}catch{for(const c of n)if(c.installed){const h=`${c.absoluteOutput}.failed-${m()}`;await w(c.absoluteOutput,h).catch(()=>{}),c.backupCreated&&await w(c.backupPath,c.absoluteOutput).catch(()=>{}),c.installed=!1,await l(h,{force:!0,recursive:!0}).catch(()=>{})}else c.backupCreated&&await w(c.backupPath,c.absoluteOutput).catch(()=>{});return!1}finally{await l(a,{force:!0,recursive:!0}).catch(()=>{});for(const c of n)await l(c.prePositioned,{force:!0,recursive:!0}).catch(()=>{}),!(c.backupCreated&&!c.installed)&&await l(c.backupPath,{force:!0,recursive:!0}).catch(()=>{})}},"restoreOutputsCompressed");export{Ot as Cache,nt as DEFAULT_CACHE_DIRECTORY_NAME,kt as formatCacheSize,ut as parseCacheSize};
@@ -1 +0,0 @@
1
- var C=Object.defineProperty;var j=(t,e)=>C(t,"name",{value:e,configurable:!0});import{findCycle as P}from"./findCycle-BY8-jmzB.js";var T=Object.defineProperty,d=j((t,e)=>T(t,"name",{value:e,configurable:!0}),"g");const m=d(t=>{const e=[t.project,t.target];return t.configuration&&e.push(t.configuration),e.join(":")},"getTaskId"),$=d(t=>{const e=t.split(":");if(e.length<2)throw new Error(`Invalid task ID: ${t}`);return{configuration:e[2],project:e[0],target:e[1]}},"parseTaskId"),k=d(t=>{if(t===void 0)return;const e=typeof t=="string"?[t]:t;return e.length===0?void 0:e},"normalizeWarningPattern"),v=d((t,e,s,o)=>{const a=s.projects[t],r=a?.targets?.[e],p=o?.[e];return(r?.outputs??p?.outputs??[]).map(i=>typeof i=="string"?i.replace("{projectRoot}",a?.root??"").replace("{projectName}",t):i)},"getTaskOutputs"),l=d((t,e,s,o,a)=>{const r=o.projects[t];if(!r)return[];if(!(r.targets?.[e]!==void 0||a?.[e]!==void 0))return[];const p={project:t,target:e};return[{always:r.targets?.[e]?.always??a?.[e]?.always,cache:r.targets?.[e]?.cache??a?.[e]?.cache,cacheOnWarning:r.targets?.[e]?.cacheOnWarning??a?.[e]?.cacheOnWarning,cacheRestore:r.targets?.[e]?.cacheRestore??a?.[e]?.cacheRestore,concurrencyGroup:r.targets?.[e]?.concurrencyGroup??a?.[e]?.concurrencyGroup,concurrencyWeight:r.targets?.[e]?.concurrencyWeight??a?.[e]?.concurrencyWeight,hashMode:r.targets?.[e]?.hashMode??a?.[e]?.hashMode,id:m(p),maxConcurrent:r.targets?.[e]?.maxConcurrent??a?.[e]?.maxConcurrent,outputs:v(t,e,o,a),overrides:s,parallelism:r.targets?.[e]?.parallelism??a?.[e]?.parallelism,projectRoot:r.root,pty:r.targets?.[e]?.pty??a?.[e]?.pty,target:p,warningPattern:k(r.targets?.[e]?.warningPattern??a?.[e]?.warningPattern),when:r.targets?.[e]?.when??a?.[e]?.when}]},"getSameProjectTask"),W=d((t,e,s,o,a,r)=>{const p=[],i=a.dependencies[t]??[];for(const g of i){if(g.target===t||g.type==="peerDependency")continue;const c=o.projects[g.target];if(c&&(c.targets?.[e]!==void 0||r?.[e]!==void 0)){const u={project:g.target,target:e};p.push({soft:g.type==="devDependency",task:{always:c.targets?.[e]?.always??r?.[e]?.always,cache:c.targets?.[e]?.cache??r?.[e]?.cache,cacheOnWarning:c.targets?.[e]?.cacheOnWarning??r?.[e]?.cacheOnWarning,cacheRestore:c.targets?.[e]?.cacheRestore??r?.[e]?.cacheRestore,concurrencyGroup:c.targets?.[e]?.concurrencyGroup??r?.[e]?.concurrencyGroup,concurrencyWeight:c.targets?.[e]?.concurrencyWeight??r?.[e]?.concurrencyWeight,hashMode:c.targets?.[e]?.hashMode??r?.[e]?.hashMode,id:m(u),maxConcurrent:c.targets?.[e]?.maxConcurrent??r?.[e]?.maxConcurrent,outputs:v(g.target,e,o,r),overrides:s,parallelism:c.targets?.[e]?.parallelism??r?.[e]?.parallelism,projectRoot:c.root,pty:c.targets?.[e]?.pty??r?.[e]?.pty,target:u,warningPattern:k(c.targets?.[e]?.warningPattern??r?.[e]?.warningPattern),when:c.targets?.[e]?.when??r?.[e]?.when}})}}return p},"getDependencyProjectTasks"),y=d(t=>t.map(e=>({soft:!1,task:e})),"asHardDependencies"),D=d((t,e,s,o,a)=>{if(e.startsWith("^")){const r=e.slice(1);return W(t.target.project,r,{},s,o,a)}return y(l(t.target.project,e,{},s,a))},"resolveStringDependency"),G=d((t,e,s,o,a)=>{const r=[];if(e.dependencies)r.push(...W(t.target.project,e.target,e.params==="forward"?t.overrides:{},s,o,a));else if(e.projects){const p=Array.isArray(e.projects)?e.projects:[e.projects];for(const i of p)r.push(...y(l(i,e.target,e.params==="forward"?t.overrides:{},s,a)))}else r.push(...y(l(t.target.project,e.target,e.params==="forward"?t.overrides:{},s,a)));return r},"resolveConfigDependency"),R=d((t,e,s,o,a)=>typeof e=="string"?D(t,e,s,o,a):G(t,e,s,o,a),"resolveDependency"),S=d((t,e)=>{const{projectGraph:s,targetDefaults:o,workspace:a}=e,r=a.projects[t.target.project];if(!r)return[];const p=r.targets?.[t.target.target],i=o?.[t.target.target],g=p?.dependsOn??i?.dependsOn??[],c=[];for(const u of g){const n=R(t,u,a,s,o);c.push(...n)}return c},"resolveTaskDependencies"),b="\0",w=d((t,e)=>`${t}${b}${e}`,"edgeKey"),x=d((t,e,s,o,a)=>{if(s.size===0)return;const r=d((p,i)=>{const g=w(p,i);return s.has(g)&&!o.has(g)},"isSoftEdge");for(let p=s.size;p>=0;p-=1){const i=P({dependencies:e,roots:[],tasks:t});if(!i||i.length<2)return;let g=!0;for(let n=0;n<i.length-1;n+=1)if(!r(i[n],i[n+1])){g=!1;break}if(!g)return;const c=i.at(-2),u=i.at(-1);e[c]=(e[c]??[]).filter(n=>n!==u),s.delete(w(c,u)),a?.(i)}},"breakSoftOnlyCycles"),z=d((t,e)=>{const s={},o={},a=new Set,r=new Set,p=new Set,i=new Set(t.map(n=>n.id)),g=[...t];for(;g.length>0;){const n=g.shift();if(!n)break;if(p.has(n.id))continue;p.add(n.id),s[n.id]=n,o[n.id]=[];const f=S(n,e);for(const{soft:O,task:h}of f)o[n.id]?.push(h.id),(O?a:r).add(w(n.id,h.id)),!p.has(h.id)&&!i.has(h.id)&&(g.push(h),i.add(h.id))}x(s,o,a,r,e.onCycleBroken);const c=new Set;for(const n of Object.values(o))for(const f of n)c.add(f);const u=Object.keys(s).filter(n=>!c.has(n));return{dependencies:o,roots:u,tasks:s}},"createTaskGraph");export{z as createTaskGraph,m as getTaskId,$ as parseTaskId};
@@ -1 +0,0 @@
1
- var _=Object.defineProperty;var u=(t,e)=>_(t,"name",{value:e,configurable:!0});import{createRequire as v}from"node:module";import{isAbsolute as P,resolve as m,relative as O,join as T}from"@visulima/path";const b=v(import.meta.url),c=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,d=u(t=>{if(typeof c<"u"&&c.versions&&c.versions.node){const[e,s]=c.versions.node.split(".").map(Number);if(e>22||e===22&&s>=3||e===20&&s>=16)return c.getBuiltinModule(t)}return b(t)},"__cjs_getBuiltinModule"),{stat:y,glob:j}=d("node:fs/promises"),{matchesGlob:w}=d("node:path");var q=Object.defineProperty,l=u((t,e)=>q(t,"name",{value:e,configurable:!0}),"c");const R=/[*?[\]{}]/,f=l((t,e)=>{const s=O(t,e);if(!(s.length===0||s.startsWith("..")))return s},"toWorkspaceRelative"),M=l(async(t,e,s)=>{if(!e||e.length===0)return[];const r=[],n=[];let p=!1;for(const o of e){if(typeof o!="string"){o.auto&&(p=!0);continue}if(o.length!==0){if(o.startsWith("!")){const i=o.slice(1);i.length>0&&n.push(i);continue}r.push(o)}}const a=new Set;if(p&&s)for(const o of s){const i=P(o)?o:m(t,o),h=f(t,i);h&&a.add(h)}const g=await Promise.all(r.map(o=>W(t,o)));for(const o of g)for(const i of o)a.add(i);return n.length===0?[...a].sort():[...a].filter(o=>!n.some(i=>w(o,i))).sort()},"resolveOutputs"),W=l(async(t,e)=>{if(!R.test(e)){const r=m(t,e),n=f(t,r);if(!n)return[];try{return await y(r),[n]}catch{return[]}}const s=[];for await(const r of j(e,{cwd:t,withFileTypes:!0})){if(!r.isFile())continue;const n=f(t,T(r.parentPath,r.name));n&&s.push(n)}return s},"expandPattern");export{M as resolveOutputs};