agentsmesh 0.15.0 → 0.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -0
- package/README.md +1 -1
- package/dist/canonical.d.ts +2 -2
- package/dist/canonical.js +305 -104
- package/dist/canonical.js.map +1 -1
- package/dist/cli.js +190 -188
- package/dist/engine.d.ts +2 -2
- package/dist/engine.js +320 -108
- package/dist/engine.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.js +320 -108
- package/dist/index.js.map +1 -1
- package/dist/{schema-o4oXUVBP.d.ts → schema-CD2qcmDL.d.ts} +1 -0
- package/dist/{target-descriptor--Nw5i4v3.d.ts → target-descriptor-CvB1qzPn.d.ts} +1 -1
- package/dist/targets.d.ts +3 -3
- package/dist/targets.js +129 -98
- package/dist/targets.js.map +1 -1
- package/package.json +1 -1
- package/schemas/agentsmesh.json +3 -0
package/dist/cli.js
CHANGED
|
@@ -1,175 +1,177 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import {rm as rm$1,readFile,readdir,stat,mkdir,writeFile,rename,lstat,unlink,access,realpath,readlink,symlink,mkdtemp,cp as cp$1,copyFile}from'fs/promises';import {
|
|
3
|
-
`);},warn(t){
|
|
4
|
-
`);},error(t){
|
|
5
|
-
`);},success(t){
|
|
6
|
-
`);},debug(t){
|
|
7
|
-
`);},table(t){if(
|
|
8
|
-
`);for(let o=0;o<t.length;o++){let a="| "+t[o].map((c,l)=>
|
|
9
|
-
`);}
|
|
10
|
-
`);}};});var
|
|
11
|
-
`)}async function y(t){try{let e=await readFile(t,"utf-8");return e.startsWith(by)?e.slice(by.length):e}catch(e){let r=e;if(r.code==="ENOENT")return null;throw new Be(t,`Failed to read ${t}: ${r.message}. Ensure the file exists and is readable.`,{cause:e,errnoCode:r.code})}}async function S(t,e){let r=dirname(t);await mkdir(r,{recursive:true});try{let i=await lstat(t);if(i.isDirectory())throw new Be(t,`Failed to write ${t}: target exists and is a directory. Remove it or choose a different path.`,{errnoCode:"EISDIR"});i.isSymbolicLink()&&await unlink(t).catch(a=>{if(a.code!=="ENOENT")throw a});}catch(i){if(i instanceof Be||i.code!=="ENOENT")throw i}let n=`${t}.tmp`,o=AT(t)?xT(e):e;try{try{(await lstat(n)).isSymbolicLink()&&await unlink(n);}catch(i){if(i.code!=="ENOENT")throw i}await writeFile(n,o,{encoding:"utf-8",flag:"w"}),await rename(n,t);}catch(i){await rm$1(n,{force:true}).catch(()=>{});let a=i;throw new Be(t,`Failed to write ${t}: ${a.message}. Check permissions and disk space.`,{cause:i,errnoCode:a.code})}}async function v(t){try{return await access(t,constants.F_OK),!0}catch{return false}}async function O(t){await mkdir(t,{recursive:true});}async function N(t,e){let r;try{r=await realpath(t);}catch(o){let i=o;if(i.code==="ENOENT"||i.code==="ENOTDIR"||i.code==="ELOOP")return [];throw new Be(t,`Failed to read directory ${t}: ${i.message}. Check permissions.`,{cause:o,errnoCode:i.code})}let n=e??new Set;if(n.has(r))return [];n.add(r);try{let o=await readdir(t,{withFileTypes:!0}),i=[];for(let a of o){let c=join(t,a.name);a.isDirectory()||a.isSymbolicLink()&&await stat(c).then(m=>m.isDirectory(),()=>!1)?i.push(...await N(c,n)):i.push(c);}return i}catch(o){let i=o;if(i.code==="ENOENT"||i.code==="ENOTDIR"||i.code==="EACCES")return [];throw new Be(t,`Failed to read directory ${t}: ${i.message}. Check permissions.`,{cause:o,errnoCode:i.code})}}async function Py(t,e){let r=resolve(t);try{if(!(await lstat(e)).isSymbolicLink()||resolve(dirname(e),await readlink(e))===r)return;await unlink(e);}catch(n){if(n.code!=="ENOENT")throw n}await symlink(r,e,"dir");}var by,LT,bT,A=d(()=>{qn();by="\uFEFF",LT=new Set([".md",".mdc",".mdx",".markdown",".txt",".json",".jsonc",".yaml",".yml",".toml",".ini",".sh",".bash",".zsh",".ps1",".js",".mjs",".cjs",".ts",".tsx",".html",".css"]),bT=new Set([".gitignore",".cursorignore",".cursorindexingignore",".aiignore",".agentignore",".clineignore",".geminiignore",".codeiumignore",".continueignore",".copilotignore",".windsurfignore",".junieignore",".kiroignore",".rooignore",".antigravityignore"]);s(AT,"shouldNormalizeLineEndings");s(xT,"normalizeLineEndings");s(y,"readFileSafe");s(S,"writeFileAtomic");s(v,"exists");s(O,"mkdirp");s(N,"readDirRecursive");s(Py,"ensureCacheSymlink");});function He(t){return qp.includes(t)}var qp,Ty=d(()=>{qp=["amp","antigravity","claude-code","cline","codex-cli","continue","copilot","cursor","gemini-cli","goose","junie","kilo-code","kiro","opencode","roo-code","warp","windsurf","zed"];s(He,"isBuiltinTargetId");});var it,Ra,ze=d(()=>{Ty();it=qp,Ra="codex-cli";});var Dy,Re,Zs,Oa,PT,TT,ka,DT,NT,jo,ln=d(()=>{ze();Dy=["rules","commands","agents","skills","mcp","hooks","ignore","permissions"],Re=z$1.enum(it),Zs=z$1.enum(Dy),Oa=z$1.object({skills:z$1.array(z$1.string()).optional(),commands:z$1.array(z$1.string()).optional(),rules:z$1.array(z$1.string()).optional(),agents:z$1.array(z$1.string()).optional()}).strict(),PT=z$1.object({name:z$1.string(),source:z$1.string(),version:z$1.string().optional(),target:Re.optional(),features:z$1.array(Zs),path:z$1.string().optional(),pick:Oa.optional()}),TT=z$1.object({strategy:z$1.enum(["merge","lock","last-wins"]).default("merge"),lock_features:z$1.array(z$1.string()).default([])}),ka=z$1.union([z$1.boolean(),z$1.object({project:z$1.boolean().optional(),global:z$1.boolean().optional()}).strict()]),DT=z$1.object({commands_to_skills:z$1.object({"codex-cli":ka.optional()}).passthrough().optional(),agents_to_skills:z$1.object({"gemini-cli":ka.optional(),cline:ka.optional(),"codex-cli":ka.optional(),windsurf:ka.optional()}).passthrough().optional()}).strict().optional(),NT=z$1.object({id:z$1.string().regex(/^[a-z][a-z0-9-]*$/),source:z$1.string(),version:z$1.string().optional()}).strict(),jo=z$1.object({version:z$1.literal(1),targets:z$1.array(Re).default([...it]),features:z$1.array(Zs).default([...Dy]),extends:z$1.array(PT).default([]),overrides:z$1.record(z$1.string(),z$1.record(z$1.string(),z$1.unknown())).default({}),collaboration:TT.default({strategy:"merge",lock_features:[]}),conversions:DT,plugins:z$1.array(NT).default([]),pluginTargets:z$1.array(z$1.string().regex(/^[a-z][a-z0-9-]*$/)).default([])});});async function MT(t){let e=resolve(t);for(;;){let r=join(e,tu);if(await v(r))return r;let n=dirname(e);if(n===e)return null;e=n;}}async function $T(t){let e=await y(t);if(e===null)throw new We(t);let r=parse(e),n=jo.safeParse(r);if(!n.success){let o=n.error.issues.map(i=>i.message);throw new Ys(t,o,{cause:n.error})}return n.data}function Qp(t,e){let r={...t};for(let[n,o]of Object.entries(e)){if(o==null)continue;let i=r[n];typeof o=="object"&&!Array.isArray(o)&&o!==null&&typeof i=="object"&&i!==null&&!Array.isArray(i)?r[n]=Qp(i,o):r[n]=o;}return r}function GT(t,e){let r={...t};return Array.isArray(e.targets)&&e.targets.length>0&&(r.targets=e.targets),Array.isArray(e.features)&&e.features.length>0&&(r.features=e.features),typeof e.overrides=="object"&&e.overrides!==null&&!Array.isArray(e.overrides)&&(r.overrides=Qp(r.overrides??{},e.overrides)),typeof e.conversions=="object"&&e.conversions!==null&&!Array.isArray(e.conversions)&&(r.conversions=Qp(r.conversions??{},e.conversions)),Array.isArray(e.extends)&&e.extends.length>0&&(r.extends=[...t.extends??[],...e.extends]),r}async function nl(t){let e=join(t,tu),r=await $T(e),n=join(t,vT),o=await y(n);if(o!==null){let i=parse(o);if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let a=GT(r,i),c=jo.safeParse(a);if(c.success)r=c.data;else {let l=c.error.issues.map(m=>m.message).join("; ");I.warn(`Ignoring invalid agentsmesh.local.yaml at ${n}: ${l}. Using project config instead.`);}}}return {config:r,configDir:t}}async function ol(t){let e=await MT(t);if(e===null)throw new We(join(t,tu));return nl(dirname(e))}var tu,vT,sl=d(()=>{A();nt();qn();ln();tu="agentsmesh.yaml",vT="agentsmesh.local.yaml";s(MT,"findConfigPath");s($T,"loadConfig");s(Qp,"deepMergeObjects");s(GT,"mergeLocalConfig");s(nl,"loadConfigFromExactDir");s(ol,"loadConfigFromDir");});function wa(t,e="project"){if(e==="project")return {scope:e,rootBase:t,configDir:t,canonicalDir:join(t,".agentsmesh")};let r=homedir(),n=join(r,".agentsmesh");return {scope:e,rootBase:r,configDir:n,canonicalDir:n}}async function lt(t,e="project"){if(e==="project"){let{config:n,configDir:o}=await ol(t);return {config:n,context:{scope:e,rootBase:o,configDir:o,canonicalDir:join(o,".agentsmesh")}}}let r=wa(t,e);try{let{config:n}=await nl(r.configDir);return {config:n,context:r}}catch(n){throw n instanceof We?new We(n.path,{cause:n,message:`agentsmesh.yaml not found at ${n.path} (global scope). Run 'agentsmesh init --global' to create it under ~/.agentsmesh, or drop the --global flag to operate on the current project.`}):n}}var le=d(()=>{sl();qn();s(wa,"resolveScopeContext");s(lt,"loadScopedConfig");});async function il(t,e,r,n,o){let i="cloneUrl"in t?"gitlab":"git",a="cloneUrl"in t?`${t.namespace}/${t.project}`:t.url,c=t.ref??"HEAD",l=o(i,a,c),m=join(n,l),p=join(m,vy),u=`${m}.tmp`,f=join(u,vy);if(!r.refresh&&await My(p))return ou(p);try{return await rm$1(u,{recursive:!0,force:!0}),await mkdir(u,{recursive:!0}),await JT(VT(t),f),t.ref&&await YT(f,t.ref),await rm$1(m,{recursive:!0,force:!0}),await rename(u,m),ou(p)}catch(g){if(await rm$1(u,{recursive:true,force:true}),r.allowOfflineFallback!==false&&await My(p))return console.warn(`[agentsmesh] Remote fetch failed for ${e}; using cached version. Error: ${g instanceof Error?g.message:String(g)}`),ou(p);throw g}}async function ou(t){return {resolvedPath:t,version:await XT(t)}}async function My(t){return v(t)}function VT(t){if("cloneUrl"in t){let e=process.env.AGENTSMESH_GITLAB_TOKEN;if(e){let r=new URL(t.cloneUrl);if(r.protocol==="https:")return r.username="oauth2",r.password=e,r.toString()}return t.cloneUrl}return t.url}async function JT(t,e){await su(["clone",t,e]);}async function YT(t,e){await su(["checkout",e],t);}async function XT(t){return su(["rev-parse","HEAD"],t)}async function su(t,e){let{stdout:r}=await zT("git",t,{cwd:e,env:{...process.env,GIT_TERMINAL_PROMPT:"0"}});return r.trim()}var zT,vy,iu=d(()=>{A();zT=promisify(execFile),vy="repo";s(il,"fetchGitRemoteExtend");s(ou,"readCachedRepo");s(My,"hasCachedRepo");s(VT,"resolveCloneUrl");s(JT,"cloneRepo");s(YT,"checkoutRef");s(XT,"getHeadSha");s(su,"runGit");});async function Uy(t,e,r){let n=`https://api.github.com/repos/${t}/${e}/releases/latest`,o={Accept:"application/vnd.github+json"};r&&(o.Authorization=`Bearer ${r}`);let i=await globalThis.fetch(n,{headers:o});if(!i.ok)throw new Error(`Failed to resolve latest release for ${t}/${e}: ${i.status} ${i.statusText}`);let a=await i.json();if(!a.tag_name||typeof a.tag_name!="string")throw new Error(`No tag_name in releases/latest response for ${t}/${e}`);return a.tag_name}async function Ky(t,e,r,n,o,i=false){let a=r.token??process.env.AGENTSMESH_GITHUB_TOKEN,c=r.refresh===true,l=t.tag;if(l==="latest")try{l=await Uy(t.org,t.repo,a);}catch(_){if(!i)throw _;return eD(t,e,r,n,o,a)}let m=o("github",`${t.org}/${t.repo}`,l),p=join(n,m);if(!c&&await v(p)){let _=await au(p);if(_)return {resolvedPath:join(p,_),version:l}}let u=`https://github.com/${t.org}/${t.repo}/tarball/${l}`,f={};a&&(f.Authorization=`Bearer ${a}`);let g;try{let _=await globalThis.fetch(u,{headers:f,redirect:"follow"});if(!_.ok)throw new Error(`HTTP ${_.status}: ${_.statusText}`);g=await _.arrayBuffer();}catch(_){if(r.allowOfflineFallback!==false&&await v(p)){let T=await au(p);if(T)return console.warn(`[agentsmesh] Network failed for ${e}; using cached version. Error: ${_ instanceof Error?_.message:String(_)}`),{resolvedPath:join(p,T),version:l}}throw _}await rm$1(p,{recursive:true,force:true}),await mkdir(p,{recursive:true});let h=join(p,"archive.tar.gz");await writeFile(h,new Uint8Array(g));try{await jy.extract({file:h,cwd:p,strict:!0,filter:s((_,E)=>!(tD(_)||E&&"type"in E&&(E.type==="Link"||E.type==="SymbolicLink")),"filter")});}finally{await rm$1(h,{force:true}).catch(()=>{});}let R=await au(p);if(!R)throw new Error(`Extend "${e}": archive has no top-level directory. Expected a single top-level directory inside the archive.`);return {resolvedPath:join(p,R),version:l}}async function au(t){let r=(await readdir(t,{withFileTypes:true})).filter(n=>n.isDirectory()&&!n.name.startsWith("."));return r.length===1?r[0].name:null}function Gy(t,e,r){return r?`https://x-access-token:${encodeURIComponent(r)}@github.com/${t}/${e}.git`:`https://github.com/${t}/${e}.git`}function tD(t){let e=t.replace(/\\/g,"/");return e.startsWith("/")||e.split("/").includes("..")}async function eD(t,e,r,n,o,i){let a=i?[Gy(t.org,t.repo,i)]:[Gy(t.org,t.repo),`ssh://git@github.com/${t.org}/${t.repo}.git`],c;for(let l of a){let m={url:l};try{return await il(m,e,r,n,o)}catch(p){c=p;}}throw c instanceof Error?c:new Error("Failed to clone GitHub default branch")}var Wy=d(()=>{A();iu();s(Uy,"resolveLatestTag");s(Ky,"fetchGithubRemoteExtend");s(au,"findExtractTopDir");s(Gy,"buildGithubCloneUrl");s(tD,"isZipSlipPath");s(eD,"fetchGithubDefaultBranch");});function By(t,e,r){if(!t.startsWith(e))return null;let n=t.slice(e.length).trim();if(!n)return null;let o=n.lastIndexOf("@");if(o<0)return [n,r];let i=n.slice(0,o).trim(),a=n.slice(o+1).trim();return !i||!a?null:[i,a]}function Hy(t){let e=By(t,"github:","latest");if(!e)return null;let[r,n]=e,o=r.indexOf("/");if(o<0)return null;let i=r.slice(0,o).trim(),a=r.slice(o+1).trim();return !i||!a||!n?null:{org:i,repo:a,tag:n}}function zy(t){let e=By(t,"gitlab:");if(!e)return null;let[r,n]=e,o=r.lastIndexOf("/");if(o<0)return null;let i=r.slice(0,o).trim(),a=r.slice(o+1).trim();return !i||!a?null:{namespace:i,project:a,ref:n,cloneUrl:`https://gitlab.com/${i}/${a}.git`}}function Vy(t){if(!t.startsWith("git+"))return null;let e=t.slice(4).trim();if(!e)return null;let r=e.lastIndexOf("#"),n=(r<0?e:e.slice(0,r)).trim(),o=r<0?void 0:e.slice(r+1).trim();if(!n||r>=0&&!o)return null;let i;try{i=new URL(n);}catch{return null}return ["https:","http:","ssh:","file:"].includes(i.protocol)?{url:n,ref:o}:null}function Uo(t){let e=Hy(t);if(e)return {kind:"github",...e};let r=zy(t);if(r)return {kind:"gitlab",...r};let n=Vy(t);return n?{kind:"git",...n}:null}function cu(t){return Uo(t)!==null}var La=d(()=>{s(By,"splitSourceRef");s(Hy,"parseGithubSource");s(zy,"parseGitlabSource");s(Vy,"parseGitSource");s(Uo,"parseRemoteSource");s(cu,"isSupportedRemoteSource");});function sD(t){let e=Uo(t);return e?e.kind==="github"?qs("github",`${e.org}/${e.repo}`,e.tag):e.kind==="gitlab"?qs("gitlab",`${e.namespace}/${e.project}`,e.ref??"HEAD"):qs("git",e.url,e.ref??"HEAD"):null}async function Xy(t,e){let r=sD(t);if(!r)return;let n=e??me(),o=join(n,r);await rm$1(o,{recursive:true,force:true});}async function Zy(t,e){let r=t??me(),n=e??Number(process.env.AGENTSMESH_CACHE_MAX_AGE_DAYS??30)*864e5,o;try{o=await readdir(r);}catch{return}let i=Date.now();await Promise.all(o.map(async a=>{let c=join(r,a);try{let{mtimeMs:l}=await stat(c);i-l>n&&await rm$1(c,{recursive:!0,force:!0});}catch{}}));}var lu=d(()=>{ba();La();s(sD,"cacheKeyFromSource");s(Xy,"cleanInstallCache");s(Zy,"sweepStaleCache");});function qs(t,e,r){let n=s(i=>i.replace(/[^a-zA-Z0-9_.-]/g,"_").replace(/^\.+/,"_"),"safe"),o;if(t==="github"){let[i,a]=e.split("/",2);i&&a?o=`${n(i)}--${n(a)}--${n(r)}`:o=`${n(t)}__${n(e)}__${n(r)}`;}else o=`${n(t)}__${n(e)}__${n(r)}`;if(o.length>qy){let i=createHash("sha256").update(o).digest("hex").slice(0,16);o=`${o.slice(0,qy-18)}--${i}`;}return o}function me(){let t=process.env.AGENTSMESH_CACHE;return t||join(homedir(),".agentsmesh","cache")}async function Qs(t,e,r={}){let n=Uo(t);if(!n)throw t.startsWith("github:")?new Error(`Invalid github: source: "${t}" for extend "${e}"`):t.startsWith("gitlab:")?new Error(`Invalid gitlab: source: "${t}" for extend "${e}"`):t.startsWith("git+")?new Error(`Invalid git+ source: "${t}" for extend "${e}"`):new Error(`Invalid remote source: "${t}" for extend "${e}". Use github:org/repo@tag, gitlab:group/project@ref, or git+https://host/org/repo.git#ref.`);let o=r.cacheDir??me();return Zy(o).catch(()=>{}),n.kind==="github"?Ky(n,e,r,o,qs,!t.includes("@")):il(n,e,r,o,qs)}var qy,ba=d(()=>{iu();Wy();La();lu();qy=80;s(qs,"buildCacheKey");s(me,"getCacheDir");s(Qs,"fetchRemoteExtend");});function uD(t){return t.startsWith("http://")||t.startsWith("https://")}async function ti(t,e,r={}){if(t.extends.length===0)return [];if(r.refreshCache===true&&t.extends.some(o=>cu(o.source))){let o=me();await rm$1(o,{recursive:true,force:true}),await mkdir(o,{recursive:true});}let n=[];for(let o of t.extends){if(uD(o.source))throw new Error(`Remote extends (http/https) not supported: "${o.source}" for extend "${o.name}". Use github:org/repo@tag, gitlab:group/project@ref, git+https://host/org/repo.git#ref, or a local path (e.g. ./shared/).`);if(cu(o.source)){let a=await Qs(o.source,o.name,{cacheDir:me(),refresh:r.refreshCache===true});n.push({name:o.name,resolvedPath:a.resolvedPath,features:[...o.features],target:o.target,version:a.version,path:o.path,pick:o.pick});continue}let i=resolve(e,o.source);if(!await v(i))throw new Error(`Extend "${o.name}": path does not exist: ${i}. Check extends.source in agentsmesh.yaml.`);n.push({name:o.name,resolvedPath:i,features:[...o.features],target:o.target,path:o.path,pick:o.pick});}return n}var al=d(()=>{A();ba();La();s(uD,"isOtherRemoteSource");s(ti,"resolveExtendPaths");});function w(t){if(t.indexOf("---")!==0)return {frontmatter:{},body:t.trim()};let r=t.indexOf("---",3);if(r===-1)return {frontmatter:{},body:t.trim()};let n=t.slice(3,r).trim(),o=t.slice(r+3).trim();return {frontmatter:n===""?{}:parse(n)??{},body:o}}function F(t,e){return Object.keys(t).length===0?e:`---
|
|
2
|
+
import {resolve,join,sep,dirname,extname,basename,relative,win32,posix,normalize}from'path';import {rm as rm$1,readFile,readdir,stat,mkdir,writeFile,rename,lstat,unlink,chmod,access,realpath,readlink,symlink,mkdtemp,cp as cp$1,copyFile}from'fs/promises';import {realpathSync,rmSync,statSync,existsSync,mkdtempSync,readdirSync,symlinkSync,mkdirSync,constants,readFileSync}from'fs';import {z as z$1}from'zod';import {parse,stringify}from'yaml';import {homedir,tmpdir,hostname}from'os';import {execFile}from'child_process';import {fileURLToPath,pathToFileURL,URL}from'url';import {promisify}from'util';import*as l_ from'tar';import {createHash}from'crypto';import {parse as parse$1}from'smol-toml';import {Buffer as Buffer$1}from'buffer';import {createRequire}from'module';import {createTwoFilesPatch}from'diff';import j0 from'chokidar';import*as IP from'readline';import {Server}from'@modelcontextprotocol/sdk/server/index.js';import {StdioServerTransport}from'@modelcontextprotocol/sdk/server/stdio.js';import {ListToolsRequestSchema,CallToolRequestSchema,ListResourcesRequestSchema,ReadResourceRequestSchema}from'@modelcontextprotocol/sdk/types.js';import {toJSONSchema}from'zod/v4/core';var Ny=Object.defineProperty;var s=(t,e)=>Ny(t,"name",{value:e,configurable:true});var d=(t,e)=>()=>(t&&(e=t(t=0)),e);var iu=(t,e)=>{for(var r in e)Ny(t,r,{get:e[r],enumerable:true});};function My(){zo=true;}function $y(){vy=true;}function Qs(t){vy?process.stderr.write(t):process.stdout.write(t);}function WT(){return process.env.NO_COLOR!==void 0&&process.env.NO_COLOR!==""}function Ea(t,e){return WT()?e:`${t}${e}${ti.reset}`}function KT(t,e){let r=[...t].length;return t+" ".repeat(Math.max(0,e-r))}var ti,zo,vy,I,st=d(()=>{ti={green:"\x1B[32m",red:"\x1B[31m",yellow:"\x1B[33m",cyan:"\x1B[36m",reset:"\x1B[0m"},zo=false,vy=false;s(My,"muteLogger");s($y,"redirectLoggerToStderr");s(Qs,"out");s(WT,"noColor");s(Ea,"c");s(KT,"pad");I={info(t){zo||Qs(Ea(ti.cyan,t)+`
|
|
3
|
+
`);},warn(t){zo||process.stderr.write(Ea(ti.yellow,"\u26A0 ")+t+`
|
|
4
|
+
`);},error(t){zo||process.stderr.write(Ea(ti.red,"\u2717 ")+t+`
|
|
5
|
+
`);},success(t){zo||Qs(Ea(ti.green,"\u2713 ")+t+`
|
|
6
|
+
`);},debug(t){zo||process.env.AGENTSMESH_DEBUG==="1"&&Qs(Ea(ti.cyan,"[debug] ")+t+`
|
|
7
|
+
`);},table(t){if(zo||t.length===0)return;let e=t[0].length,r=[];for(let o=0;o<e;o++){let i=0;for(let a=0;a<t.length;a++){let c=[...t[a][o]].length;c>i&&(i=c);}r[o]=i;}let n="+"+r.map(o=>"-".repeat(o+2)).join("+")+"+";Qs(n+`
|
|
8
|
+
`);for(let o=0;o<t.length;o++){let a="| "+t[o].map((c,l)=>KT(c,r[l])).join(" | ")+" |";Qs(a+`
|
|
9
|
+
`);}Qs(n+`
|
|
10
|
+
`);}};});var un,Je,ri,br,ni,we,dn=d(()=>{un=class extends Error{static{s(this,"AgentsMeshError");}code;constructor(e,r,n){super(r,n),this.name="AgentsMeshError",this.code=e;}},Je=class extends un{static{s(this,"ConfigNotFoundError");}path;constructor(e,r){super("AM_CONFIG_NOT_FOUND",r?.message??`agentsmesh.yaml not found at ${e}. Run 'agentsmesh init' to create one.`,r),this.name="ConfigNotFoundError",this.path=e;}},ri=class extends un{static{s(this,"ConfigValidationError");}issues;constructor(e,r,n){super("AM_CONFIG_INVALID",`Invalid config at ${e}: ${r.join("; ")}. Fix the YAML and try again.`,n),this.name="ConfigValidationError",this.issues=r;}},br=class extends un{static{s(this,"TargetNotFoundError");}target;constructor(e,r){let n=r?.supported?` Supported: ${r.supported.join(", ")}.`:"";super("AM_TARGET_NOT_FOUND",`Unknown target "${e}".${n}`,r),this.name="TargetNotFoundError",this.target=e;}},ni=class extends un{static{s(this,"LockAcquisitionError");}lockPath;holder;constructor(e,r,n){super("AM_LOCK_ACQUISITION_FAILED",`Could not acquire generate lock at ${e}: currently held by ${r}. Wait for the other process to finish, or remove ${e} manually if you are sure no agentsmesh process is running.`,n),this.name="LockAcquisitionError",this.lockPath=e,this.holder=r;}},we=class extends un{static{s(this,"FileSystemError");}path;errnoCode;constructor(e,r,n){super("AM_FILESYSTEM",r,n),this.name="FileSystemError",this.path=e,this.errnoCode=n?.errnoCode;}};});function Vy(t){let e=extname(t).toLowerCase();if(e.length>0)return XT.has(e);let r=basename(t).toLowerCase();return ZT.has(r)}function Jy(t){return t.replace(/\r\n?/g,`
|
|
11
|
+
`)}function cu(t){return qT.has(extname(t).toLowerCase())?493:void 0}var au,XT,ZT,qT,lu=d(()=>{au="\uFEFF",XT=new Set([".md",".mdc",".mdx",".markdown",".txt",".json",".jsonc",".yaml",".yml",".toml",".ini",".sh",".bash",".zsh",".ps1",".js",".mjs",".cjs",".ts",".tsx",".html",".css"]),ZT=new Set([".gitignore",".cursorignore",".cursorindexingignore",".aiignore",".agentignore",".clineignore",".geminiignore",".codeiumignore",".continueignore",".copilotignore",".windsurfignore",".junieignore",".kiroignore",".rooignore",".antigravityignore"]);s(Vy,"shouldNormalizeLineEndings");s(Jy,"normalizeLineEndings");qT=new Set([".sh",".bash",".zsh"]);s(cu,"executableModeFor");});async function D(t,e){let r;try{r=await realpath(t);}catch(o){let i=o;if(i.code==="ENOENT"||i.code==="ENOTDIR"||i.code==="ELOOP")return [];throw new we(t,`Failed to read directory ${t}: ${i.message}. Check permissions.`,{cause:o,errnoCode:i.code})}let n=e??new Set;if(n.has(r))return [];n.add(r);try{let o=await readdir(t,{withFileTypes:!0}),i=[];for(let a of o){let c=join(t,a.name);a.isDirectory()||a.isSymbolicLink()&&await stat(c).then(m=>m.isDirectory(),()=>!1)?i.push(...await D(c,n)):i.push(c);}return i}catch(o){let i=o;if(i.code==="ENOENT"||i.code==="ENOTDIR"||i.code==="EACCES")return [];throw new we(t,`Failed to read directory ${t}: ${i.message}. Check permissions.`,{cause:o,errnoCode:i.code})}}async function mu(t,e){let r=resolve(t);try{if(!(await lstat(e)).isSymbolicLink()||resolve(dirname(e),await readlink(e))===r)return;await unlink(e);}catch(n){if(n.code!=="ENOENT")throw n}await symlink(r,e,"dir");}var Xy=d(()=>{dn();s(D,"readDirRecursive");s(mu,"ensureCacheSymlink");});async function y(t){try{let e=await readFile(t,"utf-8");return e.startsWith(au)?e.slice(au.length):e}catch(e){let r=e;if(r.code==="ENOENT")return null;throw new we(t,`Failed to read ${t}: ${r.message}. Ensure the file exists and is readable.`,{cause:e,errnoCode:r.code})}}async function C(t,e,r){let n=dirname(t);await mkdir(n,{recursive:true});try{let c=await lstat(t);if(c.isDirectory())throw new we(t,`Failed to write ${t}: target exists and is a directory. Remove it or choose a different path.`,{errnoCode:"EISDIR"});c.isSymbolicLink()&&await unlink(t).catch(l=>{if(l.code!=="ENOENT")throw l});}catch(c){if(c instanceof we||c.code!=="ENOENT")throw c}let o=`${t}.tmp`,i=Vy(t)?Jy(e):e,a=r?.mode??cu(t);try{try{(await lstat(o)).isSymbolicLink()&&await unlink(o);}catch(l){if(l.code!=="ENOENT")throw l}let c={encoding:"utf-8",flag:"w"};a!==void 0&&(c.mode=a),await writeFile(o,i,c),await rename(o,t),a!==void 0&&await chmod(t,a);}catch(c){await rm$1(o,{force:true}).catch(()=>{});let l=c;throw new we(t,`Failed to write ${t}: ${l.message}. Check permissions and disk space.`,{cause:c,errnoCode:l.code})}}async function F(t){try{return await access(t,constants.F_OK),!0}catch{return false}}async function O(t){await mkdir(t,{recursive:true});}var b=d(()=>{dn();lu();Xy();lu();s(y,"readFileSafe");s(C,"writeFileAtomic");s(F,"exists");s(O,"mkdirp");});function Ye(t){return pu.includes(t)}var pu,t_=d(()=>{pu=["amp","antigravity","claude-code","cline","codex-cli","continue","copilot","cursor","gemini-cli","goose","junie","kilo-code","kiro","opencode","roo-code","warp","windsurf","zed"];s(Ye,"isBuiltinTargetId");});var lt,wa,Xe=d(()=>{t_();lt=pu,wa="codex-cli";});var e_,Le,oi,ba,hD,yD,La,_D,ID,Vo,fn=d(()=>{Xe();e_=["rules","commands","agents","skills","mcp","hooks","ignore","permissions"],Le=z$1.enum(lt),oi=z$1.enum(e_),ba=z$1.object({skills:z$1.array(z$1.string()).optional(),commands:z$1.array(z$1.string()).optional(),rules:z$1.array(z$1.string()).optional(),agents:z$1.array(z$1.string()).optional()}).strict(),hD=z$1.object({name:z$1.string(),source:z$1.string(),version:z$1.string().optional(),target:Le.optional(),features:z$1.array(oi),path:z$1.string().optional(),pick:ba.optional()}),yD=z$1.object({strategy:z$1.enum(["merge","lock","last-wins"]).default("merge"),lock_features:z$1.array(z$1.string()).default([])}),La=z$1.union([z$1.boolean(),z$1.object({project:z$1.boolean().optional(),global:z$1.boolean().optional()}).strict()]),_D=z$1.object({commands_to_skills:z$1.object({"codex-cli":La.optional()}).passthrough().optional(),agents_to_skills:z$1.object({"gemini-cli":La.optional(),cline:La.optional(),"codex-cli":La.optional(),windsurf:La.optional()}).passthrough().optional()}).strict().optional(),ID=z$1.object({id:z$1.string().regex(/^[a-z][a-z0-9-]*$/),source:z$1.string(),version:z$1.string().optional(),strict:z$1.boolean().optional()}).strict(),Vo=z$1.object({version:z$1.literal(1),targets:z$1.array(Le).default([...lt]),features:z$1.array(oi).default([...e_]),extends:z$1.array(hD).default([]),overrides:z$1.record(z$1.string(),z$1.record(z$1.string(),z$1.unknown())).default({}),collaboration:yD.default({strategy:"merge",lock_features:[]}),conversions:_D,plugins:z$1.array(ID).default([]),pluginTargets:z$1.array(z$1.string().regex(/^[a-z][a-z0-9-]*$/)).default([])});});async function RD(t){let e=resolve(t);for(;;){let r=join(e,du);if(await F(r))return r;let n=dirname(e);if(n===e)return null;e=n;}}async function OD(t){let e=await y(t);if(e===null)throw new Je(t);let r=parse(e),n=Vo.safeParse(r);if(!n.success){let o=n.error.issues.map(i=>i.message);throw new ri(t,o,{cause:n.error})}return n.data}function uu(t,e){let r={...t};for(let[n,o]of Object.entries(e)){if(o==null)continue;let i=r[n];typeof o=="object"&&!Array.isArray(o)&&o!==null&&typeof i=="object"&&i!==null&&!Array.isArray(i)?r[n]=uu(i,o):r[n]=o;}return r}function ED(t,e){let r={...t};return Array.isArray(e.targets)&&e.targets.length>0&&(r.targets=e.targets),Array.isArray(e.features)&&e.features.length>0&&(r.features=e.features),typeof e.overrides=="object"&&e.overrides!==null&&!Array.isArray(e.overrides)&&(r.overrides=uu(r.overrides??{},e.overrides)),typeof e.conversions=="object"&&e.conversions!==null&&!Array.isArray(e.conversions)&&(r.conversions=uu(r.conversions??{},e.conversions)),Array.isArray(e.extends)&&e.extends.length>0&&(r.extends=[...t.extends??[],...e.extends]),r}async function ll(t){let e=join(t,du),r=await OD(e),n=join(t,CD),o=await y(n);if(o!==null){let i=parse(o);if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let a=ED(r,i),c=Vo.safeParse(a);if(c.success)r=c.data;else {let l=c.error.issues.map(m=>m.message).join("; ");I.warn(`Ignoring invalid agentsmesh.local.yaml at ${n}: ${l}. Using project config instead.`);}}}return {config:r,configDir:t}}async function ml(t){let e=await RD(t);if(e===null)throw new Je(join(t,du));return ll(dirname(e))}var du,CD,pl=d(()=>{b();st();dn();fn();du="agentsmesh.yaml",CD="agentsmesh.local.yaml";s(RD,"findConfigPath");s(OD,"loadConfig");s(uu,"deepMergeObjects");s(ED,"mergeLocalConfig");s(ll,"loadConfigFromExactDir");s(ml,"loadConfigFromDir");});function Aa(t,e="project"){if(e==="project")return {scope:e,rootBase:t,configDir:t,canonicalDir:join(t,".agentsmesh")};let r=homedir(),n=join(r,".agentsmesh");return {scope:e,rootBase:r,configDir:n,canonicalDir:n}}async function ut(t,e="project"){if(e==="project"){let{config:n,configDir:o}=await ml(t);return {config:n,context:{scope:e,rootBase:o,configDir:o,canonicalDir:join(o,".agentsmesh")}}}let r=Aa(t,e);try{let{config:n}=await ll(r.configDir);return {config:n,context:r}}catch(n){throw n instanceof Je?new Je(n.path,{cause:n,message:`agentsmesh.yaml not found at ${n.path} (global scope). Run 'agentsmesh init --global' to create it under ~/.agentsmesh, or drop the --global flag to operate on the current project.`}):n}}var de=d(()=>{pl();dn();s(Aa,"resolveScopeContext");s(ut,"loadScopedConfig");});function i_(t,e){if(t.startsWith("-"))throw new Error(`agentsmesh refuses ${e} starting with "-" (option-injection guard): ${t}`)}async function ul(t,e,r,n,o){let i="cloneUrl"in t?"gitlab":"git",a="cloneUrl"in t?`${t.namespace}/${t.project}`:t.url,c=t.ref??"HEAD",l=o(i,a,c),m=join(n,l),p=join(m,o_),u=`${m}.tmp`,f=join(u,o_);if(!r.refresh&&await s_(p))return yu(p);try{return await rm$1(u,{recursive:!0,force:!0}),await mkdir(u,{recursive:!0}),await DD(TD(t),f),t.ref&&await ND(f,t.ref),await rm$1(m,{recursive:!0,force:!0}),await rename(u,m),yu(p)}catch(g){if(await rm$1(u,{recursive:true,force:true}),r.allowOfflineFallback!==false&&await s_(p))return console.warn(`[agentsmesh] Remote fetch failed for ${e}; using cached version. Error: ${g instanceof Error?g.message:String(g)}`),yu(p);throw g}}async function yu(t){return {resolvedPath:t,version:await FD(t)}}async function s_(t){return F(t)}function TD(t){if("cloneUrl"in t){let e=process.env.AGENTSMESH_GITLAB_TOKEN;if(e){let r=new URL(t.cloneUrl);if(r.protocol==="https:")return r.username="oauth2",r.password=e,r.toString()}return t.cloneUrl}return t.url}async function DD(t,e){i_(t,"clone-url"),await _u(["clone",t,e]);}async function ND(t,e){i_(e,"ref"),await _u(["checkout",e],t);}async function FD(t){return _u(["rev-parse","HEAD"],t)}async function _u(t,e){let{stdout:r}=await PD("git",t,{cwd:e,env:{...process.env,GIT_TERMINAL_PROMPT:"0"}});return r.trim()}var PD,o_,Iu=d(()=>{b();PD=promisify(execFile),o_="repo";s(i_,"ensureNotFlag");s(ul,"fetchGitRemoteExtend");s(yu,"readCachedRepo");s(s_,"hasCachedRepo");s(TD,"resolveCloneUrl");s(DD,"cloneRepo");s(ND,"checkoutRef");s(FD,"getHeadSha");s(_u,"runGit");});async function jD(t,e){let r=typeof t.headers?.get=="function"?t.headers.get("content-length"):null;if(r!==null){let m=Number(r);if(Number.isFinite(m)&&m>e)throw new Error(`remote response declared ${m} bytes; exceeds cap of ${e}`)}let n=t.body;if(!n){let m=await t.arrayBuffer();if(m.byteLength>e)throw new Error(`remote response is ${m.byteLength} bytes; exceeds cap of ${e}`);return new Uint8Array(m)}let o=n.getReader(),i=[],a=0;for(;;){let{done:m,value:p}=await o.read();if(m)break;if(p){if(a+=p.byteLength,a>e)throw await o.cancel().catch(()=>{}),new Error(`remote response exceeded cap of ${e} bytes during streaming`);i.push(p);}}let c=new Uint8Array(a),l=0;for(let m of i)c.set(m,l),l+=m.byteLength;return c}async function m_(t,e,r){let n=`https://api.github.com/repos/${t}/${e}/releases/latest`,o={Accept:"application/vnd.github+json"};r&&(o.Authorization=`Bearer ${r}`);let i=await globalThis.fetch(n,{headers:o});if(!i.ok)throw new Error(`Failed to resolve latest release for ${t}/${e}: ${i.status} ${i.statusText}`);let a=await i.json();if(!a.tag_name||typeof a.tag_name!="string")throw new Error(`No tag_name in releases/latest response for ${t}/${e}`);return a.tag_name}async function p_(t,e,r,n,o,i=false){let a=r.token??process.env.AGENTSMESH_GITHUB_TOKEN,c=r.refresh===true,l=t.tag;if(l==="latest")try{l=await m_(t.org,t.repo,a);}catch(_){if(!i)throw _;return WD(t,e,r,n,o,a)}let m=o("github",`${t.org}/${t.repo}`,l),p=join(n,m);if(!c&&await F(p)){let _=await Su(p);if(_)return {resolvedPath:join(p,_),version:l}}let u=`https://github.com/${t.org}/${t.repo}/tarball/${l}`,f={};a&&(f.Authorization=`Bearer ${a}`);let g;try{let _=await globalThis.fetch(u,{headers:f,redirect:"follow"});if(!_.ok)throw new Error(`HTTP ${_.status}: ${_.statusText}`);g=await jD(_,GD);}catch(_){if(r.allowOfflineFallback!==false&&await F(p)){let T=await Su(p);if(T)return console.warn(`[agentsmesh] Network failed for ${e}; using cached version. Error: ${_ instanceof Error?_.message:String(_)}`),{resolvedPath:join(p,T),version:l}}throw _}await rm$1(p,{recursive:true,force:true}),await mkdir(p,{recursive:true});let h=join(p,"archive.tar.gz");await writeFile(h,g);try{await l_.extract({file:h,cwd:p,strict:!0,filter:s((_,k)=>!(UD(_)||k&&"type"in k&&(k.type==="Link"||k.type==="SymbolicLink")),"filter")});}finally{await rm$1(h,{force:true}).catch(()=>{});}let R=await Su(p);if(!R)throw new Error(`Extend "${e}": archive has no top-level directory. Expected a single top-level directory inside the archive.`);return {resolvedPath:join(p,R),version:l}}async function Su(t){let r=(await readdir(t,{withFileTypes:true})).filter(n=>n.isDirectory()&&!n.name.startsWith("."));return r.length===1?r[0].name:null}function c_(t,e,r){return r?`https://x-access-token:${encodeURIComponent(r)}@github.com/${t}/${e}.git`:`https://github.com/${t}/${e}.git`}function UD(t){let e=t.replace(/\\/g,"/");return e.startsWith("/")||e.split("/").includes("..")}async function WD(t,e,r,n,o,i){let a=i?[c_(t.org,t.repo,i)]:[c_(t.org,t.repo),`ssh://git@github.com/${t.org}/${t.repo}.git`],c;for(let l of a){let m={url:l};try{return await ul(m,e,r,n,o)}catch(p){c=p;}}throw c instanceof Error?c:new Error("Failed to clone GitHub default branch")}var GD,u_=d(()=>{b();Iu();GD=500*1024*1024;s(jD,"readBoundedResponse");s(m_,"resolveLatestTag");s(p_,"fetchGithubRemoteExtend");s(Su,"findExtractTopDir");s(c_,"buildGithubCloneUrl");s(UD,"isZipSlipPath");s(WD,"fetchGithubDefaultBranch");});function d_(t,e,r){if(!t.startsWith(e))return null;let n=t.slice(e.length).trim();if(!n)return null;let o=n.lastIndexOf("@");if(o<0)return [n,r];let i=n.slice(0,o).trim(),a=n.slice(o+1).trim();return !i||!a?null:[i,a]}function f_(t){let e=d_(t,"github:","latest");if(!e)return null;let[r,n]=e,o=r.indexOf("/");if(o<0)return null;let i=r.slice(0,o).trim(),a=r.slice(o+1).trim();return !i||!a||!n?null:{org:i,repo:a,tag:n}}function g_(t){let e=d_(t,"gitlab:");if(!e)return null;let[r,n]=e,o=r.lastIndexOf("/");if(o<0)return null;let i=r.slice(0,o).trim(),a=r.slice(o+1).trim();return !i||!a?null:{namespace:i,project:a,ref:n,cloneUrl:`https://gitlab.com/${i}/${a}.git`}}function h_(t){if(!t.startsWith("git+"))return null;let e=t.slice(4).trim();if(!e)return null;let r=e.lastIndexOf("#"),n=(r<0?e:e.slice(0,r)).trim(),o=r<0?void 0:e.slice(r+1).trim();if(!n||r>=0&&!o)return null;let i;try{i=new URL(n);}catch{return null}return ["https:","http:","ssh:","file:"].includes(i.protocol)?{url:n,ref:o}:null}function Jo(t){let e=f_(t);if(e)return {kind:"github",...e};let r=g_(t);if(r)return {kind:"gitlab",...r};let n=h_(t);return n?{kind:"git",...n}:null}function Cu(t){return Jo(t)!==null}var Pa=d(()=>{s(d_,"splitSourceRef");s(f_,"parseGithubSource");s(g_,"parseGitlabSource");s(h_,"parseGitSource");s(Jo,"parseRemoteSource");s(Cu,"isSupportedRemoteSource");});function zD(t){let e=Jo(t);return e?e.kind==="github"?si("github",`${e.org}/${e.repo}`,e.tag):e.kind==="gitlab"?si("gitlab",`${e.namespace}/${e.project}`,e.ref??"HEAD"):si("git",e.url,e.ref??"HEAD"):null}async function I_(t,e){let r=zD(t);if(!r)return;let n=e??fe(),o=join(n,r);await rm$1(o,{recursive:true,force:true});}async function S_(t,e){let r=t??fe(),n=e??Number(process.env.AGENTSMESH_CACHE_MAX_AGE_DAYS??30)*864e5,o;try{o=await readdir(r);}catch{return}let i=Date.now();await Promise.all(o.map(async a=>{let c=join(r,a);try{let{mtimeMs:l}=await stat(c);i-l>n&&await rm$1(c,{recursive:!0,force:!0});}catch{}}));}var Ru=d(()=>{Ta();Pa();s(zD,"cacheKeyFromSource");s(I_,"cleanInstallCache");s(S_,"sweepStaleCache");});function si(t,e,r){let n=s(i=>i.replace(/[^a-zA-Z0-9_.-]/g,"_").replace(/^\.+/,"_"),"safe"),o;if(t==="github"){let[i,a]=e.split("/",2);i&&a?o=`${n(i)}--${n(a)}--${n(r)}`:o=`${n(t)}__${n(e)}__${n(r)}`;}else o=`${n(t)}__${n(e)}__${n(r)}`;if(o.length>O_){let i=createHash("sha256").update(o).digest("hex").slice(0,16);o=`${o.slice(0,O_-18)}--${i}`;}return o}function fe(){let t=process.env.AGENTSMESH_CACHE;if(t){let e=t.trim();if(!e)return join(homedir(),".agentsmesh","cache");if(!/^([A-Za-z]:[\\/]|\/)/.test(e))throw new Error(`AGENTSMESH_CACHE must be an absolute path (got: "${e}").`);if(e==="/"||/^[A-Za-z]:[\\/]?$/.test(e))throw new Error(`AGENTSMESH_CACHE must not be the filesystem root (got: "${e}").`);return e}return join(homedir(),".agentsmesh","cache")}async function ii(t,e,r={}){let n=Jo(t);if(!n)throw t.startsWith("github:")?new Error(`Invalid github: source: "${t}" for extend "${e}"`):t.startsWith("gitlab:")?new Error(`Invalid gitlab: source: "${t}" for extend "${e}"`):t.startsWith("git+")?new Error(`Invalid git+ source: "${t}" for extend "${e}"`):new Error(`Invalid remote source: "${t}" for extend "${e}". Use github:org/repo@tag, gitlab:group/project@ref, or git+https://host/org/repo.git#ref.`);let o=r.cacheDir??fe();return S_(o).catch(()=>{}),n.kind==="github"?p_(n,e,r,o,si,!t.includes("@")):ul(n,e,r,o,si)}var O_,Ta=d(()=>{Iu();u_();Pa();Ru();O_=80;s(si,"buildCacheKey");s(fe,"getCacheDir");s(ii,"fetchRemoteExtend");});function ZD(t){return t.startsWith("http://")||t.startsWith("https://")}async function ai(t,e,r={}){if(t.extends.length===0)return [];if(r.refreshCache===true&&t.extends.some(o=>Cu(o.source))){let o=fe();await rm$1(o,{recursive:true,force:true}),await mkdir(o,{recursive:true});}let n=[];for(let o of t.extends){if(ZD(o.source))throw new Error(`Remote extends (http/https) not supported: "${o.source}" for extend "${o.name}". Use github:org/repo@tag, gitlab:group/project@ref, git+https://host/org/repo.git#ref, or a local path (e.g. ./shared/).`);if(Cu(o.source)){let a=await ii(o.source,o.name,{cacheDir:fe(),refresh:r.refreshCache===true});n.push({name:o.name,resolvedPath:a.resolvedPath,features:[...o.features],target:o.target,version:a.version,path:o.path,pick:o.pick});continue}let i=resolve(e,o.source);if(!await F(i))throw new Error(`Extend "${o.name}": path does not exist: ${i}. Check extends.source in agentsmesh.yaml.`);n.push({name:o.name,resolvedPath:i,features:[...o.features],target:o.target,path:o.path,pick:o.pick});}return n}var dl=d(()=>{b();Ta();Pa();s(ZD,"isOtherRemoteSource");s(ai,"resolveExtendPaths");});function E(t){if(t.indexOf("---")!==0)return {frontmatter:{},body:t.trim()};let r=t.indexOf("---",3);if(r===-1)return {frontmatter:{},body:t.trim()};let n=t.slice(3,r).trim(),o=t.slice(r+3).trim();return {frontmatter:n===""?{}:parse(n)??{},body:o}}function N(t,e){return Object.keys(t).length===0?e:`---
|
|
12
12
|
${stringify(t,{lineWidth:0}).trimEnd()}
|
|
13
13
|
---
|
|
14
14
|
|
|
15
|
-
${e}`}var
|
|
16
|
-
`;)r++;continue}e+=o,r++;}return e}async function
|
|
15
|
+
${e}`}var v=d(()=>{s(E,"parseFrontmatter");s(N,"serializeFrontmatter");});function rN(t){let e=t.replace(/\.[^.]*$/,"").toUpperCase();return tN.has(e)}function E_(t){let e=[],r=t.split(/[\\/]/);for(let n of r)if(!(n===""||n==="."||n==="..")){if(eN.test(n)){e.push({segment:n,reason:"illegal-character"});continue}if(/[. ]$/.test(n)){e.push({segment:n,reason:"trailing-dot-or-space"});continue}rN(n)&&e.push({segment:n,reason:"reserved-name"});}return e}var tN,eN,k_=d(()=>{tN=new Set(["CON","PRN","AUX","NUL","COM1","COM2","COM3","COM4","COM5","COM6","COM7","COM8","COM9","LPT1","LPT2","LPT3","LPT4","LPT5","LPT6","LPT7","LPT8","LPT9"]),eN=new RegExp('[<>:"|?*\\u0000-\\u001F]');s(rN,"segmentReservedName");s(E_,"findWindowsPathIssues");});function gn(t,e){let r=E_(e);if(r.length===0)return;let n=r.map(o=>`${o.segment} (${o.reason})`).join(", ");throw new fl(t,e,`canonical ${t} name "${e}" is not portable to Windows: ${n}. Rename the file.`)}function gl(t,e,r){let n=new Map;for(let o of e){let i=o.lastIndexOf("/"),a=o.lastIndexOf("\\"),c=Math.max(i,a),l=c===-1?o:o.slice(c+1),m=l.endsWith(r)?l.slice(0,-r.length):l,p=n.get(m);if(p!==void 0&&p!==o)throw new fl(t,m,`canonical ${t} files collide on slug "${m}": ${p} vs ${o}. Rename one.`);n.set(m,o);}}var fl,Da=d(()=>{k_();fl=class extends Error{static{s(this,"CanonicalNameError");}feature;name;constructor(e,r,n){super(n),this.feature=e,this.name=r;}};s(gn,"assertCanonicalName");s(gl,"assertNoBasenameCollisions");});function L_(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):typeof t=="string"?t?[t]:[]:[]}async function Yo(t){let r=(await D(t)).filter(o=>{if(!o.endsWith(".md"))return false;let i=basename(o,".md");return i==="_root"||!i.startsWith("_")}),n=[];for(let o of r){let i=await y(o);if(!i)continue;let{frontmatter:a,body:c}=E(i),l=basename(o,".md");gn("rule",l);let m=l==="_root",p=a.root===true,u=a.trigger,f=typeof u=="string"&&nN.includes(u)?u:void 0,g=a.codex_emit,h=g==="execution"?"execution":g==="advisory"?"advisory":void 0,S=a.codex_instruction==="override"?"override":void 0;n.push({source:o,root:m||p,targets:L_(a.targets),description:typeof a.description=="string"?a.description:"",globs:L_(a.globs),body:c,...f!==void 0&&{trigger:f},...h!==void 0&&{codexEmit:h},...S!==void 0&&{codexInstructionVariant:S}});}return n}var nN,hl=d(()=>{b();v();Da();nN=["always_on","model_decision","glob","manual"];s(L_,"toStrArray");s(Yo,"parseRules");});function A_(t){return t===true||t==="true"||t===1||t==="1"}function x_(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}async function Xo(t){let r=(await D(t)).filter(o=>o.endsWith(".md")&&!basename(o).startsWith("_"));gl("command",r,".md");let n=[];for(let o of r){let i=await y(o);if(!i)continue;let{frontmatter:a,body:c}=E(i),l=basename(o,".md");gn("command",l);let m=x_(a.allowedTools),p=x_(a["allowed-tools"]),u=m.length>0?m:p;n.push({source:o,name:l,description:typeof a.description=="string"?a.description:"",allowedTools:u,outputStyle:A_(a.outputStyle)||A_(a["output-style"]),body:c});}return n}var yl=d(()=>{b();v();Da();s(A_,"toBool");s(x_,"toToolsArray");s(Xo,"parseCommands");});function Zo(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function T_(t){return t===true||t==="true"||t===1||t==="1"}function D_(t){if(typeof t=="number"&&Number.isInteger(t)&&t>=0)return t;if(typeof t=="string"){let e=parseInt(t,10);return Number.isInteger(e)&&e>=0?e:0}return 0}function oN(t){return t!==null&&typeof t=="object"&&!Array.isArray(t)?t:{}}async function qo(t){let r=(await D(t)).filter(o=>o.endsWith(".md")&&!basename(o).startsWith("_"));gl("agent",r,".md");let n=[];for(let o of r){let i=await y(o);if(!i)continue;let{frontmatter:a,body:c}=E(i),l=basename(o,".md");gn("agent",l);let m=Zo(a.tools),p=Zo(a.tools),u=m.length>0?m:p,f=Zo(a.disallowedTools),g=Zo(a["disallowed-tools"]),h=f.length>0?f:g,R=Zo(a.mcpServers),S=Zo(a["mcp-servers"]),_=R.length>0?R:S,k=Zo(a.skills),T=D_(a.maxTurns),P=D_(a["max-turns"]),A=T>0?T:P>0?P:0;n.push({source:o,name:l,description:typeof a.description=="string"?a.description:"",tools:u,disallowedTools:h,model:typeof a.model=="string"?a.model:"",permissionMode:typeof a.permissionMode=="string"?a.permissionMode:typeof a["permission-mode"]=="string"?a["permission-mode"]:"",maxTurns:A,mcpServers:_,hooks:oN(a.hooks),skills:k,memory:typeof a.memory=="string"?a.memory:"",outputStyle:T_(a.outputStyle)||T_(a["output-style"]),body:c});}return n}var _l=d(()=>{b();v();Da();s(Zo,"toStrArray");s(T_,"toBool");s(D_,"toInt");s(oN,"toHooks");s(qo,"parseAgents");});async function aN(t){return await y(t)??""}function lN(t){return t.toLowerCase().replace(/[^a-z0-9-]+/g,"-").replace(/-+/g,"-").replace(/^-|-$/g,"")}async function N_(t){let e=await D(t),r=[];for(let n of e){let i=n.slice(t.length+1).replace(/\\/g,"/");if(i===Il||i.endsWith(`/${Il}`))continue;let a=i.split("/")[0];if(cN.some(l=>a===l)||i===".DS_Store"||i.endsWith("/.DS_Store"))continue;let c=await aN(n);r.push({relativePath:i,absolutePath:n,content:c});}return r.sort((n,o)=>n.relativePath.localeCompare(o.relativePath))}async function F_(t){let e=join(t,Il),r=await y(e);if(!r)return null;let{frontmatter:n,body:o}=E(r),i=await N_(t),c=(typeof n.name=="string"?lN(n.name):"")||basename(t);return gn("skill",c),{source:e,name:c,description:typeof n.description=="string"?n.description:"",body:o,supportingFiles:i}}async function ci(t){let e;try{e=await readdir(t,{withFileTypes:!0});}catch{return []}let r=[];for(let n of e){if(!n.isDirectory()||n.name.startsWith("_"))continue;gn("skill",n.name);let o=join(t,n.name),i=join(o,Il),a=await y(i);if(!a)continue;let{frontmatter:c,body:l}=E(a),m=await N_(o);r.push({source:i,name:n.name,description:typeof c.description=="string"?c.description:"",body:l,supportingFiles:m});}return r.sort((n,o)=>n.name.localeCompare(o.name))}var Il,cN,Sl=d(()=>{b();v();Da();s(aN,"readContent");Il="SKILL.md",cN=[".git","node_modules"];s(lN,"sanitizeSkillName");s(N_,"listSupportingFiles");s(F_,"parseSkillDirectory");s(ci,"parseSkills");});function v_(t){return t===null||typeof t!="object"||Array.isArray(t)?{}:Object.fromEntries(Object.entries(t).filter(e=>typeof e[1]=="string"))}function mN(t){if(!t||typeof t!="object")return null;let e=t,r=typeof e.type=="string"?e.type:"stdio",n=v_(e.env),o=typeof e.description=="string"?e.description:void 0,i=typeof e.url=="string"?e.url:"";if(i)return {...o!==void 0&&{description:o},type:r,url:i,headers:v_(e.headers),env:n};let a=typeof e.command=="string"?e.command:"";if(!a)return null;let c=Array.isArray(e.args)?e.args.filter(l=>typeof l=="string"):[];return {...o!==void 0&&{description:o},type:r,command:a,args:c,env:n}}function pN(t){let e="",r=0,n=t.length;for(;r<n;){let o=t[r];if(o==='"'){for(e+=o,r++;r<n;){let i=t[r];if(e+=i,i==="\\")r++,r<n&&(e+=t[r]);else if(i==='"')break;r++;}r++;continue}if(o==="/"&&t[r+1]==="*"){for(r+=2;r<n;){if(t[r]==="*"&&t[r+1]==="/"){r+=2;break}r++;}continue}if(o==="/"&&t[r+1]==="/"){for(r+=2;r<n&&t[r]!==`
|
|
16
|
+
`;)r++;continue}e+=o,r++;}return e}async function Ze(t){let e=await y(t);if(!e)return null;let r;try{r=JSON.parse(pN(e));}catch{return null}if(!r||typeof r!="object")return null;let n=r.mcpServers;if(n===void 0||typeof n!="object"||n===null)return null;let o={};for(let[i,a]of Object.entries(n)){let c=mN(a);c&&(o[i]=c);}return {mcpServers:o}}var Na=d(()=>{b();s(v_,"parseStringMap");s(mN,"parseServer");s(pN,"stripJsonComments");s(Ze,"parseMcp");});function Eu(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):[]}async function Cl(t){let e=await y(t);if(e===null)return null;if(!e.trim())return {allow:[],deny:[],ask:[]};let r;try{r=parse(e);}catch{return null}if(!r||typeof r!="object")return null;let n=r,o=Eu(n.allow),i=Eu(n.deny),a=Eu(n.ask);return {allow:o,deny:i,ask:a}}var ku=d(()=>{b();s(Eu,"ensureStringArray");s(Cl,"parsePermissions");});function M_(t){return typeof t=="string"?t.trim():""}function At(t){return M_(t.command)}function Qt(t){return M_(t.prompt)}function wu(t){let e=At(t),r=Qt(t);return t.type==="prompt"?r||e:e||r}function hn(t){return At(t).length>0}function Ar(t){return wu(t).length>0}var qe=d(()=>{s(M_,"trimString");s(At,"getHookCommand");s(Qt,"getHookPrompt");s(wu,"getHookText");s(hn,"hasHookCommand");s(Ar,"hasHookText");});function gN(t){if(!t||typeof t!="object")return null;let e=t,r=e.matcher;if(typeof r!="string")return null;let n=wu(e);if(!n)return null;let o=typeof e.type=="string"&&fN.includes(e.type)?e.type:void 0,i=typeof e.timeout=="number"&&Number.isFinite(e.timeout)?e.timeout:void 0,a=Qt(e)||void 0;return {matcher:r,command:n,...i!==void 0&&{timeout:i},...o&&{type:o},...a&&{prompt:a}}}async function Rl(t){let e=await y(t);if(e===null)return null;if(!e.trim())return {};let r;try{r=parse(e);}catch{return null}if(!r||typeof r!="object")return null;let n={},o=r;for(let[i,a]of Object.entries(o)){if(!Array.isArray(a))continue;let c=[];for(let l of a){let m=gN(l);m&&c.push(m);}c.length>0&&(n[i]=c);}return n}var fN,Lu=d(()=>{b();qe();fN=["command","prompt"];s(gN,"toHookEntry");s(Rl,"parseHooks");});async function Ol(t){let e=await y(t);if(e===null||!e.trim())return [];let r=e.split(/\r?\n/),n=[];for(let o of r){let i=o.trim();i===""||i.startsWith("#")||n.push(i);}return n}var bu=d(()=>{b();s(Ol,"parseIgnore");});async function ge(t){let e=join(t,".agentsmesh"),r=await F(e)?e:t,[n,o,i,a,c,l,m,p]=await Promise.all([Yo(join(r,"rules")),Xo(join(r,"commands")),qo(join(r,"agents")),ci(join(r,"skills")),Ze(join(r,"mcp.json")),Cl(join(r,"permissions.yaml")),Rl(join(r,"hooks.yaml")),Ol(join(r,"ignore"))]);return {rules:n,commands:o,agents:i,skills:a,mcp:c,permissions:l,hooks:m,ignore:p}}var Qo=d(()=>{hl();yl();_l();Sl();Na();ku();Lu();bu();b();s(ge,"loadCanonicalFiles");});function $_(t){return basename(t.source,".md")}function li(t,e){let r=new Map(t.rules.map(p=>[$_(p),p]));for(let p of e.rules)r.set($_(p),p);let n=new Map(t.commands.map(p=>[p.name,p]));for(let p of e.commands)n.set(p.name,p);let o=new Map(t.agents.map(p=>[p.name,p]));for(let p of e.agents)o.set(p.name,p);let i=new Map(t.skills.map(p=>[p.name,p]));for(let p of e.skills)i.set(p.name,p);let a=yN(t.mcp,e.mcp),c=_N(t.permissions,e.permissions),l=IN(t.hooks,e.hooks),m=SN(t.ignore,e.ignore);return {rules:Array.from(r.values()),commands:Array.from(n.values()),agents:Array.from(o.values()),skills:Array.from(i.values()),mcp:a,permissions:c,hooks:l,ignore:m}}function yN(t,e){if(!t&&!e)return null;let r=t?.mcpServers??{},n=e?.mcpServers??{};return {mcpServers:{...r,...n}}}function _N(t,e){if(!t&&!e)return null;let r=Au(t?.allow??[],e?.allow??[]),n=Au(t?.deny??[],e?.deny??[]),o=Au(t?.ask??[],e?.ask??[]);return {allow:r,deny:n,ask:o}}function Au(t,e){let r=new Set(t),n=[...t];for(let o of e)r.has(o)||(r.add(o),n.push(o));return n}function IN(t,e){if(!t&&!e)return null;let r={},n=new Set([...Object.keys(t??{}),...Object.keys(e??{})]);for(let o of n){let i=e?.[o],a=t?.[o];r[o]=i!==void 0&&i.length>0?i:a??[];}return r}function SN(t,e){let r=new Set(t),n=[...t];for(let o of e)r.has(o)||(r.add(o),n.push(o));return n}var xu=d(()=>{s($_,"ruleSlug");s(li,"mergeCanonicalFiles");s(yN,"mergeMcp");s(_N,"mergePermissions");s(Au,"mergeUniqueStrings");s(IN,"mergeHooks");s(SN,"mergeIgnore");});async function El(t){let e=null,r=0;for(let n of G_){let o=0;for(let i of n.paths)await F(join(t,i))&&o++;o>r&&(r=o,e=n.target);}return r>0?e:null}var G_,j_,Pu=d(()=>{b();G_=[{target:"claude-code",paths:["CLAUDE.md",".claude/rules",".claude/commands",".claude/agents",".claude/skills",".claude/settings.json",".claudeignore"]},{target:"cursor",paths:[".cursorrules",".cursor/rules",".cursor",".cursor/mcp.json"]},{target:"copilot",paths:[".github/copilot-instructions.md",".github/copilot",".github/instructions",".github/prompts",".github/skills",".github/agents",".github/hooks"]},{target:"gemini-cli",paths:["GEMINI.md",".gemini",".gemini/settings.json"]},{target:"codex-cli",paths:[".codex",".codex/config.toml","AGENTS.md","codex.md"]},{target:"windsurf",paths:[".windsurfrules",".windsurf",".windsurf/workflows"]},{target:"cline",paths:[".clinerules",".cline"]},{target:"continue",paths:[".continue",".continuerc.json"]},{target:"junie",paths:[".junie",".junie/guidelines.md"]},{target:"kiro",paths:[".kiro",".kiro/steering",".kiro/settings/mcp.json"]},{target:"kilo-code",paths:[".kilo",".kilo/rules",".kilo/commands",".kilo/agents",".kilo/skills",".kilocodeignore",".kilocode",".kilocodemodes","kilo.jsonc","kilo.json"]}];s(El,"detectNativeFormat");j_=G_.map(t=>t.paths[0]).filter(t=>t!==void 0);});function J(t){return t.includes("\\")||Qe.test(t)?win32:posix}function ft(t){return t.replace(/\\/g,"/")}function U(t,e){let r=J(t),n=r.normalize(r===win32?e.replace(/\//g,"\\"):ft(e));return n.endsWith(r.sep)&&n.length>1?n.slice(0,-1):n}function W_(t,e){return J(t).isAbsolute(e)||Qe.test(e)}function mi(t){let e=t,r="";for(;ON.test(e);)r=e.at(-1)+r,e=e.slice(0,-1);return {candidate:e,suffix:r}}function K_(t,e){let r=J(e),n=t.replace(/^(\.\.\/)+/,"").replace(/^\.\//,"");return n&&n!==t?U(e,r.join(e,n)):null}var Qe,ON,Vt=d(()=>{Qe=/^[A-Za-z]:[\\/]/,ON=/[.!?:;]+$/;s(J,"pathApi");s(ft,"normalizeSeparators");s(U,"normalizeForProject");s(W_,"isAbsoluteForProject");s(mi,"stripTrailingPunctuation");s(K_,"rootFallbackPath");});function EN(t){return Object.prototype.hasOwnProperty.call(B_,t)}function kN(t){return Object.prototype.hasOwnProperty.call(H_,t)}function z_(t,e){if(t!==void 0)return typeof t=="boolean"?t:t[e]}function pi(t,e,r,n="project"){let o=t.conversions?.commands_to_skills?.[e],i=z_(o,n);return i!==void 0?i:EN(e)?B_[e]:r??false}function be(t,e,r,n="project"){let o=t.conversions?.agents_to_skills?.[e],i=z_(o,n);return i!==void 0?i:kN(e)?H_[e]:r??false}var B_,H_,ui=d(()=>{B_={amp:true,"codex-cli":true,goose:true,kiro:true,warp:true},H_={amp:true,"gemini-cli":false,cline:true,"codex-cli":false,windsurf:true,goose:true,antigravity:true,continue:true,warp:true};s(EN,"usesCommandSkillProjection");s(kN,"usesAgentSkillProjection");s(z_,"resolveConversionValue");s(pi,"shouldConvertCommandsToSkills");s(be,"shouldConvertAgentsToSkills");});function er(t,e){return e!==void 0?{level:t,flavor:e}:{level:t}}function tr(t){return typeof t=="string"?{level:t}:t}function V_(t){return {rules:tr(t.rules),additionalRules:tr(t.additionalRules),commands:tr(t.commands),agents:tr(t.agents),skills:tr(t.skills),mcp:tr(t.mcp),hooks:tr(t.hooks),ignore:tr(t.ignore),permissions:tr(t.permissions)}}var ts=d(()=>{s(er,"cap");s(tr,"normalizeCapabilityValue");s(V_,"normalizeTargetCapabilities");});function J_(t){for(let e of Gt)if(e.sharedArtifacts){for(let[r,n]of Object.entries(e.sharedArtifacts))if(n==="owner"&&t.startsWith(r))return e.id}return null}function wN(t){let e=[];for(let n of t)if(n.sharedArtifacts)for(let[o,i]of Object.entries(n.sharedArtifacts))i==="owner"&&e.push({targetId:n.id,prefix:o});let r=[];for(let n=0;n<e.length;n++)for(let o=n+1;o<e.length;o++){let i=e[n],a=e[o];i===void 0||a===void 0||(i.prefix===a.prefix||i.prefix.startsWith(a.prefix)||a.prefix.startsWith(i.prefix))&&r.push({a:i,b:a});}return r}function Y_(t){let e=wN(t);if(e.length===0)return;let r=e.map(({a:n,b:o})=>` - "${n.targetId}" owns "${n.prefix}" and "${o.targetId}" owns "${o.prefix}"`);throw new Error(`Shared-artifact ownership conflict: two targets claim the same or overlapping prefix.
|
|
17
17
|
`+r.join(`
|
|
18
18
|
`)+`
|
|
19
|
-
Resolve by changing one target's role to 'consumer' or by namespacing its prefix.`)}var
|
|
19
|
+
Resolve by changing one target's role to 'consumer' or by namespacing its prefix.`)}var Tu=d(()=>{gt();s(J_,"ownerTargetIdForSharedPath");s(wN,"findSharedArtifactOwnershipConflicts");s(Y_,"assertSharedArtifactOwnersUnique");});function LN(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"&&e.length>0):typeof t=="string"&&t.length>0?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function at(t){return `${di}${t}`}function xr(t){let e={name:at(t.name),description:t.description||void 0,"x-agentsmesh-kind":"command","x-agentsmesh-name":t.name,"x-agentsmesh-allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return e.description===void 0&&delete e.description,e["x-agentsmesh-allowed-tools"]===void 0&&delete e["x-agentsmesh-allowed-tools"],N(e,t.body.trim()||"")}function kl(t,e){if(t["x-agentsmesh-kind"]!=="command")return null;let r=typeof t["x-agentsmesh-name"]=="string"?t["x-agentsmesh-name"]:"",n=e.startsWith(di)?e.slice(di.length):e.startsWith(Fa)?e.slice(Fa.length):"",o=(r||n).trim();return o?{name:o,description:typeof t.description=="string"?t.description:"",allowedTools:LN(t["x-agentsmesh-allowed-tools"])}:null}function wl(t,e){return N({description:t.description,"allowed-tools":t.allowedTools},e.trim()||"")}var di,Fa,ae=d(()=>{v();di="am-command-",Fa="ab-command-";s(LN,"toStringArray");s(at,"commandSkillDirName");s(xr,"serializeCommandSkill");s(kl,"parseCommandSkillFrontmatter");s(wl,"serializeImportedCommand");});function Ll(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"&&e.length>0):typeof t=="string"&&t.length>0?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function bN(t){if(!t||typeof t!="object"||Array.isArray(t))return {};let e={};for(let[r,n]of Object.entries(t))Array.isArray(n)&&(e[r]=n.filter(o=>o!==null&&typeof o=="object"&&typeof o.matcher=="string"&&typeof o.command=="string"));return e}function z(t){return `${fi}${t}`}function ce(t){let e={name:z(t.name),description:t.description||void 0,"x-agentsmesh-kind":"agent","x-agentsmesh-name":t.name,"x-agentsmesh-tools":t.tools.length>0?t.tools:void 0,"x-agentsmesh-disallowed-tools":t.disallowedTools.length>0?t.disallowedTools:void 0,"x-agentsmesh-model":t.model||void 0,"x-agentsmesh-permission-mode":t.permissionMode||void 0,"x-agentsmesh-max-turns":t.maxTurns>0?t.maxTurns:void 0,"x-agentsmesh-mcp-servers":t.mcpServers.length>0?t.mcpServers:void 0,"x-agentsmesh-hooks":Object.keys(t.hooks).length>0?t.hooks:void 0,"x-agentsmesh-skills":t.skills.length>0?t.skills:void 0,"x-agentsmesh-memory":t.memory||void 0};return Object.keys(e).forEach(r=>{e[r]===void 0&&delete e[r];}),N(e,t.body.trim()||"")}function Pr(t,e){if(t["x-agentsmesh-kind"]!=="agent")return null;let r=typeof t["x-agentsmesh-name"]=="string"?t["x-agentsmesh-name"]:"",n=e.startsWith(fi)?e.slice(fi.length):e.startsWith(va)?e.slice(va.length):"",o=(r||n).trim();return o?{name:o,description:typeof t.description=="string"?t.description:"",tools:Ll(t["x-agentsmesh-tools"]),disallowedTools:Ll(t["x-agentsmesh-disallowed-tools"]),model:typeof t["x-agentsmesh-model"]=="string"?t["x-agentsmesh-model"]:"",permissionMode:typeof t["x-agentsmesh-permission-mode"]=="string"?t["x-agentsmesh-permission-mode"]:"",maxTurns:typeof t["x-agentsmesh-max-turns"]=="number"?t["x-agentsmesh-max-turns"]:Number(t["x-agentsmesh-max-turns"]??0),mcpServers:Ll(t["x-agentsmesh-mcp-servers"]),hooks:bN(t["x-agentsmesh-hooks"]),skills:Ll(t["x-agentsmesh-skills"]),memory:typeof t["x-agentsmesh-memory"]=="string"?t["x-agentsmesh-memory"]:""}:null}function Ae(t,e){let r={name:t.name,description:t.description,tools:t.tools,disallowedTools:t.disallowedTools.length>0?t.disallowedTools:void 0,model:t.model||void 0,permissionMode:t.permissionMode||void 0,maxTurns:t.maxTurns>0?t.maxTurns:void 0,mcpServers:t.mcpServers.length>0?t.mcpServers:void 0,hooks:Object.keys(t.hooks).length>0?t.hooks:void 0,skills:t.skills.length>0?t.skills:void 0,memory:t.memory||void 0};return Object.keys(r).forEach(n=>{r[n]===void 0&&delete r[n];}),N(r,e.trim()||"")}var fi,va,ht=d(()=>{v();fi="am-agent-",va="ab-agent-";s(Ll,"toStringArray");s(bN,"toHooks");s(z,"projectedAgentSkillDirName");s(ce,"serializeProjectedAgentSkill");s(Pr,"parseProjectedAgentSkillFrontmatter");s(Ae,"serializeImportedAgent");});function Ma(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Du(t,e){return new RegExp(`${Ma(t)}[\\s\\S]*?${Ma(e)}`,"g")}function tI(t,e,r,n){let o=Du(e,r);if(o.test(t))return t.replace(o,n).trim();let i=t.trim();return i?`${i}
|
|
20
20
|
|
|
21
|
-
${n}`:n}function
|
|
22
|
-
`)}function
|
|
23
|
-
`)}function
|
|
21
|
+
${n}`:n}function Nu(t,e,r){return t.replace(Du(e,r),"").trim()}function PN(t){let e=t.replace(/\\/g,"/"),r=e.lastIndexOf(".agentsmesh/");return r>=0?e.slice(r+12):e.startsWith("rules/")?e:join("rules",basename(e)).replace(/\\/g,"/")}function TN(t){return {source:PN(t.source),description:t.description,globs:t.globs,targets:t.targets}}function DN(t){return `${q_}${JSON.stringify(TN(t))}${Q_}`}function NN(t){let e=[DN(t)];return t.description.trim()&&e.push(`## ${t.description.trim()}`,""),e.push(t.body.trim(),Z_),e.filter(r=>r.length>0).join(`
|
|
22
|
+
`)}function FN(t){return t.length===0?"":[bl,...t.map(NN),Al].join(`
|
|
23
|
+
`)}function xt(t,e){let r=FN(e),n=Nu(t,bl,Al);return r?n?`${n}
|
|
24
24
|
|
|
25
|
-
${r}`:r:n}function
|
|
25
|
+
${r}`:r:n}function X_(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):[]}function vN(t){try{let e=JSON.parse(t);if(!e||typeof e!="object"||Array.isArray(e))return null;let r=e;return typeof r.source!="string"||!r.source.startsWith("rules/")?null:{source:r.source,description:typeof r.description=="string"?r.description:"",globs:X_(r.globs),targets:X_(r.targets)}}catch{return null}}function MN(t,e){let r=t.trim();if(!e.trim())return r;let n=`## ${e.trim()}`;return r.startsWith(n)?r.slice(n.length).trim():r}function eI(t){let e=[],r=Du(bl,Al);return {rootContent:t.replace(r,o=>{let i=o.replace(bl,"").replace(Al,"").trim(),a=new RegExp(`${Ma(q_)}([\\s\\S]*?)${Ma(Q_)}([\\s\\S]*?)${Ma(Z_)}`,"g");for(let c of i.matchAll(a)){let l=c[1],m=c[2];if(l===void 0||m===void 0)continue;let p=vN(l);p&&e.push({...p,body:MN(m,p.description)});}return ""}).trim(),rules:e}}var $a,Ga,bl,Al,Z_,q_,Q_,xe=d(()=>{$a="<!-- agentsmesh:root-generation-contract:start -->",Ga="<!-- agentsmesh:root-generation-contract:end -->",bl="<!-- agentsmesh:embedded-rules:start -->",Al="<!-- agentsmesh:embedded-rules:end -->",Z_="<!-- agentsmesh:embedded-rule:end -->",q_="<!-- agentsmesh:embedded-rule:start ",Q_=" -->";s(Ma,"escapeRegExp");s(Du,"managedBlockPattern");s(tI,"replaceManagedBlock");s(Nu,"stripManagedBlock");s(PN,"ruleSource");s(TN,"markerForRule");s(DN,"embeddedRuleStart");s(NN,"renderRule");s(FN,"renderEmbeddedRulesBlock");s(xt,"appendEmbeddedRulesBlock");s(X_,"toStringArray");s(vN,"parseMarker");s(MN,"stripGeneratedHeading");s(eI,"extractEmbeddedRules");});function Fu(t){return t.replace(/\s+/g," ").trim()}function nI(t){let e=t.trim();if(e.includes($a)&&e.includes(Ga))return tI(e,$a,Ga,gi);let r=Fu(e);if(r.includes(Fu(gi)))return e;for(let n of rI)if(r.includes(Fu(n)))return e.replace(n,gi);return e?`${e}
|
|
26
26
|
|
|
27
|
-
${
|
|
27
|
+
${gi}`:gi}function oI(t){let e=Nu(t,$a,Ga);e=e.replace(`
|
|
28
28
|
|
|
29
|
-
${
|
|
29
|
+
${gi}`,"");for(let r of rI)e=e.replace(`
|
|
30
30
|
|
|
31
|
-
${r}`,"");return e.trim()}var
|
|
31
|
+
${r}`,"");return e.trim()}var vu,$N,GN,jN,UN,WN,KN,BN,HN,zN,VN,JN,YN,XN,ZN,qN,QN,gi,rI,Mu=d(()=>{xe();vu="AgentsMesh is a config sync library for AI coding tools. The only canonical source of truth is `.agentsmesh/`; files emitted into target formats such as `AGENTS.md`, `.claude/`, `.cursor/`, `.junie/`, and similar directories are generated artifacts. When making changes, edit canonical config first, then regenerate and verify the target outputs. Preserve the library's bidirectional contract: import native tool config into canonical form, generate back to target-specific layouts, and keep projected or embedded features round-trippable rather than treating them as plain text exports.",$N="AgentsMesh is a config sync library for AI coding tools. The only canonical source of truth is the `.agentsmesh` directory at the project root; files emitted into target formats such as `AGENTS.md`, `.claude/`, `.cursor/`, `.junie/`, and similar directories are generated artifacts. When making changes, edit canonical config first, then regenerate and verify the target outputs. Preserve the library's bidirectional contract: import native tool config into canonical form, generate back to target-specific layouts, and keep projected or embedded features round-trippable rather than treating them as plain text exports.",GN="AgentsMesh syncs AI coding tool configuration from a single canonical `.agentsmesh` directory. All target-specific files (`.claude/`, `.cursor/`, `AGENTS.md`, etc.) are generated artifacts \u2014 edit canonical config first, then regenerate. The import/generate contract is bidirectional and lossless: embedded or projected features round-trip without data loss.",jN="Create agents, skills, commands, rules, hooks, and MCP in `.agentsmesh`, then run `agentsmesh generate` to sync each tool's native files. Edit `.agentsmesh`, not generated outputs.",UN="Use Claude-style Markdown in `.agentsmesh`: `agents/*.md`, `commands/*.md`, and `skills/*/SKILL.md`; keep rules in `rules/*.md`, hooks in `hooks.yaml`, MCP in `mcp.json`, permissions in `permissions.yaml`, and ignore patterns in `ignore`, then run `agentsmesh generate`.",WN="Create canonical files in `.agentsmesh`: `rules/_root.md` and `rules/*.md` are Markdown rules; `commands/*.md`, `agents/*.md`, and `skills/*/SKILL.md` plus supporting files use Claude-style frontmatter Markdown; `mcp.json` is MCP JSON; `hooks.yaml` and `permissions.yaml` are YAML; `ignore` is gitignore-style text. Then run `agentsmesh generate`.",KN="`.agentsmesh` is the only folder you edit or add these files in: `rules/_root.md` and `rules/*.md` are Markdown rules; `commands/*.md`, `agents/*.md`, and `skills/*/SKILL.md` plus supporting files use Claude-style frontmatter Markdown; `mcp.json` is MCP JSON; `hooks.yaml` and `permissions.yaml` are YAML; `ignore` is gitignore-style text. Do not edit generated tool files; run `agentsmesh generate`.",BN="`agentsmesh.yaml` selects targets/features (`agentsmesh.local.yaml` overrides locally), and `.agentsmesh` is the only place to add or edit canonical items: `rules/_root.md`, `rules/*.md`, `commands/*.md`, `agents/*.md`, `skills/*/SKILL.md` plus supporting files, `mcp.json`, `hooks.yaml`, `permissions.yaml`, and `ignore`; if missing run `agentsmesh init`, use `agentsmesh import --from <tool>` for native configs, `agentsmesh install <source>` or `install --sync` for reusable packs, then run `agentsmesh generate`. Use `diff`, `lint`, `check`, `watch`, `matrix`, and `merge` as needed; never edit generated tool files.",HN=vu,zN=`## Project-Specific Rules
|
|
32
32
|
|
|
33
|
-
${
|
|
33
|
+
${vu}`,VN=`## AgentsMesh Generation Contract
|
|
34
34
|
|
|
35
|
-
${
|
|
35
|
+
${vu}`,JN=`## AgentsMesh Generation Contract
|
|
36
36
|
|
|
37
|
-
${
|
|
37
|
+
${$N}`,YN=`## AgentsMesh Generation Contract
|
|
38
38
|
|
|
39
|
-
${
|
|
39
|
+
${GN}`,XN=`## AgentsMesh Generation Contract
|
|
40
40
|
|
|
41
|
-
${
|
|
41
|
+
${jN}`,ZN=`## AgentsMesh Generation Contract
|
|
42
42
|
|
|
43
|
-
${
|
|
43
|
+
${UN}`,qN=`## AgentsMesh Generation Contract
|
|
44
44
|
|
|
45
|
-
${
|
|
45
|
+
${WN}`,QN=`## AgentsMesh Generation Contract
|
|
46
46
|
|
|
47
|
-
${
|
|
47
|
+
${KN}`,gi=`${$a}
|
|
48
48
|
## AgentsMesh Generation Contract
|
|
49
49
|
|
|
50
|
-
${
|
|
51
|
-
${Na}`;s(Ru,"normalizeWhitespace");A_=[pN,mN,lN,cN,aN,iN,sN,oN,nN];s(x_,"appendAgentsmeshRootInstructionParagraph");s(P_,"stripAgentsmeshRootInstructionParagraph");});function Xt(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}async function li(t){let e=await y(t);return e?w(e).frontmatter:{}}function vt(t,e){return typeof t[e]=="string"?t[e]:void 0}function wu(t){let e=t.hooks;return e&&typeof e=="object"&&!Array.isArray(e)?e:void 0}function uN(t){return Object.fromEntries(Object.entries(t).filter(([,e])=>e!==void 0))}function dN(t,e){let r=basename(t,".md")==="_root",n={...e};return delete n.root,{root:r,...n}}async function j(t,e,r){let n=await li(t),o=basename(t,".md")==="_root"?P_(r):r.trim(),i=dN(t,uN({...n,...e})),a={root:i.root===true,description:typeof i.description=="string"?i.description:""};a.root===false&&(a.globs=Xt(i.globs));for(let[c,l]of Object.entries(i))c==="root"||c==="description"||c==="globs"||l===void 0||(a[c]=l);return F(a,o||"")}var Eu=d(()=>{A();M();Ou();s(Xt,"toStringArray");s(li,"readExistingFrontmatter");s(vt,"readString");s(wu,"readHooks");s(uN,"pruneUndefined");s(dN,"serializeCanonicalRuleFrontmatter");s(j,"serializeImportedRuleWithFallback");});async function ot(t,e,r){let n=await li(t),o=(()=>{let c=Xt(n.allowedTools);return c.length>0?c:Xt(n["allowed-tools"])})(),i=e.hasDescription?e.description??"":typeof n.description=="string"?n.description:"",a=e.hasAllowedTools?e.allowedTools??[]:o;return F({description:i,"allowed-tools":a},r.trim()||"")}async function Lr(t,e,r){let n=await li(t),o=basename(dirname(t)),i=vt(e,"name")??vt(n,"name")??o,a=vt(e,"description")??vt(n,"description")??"";return F({name:i,description:a},r.trim()||"")}async function Lt(t,e,r){let n=await li(t),o=Object.prototype.hasOwnProperty.call(e,"tools")?Xt(e.tools):(()=>{let R=Xt(n.tools);return R.length>0?R:[]})(),i=Object.prototype.hasOwnProperty.call(e,"disallowedTools")?Xt(e.disallowedTools):Object.prototype.hasOwnProperty.call(e,"disallowed-tools")?Xt(e["disallowed-tools"]):Xt(n.disallowedTools),a=Object.prototype.hasOwnProperty.call(e,"mcpServers")?Xt(e.mcpServers):Object.prototype.hasOwnProperty.call(e,"mcp-servers")?Xt(e["mcp-servers"]):Xt(n.mcpServers),c=Object.prototype.hasOwnProperty.call(e,"skills")?Xt(e.skills):Xt(n.skills),l=e.maxTurns??e["max-turns"]??n.maxTurns,m=typeof l=="number"?l:Number(l??0),p=wu(e)??wu(n),u={name:vt(e,"name")??vt(n,"name")??basename(t,".md"),description:vt(e,"description")??vt(n,"description")??"",tools:o};i.length>0&&(u.disallowedTools=i);let f=vt(e,"model")??vt(n,"model");f&&(u.model=f);let g=vt(e,"permissionMode")??vt(e,"permission-mode")??vt(n,"permissionMode")??vt(n,"permission-mode");g&&(u.permissionMode=g),Number.isInteger(m)&&m>0&&(u.maxTurns=m),a.length>0&&(u.mcpServers=a),p&&Object.keys(p).length>0&&(u.hooks=p),c.length>0&&(u.skills=c);let h=vt(e,"memory")??vt(n,"memory");return h&&(u.memory=h),F(u,r.trim()||"")}var N_=d(()=>{M();Eu();s(ot,"serializeImportedCommandWithFallback");s(Lr,"serializeImportedSkillWithFallback");s(Lt,"serializeImportedAgentWithFallback");});var et=d(()=>{Eu();N_();});function Rl(t){let e=t.split("/").filter(Boolean);return e.length===0||e.some(n=>n.startsWith("."))?false:!e.join("/").startsWith("tests/e2e/fixtures/")}async function Ee(t){await rm$1(t,{recursive:true,force:true});}var mi=d(()=>{s(Rl,"shouldImportScopedAgentsRule");s(Ee,"removePathIfExists");});function St(t,e){let r=[];for(let n of t.skills){let o={name:n.name,description:n.description||void 0};o.description===void 0&&delete o.description,r.push({path:`${e}/${n.name}/SKILL.md`,content:F(o,n.body.trim()||"")});for(let i of n.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");r.push({path:`${e}/${n.name}/${a}`,content:i.content});}}return r}async function yt(t,e,r,n,o){let i=await readdir(join(t,e),{encoding:"utf8",withFileTypes:true}).catch(()=>null);if(i!==null)for(let a of i){if(!a.isDirectory())continue;let c=join(t,e,a.name),l=join(c,"SKILL.md"),m=await y(l);if(m===null)continue;let p=join(t,Fa,a.name),u=join(p,"SKILL.md"),{frontmatter:f,body:g}=w(o(m,l,u)),h=yl(f,a.name);if(h){await Ee(join(t,Fa,a.name));let E=join(t,F_);await O(E);let T=join(E,`${h.name}.md`);await S(T,_l(h,o(g,l,T))),n.push({fromTool:r,fromPath:l,toPath:`${F_}/${h.name}.md`,feature:"commands"});continue}let R=Er(f,a.name);if(R){await Ee(join(t,Fa,a.name));let E=join(t,v_);await O(E);let T=join(E,`${R.name}.md`);await S(T,Oe(R,o(g,l,T))),n.push({fromTool:r,fromPath:l,toPath:`${v_}/${R.name}.md`,feature:"agents"});continue}let C=await Lr(u,{...f,name:a.name},g);await O(p),await S(u,C),n.push({fromTool:r,fromPath:l,toPath:`${Fa}/${a.name}/SKILL.md`,feature:"skills"});let _=await N(c);for(let E of _){if(E===l)continue;let T=relative(c,E).replace(/\\/g,"/"),D=await y(E);if(D===null)continue;let x=join(p,T);await O(dirname(x)),await S(x,o(D,E,x)),n.push({fromTool:r,fromPath:E,toPath:`${Fa}/${a.name}/${T}`,feature:"skills"});}}}var Fa,F_,v_,_t=d(()=>{A();M();et();dt();ne();mi();Fa=".agentsmesh/skills",F_=".agentsmesh/commands",v_=".agentsmesh/agents";s(St,"generateEmbeddedSkills");s(yt,"importEmbeddedSkills");});var be,Bt,br,Lu,un,Ae,dn,M_,Jo=d(()=>{be="AGENTS.md",Bt=".agents/skills",br=".amp/settings.json",Lu=".config/amp",un=`${Lu}/AGENTS.md`,Ae=`${Lu}/skills`,dn=`${Lu}/settings.json`,M_=".agentsmesh/rules";});function $_(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes("amp")),n=e?.body.trim()??"",o=Et(n,r);return o?[{path:be,content:o}]:[]}function G_(t){return St(t,Bt)}function j_(t){return t.commands.map(e=>({path:`${Bt}/${st(e.name)}/SKILL.md`,content:wr(e)}))}function U_(t){return t.agents.map(e=>({path:`${Bt}/${V(e.name)}/SKILL.md`,content:oe(e)}))}var K_=d(()=>{_t();we();dt();ne();Jo();s($_,"generateRules");s(G_,"generateSkills");s(j_,"generateCommands");s(U_,"generateAgents");});function at(t,e,r){return t.startsWith(`${e}/`)&&!r.includes("codex-cli")?`.agents/skills/${t.slice(e.length+1)}`:null}var ue=d(()=>{s(at,"mirrorSkillsToAgents");});async function Ht(t,e,r){let n=join(t,e),i={...await SN(n),...r};await O(dirname(n)),await S(n,JSON.stringify({mcpServers:i},null,2));}async function SN(t){let e=await y(t);if(e===null)return {};let r;try{r=JSON.parse(e);}catch{return {}}if(!r||typeof r!="object"||Array.isArray(r))return {};let n=r.mcpServers;if(!n||typeof n!="object"||Array.isArray(n))return {};let o={};for(let[i,a]of Object.entries(n))!a||typeof a!="object"||Array.isArray(a)||(o[i]=a);return o}var fn=d(()=>{A();s(Ht,"writeMcpWithMerge");s(SN,"readExistingServers");});function gn(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):typeof t=="string"?t?[t]:[]:[]}function xe(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function pi(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):[]}function ui(t){return !t||typeof t!="object"||Array.isArray(t)?{}:Object.fromEntries(Object.entries(t).filter(e=>typeof e[1]=="string"))}var Qe=d(()=>{s(gn,"toGlobsArray");s(xe,"toToolsArray");s(pi,"toStringArray");s(ui,"toStringRecord");});function ON(t,e){return e.some(r=>t.endsWith(r))}async function mt(t){let r=(await N(t.srcDir)).filter(o=>ON(o,t.extensions)),n=[];for(let o of r){let i=await y(o);if(!i)continue;let a=relative(t.srcDir,o).replace(/\\/g,"/"),c=await t.mapEntry({srcPath:o,relativePath:a,content:i,normalizeTo:s((l,m=i)=>t.normalize(m,o,l),"normalizeTo")});c&&(await O(dirname(c.destPath)),await S(c.destPath,c.content),n.push({fromTool:t.fromTool,fromPath:o,toPath:c.toPath,feature:c.feature}));}return n}var tr=d(()=>{A();s(ON,"matchesExtension");s(mt,"importFileDirectory");});function W_(t){return typeof t=="string"?t:void 0}function wN(t){for(let e of Object.keys(t))t[e]===void 0&&delete t[e];return t}function Au(t,e){return e?e(t):t}function EN(t){return async e=>{let r=join(e.destDir,e.relativePath),{frontmatter:n,body:o}=w(e.normalizeTo(r)),i=Au(n,t.frontmatterRemap),a=wN({root:false,description:W_(i.description),globs:Array.isArray(i.globs)?i.globs:void 0,...i});return {destPath:r,toPath:`${t.canonicalDir}/${e.relativePath}`,content:await j(r,a,o)}}}function LN(t){return async e=>{let r=join(e.destDir,e.relativePath),{frontmatter:n,body:o}=w(e.normalizeTo(r)),i=Au(n,t.frontmatterRemap),a=await ot(r,{hasDescription:true,description:W_(i.description),hasAllowedTools:true,allowedTools:pi(i["allowed-tools"])},o);return {destPath:r,toPath:`${t.canonicalDir}/${e.relativePath}`,content:a}}}function bN(t){return async e=>{let r=join(e.destDir,e.relativePath),{frontmatter:n,body:o}=w(e.normalizeTo(r)),i=Au(n,t.frontmatterRemap);return {destPath:r,toPath:`${t.canonicalDir}/${e.relativePath}`,content:await Lt(r,i,o)}}}function B_(t){if(t.map)return t.map;switch(t.preset){case "rule":return EN(t);case "command":return LN(t);case "agent":return bN(t);default:throw new Error(`ImportFeatureSpec for ${t.feature} (mode: ${t.mode}) needs a \`preset\` or \`map\``)}}var H_=d(()=>{M();et();Qe();s(W_,"pickString");s(wN,"pruneUndefined");s(Au,"applyRemap");s(EN,"ruleMapper");s(LN,"commandMapper");s(bN,"agentMapper");s(B_,"resolveMapper");});function xu(t,e){return t?t[e]??[]:[]}var z_,V_=d(()=>{z_=["rules","commands","agents","skills","mcp","hooks","permissions","ignore"];s(xu,"resolveScopedSources");});async function PN(t,e,r,n,o){if(!t.canonicalRootFilename)throw new Error(`singleFile spec for ${t.feature} must set canonicalRootFilename`);let i=join(r,t.canonicalDir);for(let a of e){let c=join(r,a),l=await y(c);if(l===null)continue;await O(i);let m=join(i,t.canonicalRootFilename),p=s(C=>o(l,c,C),"normalizeTo");if(t.map){let C=await t.map({absolutePath:c,relativePath:a,content:l,destDir:i,normalizeTo:p});if(!C)continue;return await S(C.destPath,C.content),[{fromTool:n,fromPath:c,toPath:C.toPath,feature:t.feature}]}let{frontmatter:u,body:f}=w(p(m)),g=t.frontmatterRemap?t.frontmatterRemap(u):u,h=t.markAsRoot?{...g,root:true}:g,R=await j(m,h,f);return await S(m,R),[{fromTool:n,fromPath:c,toPath:`${t.canonicalDir}/${t.canonicalRootFilename}`,feature:t.feature}]}return []}async function TN(t,e,r,n,o){let i=B_(t),a=join(r,t.canonicalDir),c=[];for(let l of e){let m=join(r,l),p=await mt({srcDir:m,destDir:a,extensions:[...t.extensions??[".md"]],fromTool:n,normalize:o,mapEntry:s(async({srcPath:u,relativePath:f,content:g,normalizeTo:h})=>{let R=await i({absolutePath:u,relativePath:f,content:g,destDir:a,normalizeTo:s(C=>h(C),"normalizeTo")});return R?{destPath:R.destPath,toPath:R.toPath,feature:t.feature,content:R.content}:null},"mapEntry")});c.push(...p);}return c}function Y_(t){let e=t.canonicalFilename;return e.includes("/")||e.includes("\\")?e:posix.join(t.canonicalDir,e)}async function DN(t,e,r,n){if(!t.canonicalFilename)throw new Error(`flatFile spec for ${t.feature} must set canonicalFilename`);let o=Y_(t);for(let i of e){let a=join(r,i),c=await y(a);if(c===null)continue;let l=join(r,o);return await O(dirname(l)),await S(l,c.trimEnd()),[{fromTool:n,fromPath:a,toPath:o,feature:t.feature}]}return []}function NN(t){let e;try{e=JSON.parse(t);}catch{return {}}if(!e||typeof e!="object")return {};let r=e.mcpServers;if(!r||typeof r!="object"||Array.isArray(r))return {};let n={};for(let[o,i]of Object.entries(r)){if(!i||typeof i!="object"||Array.isArray(i))continue;let a=i,c=typeof a.description=="string"?a.description:void 0;if(typeof a.command=="string"){n[o]={type:typeof a.type=="string"?a.type:"stdio",command:a.command,args:pi(a.args),env:ui(a.env),description:c};continue}typeof a.url=="string"&&(n[o]={type:typeof a.type=="string"?a.type:"http",url:a.url,headers:ui(a.headers),env:ui(a.env),description:c});}return n}async function FN(t,e,r,n){if(!t.canonicalFilename)throw new Error(`mcpJson spec for ${t.feature} must set canonicalFilename`);let o=Y_(t);for(let i of e){let a=join(r,i),c=await y(a);if(c===null)continue;let l=NN(c);return Object.keys(l).length===0?[]:(await Ht(r,o,l),[{fromTool:n,fromPath:a,toPath:o,feature:t.feature}])}return []}function J_(t,e,r,n,o){switch(t.mode){case "singleFile":return PN(t,e,r,n,o);case "directory":return TN(t,e,r,n,o);case "flatFile":return DN(t,e,r,n);case "mcpJson":return FN(t,e,r,n)}}async function vN(t,e,r,n,o){let i=xu(t.source,e),a=xu(t.fallbacks,e);if(i.length===0&&a.length===0)return [];if(i.length>0){let c=await J_(t,i,r,n,o);if(c.length>0)return c}return a.length>0?J_(t,a,r,n,o):[]}function MN(t,e){let r=t[e];return r?Array.isArray(r)?r:[r]:[]}async function Q(t,e,r,n){let o=t.importer;if(!o)return [];let i=n?.normalize??await z(t.id,e,r),a=[];for(let c of z_)for(let l of MN(o,c))a.push(...await vN(l,r,e,t.id,i));return a}var Mt=d(()=>{It();A();fn();M();Qe();et();tr();H_();V_();s(PN,"runSingleFile");s(TN,"runDirectory");s(Y_,"resolveCanonicalFilePath");s(DN,"runFlatFile");s(NN,"parseMcpJson");s(FN,"runMcpJson");s(J_,"dispatchSpec");s(vN,"runSpec");s(MN,"specsForFeature");s(Q,"runDescriptorImport");});async function Z_(t,e,r){let n=await y(join(t,e));if(n===null)return;let o;try{o=JSON.parse(n);}catch{return}if(o===null||typeof o!="object"||Array.isArray(o))return;let i=o,a=i["amp.mcpServers"]??i.mcpServers;if(a==null||typeof a!="object"||Array.isArray(a)||Object.keys(a).length===0)return;let c={};for(let[l,m]of Object.entries(a))!m||typeof m!="object"||Array.isArray(m)||(c[l]=m);Object.keys(c).length!==0&&(await Ht(t,X_,c),r.push({fromTool:"amp",fromPath:e,toPath:X_,feature:"mcp"}));}var X_,q_=d(()=>{A();fn();Jo();X_=".agentsmesh/mcp.json";s(Z_,"importAmpMcp");});async function Q_(t,e={}){let r=e.scope??"project",n=[],o=await z("amp",t,r);return n.push(...await Q(kl,t,r,{normalize:o})),await yt(t,r==="global"?Ae:Bt,"amp",n,o),await Z_(t,r==="global"?dn:br,n),n}var tI=d(()=>{It();_t();Mt();q_();Jo();Pu();s(Q_,"importFromAmp");});function GN(t,e){return rI(e).some(n=>jN(t,n))}function eI(t,e){return t.filter(r=>GN(r,e))}function rI(t){let e=t.match(/^(.+)\{([^}]+)\}(.*)$/);if(!e)return [t];let[,r,n,o]=e;if(!n)return [t];let i=n.split(",").map(c=>c.trim()),a=[];for(let c of i)for(let l of rI(r+c+o))a.push(l);return a}function jN(t,e){return UN(e).test(t)}function UN(t){let e=[],r=0;for(;r<t.length;){if(t.startsWith("**",r)){let i=t.slice(r+2);if(i.length===0&&e.length===0)e.push(".*");else if(e.push(i.startsWith("/")?"(?:[^/]+/)*":"(?:/[^/]+)*?"),i.startsWith("/")){r+=3;continue}r+=2;continue}if(t[r]==="*"){e.push("[^/]*"),r+=1;continue}if(t[r]==="?"){e.push("[^/]"),r+=1;continue}if(t[r]==="{"){e.push("(?:"),r+=1;continue}if(t[r]==="}"){e.push(")"),r+=1;continue}if(t[r]===","){e.push("|"),r+=1;continue}".^$+?()[]{}|\\".includes(t[r])?e.push("\\"+t[r]):e.push(t[r]),r+=1;}let n="^"+e.join("")+"$";return new RegExp(n)}var nI=d(()=>{s(GN,"globMatch");s(eI,"globFilter");s(rI,"expandBraces");s(jN,"matchOne");s(UN,"globToRegex");});function q(t,e,r,n={}){let o=[],{rules:i}=t;if(i.length===0)return [];if(i.some(c=>c.root)||o.push({level:"error",file:relative(e,i[0].source),message:"Rules exist but no root rule (_root.md or root: true). Add a root rule."}),n.checkGlobMatches===false)return o;for(let c of i){if(c.globs.length===0)continue;let l=false;for(let m of c.globs)if(eI(r,m).length>0){l=true;break}l||o.push({level:"warning",file:relative(e,c.source),message:`globs "${c.globs.join(", ")}" match 0 files in project`});}return o}var $t=d(()=>{nI();s(q,"validateRules");});function sI(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:"amp"}))}var iI=d(()=>{$t();Jo();s(sI,"lintRules");});function U(t,e,r){return {level:"warning",file:t,target:e,message:r}}function KN(t){return t.length===0?"":t.length===1?t[0]:t.length===2?`${t[0]} and ${t[1]}`:`${t.slice(0,-1).join(", ")}, and ${t[t.length-1]}`}function di(t,e,r,n){let o=n?.unsupportedBy??e,i=KN(r);return U(".agentsmesh/hooks.yaml",e,`${t} is not supported by ${o}; only ${i} are projected.`)}var bt=d(()=>{s(U,"createWarning");s(KN,"formatOxfordComma");s(di,"createUnsupportedHookWarning");});function aI(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[U(".agentsmesh/hooks.yaml","amp","Amp has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function cI(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[U(".agentsmesh/permissions.yaml","amp","Amp permissions are managed via amp.permissions in settings.json; canonical permissions are not projected.")]}function lI(t){return t.ignore.length===0?[]:[U(".agentsmesh/ignore","amp","Amp has no dedicated ignore file and relies on .gitignore; canonical ignore patterns are not projected.")]}var mI=d(()=>{bt();s(aI,"lintHooks");s(cI,"lintPermissions");s(lI,"lintIgnore");});function L(t,e){return Y(t).relative(t,e).replace(/\\/g,"/")}async function b(t,e){return N(Y(t).join(t,e)).catch(()=>[])}function uI(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}function JN(t,e,r,n){let o=posix.dirname(e),i=posix.dirname(r);for(;o!==n&&o!==".";)uI(t,o,i),o=posix.dirname(o),i=posix.dirname(i);}function $(t,e,r,n){t.set(e,`${r}/${basename(e,n)}.md`);}function W(t,e,r){if(!e.startsWith(`${r}/`))return;let n=e.slice(r.length+1);if(!n)return;if(!n.includes("/")){if(!n.endsWith(".md")||basename(n)==="SKILL.md")return;let u=basename(n,".md");t.set(e,`${pI}/${u}/SKILL.md`);return}let[o,...i]=n.split("/"),a=i.join("/");if(!o||!a)return;let c=o.startsWith(ii)?ii:o.startsWith(xa)?xa:null;if(c&&a==="SKILL.md"){t.set(e,`${zN}/${o.slice(c.length)}.md`);return}let l=o.startsWith(ai)?ai:o.startsWith(Pa)?Pa:null;if(l&&a==="SKILL.md"){t.set(e,`${VN}/${o.slice(l.length)}.md`);return}let m=`${pI}/${o}`;a==="SKILL.md"&&uI(t,`${r}/${o}`,m);let p=`${m}/${a}`;t.set(e,p),a!=="SKILL.md"&&JN(t,e,p,`${r}/${o}`);}function YN(t){return t.split("/").filter(Boolean)[0]??""}async function XN(){if(Tu!==void 0)return Tu;let{BUILTIN_TARGETS:t}=await Promise.resolve().then(()=>(ut(),dI)),e=new Set;for(let r of t)for(let n of [r.project.rootInstructionPath,r.project.skillDir,...r.project.managedOutputs?.dirs??[],...r.project.managedOutputs?.files??[],...r.detectionPaths,r.globalSupport?.layout.rootInstructionPath,r.globalSupport?.layout.skillDir,...r.globalSupport?.layout.managedOutputs?.dirs??[],...r.globalSupport?.layout.managedOutputs?.files??[],...r.globalSupport?.detectionPaths??[]])if(n!==void 0){let o=YN(n);o.startsWith(".")&&e.add(o);}return Tu=e,e}function Nu(t){return t.split("/").some(e=>e.startsWith("."))}async function ZN(t){let e=[],r=await XN(),n=Y(t);async function o(i){let a=n.join(t,i),c=await readdir(a,{withFileTypes:true}).catch(()=>[]);for(let l of c){let m=i?`${i}/${l.name}`:l.name;if(l.isDirectory()){if(r.has(l.name)||Nu(m))continue;await o(m);continue}if(l.isSymbolicLink()&&await stat(n.join(t,m)).then(p=>p.isDirectory(),()=>false)){if(r.has(l.name)||Nu(m))continue;await o(m);continue}(l.name==="AGENTS.md"||l.name==="AGENTS.override.md")&&e.push(n.join(t,m));}}return s(o,"walk"),await o(""),e}async function Ol(t,e){let r=await ZN(e);for(let n of r){let o=L(e,n),i=o.endsWith("/AGENTS.md")&&o!=="AGENTS.md"&&!o.endsWith("/AGENTS.override.md"),a=o.endsWith("/AGENTS.override.md")&&o!=="AGENTS.override.md";if(!i&&!a)continue;let c=posix.dirname(o);if(Nu(c))continue;let l=c.replace(/\//g,"-");t.set(o,`${HN}/${l}.md`);}}var HN,zN,VN,pI,Tu,Nt=d(()=>{Wt();A();ne();dt();HN=".agentsmesh/rules",zN=".agentsmesh/commands",VN=".agentsmesh/agents",pI=".agentsmesh/skills";s(L,"rel");s(b,"listFiles");s(uI,"addDirectoryMapping");s(JN,"addAncestorMappings");s($,"addSimpleFileMapping");s(W,"addSkillLikeMapping");s(YN,"firstPathSegment");s(XN,"targetRootSegments");s(Nu,"hasHiddenSegment");s(ZN,"listScopedAgentsFiles");s(Ol,"addScopedAgentsMappings");});var P,rt,ft,At=d(()=>{P=".agentsmesh/rules",rt=".agentsmesh/commands",ft=".agentsmesh/agents";});async function Fu(t,e,r="project"){if(r==="global"){t.set(un,`${P}/_root.md`);for(let n of await b(e,Ae))W(t,L(e,n),Ae);t.set(dn,".agentsmesh/mcp.json");return}t.set(be,`${P}/_root.md`);for(let n of await b(e,Bt))W(t,L(e,n),Bt);t.set(br,".agentsmesh/mcp.json");}var fI=d(()=>{Nt();Jo();At();s(Fu,"buildAmpImportPaths");});var Yo,wl,Ar,er,Ma,rr,hn,$a,xr,yn,Ga,fi,vu,Xo,El,gI,Zo=d(()=>{Yo="antigravity",wl=".agents",Ar=`${wl}/rules`,er=`${Ar}/general.md`,Ma=`${Ar}/_root.md`,rr=`${wl}/skills`,hn=`${wl}/workflows`,$a=`${wl}/antigravity/mcp_config.json`,xr=".gemini/antigravity/GEMINI.md",yn=".gemini/antigravity/skills",Ga=".gemini/antigravity/workflows",fi=".gemini/antigravity/mcp_config.json",vu=".agentsmesh/rules/_root.md",Xo=".agentsmesh/rules",El=".agentsmesh/commands",gI=".agentsmesh/mcp.json";});async function Mu(t,e,r="project"){if(r==="global"){t.set(xr,`${P}/_root.md`);for(let n of await b(e,yn))W(t,L(e,n),yn);t.set(fi,".agentsmesh/mcp.json");return}t.set(er,`${P}/_root.md`),t.set(Ma,`${P}/_root.md`);for(let n of await b(e,Ar)){let o=L(e,n);o===er||o===Ma||$(t,o,P,".md");}for(let n of await b(e,hn))$(t,L(e,n),rt,".md");for(let n of await b(e,rr))W(t,L(e,n),rr);}var hI=d(()=>{Nt();Zo();At();s(Mu,"buildAntigravityImportPaths");});var yI,to,_I,ja,Ua,Ka,Wa,Ba,_n,$u,Ha,gi,za,Va,Ll,bl,Gu,Ja,ju,qo,II,In=d(()=>{yI="claude-code",to=".claude/CLAUDE.md",_I="CLAUDE.md",ja=".claude/rules",Ua=".claude/commands",Ka=".claude/agents",Wa=".claude/skills",Ba=".claude/settings.json",_n=".claude/hooks.json",$u=".claude/output-styles",Ha=".claudeignore",gi=".mcp.json",za=".claude.json",Va=".agentsmesh/rules",Ll=".agentsmesh/commands",bl=".agentsmesh/agents",Gu=".agentsmesh/skills",Ja=".agentsmesh/mcp.json",ju=".agentsmesh/permissions.yaml",qo=".agentsmesh/hooks.yaml",II=".agentsmesh/ignore";});async function Uu(t,e,r="project"){if(t.set(".claude/CLAUDE.md",`${P}/_root.md`),t.set(_n,qo),r==="project"&&t.set("CLAUDE.md",`${P}/_root.md`),r==="global")for(let n of await b(e,".agents/skills"))W(t,L(e,n),".agents/skills");for(let n of await b(e,".claude/rules"))$(t,L(e,n),P,".md");for(let n of await b(e,".claude/commands"))$(t,L(e,n),rt,".md");for(let n of await b(e,".claude/agents"))$(t,L(e,n),ft,".md");for(let n of await b(e,".claude/skills"))W(t,L(e,n),".claude/skills");}var CI=d(()=>{Nt();In();At();s(Uu,"buildClaudeCodeImportPaths");});var eo,Cn,Qo,Sn,SI,Gt,Pr,ro,ts,es,rs,ns,Ku,no,Al,Wu,Bu,Hu,RI,Pe=d(()=>{eo="cline",Cn=".clinerules",Qo=".clineignore",Sn=".cline/cline_mcp_settings.json",SI=".cline/mcp_settings.json",Gt=".cline/skills",Pr=".clinerules/workflows",ro="AGENTS.md",ts=".clinerules/hooks",es="Documents/Cline/Rules",rs="Documents/Cline/Workflows",ns="Documents/Cline/Hooks",Ku=".agentsmesh/hooks.yaml",no=".agentsmesh/rules",Al=".agentsmesh/commands",Wu=".agentsmesh/ignore",Bu=".agentsmesh/mcp.json",Hu=".agentsmesh/agents",RI=".agentsmesh/skills";});async function zu(t,e,r="project"){if(r==="global"){for(let n of await b(e,es))$(t,L(e,n),P,".md");for(let n of await b(e,rs))$(t,L(e,n),rt,".md");for(let n of await b(e,Gt))W(t,L(e,n),Gt);t.set(Sn,".agentsmesh/mcp.json");return}t.set(".clinerules/_root.md",`${P}/_root.md`);for(let n of await b(e,".clinerules")){let o=L(e,n);!o.endsWith(".md")||o.includes("/workflows/")||basename(o)==="_root.md"||$(t,o,P,".md");}for(let n of await b(e,".clinerules/workflows"))$(t,L(e,n),rt,".md");for(let n of await b(e,".cline/skills"))W(t,L(e,n),".cline/skills");}var kI=d(()=>{Nt();Pe();At();s(zu,"buildClineImportPaths");});async function Vu(t,e,r="project"){if(r==="global"?(t.set(".codex/AGENTS.md",`${P}/_root.md`),t.set(".codex/AGENTS.override.md",`${P}/_root.md`)):(t.set("AGENTS.md",`${P}/_root.md`),t.set("codex.md",`${P}/_root.md`),await Ol(t,e)),r==="project")for(let n of await b(e,".codex/instructions"))$(t,L(e,n),P,".md");for(let n of await b(e,".codex/rules")){let o=L(e,n);o.endsWith(".rules")?$(t,o,P,".rules"):o.endsWith(".md")&&$(t,o,P,".md");}for(let n of await b(e,".codex/agents"))$(t,L(e,n),ft,".toml");for(let n of await b(e,".agents/skills"))W(t,L(e,n),".agents/skills");}var OI=d(()=>{Nt();At();s(Vu,"buildCodexCliImportPaths");});var hi,nr,Tr,Ju,xl,Rn,Yu,de,yi,Ya,Pl,Tl,Xu,Dr=d(()=>{hi="continue",nr=".continue/rules",Tr=".continue/prompts",Ju=".continue/mcpServers",xl=`${Ju}/agentsmesh.json`,Rn=`${nr}/general.md`,Yu=`${nr}/_root.md`,de=".continue/skills",yi=".continue/AGENTS.md",Ya=".continue/config.yaml",Pl=".agentsmesh/rules",Tl=".agentsmesh/commands",Xu=".agentsmesh/mcp.json";});async function Zu(t,e,r="project"){t.set(Rn,`${P}/_root.md`),t.set(Yu,`${P}/_root.md`);for(let n of await b(e,".continue/rules")){let o=L(e,n);o===Rn||o===Yu||$(t,o,P,".md");}for(let n of await b(e,".continue/prompts"))t.set(L(e,n),`${rt}/${basename(n,".md")}.md`);for(let n of await b(e,".continue/skills"))W(t,L(e,n),".continue/skills");if(r==="global")for(let n of await b(e,".agents/skills"))W(t,L(e,n),".agents/skills");}var wI=d(()=>{Nt();Dr();At();s(Zu,"buildContinueImportPaths");});function tF(t,e){if(e.endsWith(".instructions.md")){t.set(e,`${P}/${basename(e,".instructions.md")}.md`);return}$(t,e,P,".md");}async function qu(t,e){t.set(".github/copilot-instructions.md",`${P}/_root.md`);for(let r of await b(e,".github/copilot"))t.set(L(e,r),`${P}/${basename(r,".instructions.md")}.md`);for(let r of await b(e,".github/instructions"))tF(t,L(e,r));for(let r of await b(e,".github/prompts"))t.set(L(e,r),`${rt}/${basename(r,".prompt.md")}.md`);for(let r of await b(e,".github/agents"))t.set(L(e,r),`${ft}/${basename(r,".agent.md")}.md`);for(let r of await b(e,".github/skills"))W(t,L(e,r),".github/skills");}var EI=d(()=>{Nt();At();s(tF,"addCopilotInstructionMapping");s(qu,"buildCopilotImportPaths");});var LI,oo,bI,Te,kn,De,_i,Nr,Fr,vr,Nl,or,Qu,eF,Ii,sr,Xa,so,io,Mr,ao,co,AI,Ci,td,Za,ed,Rt=d(()=>{LI="cursor",oo="AGENTS.md",bI=".cursorrules",Te=".cursor/rules",kn=`${Te}/general.mdc`,De=".cursor/commands",_i=".cursor/agents",Nr=".cursor/skills",Fr=".cursor/mcp.json",vr=".cursor/hooks.json",Nl=".cursor/settings.json",or=".cursorignore",Qu=".cursorindexingignore",eF=".agentsmesh-exports/cursor",Ii=`${eF}/user-rules.md`,sr=".cursor/AGENTS.md",Xa=Fr,so=Nr,io=_i,Mr=".agentsmesh/rules",ao=".agentsmesh/commands",co=".agentsmesh/agents",AI=".agentsmesh/skills",Ci=".agentsmesh/mcp.json",td=".agentsmesh/permissions.yaml",Za=".agentsmesh/hooks.yaml",ed=".agentsmesh/ignore";});async function rd(t,e,r="project"){if(r==="global"){t.set(Fr,".agentsmesh/mcp.json"),t.set(".cursor/AGENTS.md",`${P}/_root.md`);for(let n of await b(e,".cursor/rules"))$(t,L(e,n),P,".mdc");for(let n of await b(e,".cursor/commands"))$(t,L(e,n),rt,".md");for(let n of await b(e,".cursor/agents"))$(t,L(e,n),ft,".md");for(let n of await b(e,".cursor/skills"))W(t,L(e,n),".cursor/skills");return}t.set("AGENTS.md",`${P}/_root.md`);for(let n of await b(e,".cursor/rules"))$(t,L(e,n),P,".mdc");for(let n of await b(e,".cursor/commands"))$(t,L(e,n),rt,".md");for(let n of await b(e,".cursor/agents"))$(t,L(e,n),ft,".md");for(let n of await b(e,".cursor/skills"))W(t,L(e,n),".cursor/skills");}var xI=d(()=>{Nt();Rt();At();s(rd,"buildCursorImportPaths");});async function nd(t,e){for(let r of await b(e,".gemini/rules"))$(t,L(e,r),P,".md");for(let r of await b(e,".gemini/commands")){let n=L(e,r);if(!n.endsWith(".toml")&&!n.endsWith(".md"))continue;let o=n.replace(/\.(toml|md)$/i,""),i=".gemini/commands/",l=(o.startsWith(i)?o.slice(i.length):o).split("/").filter(Boolean).join(":");t.set(n,`${rt}/${l}.md`);}for(let r of await b(e,".gemini/agents"))$(t,L(e,r),ft,".md");for(let r of await b(e,".gemini/skills"))W(t,L(e,r),".gemini/skills");}var PI=d(()=>{Nt();At();s(nd,"buildGeminiCliImportPaths");});var $r,Ne,Zt,On,TI,wn,os,Fe,DI,NI,Si=d(()=>{$r="goose",Ne=".goosehints",Zt=".agents/skills",On=".gooseignore",TI=".config/goose",wn=`${TI}/.goosehints`,os=`${TI}/.gooseignore`,Fe=".agents/skills",DI=".agentsmesh/rules",NI=".agentsmesh/ignore";});async function od(t,e,r="project"){if(r==="global"){t.set(wn,`${P}/_root.md`);for(let n of await b(e,Fe))W(t,L(e,n),Fe);t.set(os,".agentsmesh/ignore");return}t.set(Ne,`${P}/_root.md`);for(let n of await b(e,Zt))W(t,L(e,n),Zt);t.set(On,".agentsmesh/ignore");}var FI=d(()=>{Nt();Si();At();s(od,"buildGooseImportPaths");});var ss,lo,Fl,vI,Gr,MI,rF,qa,is,Qa,Ri,ki,tc,ec,rc,nc,oc,nF,vl,as,$I,sd,Ml,GI,jI,UI,KI,Oi=d(()=>{ss="junie",lo=".junie",Fl=`${lo}/guidelines.md`,vI=`${lo}/ci-guidelines.md`,Gr=`${lo}/AGENTS.md`,MI="AGENTS.md",rF=`${lo}/mcp`,qa=`${rF}/mcp.json`,is=`${lo}/skills`,Qa=`${lo}/rules`,Ri=`${lo}/commands`,ki=`${lo}/agents`,tc=".aiignore",ec=".junie",rc=`${ec}/skills`,nc=`${ec}/agents`,oc=`${ec}/commands`,nF=`${ec}/mcp`,vl=`${nF}/mcp.json`,as=`${ec}/AGENTS.md`,$I=".agents/skills",sd=".agentsmesh/rules/_root.md",Ml=".agentsmesh/rules",GI=".agentsmesh/commands",jI=".agentsmesh/agents",UI=".agentsmesh/mcp.json",KI=".agentsmesh/ignore";});async function id(t,e){t.set(Fl,`${P}/_root.md`),t.set(Gr,`${P}/_root.md`),t.set("AGENTS.md",`${P}/_root.md`);for(let r of await b(e,".junie/rules"))$(t,L(e,r),P,".md");for(let r of await b(e,".junie/commands"))$(t,L(e,r),rt,".md");for(let r of await b(e,".junie/agents"))$(t,L(e,r),ft,".md");for(let r of await b(e,".junie/skills"))W(t,L(e,r),".junie/skills");}var WI=d(()=>{Nt();Oi();At();s(id,"buildJunieImportPaths");});var qt,sc,jr,En,Ln,bn,ir,mo,wi,$l,cs,Ei,ls,ic,Gl,Li,po,ms,ps,us,uo,bi,jl,BI,fo,Ai,ds,HI,zI,fs=d(()=>{qt="kilo-code",sc=".kilo",jr="AGENTS.md",En=`${sc}/rules`,Ln=`${sc}/commands`,bn=`${sc}/agents`,ir=`${sc}/skills`,mo=`${sc}/mcp.json`,wi=".kilocodeignore",$l=".kilocode",cs=`${$l}/rules`,Ei=`${$l}/workflows`,ls=`${$l}/skills`,ic=`${$l}/mcp.json`,Gl=".kilocodemodes",Li=".kilo",po=`${Li}/AGENTS.md`,ms=`${Li}/rules`,ps=`${Li}/commands`,us=`${Li}/agents`,uo=`${Li}/skills`,bi=`${Li}/mcp.json`,jl=".kilocodeignore",BI=".agents/skills",fo=".agentsmesh/rules",Ai=".agentsmesh/commands",ds=".agentsmesh/agents",HI=".agentsmesh/mcp.json",zI=".agentsmesh/ignore";});async function ad(t,e,r="project"){if(r==="global"){t.set(po,`${P}/_root.md`);for(let n of await b(e,ms))$(t,L(e,n),P,".md");for(let n of await b(e,ps))$(t,L(e,n),rt,".md");for(let n of await b(e,us))$(t,L(e,n),ft,".md");for(let n of await b(e,uo))W(t,L(e,n),uo);t.set(bi,".agentsmesh/mcp.json");return}t.set(jr,`${P}/_root.md`);for(let n of await b(e,En))$(t,L(e,n),P,".md");for(let n of await b(e,Ln))$(t,L(e,n),rt,".md");for(let n of await b(e,bn))$(t,L(e,n),ft,".md");for(let n of await b(e,ir))W(t,L(e,n),ir);t.set(mo,".agentsmesh/mcp.json");for(let n of await b(e,cs)){let o=L(e,n);if(basename(o)==="00-root.md"){t.set(o,`${P}/_root.md`);continue}$(t,o,P,".md");}for(let n of await b(e,Ei))$(t,L(e,n),rt,".md");for(let n of await b(e,ls))W(t,L(e,n),ls);t.set(ic,".agentsmesh/mcp.json");}var VI=d(()=>{Nt();fs();At();s(ad,"buildKiloCodeImportPaths");});var fe,ar,ac,cr,Qt,lr,go,JI,xi,Pi,gs,mr,ho,hs,cc,lc,YI,cd,ld,XI,ZI,md,qI,Ti=d(()=>{fe="kiro",ar="AGENTS.md",ac=".kiro",cr=`${ac}/steering`,Qt=`${ac}/skills`,lr=`${ac}/agents`,go=`${ac}/hooks`,JI=`${ac}/settings`,xi=`${JI}/mcp.json`,Pi=".kiroignore",gs=".kiro/steering",mr=".kiro/steering/AGENTS.md",ho=".kiro/skills",hs=".kiro/agents",cc=".kiro/settings/mcp.json",lc=".kiro/settings/kiroignore",YI=".agents/skills",cd=".agentsmesh/rules/_root.md",ld=".agentsmesh/rules",XI=".agentsmesh/agents",ZI=".agentsmesh/mcp.json",md=".agentsmesh/hooks.yaml",qI=".agentsmesh/ignore";});async function pd(t,e,r="project"){if(r==="global"){t.set(mr,`${P}/_root.md`);for(let n of await b(e,gs)){let o=L(e,n);o!==mr&&$(t,o,P,".md");}for(let n of await b(e,ho))W(t,L(e,n),ho);for(let n of await b(e,hs))$(t,L(e,n),ft,".md");return}t.set(ar,`${P}/_root.md`);for(let n of await b(e,cr))$(t,L(e,n),P,".md");for(let n of await b(e,Qt))W(t,L(e,n),Qt);for(let n of await b(e,lr))$(t,L(e,n),ft,".md");}var QI=d(()=>{Nt();Ti();At();s(pd,"buildKiroImportPaths");});var pr,Ul,Ur,An,xn,Pn,ur,Kr,Di,yo,ys,_s,Is,_o,Io,tC,mc,Kl,Wl,ud,Cs=d(()=>{pr="opencode",Ul=".opencode",Ur="AGENTS.md",An=`${Ul}/rules`,xn=`${Ul}/commands`,Pn=`${Ul}/agents`,ur=`${Ul}/skills`,Kr="opencode.json",Di=".config/opencode",yo=`${Di}/AGENTS.md`,ys=`${Di}/rules`,_s=`${Di}/commands`,Is=`${Di}/agents`,_o=`${Di}/skills`,Io=`${Di}/opencode.json`,tC=".agents/skills",mc=".agentsmesh/rules",Kl=".agentsmesh/commands",Wl=".agentsmesh/agents",ud=".agentsmesh/mcp.json";});async function dd(t,e,r="project"){if(r==="global"){t.set(yo,`${P}/_root.md`);for(let n of await b(e,ys))$(t,L(e,n),P,".md");for(let n of await b(e,_s))$(t,L(e,n),rt,".md");for(let n of await b(e,Is))$(t,L(e,n),ft,".md");for(let n of await b(e,_o))W(t,L(e,n),_o);t.set(Io,".agentsmesh/mcp.json");return}t.set(Ur,`${P}/_root.md`);for(let n of await b(e,An))$(t,L(e,n),P,".md");for(let n of await b(e,xn))$(t,L(e,n),rt,".md");for(let n of await b(e,Pn))$(t,L(e,n),ft,".md");for(let n of await b(e,ur))W(t,L(e,n),ur);t.set(Kr,".agentsmesh/mcp.json");}var eC=d(()=>{Nt();Cs();At();s(dd,"buildOpencodeImportPaths");});var Co,Ss,dr,pc,Tn,Dn,Wr,uc,dc,Ni,fc,Bl,So,Ro,Nn,Rs,gc,ko,rC,ks,Hl,nC,oC,Os=d(()=>{Co="roo-code",Ss=".roo",dr=`${Ss}/rules/00-root.md`,pc=".roorules",Tn=`${Ss}/rules`,Dn=`${Ss}/commands`,Wr=`${Ss}/skills`,uc=`${Ss}/mcp.json`,dc=".rooignore",Ni=".roomodes",fc="settings/custom_modes.yaml",Bl=".roo",So=`${Bl}/rules`,Ro=`${Bl}/commands`,Nn=`${Bl}/skills`,Rs="mcp_settings.json",gc=".rooignore",ko=`${Bl}/AGENTS.md`,rC=".agents/skills",ks=".agentsmesh/rules",Hl=".agentsmesh/commands",nC=".agentsmesh/mcp.json",oC=".agentsmesh/ignore";});async function fd(t,e,r="project"){if(r==="global"){t.set(ko,`${P}/_root.md`);for(let n of await b(e,So))$(t,L(e,n),P,".md");for(let n of await b(e,Ro))$(t,L(e,n),rt,".md");for(let n of await b(e,Nn))W(t,L(e,n),Nn);t.set(Rs,".agentsmesh/mcp.json");return}t.set(dr,`${P}/_root.md`),t.set(pc,`${P}/_root.md`);for(let n of await b(e,Tn)){let o=L(e,n);o!==dr&&$(t,o,P,".md");}for(let n of await b(e,".roo")){let o=L(e,n);/^\.roo\/rules-[^/]+\/.+\.md$/.test(o)&&$(t,o,P,".md");}for(let n of await b(e,Dn))$(t,L(e,n),rt,".md");for(let n of await b(e,Wr))W(t,L(e,n),Wr);}var sC=d(()=>{Nt();Os();At();s(fd,"buildRooCodeImportPaths");});var Br,fr,gd,zt,Oo,se,iC,Fi=d(()=>{Br="warp",fr="AGENTS.md",gd="WARP.md",zt=".warp/skills",Oo=".mcp.json",se=".warp/skills",iC=".agentsmesh/rules";});async function hd(t,e,r="project"){if(r==="global"){for(let n of await b(e,se))W(t,L(e,n),se);return}t.set(fr,`${P}/_root.md`);for(let n of await b(e,zt))W(t,L(e,n),zt);t.set(Oo,".agentsmesh/mcp.json");}var aC=d(()=>{Nt();Fi();At();s(hd,"buildWarpImportPaths");});async function yd(t,e){t.set("AGENTS.md",`${P}/_root.md`),t.set(".windsurfrules",`${P}/_root.md`),await Ol(t,e);for(let r of await b(e,".windsurf/rules"))$(t,L(e,r),P,".md");for(let r of await b(e,".windsurf/workflows"))$(t,L(e,r),rt,".md");for(let r of await b(e,".windsurf/skills"))W(t,L(e,r),".windsurf/skills");}var cC=d(()=>{Nt();At();s(yd,"buildWindsurfImportPaths");});var gr,Hr,sF,zr,lC,ws=d(()=>{gr=".rules",Hr=".zed/settings.json",sF=".config/zed",zr=`${sF}/settings.json`,lC=".agentsmesh/rules";});async function _d(t,e,r="project"){if(r==="global"){t.set(zr,".agentsmesh/mcp.json");return}t.set(gr,`${P}/_root.md`),t.set(Hr,".agentsmesh/mcp.json");}var mC=d(()=>{ws();At();s(_d,"buildZedImportPaths");});var pC=d(()=>{fI();hI();CI();kI();OI();wI();EI();xI();PI();FI();WI();VI();QI();eC();sC();aC();cC();mC();});var xt=d(()=>{pC();});function lF(t,e){if(t===null)return e;let r;try{let i=JSON.parse(t);r=i!==null&&typeof i=="object"&&!Array.isArray(i)?i:{};}catch{r={};}let n=JSON.parse(e);if(n===null||typeof n!="object"||Array.isArray(n))return t;let o=n;return o["amp.mcpServers"]!==void 0&&(r["amp.mcpServers"]=o["amp.mcpServers"]),JSON.stringify(r,null,2)}var iF,aF,cF,uC,kl,Pu=d(()=>{ne();dt();K_();ue();tI();iI();mI();xt();Jo();iF={name:"amp",primaryRootInstructionPath:be,generateRules:$_,generateCommands:j_,generateAgents:U_,generateSkills:G_,importFrom:Q_},aF={rootInstructionPath:be,skillDir:Bt,managedOutputs:{dirs:[Bt],files:[be,br]},paths:{rulePath(t){return be},commandPath(t){return `${Bt}/${st(t)}/SKILL.md`},agentPath(t){return `${Bt}/${V(t)}/SKILL.md`}}},cF={rootInstructionPath:un,skillDir:Ae,managedOutputs:{dirs:[Ae],files:[un,dn]},rewriteGeneratedPath(t){return t===be?un:t===br?dn:t.startsWith(`${Bt}/`)?t.replace(`${Bt}/`,`${Ae}/`):t},mirrorGlobalPath(t,e){return at(t,Ae,e)},paths:{rulePath(t){return un},commandPath(t){return `${Ae}/${st(t)}/SKILL.md`},agentPath(t){return `${Ae}/${V(t)}/SKILL.md`}}},uC={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"};s(lF,"mergeAmpSettings");kl={id:"amp",generators:iF,capabilities:uC,emptyImportMessage:"No Amp config found (AGENTS.md, .agents/skills, or .amp/settings.json).",lintRules:sI,lint:{hooks:aI,permissions:cI,ignore:lI},supportsConversion:{commands:true,agents:true},project:aF,globalSupport:{capabilities:uC,detectionPaths:[un,dn],layout:cF},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[be],global:[un]},canonicalDir:M_,canonicalRootFilename:"_root.md",markAsRoot:true}},emitScopedSettings(t,e){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:br,content:JSON.stringify({"amp.mcpServers":t.mcp.mcpServers},null,2)}]},mergeGeneratedOutputContent(t,e,r,n){return n===br||n===dn?lF(t,r):null},sharedArtifacts:{".agents/skills/":"consumer"},buildImportPaths:Fu,detectionPaths:[be,br]};});function dC(t){let e=t.rules.find(n=>n.root);if(!e)return [];let r=[{path:er,content:e.body.trim()||""}];for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("antigravity"))continue;let o=basename(n.source,".md");r.push({path:`${Ar}/${o}.md`,content:n.body.trim()||""});}return r}function fC(t){return t.commands.map(e=>{let r=e.description.trim(),n=e.body.trim(),o=r&&n&&!n.startsWith(r)?`${r}
|
|
50
|
+
${BN}
|
|
51
|
+
${Ga}`;s(Fu,"normalizeWhitespace");rI=[QN,qN,ZN,XN,YN,JN,VN,zN,HN];s(nI,"appendAgentsmeshRootInstructionParagraph");s(oI,"stripAgentsmeshRootInstructionParagraph");});function te(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}async function hi(t){let e=await y(t);return e?E(e).frontmatter:{}}function jt(t,e){return typeof t[e]=="string"?t[e]:void 0}function $u(t){let e=t.hooks;return e&&typeof e=="object"&&!Array.isArray(e)?e:void 0}function tF(t){return Object.fromEntries(Object.entries(t).filter(([,e])=>e!==void 0))}function eF(t,e){let r=basename(t,".md")==="_root",n={...e};return delete n.root,{root:r,...n}}async function G(t,e,r){let n=await hi(t),o=basename(t,".md")==="_root"?oI(r):r.trim(),i=eF(t,tF({...n,...e})),a={root:i.root===true,description:typeof i.description=="string"?i.description:""};a.root===false&&(a.globs=te(i.globs));for(let[c,l]of Object.entries(i))c==="root"||c==="description"||c==="globs"||l===void 0||(a[c]=l);return N(a,o||"")}var Gu=d(()=>{b();v();Mu();s(te,"toStringArray");s(hi,"readExistingFrontmatter");s(jt,"readString");s($u,"readHooks");s(tF,"pruneUndefined");s(eF,"serializeCanonicalRuleFrontmatter");s(G,"serializeImportedRuleWithFallback");});async function it(t,e,r){let n=await hi(t),o=(()=>{let c=te(n.allowedTools);return c.length>0?c:te(n["allowed-tools"])})(),i=e.hasDescription?e.description??"":typeof n.description=="string"?n.description:"",a=e.hasAllowedTools?e.allowedTools??[]:o;return N({description:i,"allowed-tools":a},r.trim()||"")}async function Tr(t,e,r){let n=await hi(t),o=basename(dirname(t)),i=jt(e,"name")??jt(n,"name")??o,a=jt(e,"description")??jt(n,"description")??"";return N({name:i,description:a},r.trim()||"")}async function Pt(t,e,r){let n=await hi(t),o=Object.prototype.hasOwnProperty.call(e,"tools")?te(e.tools):(()=>{let R=te(n.tools);return R.length>0?R:[]})(),i=Object.prototype.hasOwnProperty.call(e,"disallowedTools")?te(e.disallowedTools):Object.prototype.hasOwnProperty.call(e,"disallowed-tools")?te(e["disallowed-tools"]):te(n.disallowedTools),a=Object.prototype.hasOwnProperty.call(e,"mcpServers")?te(e.mcpServers):Object.prototype.hasOwnProperty.call(e,"mcp-servers")?te(e["mcp-servers"]):te(n.mcpServers),c=Object.prototype.hasOwnProperty.call(e,"skills")?te(e.skills):te(n.skills),l=e.maxTurns??e["max-turns"]??n.maxTurns,m=typeof l=="number"?l:Number(l??0),p=$u(e)??$u(n),u={name:jt(e,"name")??jt(n,"name")??basename(t,".md"),description:jt(e,"description")??jt(n,"description")??"",tools:o};i.length>0&&(u.disallowedTools=i);let f=jt(e,"model")??jt(n,"model");f&&(u.model=f);let g=jt(e,"permissionMode")??jt(e,"permission-mode")??jt(n,"permissionMode")??jt(n,"permission-mode");g&&(u.permissionMode=g),Number.isInteger(m)&&m>0&&(u.maxTurns=m),a.length>0&&(u.mcpServers=a),p&&Object.keys(p).length>0&&(u.hooks=p),c.length>0&&(u.skills=c);let h=jt(e,"memory")??jt(n,"memory");return h&&(u.memory=h),N(u,r.trim()||"")}var aI=d(()=>{v();Gu();s(it,"serializeImportedCommandWithFallback");s(Tr,"serializeImportedSkillWithFallback");s(Pt,"serializeImportedAgentWithFallback");});var nt=d(()=>{Gu();aI();});function xl(t){let e=t.split("/").filter(Boolean);return e.length===0||e.some(n=>n.startsWith("."))?false:!e.join("/").startsWith("tests/e2e/fixtures/")}async function Pe(t){await rm$1(t,{recursive:true,force:true});}var yi=d(()=>{s(xl,"shouldImportScopedAgentsRule");s(Pe,"removePathIfExists");});function kt(t,e){let r=[];for(let n of t.skills){let o={name:n.name,description:n.description||void 0};o.description===void 0&&delete o.description,r.push({path:`${e}/${n.name}/SKILL.md`,content:N(o,n.body.trim()||"")});for(let i of n.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");r.push({path:`${e}/${n.name}/${a}`,content:i.content});}}return r}async function Ct(t,e,r,n,o){let i=await readdir(join(t,e),{encoding:"utf8",withFileTypes:true}).catch(()=>null);if(i!==null)for(let a of i){if(!a.isDirectory())continue;let c=join(t,e,a.name),l=join(c,"SKILL.md"),m=await y(l);if(m===null)continue;let p=join(t,ja,a.name),u=join(p,"SKILL.md"),{frontmatter:f,body:g}=E(o(m,l,u)),h=kl(f,a.name);if(h){await Pe(join(t,ja,a.name));let k=join(t,cI);await O(k);let T=join(k,`${h.name}.md`);await C(T,wl(h,o(g,l,T))),n.push({fromTool:r,fromPath:l,toPath:`${cI}/${h.name}.md`,feature:"commands"});continue}let R=Pr(f,a.name);if(R){await Pe(join(t,ja,a.name));let k=join(t,lI);await O(k);let T=join(k,`${R.name}.md`);await C(T,Ae(R,o(g,l,T))),n.push({fromTool:r,fromPath:l,toPath:`${lI}/${R.name}.md`,feature:"agents"});continue}let S=await Tr(u,{...f,name:a.name},g);await O(p),await C(u,S),n.push({fromTool:r,fromPath:l,toPath:`${ja}/${a.name}/SKILL.md`,feature:"skills"});let _=await D(c);for(let k of _){if(k===l)continue;let T=relative(c,k).replace(/\\/g,"/"),P=await y(k);if(P===null)continue;let A=join(p,T);await O(dirname(A)),await C(A,o(P,k,A)),n.push({fromTool:r,fromPath:k,toPath:`${ja}/${a.name}/${T}`,feature:"skills"});}}}var ja,cI,lI,Rt=d(()=>{b();v();nt();ht();ae();yi();ja=".agentsmesh/skills",cI=".agentsmesh/commands",lI=".agentsmesh/agents";s(kt,"generateEmbeddedSkills");s(Ct,"importEmbeddedSkills");});var De,Jt,Dr,ju,_n,Ne,In,mI,es=d(()=>{De="AGENTS.md",Jt=".agents/skills",Dr=".amp/settings.json",ju=".config/amp",_n=`${ju}/AGENTS.md`,Ne=`${ju}/skills`,In=`${ju}/settings.json`,mI=".agentsmesh/rules";});function pI(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes("amp")),n=e?.body.trim()??"",o=xt(n,r);return o?[{path:De,content:o}]:[]}function uI(t){return kt(t,Jt)}function dI(t){return t.commands.map(e=>({path:`${Jt}/${at(e.name)}/SKILL.md`,content:xr(e)}))}function fI(t){return t.agents.map(e=>({path:`${Jt}/${z(e.name)}/SKILL.md`,content:ce(e)}))}var gI=d(()=>{Rt();xe();ht();ae();es();s(pI,"generateRules");s(uI,"generateSkills");s(dI,"generateCommands");s(fI,"generateAgents");});function mt(t,e,r){return t.startsWith(`${e}/`)&&!r.includes("codex-cli")?`.agents/skills/${t.slice(e.length+1)}`:null}var he=d(()=>{s(mt,"mirrorSkillsToAgents");});async function Yt(t,e,r){let n=join(t,e),i={...await lF(n),...r};await O(dirname(n)),await C(n,JSON.stringify({mcpServers:i},null,2));}async function lF(t){let e=await y(t);if(e===null)return {};let r;try{r=JSON.parse(e);}catch{return {}}if(!r||typeof r!="object"||Array.isArray(r))return {};let n=r.mcpServers;if(!n||typeof n!="object"||Array.isArray(n))return {};let o={};for(let[i,a]of Object.entries(n))!a||typeof a!="object"||Array.isArray(a)||(o[i]=a);return o}var Sn=d(()=>{b();s(Yt,"writeMcpWithMerge");s(lF,"readExistingServers");});function Cn(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):typeof t=="string"?t?[t]:[]:[]}function Fe(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function _i(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"):[]}function Ii(t){return !t||typeof t!="object"||Array.isArray(t)?{}:Object.fromEntries(Object.entries(t).filter(e=>typeof e[1]=="string"))}var nr=d(()=>{s(Cn,"toGlobsArray");s(Fe,"toToolsArray");s(_i,"toStringArray");s(Ii,"toStringRecord");});function uF(t,e){return e.some(r=>t.endsWith(r))}async function dt(t){let r=(await D(t.srcDir)).filter(o=>uF(o,t.extensions)),n=[];for(let o of r){let i=await y(o);if(!i)continue;let a=relative(t.srcDir,o).replace(/\\/g,"/"),c=await t.mapEntry({srcPath:o,relativePath:a,content:i,normalizeTo:s((l,m=i)=>t.normalize(m,o,l),"normalizeTo")});c&&(await O(dirname(c.destPath)),await C(c.destPath,c.content),n.push({fromTool:t.fromTool,fromPath:o,toPath:c.toPath,feature:c.feature}));}return n}var or=d(()=>{b();s(uF,"matchesExtension");s(dt,"importFileDirectory");});function hI(t){return typeof t=="string"?t:void 0}function dF(t){for(let e of Object.keys(t))t[e]===void 0&&delete t[e];return t}function Wu(t,e){return e?e(t):t}function fF(t){return async e=>{let r=join(e.destDir,e.relativePath),{frontmatter:n,body:o}=E(e.normalizeTo(r)),i=Wu(n,t.frontmatterRemap),a=dF({root:false,description:hI(i.description),globs:Array.isArray(i.globs)?i.globs:void 0,...i});return {destPath:r,toPath:`${t.canonicalDir}/${e.relativePath}`,content:await G(r,a,o)}}}function gF(t){return async e=>{let r=join(e.destDir,e.relativePath),{frontmatter:n,body:o}=E(e.normalizeTo(r)),i=Wu(n,t.frontmatterRemap),a=await it(r,{hasDescription:true,description:hI(i.description),hasAllowedTools:true,allowedTools:_i(i["allowed-tools"])},o);return {destPath:r,toPath:`${t.canonicalDir}/${e.relativePath}`,content:a}}}function hF(t){return async e=>{let r=join(e.destDir,e.relativePath),{frontmatter:n,body:o}=E(e.normalizeTo(r)),i=Wu(n,t.frontmatterRemap);return {destPath:r,toPath:`${t.canonicalDir}/${e.relativePath}`,content:await Pt(r,i,o)}}}function yI(t){if(t.map)return t.map;switch(t.preset){case "rule":return fF(t);case "command":return gF(t);case "agent":return hF(t);default:throw new Error(`ImportFeatureSpec for ${t.feature} (mode: ${t.mode}) needs a \`preset\` or \`map\``)}}var _I=d(()=>{v();nt();nr();s(hI,"pickString");s(dF,"pruneUndefined");s(Wu,"applyRemap");s(fF,"ruleMapper");s(gF,"commandMapper");s(hF,"agentMapper");s(yI,"resolveMapper");});function Ku(t,e){return t?t[e]??[]:[]}var II,SI=d(()=>{II=["rules","commands","agents","skills","mcp","hooks","permissions","ignore"];s(Ku,"resolveScopedSources");});async function IF(t,e,r,n,o){if(!t.canonicalRootFilename)throw new Error(`singleFile spec for ${t.feature} must set canonicalRootFilename`);let i=join(r,t.canonicalDir);for(let a of e){let c=join(r,a),l=await y(c);if(l===null)continue;await O(i);let m=join(i,t.canonicalRootFilename),p=s(S=>o(l,c,S),"normalizeTo");if(t.map){let S=await t.map({absolutePath:c,relativePath:a,content:l,destDir:i,normalizeTo:p});if(!S)continue;return await C(S.destPath,S.content),[{fromTool:n,fromPath:c,toPath:S.toPath,feature:t.feature}]}let{frontmatter:u,body:f}=E(p(m)),g=t.frontmatterRemap?t.frontmatterRemap(u):u,h=t.markAsRoot?{...g,root:true}:g,R=await G(m,h,f);return await C(m,R),[{fromTool:n,fromPath:c,toPath:`${t.canonicalDir}/${t.canonicalRootFilename}`,feature:t.feature}]}return []}async function SF(t,e,r,n,o){let i=yI(t),a=join(r,t.canonicalDir),c=[];for(let l of e){let m=join(r,l),p=await dt({srcDir:m,destDir:a,extensions:[...t.extensions??[".md"]],fromTool:n,normalize:o,mapEntry:s(async({srcPath:u,relativePath:f,content:g,normalizeTo:h})=>{let R=await i({absolutePath:u,relativePath:f,content:g,destDir:a,normalizeTo:s(S=>h(S),"normalizeTo")});return R?{destPath:R.destPath,toPath:R.toPath,feature:t.feature,content:R.content}:null},"mapEntry")});c.push(...p);}return c}function RI(t){let e=t.canonicalFilename;return e.includes("/")||e.includes("\\")?e:posix.join(t.canonicalDir,e)}async function CF(t,e,r,n){if(!t.canonicalFilename)throw new Error(`flatFile spec for ${t.feature} must set canonicalFilename`);let o=RI(t);for(let i of e){let a=join(r,i),c=await y(a);if(c===null)continue;let l=join(r,o);return await O(dirname(l)),await C(l,c.trimEnd()),[{fromTool:n,fromPath:a,toPath:o,feature:t.feature}]}return []}function RF(t){let e;try{e=JSON.parse(t);}catch{return {}}if(!e||typeof e!="object")return {};let r=e.mcpServers;if(!r||typeof r!="object"||Array.isArray(r))return {};let n={};for(let[o,i]of Object.entries(r)){if(!i||typeof i!="object"||Array.isArray(i))continue;let a=i,c=typeof a.description=="string"?a.description:void 0;if(typeof a.command=="string"){n[o]={type:typeof a.type=="string"?a.type:"stdio",command:a.command,args:_i(a.args),env:Ii(a.env),description:c};continue}typeof a.url=="string"&&(n[o]={type:typeof a.type=="string"?a.type:"http",url:a.url,headers:Ii(a.headers),env:Ii(a.env),description:c});}return n}async function OF(t,e,r,n){if(!t.canonicalFilename)throw new Error(`mcpJson spec for ${t.feature} must set canonicalFilename`);let o=RI(t);for(let i of e){let a=join(r,i),c=await y(a);if(c===null)continue;let l=RF(c);return Object.keys(l).length===0?[]:(await Yt(r,o,l),[{fromTool:n,fromPath:a,toPath:o,feature:t.feature}])}return []}function CI(t,e,r,n,o){switch(t.mode){case "singleFile":return IF(t,e,r,n,o);case "directory":return SF(t,e,r,n,o);case "flatFile":return CF(t,e,r,n);case "mcpJson":return OF(t,e,r,n)}}async function EF(t,e,r,n,o){let i=Ku(t.source,e),a=Ku(t.fallbacks,e);if(i.length===0&&a.length===0)return [];if(i.length>0){let c=await CI(t,i,r,n,o);if(c.length>0)return c}return a.length>0?CI(t,a,r,n,o):[]}function kF(t,e){let r=t[e];return r?Array.isArray(r)?r:[r]:[]}async function tt(t,e,r,n){let o=t.importer;if(!o)return [];let i=n?.normalize??await H(t.id,e,r),a=[];for(let c of II)for(let l of kF(o,c))a.push(...await EF(l,r,e,t.id,i));return a}var Ut=d(()=>{Ot();b();Sn();v();nr();nt();or();_I();SI();s(IF,"runSingleFile");s(SF,"runDirectory");s(RI,"resolveCanonicalFilePath");s(CF,"runFlatFile");s(RF,"parseMcpJson");s(OF,"runMcpJson");s(CI,"dispatchSpec");s(EF,"runSpec");s(kF,"specsForFeature");s(tt,"runDescriptorImport");});async function EI(t,e,r){let n=await y(join(t,e));if(n===null)return;let o;try{o=JSON.parse(n);}catch{return}if(o===null||typeof o!="object"||Array.isArray(o))return;let i=o,a=i["amp.mcpServers"]??i.mcpServers;if(a==null||typeof a!="object"||Array.isArray(a)||Object.keys(a).length===0)return;let c={};for(let[l,m]of Object.entries(a))!m||typeof m!="object"||Array.isArray(m)||(c[l]=m);Object.keys(c).length!==0&&(await Yt(t,OI,c),r.push({fromTool:"amp",fromPath:e,toPath:OI,feature:"mcp"}));}var OI,kI=d(()=>{b();Sn();es();OI=".agentsmesh/mcp.json";s(EI,"importAmpMcp");});async function wI(t,e={}){let r=e.scope??"project",n=[],o=await H("amp",t,r);return n.push(...await tt(Pl,t,r,{normalize:o})),await Ct(t,r==="global"?Ne:Jt,"amp",n,o),await EI(t,r==="global"?In:Dr,n),n}var LI=d(()=>{Ot();Rt();Ut();kI();es();Bu();s(wI,"importFromAmp");});function LF(t,e){return AI(e).some(n=>bF(t,n))}function bI(t,e){return t.filter(r=>LF(r,e))}function AI(t){let e=t.match(/^(.+)\{([^}]+)\}(.*)$/);if(!e)return [t];let[,r,n,o]=e;if(!n)return [t];let i=n.split(",").map(c=>c.trim()),a=[];for(let c of i)for(let l of AI(r+c+o))a.push(l);return a}function bF(t,e){return AF(e).test(t)}function AF(t){let e=[],r=0;for(;r<t.length;){if(t.startsWith("**",r)){let i=t.slice(r+2);if(i.length===0&&e.length===0)e.push(".*");else if(e.push(i.startsWith("/")?"(?:[^/]+/)*":"(?:/[^/]+)*?"),i.startsWith("/")){r+=3;continue}r+=2;continue}if(t[r]==="*"){e.push("[^/]*"),r+=1;continue}if(t[r]==="?"){e.push("[^/]"),r+=1;continue}if(t[r]==="{"){e.push("(?:"),r+=1;continue}if(t[r]==="}"){e.push(")"),r+=1;continue}if(t[r]===","){e.push("|"),r+=1;continue}".^$+?()[]{}|\\".includes(t[r])?e.push("\\"+t[r]):e.push(t[r]),r+=1;}let n="^"+e.join("")+"$";return new RegExp(n)}var xI=d(()=>{s(LF,"globMatch");s(bI,"globFilter");s(AI,"expandBraces");s(bF,"matchOne");s(AF,"globToRegex");});function q(t,e,r,n={}){let o=[],{rules:i}=t;if(i.length===0)return [];if(i.some(c=>c.root)||o.push({level:"error",file:relative(e,i[0].source),message:"Rules exist but no root rule (_root.md or root: true). Add a root rule."}),n.checkGlobMatches===false)return o;for(let c of i){if(c.globs.length===0)continue;let l=false;for(let m of c.globs)if(bI(r,m).length>0){l=true;break}l||o.push({level:"warning",file:relative(e,c.source),message:`globs "${c.globs.join(", ")}" match 0 files in project`});}return o}var Wt=d(()=>{xI();s(q,"validateRules");});function TI(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:"amp"}))}var DI=d(()=>{Wt();es();s(TI,"lintRules");});function j(t,e,r){return {level:"warning",file:t,target:e,message:r}}function xF(t){return t.length===0?"":t.length===1?t[0]:t.length===2?`${t[0]} and ${t[1]}`:`${t.slice(0,-1).join(", ")}, and ${t[t.length-1]}`}function Si(t,e,r,n){let o=n?.unsupportedBy??e,i=xF(r);return j(".agentsmesh/hooks.yaml",e,`${t} is not supported by ${o}; only ${i} are projected.`)}var Tt=d(()=>{s(j,"createWarning");s(xF,"formatOxfordComma");s(Si,"createUnsupportedHookWarning");});function NI(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","amp","Amp has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function FI(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[j(".agentsmesh/permissions.yaml","amp","Amp permissions are managed via amp.permissions in settings.json; canonical permissions are not projected.")]}function vI(t){return t.ignore.length===0?[]:[j(".agentsmesh/ignore","amp","Amp has no dedicated ignore file and relies on .gitignore; canonical ignore patterns are not projected.")]}var MI=d(()=>{Tt();s(NI,"lintHooks");s(FI,"lintPermissions");s(vI,"lintIgnore");});function w(t,e){return J(t).relative(t,e).replace(/\\/g,"/")}async function L(t,e){return D(J(t).join(t,e)).catch(()=>[])}function GI(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}function vF(t,e,r,n){let o=posix.dirname(e),i=posix.dirname(r);for(;o!==n&&o!==".";)GI(t,o,i),o=posix.dirname(o),i=posix.dirname(i);}function M(t,e,r,n){t.set(e,`${r}/${basename(e,n)}.md`);}function K(t,e,r){if(!e.startsWith(`${r}/`))return;let n=e.slice(r.length+1);if(!n)return;if(!n.includes("/")){if(!n.endsWith(".md")||basename(n)==="SKILL.md")return;let u=basename(n,".md");t.set(e,`${$I}/${u}/SKILL.md`);return}let[o,...i]=n.split("/"),a=i.join("/");if(!o||!a)return;let c=o.startsWith(di)?di:o.startsWith(Fa)?Fa:null;if(c&&a==="SKILL.md"){t.set(e,`${NF}/${o.slice(c.length)}.md`);return}let l=o.startsWith(fi)?fi:o.startsWith(va)?va:null;if(l&&a==="SKILL.md"){t.set(e,`${FF}/${o.slice(l.length)}.md`);return}let m=`${$I}/${o}`;a==="SKILL.md"&&GI(t,`${r}/${o}`,m);let p=`${m}/${a}`;t.set(e,p),a!=="SKILL.md"&&vF(t,e,p,`${r}/${o}`);}function MF(t){return t.split("/").filter(Boolean)[0]??""}async function $F(){if(Hu!==void 0)return Hu;let{BUILTIN_TARGETS:t}=await Promise.resolve().then(()=>(gt(),jI)),e=new Set;for(let r of t)for(let n of [r.project.rootInstructionPath,r.project.skillDir,...r.project.managedOutputs?.dirs??[],...r.project.managedOutputs?.files??[],...r.detectionPaths,r.globalSupport?.layout.rootInstructionPath,r.globalSupport?.layout.skillDir,...r.globalSupport?.layout.managedOutputs?.dirs??[],...r.globalSupport?.layout.managedOutputs?.files??[],...r.globalSupport?.detectionPaths??[]])if(n!==void 0){let o=MF(n);o.startsWith(".")&&e.add(o);}return Hu=e,e}function Vu(t){return t.split("/").some(e=>e.startsWith("."))}async function GF(t){let e=[],r=await $F(),n=J(t);async function o(i){let a=n.join(t,i),c=await readdir(a,{withFileTypes:true}).catch(()=>[]);for(let l of c){let m=i?`${i}/${l.name}`:l.name;if(l.isDirectory()){if(r.has(l.name)||Vu(m))continue;await o(m);continue}if(l.isSymbolicLink()&&await stat(n.join(t,m)).then(p=>p.isDirectory(),()=>false)){if(r.has(l.name)||Vu(m))continue;await o(m);continue}(l.name==="AGENTS.md"||l.name==="AGENTS.override.md")&&e.push(n.join(t,m));}}return s(o,"walk"),await o(""),e}async function Tl(t,e){let r=await GF(e);for(let n of r){let o=w(e,n),i=o.endsWith("/AGENTS.md")&&o!=="AGENTS.md"&&!o.endsWith("/AGENTS.override.md"),a=o.endsWith("/AGENTS.override.md")&&o!=="AGENTS.override.md";if(!i&&!a)continue;let c=posix.dirname(o);if(Vu(c))continue;let l=c.replace(/\//g,"-");t.set(o,`${DF}/${l}.md`);}}var DF,NF,FF,$I,Hu,$t=d(()=>{Vt();b();ae();ht();DF=".agentsmesh/rules",NF=".agentsmesh/commands",FF=".agentsmesh/agents",$I=".agentsmesh/skills";s(w,"rel");s(L,"listFiles");s(GI,"addDirectoryMapping");s(vF,"addAncestorMappings");s(M,"addSimpleFileMapping");s(K,"addSkillLikeMapping");s(MF,"firstPathSegment");s($F,"targetRootSegments");s(Vu,"hasHiddenSegment");s(GF,"listScopedAgentsFiles");s(Tl,"addScopedAgentsMappings");});var x,ot,yt,Dt=d(()=>{x=".agentsmesh/rules",ot=".agentsmesh/commands",yt=".agentsmesh/agents";});async function Ju(t,e,r="project"){if(r==="global"){t.set(_n,`${x}/_root.md`);for(let n of await L(e,Ne))K(t,w(e,n),Ne);t.set(In,".agentsmesh/mcp.json");return}t.set(De,`${x}/_root.md`);for(let n of await L(e,Jt))K(t,w(e,n),Jt);t.set(Dr,".agentsmesh/mcp.json");}var UI=d(()=>{$t();es();Dt();s(Ju,"buildAmpImportPaths");});var rs,Dl,Nr,sr,Wa,ir,Rn,Ka,Fr,On,Ba,Ci,Yu,ns,Nl,WI,os=d(()=>{rs="antigravity",Dl=".agents",Nr=`${Dl}/rules`,sr=`${Nr}/general.md`,Wa=`${Nr}/_root.md`,ir=`${Dl}/skills`,Rn=`${Dl}/workflows`,Ka=`${Dl}/antigravity/mcp_config.json`,Fr=".gemini/antigravity/GEMINI.md",On=".gemini/antigravity/skills",Ba=".gemini/antigravity/workflows",Ci=".gemini/antigravity/mcp_config.json",Yu=".agentsmesh/rules/_root.md",ns=".agentsmesh/rules",Nl=".agentsmesh/commands",WI=".agentsmesh/mcp.json";});async function Xu(t,e,r="project"){if(r==="global"){t.set(Fr,`${x}/_root.md`);for(let n of await L(e,On))K(t,w(e,n),On);t.set(Ci,".agentsmesh/mcp.json");return}t.set(sr,`${x}/_root.md`),t.set(Wa,`${x}/_root.md`);for(let n of await L(e,Nr)){let o=w(e,n);o===sr||o===Wa||M(t,o,x,".md");}for(let n of await L(e,Rn))M(t,w(e,n),ot,".md");for(let n of await L(e,ir))K(t,w(e,n),ir);}var KI=d(()=>{$t();os();Dt();s(Xu,"buildAntigravityImportPaths");});var BI,so,HI,Ha,za,Va,Ja,Ya,En,Zu,Xa,Ri,Za,qa,Fl,vl,qu,Qa,Qu,ss,zI,kn=d(()=>{BI="claude-code",so=".claude/CLAUDE.md",HI="CLAUDE.md",Ha=".claude/rules",za=".claude/commands",Va=".claude/agents",Ja=".claude/skills",Ya=".claude/settings.json",En=".claude/hooks.json",Zu=".claude/output-styles",Xa=".claudeignore",Ri=".mcp.json",Za=".claude.json",qa=".agentsmesh/rules",Fl=".agentsmesh/commands",vl=".agentsmesh/agents",qu=".agentsmesh/skills",Qa=".agentsmesh/mcp.json",Qu=".agentsmesh/permissions.yaml",ss=".agentsmesh/hooks.yaml",zI=".agentsmesh/ignore";});async function td(t,e,r="project"){if(t.set(".claude/CLAUDE.md",`${x}/_root.md`),t.set(En,ss),r==="project"&&t.set("CLAUDE.md",`${x}/_root.md`),r==="global")for(let n of await L(e,".agents/skills"))K(t,w(e,n),".agents/skills");for(let n of await L(e,".claude/rules"))M(t,w(e,n),x,".md");for(let n of await L(e,".claude/commands"))M(t,w(e,n),ot,".md");for(let n of await L(e,".claude/agents"))M(t,w(e,n),yt,".md");for(let n of await L(e,".claude/skills"))K(t,w(e,n),".claude/skills");}var VI=d(()=>{$t();kn();Dt();s(td,"buildClaudeCodeImportPaths");});var io,wn,is,Ln,JI,Kt,vr,ao,as,cs,ls,ms,ed,co,Ml,rd,nd,od,YI,ve=d(()=>{io="cline",wn=".clinerules",is=".clineignore",Ln=".cline/cline_mcp_settings.json",JI=".cline/mcp_settings.json",Kt=".cline/skills",vr=".clinerules/workflows",ao="AGENTS.md",as=".clinerules/hooks",cs="Documents/Cline/Rules",ls="Documents/Cline/Workflows",ms="Documents/Cline/Hooks",ed=".agentsmesh/hooks.yaml",co=".agentsmesh/rules",Ml=".agentsmesh/commands",rd=".agentsmesh/ignore",nd=".agentsmesh/mcp.json",od=".agentsmesh/agents",YI=".agentsmesh/skills";});async function sd(t,e,r="project"){if(r==="global"){for(let n of await L(e,cs))M(t,w(e,n),x,".md");for(let n of await L(e,ls))M(t,w(e,n),ot,".md");for(let n of await L(e,Kt))K(t,w(e,n),Kt);t.set(Ln,".agentsmesh/mcp.json");return}t.set(".clinerules/_root.md",`${x}/_root.md`);for(let n of await L(e,".clinerules")){let o=w(e,n);!o.endsWith(".md")||o.includes("/workflows/")||basename(o)==="_root.md"||M(t,o,x,".md");}for(let n of await L(e,".clinerules/workflows"))M(t,w(e,n),ot,".md");for(let n of await L(e,".cline/skills"))K(t,w(e,n),".cline/skills");}var XI=d(()=>{$t();ve();Dt();s(sd,"buildClineImportPaths");});async function id(t,e,r="project"){if(r==="global"?(t.set(".codex/AGENTS.md",`${x}/_root.md`),t.set(".codex/AGENTS.override.md",`${x}/_root.md`)):(t.set("AGENTS.md",`${x}/_root.md`),t.set("codex.md",`${x}/_root.md`),await Tl(t,e)),r==="project")for(let n of await L(e,".codex/instructions"))M(t,w(e,n),x,".md");for(let n of await L(e,".codex/rules")){let o=w(e,n);o.endsWith(".rules")?M(t,o,x,".rules"):o.endsWith(".md")&&M(t,o,x,".md");}for(let n of await L(e,".codex/agents"))M(t,w(e,n),yt,".toml");for(let n of await L(e,".agents/skills"))K(t,w(e,n),".agents/skills");}var ZI=d(()=>{$t();Dt();s(id,"buildCodexCliImportPaths");});var Oi,ar,Mr,ad,$l,bn,cd,ye,Ei,tc,Gl,jl,ld,$r=d(()=>{Oi="continue",ar=".continue/rules",Mr=".continue/prompts",ad=".continue/mcpServers",$l=`${ad}/agentsmesh.json`,bn=`${ar}/general.md`,cd=`${ar}/_root.md`,ye=".continue/skills",Ei=".continue/AGENTS.md",tc=".continue/config.yaml",Gl=".agentsmesh/rules",jl=".agentsmesh/commands",ld=".agentsmesh/mcp.json";});async function md(t,e,r="project"){t.set(bn,`${x}/_root.md`),t.set(cd,`${x}/_root.md`);for(let n of await L(e,".continue/rules")){let o=w(e,n);o===bn||o===cd||M(t,o,x,".md");}for(let n of await L(e,".continue/prompts"))t.set(w(e,n),`${ot}/${basename(n,".md")}.md`);for(let n of await L(e,".continue/skills"))K(t,w(e,n),".continue/skills");if(r==="global")for(let n of await L(e,".agents/skills"))K(t,w(e,n),".agents/skills");}var qI=d(()=>{$t();$r();Dt();s(md,"buildContinueImportPaths");});function WF(t,e){if(e.endsWith(".instructions.md")){t.set(e,`${x}/${basename(e,".instructions.md")}.md`);return}M(t,e,x,".md");}async function pd(t,e){t.set(".github/copilot-instructions.md",`${x}/_root.md`);for(let r of await L(e,".github/copilot"))t.set(w(e,r),`${x}/${basename(r,".instructions.md")}.md`);for(let r of await L(e,".github/instructions"))WF(t,w(e,r));for(let r of await L(e,".github/prompts"))t.set(w(e,r),`${ot}/${basename(r,".prompt.md")}.md`);for(let r of await L(e,".github/agents"))t.set(w(e,r),`${yt}/${basename(r,".agent.md")}.md`);for(let r of await L(e,".github/skills"))K(t,w(e,r),".github/skills");}var QI=d(()=>{$t();Dt();s(WF,"addCopilotInstructionMapping");s(pd,"buildCopilotImportPaths");});var tS,lo,eS,Me,An,$e,ki,Gr,jr,Ur,Wl,cr,ud,KF,wi,lr,ec,mo,po,Wr,uo,fo,rS,Li,dd,rc,fd,wt=d(()=>{tS="cursor",lo="AGENTS.md",eS=".cursorrules",Me=".cursor/rules",An=`${Me}/general.mdc`,$e=".cursor/commands",ki=".cursor/agents",Gr=".cursor/skills",jr=".cursor/mcp.json",Ur=".cursor/hooks.json",Wl=".cursor/settings.json",cr=".cursorignore",ud=".cursorindexingignore",KF=".agentsmesh-exports/cursor",wi=`${KF}/user-rules.md`,lr=".cursor/AGENTS.md",ec=jr,mo=Gr,po=ki,Wr=".agentsmesh/rules",uo=".agentsmesh/commands",fo=".agentsmesh/agents",rS=".agentsmesh/skills",Li=".agentsmesh/mcp.json",dd=".agentsmesh/permissions.yaml",rc=".agentsmesh/hooks.yaml",fd=".agentsmesh/ignore";});async function gd(t,e,r="project"){if(r==="global"){t.set(jr,".agentsmesh/mcp.json"),t.set(".cursor/AGENTS.md",`${x}/_root.md`);for(let n of await L(e,".cursor/rules"))M(t,w(e,n),x,".mdc");for(let n of await L(e,".cursor/commands"))M(t,w(e,n),ot,".md");for(let n of await L(e,".cursor/agents"))M(t,w(e,n),yt,".md");for(let n of await L(e,".cursor/skills"))K(t,w(e,n),".cursor/skills");return}t.set("AGENTS.md",`${x}/_root.md`);for(let n of await L(e,".cursor/rules"))M(t,w(e,n),x,".mdc");for(let n of await L(e,".cursor/commands"))M(t,w(e,n),ot,".md");for(let n of await L(e,".cursor/agents"))M(t,w(e,n),yt,".md");for(let n of await L(e,".cursor/skills"))K(t,w(e,n),".cursor/skills");}var nS=d(()=>{$t();wt();Dt();s(gd,"buildCursorImportPaths");});async function hd(t,e){for(let r of await L(e,".gemini/rules"))M(t,w(e,r),x,".md");for(let r of await L(e,".gemini/commands")){let n=w(e,r);if(!n.endsWith(".toml")&&!n.endsWith(".md"))continue;let o=n.replace(/\.(toml|md)$/i,""),i=".gemini/commands/",l=(o.startsWith(i)?o.slice(i.length):o).split("/").filter(Boolean).join(":");t.set(n,`${ot}/${l}.md`);}for(let r of await L(e,".gemini/agents"))M(t,w(e,r),yt,".md");for(let r of await L(e,".gemini/skills"))K(t,w(e,r),".gemini/skills");}var oS=d(()=>{$t();Dt();s(hd,"buildGeminiCliImportPaths");});var Kr,Ge,ee,xn,sS,Pn,ps,je,iS,aS,bi=d(()=>{Kr="goose",Ge=".goosehints",ee=".agents/skills",xn=".gooseignore",sS=".config/goose",Pn=`${sS}/.goosehints`,ps=`${sS}/.gooseignore`,je=".agents/skills",iS=".agentsmesh/rules",aS=".agentsmesh/ignore";});async function yd(t,e,r="project"){if(r==="global"){t.set(Pn,`${x}/_root.md`);for(let n of await L(e,je))K(t,w(e,n),je);t.set(ps,".agentsmesh/ignore");return}t.set(Ge,`${x}/_root.md`);for(let n of await L(e,ee))K(t,w(e,n),ee);t.set(xn,".agentsmesh/ignore");}var cS=d(()=>{$t();bi();Dt();s(yd,"buildGooseImportPaths");});var us,go,Kl,lS,Br,mS,BF,nc,ds,oc,Ai,xi,sc,ic,ac,cc,lc,HF,Bl,fs,pS,_d,Hl,uS,dS,fS,gS,Pi=d(()=>{us="junie",go=".junie",Kl=`${go}/guidelines.md`,lS=`${go}/ci-guidelines.md`,Br=`${go}/AGENTS.md`,mS="AGENTS.md",BF=`${go}/mcp`,nc=`${BF}/mcp.json`,ds=`${go}/skills`,oc=`${go}/rules`,Ai=`${go}/commands`,xi=`${go}/agents`,sc=".aiignore",ic=".junie",ac=`${ic}/skills`,cc=`${ic}/agents`,lc=`${ic}/commands`,HF=`${ic}/mcp`,Bl=`${HF}/mcp.json`,fs=`${ic}/AGENTS.md`,pS=".agents/skills",_d=".agentsmesh/rules/_root.md",Hl=".agentsmesh/rules",uS=".agentsmesh/commands",dS=".agentsmesh/agents",fS=".agentsmesh/mcp.json",gS=".agentsmesh/ignore";});async function Id(t,e){t.set(Kl,`${x}/_root.md`),t.set(Br,`${x}/_root.md`),t.set("AGENTS.md",`${x}/_root.md`);for(let r of await L(e,".junie/rules"))M(t,w(e,r),x,".md");for(let r of await L(e,".junie/commands"))M(t,w(e,r),ot,".md");for(let r of await L(e,".junie/agents"))M(t,w(e,r),yt,".md");for(let r of await L(e,".junie/skills"))K(t,w(e,r),".junie/skills");}var hS=d(()=>{$t();Pi();Dt();s(Id,"buildJunieImportPaths");});var re,mc,Hr,Tn,Dn,Nn,mr,ho,Ti,zl,gs,Di,hs,pc,Vl,Ni,yo,ys,_s,Is,_o,Fi,Jl,yS,Io,vi,Ss,_S,IS,Cs=d(()=>{re="kilo-code",mc=".kilo",Hr="AGENTS.md",Tn=`${mc}/rules`,Dn=`${mc}/commands`,Nn=`${mc}/agents`,mr=`${mc}/skills`,ho=`${mc}/mcp.json`,Ti=".kilocodeignore",zl=".kilocode",gs=`${zl}/rules`,Di=`${zl}/workflows`,hs=`${zl}/skills`,pc=`${zl}/mcp.json`,Vl=".kilocodemodes",Ni=".kilo",yo=`${Ni}/AGENTS.md`,ys=`${Ni}/rules`,_s=`${Ni}/commands`,Is=`${Ni}/agents`,_o=`${Ni}/skills`,Fi=`${Ni}/mcp.json`,Jl=".kilocodeignore",yS=".agents/skills",Io=".agentsmesh/rules",vi=".agentsmesh/commands",Ss=".agentsmesh/agents",_S=".agentsmesh/mcp.json",IS=".agentsmesh/ignore";});async function Sd(t,e,r="project"){if(r==="global"){t.set(yo,`${x}/_root.md`);for(let n of await L(e,ys))M(t,w(e,n),x,".md");for(let n of await L(e,_s))M(t,w(e,n),ot,".md");for(let n of await L(e,Is))M(t,w(e,n),yt,".md");for(let n of await L(e,_o))K(t,w(e,n),_o);t.set(Fi,".agentsmesh/mcp.json");return}t.set(Hr,`${x}/_root.md`);for(let n of await L(e,Tn))M(t,w(e,n),x,".md");for(let n of await L(e,Dn))M(t,w(e,n),ot,".md");for(let n of await L(e,Nn))M(t,w(e,n),yt,".md");for(let n of await L(e,mr))K(t,w(e,n),mr);t.set(ho,".agentsmesh/mcp.json");for(let n of await L(e,gs)){let o=w(e,n);if(basename(o)==="00-root.md"){t.set(o,`${x}/_root.md`);continue}M(t,o,x,".md");}for(let n of await L(e,Di))M(t,w(e,n),ot,".md");for(let n of await L(e,hs))K(t,w(e,n),hs);t.set(pc,".agentsmesh/mcp.json");}var SS=d(()=>{$t();Cs();Dt();s(Sd,"buildKiloCodeImportPaths");});var _e,pr,uc,ur,ne,dr,So,CS,Mi,$i,Rs,fr,Co,Os,dc,fc,RS,Cd,Rd,OS,ES,Od,kS,Gi=d(()=>{_e="kiro",pr="AGENTS.md",uc=".kiro",ur=`${uc}/steering`,ne=`${uc}/skills`,dr=`${uc}/agents`,So=`${uc}/hooks`,CS=`${uc}/settings`,Mi=`${CS}/mcp.json`,$i=".kiroignore",Rs=".kiro/steering",fr=".kiro/steering/AGENTS.md",Co=".kiro/skills",Os=".kiro/agents",dc=".kiro/settings/mcp.json",fc=".kiro/settings/kiroignore",RS=".agents/skills",Cd=".agentsmesh/rules/_root.md",Rd=".agentsmesh/rules",OS=".agentsmesh/agents",ES=".agentsmesh/mcp.json",Od=".agentsmesh/hooks.yaml",kS=".agentsmesh/ignore";});async function Ed(t,e,r="project"){if(r==="global"){t.set(fr,`${x}/_root.md`);for(let n of await L(e,Rs)){let o=w(e,n);o!==fr&&M(t,o,x,".md");}for(let n of await L(e,Co))K(t,w(e,n),Co);for(let n of await L(e,Os))M(t,w(e,n),yt,".md");return}t.set(pr,`${x}/_root.md`);for(let n of await L(e,ur))M(t,w(e,n),x,".md");for(let n of await L(e,ne))K(t,w(e,n),ne);for(let n of await L(e,dr))M(t,w(e,n),yt,".md");}var wS=d(()=>{$t();Gi();Dt();s(Ed,"buildKiroImportPaths");});var gr,Yl,zr,Fn,vn,Mn,hr,Vr,ji,Ro,Es,ks,ws,Oo,Eo,LS,gc,Xl,Zl,kd,Ls=d(()=>{gr="opencode",Yl=".opencode",zr="AGENTS.md",Fn=`${Yl}/rules`,vn=`${Yl}/commands`,Mn=`${Yl}/agents`,hr=`${Yl}/skills`,Vr="opencode.json",ji=".config/opencode",Ro=`${ji}/AGENTS.md`,Es=`${ji}/rules`,ks=`${ji}/commands`,ws=`${ji}/agents`,Oo=`${ji}/skills`,Eo=`${ji}/opencode.json`,LS=".agents/skills",gc=".agentsmesh/rules",Xl=".agentsmesh/commands",Zl=".agentsmesh/agents",kd=".agentsmesh/mcp.json";});async function wd(t,e,r="project"){if(r==="global"){t.set(Ro,`${x}/_root.md`);for(let n of await L(e,Es))M(t,w(e,n),x,".md");for(let n of await L(e,ks))M(t,w(e,n),ot,".md");for(let n of await L(e,ws))M(t,w(e,n),yt,".md");for(let n of await L(e,Oo))K(t,w(e,n),Oo);t.set(Eo,".agentsmesh/mcp.json");return}t.set(zr,`${x}/_root.md`);for(let n of await L(e,Fn))M(t,w(e,n),x,".md");for(let n of await L(e,vn))M(t,w(e,n),ot,".md");for(let n of await L(e,Mn))M(t,w(e,n),yt,".md");for(let n of await L(e,hr))K(t,w(e,n),hr);t.set(Vr,".agentsmesh/mcp.json");}var bS=d(()=>{$t();Ls();Dt();s(wd,"buildOpencodeImportPaths");});var ko,bs,yr,hc,$n,Gn,Jr,yc,_c,Ui,Ic,ql,wo,Lo,jn,As,Sc,bo,AS,xs,Ql,xS,PS,Ps=d(()=>{ko="roo-code",bs=".roo",yr=`${bs}/rules/00-root.md`,hc=".roorules",$n=`${bs}/rules`,Gn=`${bs}/commands`,Jr=`${bs}/skills`,yc=`${bs}/mcp.json`,_c=".rooignore",Ui=".roomodes",Ic="settings/custom_modes.yaml",ql=".roo",wo=`${ql}/rules`,Lo=`${ql}/commands`,jn=`${ql}/skills`,As="mcp_settings.json",Sc=".rooignore",bo=`${ql}/AGENTS.md`,AS=".agents/skills",xs=".agentsmesh/rules",Ql=".agentsmesh/commands",xS=".agentsmesh/mcp.json",PS=".agentsmesh/ignore";});async function Ld(t,e,r="project"){if(r==="global"){t.set(bo,`${x}/_root.md`);for(let n of await L(e,wo))M(t,w(e,n),x,".md");for(let n of await L(e,Lo))M(t,w(e,n),ot,".md");for(let n of await L(e,jn))K(t,w(e,n),jn);t.set(As,".agentsmesh/mcp.json");return}t.set(yr,`${x}/_root.md`),t.set(hc,`${x}/_root.md`);for(let n of await L(e,$n)){let o=w(e,n);o!==yr&&M(t,o,x,".md");}for(let n of await L(e,".roo")){let o=w(e,n);/^\.roo\/rules-[^/]+\/.+\.md$/.test(o)&&M(t,o,x,".md");}for(let n of await L(e,Gn))M(t,w(e,n),ot,".md");for(let n of await L(e,Jr))K(t,w(e,n),Jr);}var TS=d(()=>{$t();Ps();Dt();s(Ld,"buildRooCodeImportPaths");});var Yr,_r,bd,Xt,Ao,le,DS,Wi=d(()=>{Yr="warp",_r="AGENTS.md",bd="WARP.md",Xt=".warp/skills",Ao=".mcp.json",le=".warp/skills",DS=".agentsmesh/rules";});async function Ad(t,e,r="project"){if(r==="global"){for(let n of await L(e,le))K(t,w(e,n),le);return}t.set(_r,`${x}/_root.md`);for(let n of await L(e,Xt))K(t,w(e,n),Xt);t.set(Ao,".agentsmesh/mcp.json");}var NS=d(()=>{$t();Wi();Dt();s(Ad,"buildWarpImportPaths");});async function xd(t,e){t.set("AGENTS.md",`${x}/_root.md`),t.set(".windsurfrules",`${x}/_root.md`),await Tl(t,e);for(let r of await L(e,".windsurf/rules"))M(t,w(e,r),x,".md");for(let r of await L(e,".windsurf/workflows"))M(t,w(e,r),ot,".md");for(let r of await L(e,".windsurf/skills"))K(t,w(e,r),".windsurf/skills");}var FS=d(()=>{$t();Dt();s(xd,"buildWindsurfImportPaths");});var Ir,Xr,VF,Zr,vS,Ts=d(()=>{Ir=".rules",Xr=".zed/settings.json",VF=".config/zed",Zr=`${VF}/settings.json`,vS=".agentsmesh/rules";});async function Pd(t,e,r="project"){if(r==="global"){t.set(Zr,".agentsmesh/mcp.json");return}t.set(Ir,`${x}/_root.md`),t.set(Xr,".agentsmesh/mcp.json");}var MS=d(()=>{Ts();Dt();s(Pd,"buildZedImportPaths");});var $S=d(()=>{UI();KI();VI();XI();ZI();qI();QI();nS();oS();cS();hS();SS();wS();bS();TS();NS();FS();MS();});var Nt=d(()=>{$S();});function ZF(t,e){if(t===null)return e;let r;try{let i=JSON.parse(t);r=i!==null&&typeof i=="object"&&!Array.isArray(i)?i:{};}catch{r={};}let n=JSON.parse(e);if(n===null||typeof n!="object"||Array.isArray(n))return t;let o=n;return o["amp.mcpServers"]!==void 0&&(r["amp.mcpServers"]=o["amp.mcpServers"]),JSON.stringify(r,null,2)}var JF,YF,XF,GS,Pl,Bu=d(()=>{ae();ht();gI();he();LI();DI();MI();Nt();es();JF={name:"amp",primaryRootInstructionPath:De,generateRules:pI,generateCommands:dI,generateAgents:fI,generateSkills:uI,importFrom:wI},YF={rootInstructionPath:De,skillDir:Jt,managedOutputs:{dirs:[Jt],files:[De,Dr]},paths:{rulePath(t){return De},commandPath(t){return `${Jt}/${at(t)}/SKILL.md`},agentPath(t){return `${Jt}/${z(t)}/SKILL.md`}}},XF={rootInstructionPath:_n,skillDir:Ne,managedOutputs:{dirs:[Ne],files:[_n,In]},rewriteGeneratedPath(t){return t===De?_n:t===Dr?In:t.startsWith(`${Jt}/`)?t.replace(`${Jt}/`,`${Ne}/`):t},mirrorGlobalPath(t,e){return mt(t,Ne,e)},paths:{rulePath(t){return _n},commandPath(t){return `${Ne}/${at(t)}/SKILL.md`},agentPath(t){return `${Ne}/${z(t)}/SKILL.md`}}},GS={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"};s(ZF,"mergeAmpSettings");Pl={id:"amp",generators:JF,capabilities:GS,emptyImportMessage:"No Amp config found (AGENTS.md, .agents/skills, or .amp/settings.json).",lintRules:TI,lint:{hooks:NI,permissions:FI,ignore:vI},supportsConversion:{commands:true,agents:true},project:YF,globalSupport:{capabilities:GS,detectionPaths:[_n,In],layout:XF},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[De],global:[_n]},canonicalDir:mI,canonicalRootFilename:"_root.md",markAsRoot:true}},emitScopedSettings(t,e){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:Dr,content:JSON.stringify({"amp.mcpServers":t.mcp.mcpServers},null,2)}]},mergeGeneratedOutputContent(t,e,r,n){return n===Dr||n===In?ZF(t,r):null},sharedArtifacts:{".agents/skills/":"consumer"},buildImportPaths:Ju,detectionPaths:[De,Dr]};});function jS(t){let e=t.rules.find(n=>n.root);if(!e)return [];let r=[{path:sr,content:e.body.trim()||""}];for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("antigravity"))continue;let o=basename(n.source,".md");r.push({path:`${Nr}/${o}.md`,content:n.body.trim()||""});}return r}function US(t){return t.commands.map(e=>{let r=e.description.trim(),n=e.body.trim(),o=r&&n&&!n.startsWith(r)?`${r}
|
|
52
52
|
|
|
53
|
-
${n}`:n||r;return {path:`${
|
|
53
|
+
${n}`:n||r;return {path:`${Rn}/${e.name}.md`,content:o}})}function WS(t){return kt(t,ir)}function KS(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:Ka,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function BS(t){return t.agents.map(e=>({path:`${ir}/${z(e.name)}/SKILL.md`,content:ce(e)}))}function HS(t){let e=t.rules.find(n=>n.root),r=t.rules.filter(n=>n.root?false:n.targets.length===0||n.targets.includes("antigravity"));return xt(e?.body.trim()??"",r)}var zS=d(()=>{Rt();xe();ht();os();s(jS,"generateRules");s(US,"generateCommands");s(WS,"generateSkills");s(KS,"generateMcp");s(BS,"generateAgents");s(HS,"renderAntigravityGlobalInstructions");});function QF(t){let e=t.replace(/\\/g,"/");return !e.startsWith("rules/")||e.endsWith("/")||!e.endsWith(".md")?null:e}async function qr(t){let e=eI(t.content),r=[];if(e.rules.length===0)return {rootContent:e.rootContent,results:r};await O(join(t.projectRoot,t.rulesDir));for(let n of e.rules){let o=QF(n.source);if(o===null||o==="rules/_root.md")continue;let i=join(t.projectRoot,".agentsmesh",o),a=t.normalize(n.body,t.sourcePath,i),{frontmatter:c,body:l}=E(a),m=await G(i,{...c,root:false,description:n.description||void 0,globs:n.globs.length>0?n.globs:void 0,targets:n.targets.length>0?n.targets:void 0},l);await C(i,m),r.push({fromTool:t.fromTool,fromPath:t.sourcePath,toPath:`.agentsmesh/${o}`,feature:"rules"});}return {rootContent:e.rootContent,results:r}}var Ki=d(()=>{b();v();xe();nt();s(QF,"canonicalRulePath");s(qr,"splitEmbeddedRulesToCanonical");});async function tv(t,e,r,n){let o=n==="global"?Fr:sr,i=n==="project"?[o,Wa]:[o];for(let a of i){let c=join(t,a),l=await y(c);if(l===null)continue;let m=join(t,Yu),p=await qr({content:l,projectRoot:t,rulesDir:ns,sourcePath:c,fromTool:rs,normalize:r});e.push(...p.results);let{body:u}=E(r(p.rootContent,c,m)),f=await G(m,{root:true},u);await O(join(t,ns)),await C(m,f),e.push({fromTool:rs,fromPath:c,toPath:Yu,feature:"rules"});return}}async function JS(t,e={}){let r=e.scope??"project",n=[],o=await H(rs,t,r);return await tv(t,n,o,r),n.push(...await tt(tm,t,r,{normalize:o})),await Ct(t,r==="global"?On:ir,rs,n,o),n}var YS=d(()=>{Ot();b();v();Rt();Ut();nt();Ki();os();Dd();s(tv,"importRootRule");s(JS,"importFromAntigravity");});var qS,QS,tC=d(()=>{v();nt();os();qS=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{if(basename(t)==="general.md"||basename(t)==="_root.md")return null;let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${ns}/${t}`,content:await G(n,{root:false,description:typeof o.description=="string"?o.description:void 0,globs:Array.isArray(o.globs)?o.globs:void 0},i)}},"nonRootRuleMapper"),QS=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${Nl}/${t}`,content:await it(n,{hasDescription:typeof o.description=="string",description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"workflowMapper");});function eC(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:rs}))}var rC=d(()=>{Wt();os();s(eC,"lintRules");});var ev,rv,nv,ov,tm,Dd=d(()=>{ts();ht();zS();os();YS();tC();rC();Nt();ev={name:"antigravity",primaryRootInstructionPath:sr,generateRules:jS,generateCommands:US,generateAgents:BS,generateSkills:WS,generateMcp:KS,importFrom:JS},rv={rootInstructionPath:sr,skillDir:".agents/skills",rewriteGeneratedPath(t){return t===Ka?null:t},paths:{rulePath(t,e){return `${Nr}/${t}.md`},commandPath(t,e){return `${Rn}/${t}.md`},agentPath(t){return `${ir}/${z(t)}/SKILL.md`}}},nv={rootInstructionPath:Fr,renderPrimaryRootInstruction:HS,skillDir:On,managedOutputs:{dirs:[On,Ba],files:[Fr,Ci]},rewriteGeneratedPath(t){return t===sr?Fr:t.startsWith(`${Nr}/`)?null:t.startsWith(".agents/skills/")?t.replace(".agents/skills",On):t.startsWith(`${Rn}/`)?t.replace(Rn,Ba):t===Ka?Ci:t},paths:{rulePath(t,e){return Fr},commandPath(t,e){return `${Ba}/${t}.md`},agentPath(t){return `${ir}/${z(t)}/SKILL.md`}}},ov={rules:"native",additionalRules:"embedded",commands:er("partial","workflows"),agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},tm={id:"antigravity",generators:ev,capabilities:{rules:"native",additionalRules:"native",commands:er("partial","workflows"),agents:"none",skills:"native",mcp:"none",hooks:"none",ignore:"none",permissions:"none"},emptyImportMessage:"No Antigravity config found (.agents/rules/, .agents/skills/, or .agents/workflows/).",supportsConversion:{agents:true},lintRules:eC,project:rv,globalSupport:{capabilities:ov,detectionPaths:[".gemini/antigravity/GEMINI.md",".gemini/antigravity/skills",".gemini/antigravity/workflows",".gemini/antigravity/mcp_config.json"],layout:nv},importer:{rules:{feature:"rules",mode:"directory",source:{project:[Nr]},canonicalDir:ns,extensions:[".md"],map:qS},commands:{feature:"commands",mode:"directory",source:{project:[Rn],global:[Ba]},canonicalDir:Nl,extensions:[".md"],map:QS},mcp:{feature:"mcp",mode:"flatFile",source:{global:[Ci]},canonicalDir:".agentsmesh",canonicalFilename:WI}},buildImportPaths:Xu,detectionPaths:[".agents/rules/general.md",".agents/rules/",".agents/skills/",".agents/workflows/"]};});function nC(t){if(!t.hooks||Object.keys(t.hooks).length===0)return {};let e={};for(let[r,n]of Object.entries(t.hooks)){if(!Array.isArray(n))continue;let o=[];for(let i of n){if(!Ar(i))continue;let a=At(i),c=Qt(i),l=i.type==="prompt"?c||a:a||c,m={type:i.type==="prompt"?"prompt":"command",[i.type==="prompt"?"prompt":"command"]:l};i.timeout!==void 0&&(m.timeout=i.timeout),o.push({matcher:i.matcher,hooks:[m]});}o.length>0&&(e[r]=o);}return e}var oC=d(()=>{qe();s(nC,"buildClaudeHooksObjectFromCanonical");});function sC(t){let e=[],r=t.rules.find(o=>o.root);r&&e.push({path:so,content:r.body.trim()?r.body:""});let n=t.rules.filter(o=>!o.root&&(o.targets.length===0||o.targets.includes("claude-code")));for(let o of n){let i=basename(o.source,".md"),a={};o.description&&(a.description=o.description),o.globs.length>0&&(a.globs=o.globs);let c=N(a,o.body.trim()||"");e.push({path:`${Ha}/${i}.md`,content:c});}return e}function iC(t){return t.commands.map(e=>{let r={description:e.description,"allowed-tools":e.allowedTools.length>0?e.allowedTools:void 0};r["allowed-tools"]===void 0&&delete r["allowed-tools"];let n=N(r,e.body.trim()||"");return {path:`${za}/${e.name}.md`,content:n}})}function aC(t){return t.agents.map(e=>{let r={name:e.name,description:e.description,tools:e.tools.length>0?e.tools:void 0,disallowedTools:e.disallowedTools.length>0?e.disallowedTools:void 0,model:e.model||void 0,permissionMode:e.permissionMode||void 0,maxTurns:e.maxTurns>0?e.maxTurns:void 0,mcpServers:e.mcpServers.length>0?e.mcpServers:void 0,hooks:Object.keys(e.hooks).length>0?e.hooks:void 0,skills:e.skills.length>0?e.skills:void 0,memory:e.memory||void 0};Object.keys(r).forEach(a=>{r[a]===void 0&&delete r[a];});let n=e.body.trim()||"",o=/^##\s*Role\b/m.test(n)?n:`## Role
|
|
54
54
|
|
|
55
|
-
${n}`,i=
|
|
55
|
+
${n}`,i=N(r,o);return {path:`${Va}/${e.name}.md`,content:i}})}function cC(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=JSON.stringify({mcpServers:t.mcp.mcpServers},null,2);return [{path:Ri,content:e}]}function lC(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=r.body.trim()||"",i=!o||/^##\s*Purpose\b/m.test(o)?o:`## Purpose
|
|
56
56
|
|
|
57
|
-
${o}`,a=
|
|
58
|
-
`);return [{path:
|
|
57
|
+
${o}`,a=N(n,i);e.push({path:`${Ja}/${r.name}/SKILL.md`,content:a});for(let c of r.supportingFiles){let l=c.relativePath.replace(/\\/g,"/");e.push({path:`${Ja}/${r.name}/${l}`,content:c.content});}}return e}function mC(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];if(e.length===0&&r.length===0&&n.length===0)return [];let o=JSON.stringify({permissions:{allow:e,deny:r,ask:n}},null,2);return [{path:Ya,content:o}]}function pC(t,e){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let r=nC(t);if(Object.keys(r).length===0)return [];if(e?.scope==="global")return [{path:En,content:JSON.stringify(r,null,2)}];let n=JSON.stringify({hooks:r},null,2);return [{path:Ya,content:n}]}function uC(t){if(!t.ignore||t.ignore.length===0)return [];let e=t.ignore.join(`
|
|
58
|
+
`);return [{path:Xa,content:e}]}var dC=d(()=>{v();kn();oC();s(sC,"generateRules");s(iC,"generateCommands");s(aC,"generateAgents");s(cC,"generateMcp");s(lC,"generateSkills");s(mC,"generatePermissions");s(pC,"generateHooks");s(uC,"generateIgnore");});function av(t){let e=t.description.trim();return e||(basename(t.source)||"rule").replace(/\.md$/i,"")||"Rule"}function fC(t){let e=t.rules.find(o=>o.root),r=(e?.body??"").trim();return r?`# Global Instructions
|
|
59
59
|
|
|
60
|
-
## ${e?
|
|
60
|
+
## ${e?av(e):"Guidance"}
|
|
61
61
|
|
|
62
62
|
${r}
|
|
63
|
-
`:""}var
|
|
63
|
+
`:""}var gC=d(()=>{s(av,"ruleSectionTitle");s(fC,"renderClaudeGlobalPrimaryInstructions");});function yC(t,e){return t===null?"created":t!==e?"updated":"unchanged"}async function _C(t,e,r,n){if(r!=="global")return [];let o=n.has("agents"),i=n.has("commands");if(!o&&!i)return [];let a=[];if(o)for(let c of t.agents){if(!c.outputStyle)continue;let l={name:c.name,description:c.description||void 0},m=N(l,c.body.trim()),p=`${Zu}/${c.name}.md`,u=await y(join(e,p));a.push({target:"claude-code",path:p,content:m,currentContent:u??void 0,status:yC(u,m)});}if(i)for(let c of t.commands){if(!c.outputStyle)continue;let l={name:c.name,description:c.description||void 0},m=N(l,c.body.trim()),p=`${Zu}/${c.name}.md`,u=await y(join(e,p));a.push({target:"claude-code",path:p,content:m,currentContent:u??void 0,status:yC(u,m)});}return a}var IC=d(()=>{b();v();kn();s(yC,"computeStatus");s(_C,"generateClaudeGlobalExtras");});var SC,CC,RC,OC=d(()=>{v();nt();nr();kn();SC=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${qa}/${t}`,content:await G(n,{...o,root:false},i)}},"claudeRuleMapper"),CC=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n)),a=Fe(o.allowedTools),c=a.length>0?a:Fe(o["allowed-tools"]);return {destPath:n,toPath:`${Fl}/${t}`,content:await it(n,{description:typeof o.description=="string"?o.description:void 0,hasDescription:Object.prototype.hasOwnProperty.call(o,"description"),allowedTools:c,hasAllowedTools:Object.prototype.hasOwnProperty.call(o,"allowedTools")||Object.prototype.hasOwnProperty.call(o,"allowed-tools")},i)}},"claudeCommandMapper"),RC=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${vl}/${t}`,content:await Pt(n,o,i)}},"claudeAgentMapper");});function EC(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(i=>({...i,target:BI}))}var kC=d(()=>{Wt();kn();s(EC,"lintRules");});var cv,wC,lv,mv,em,Fd=d(()=>{dC();kn();he();gC();IC();vd();OC();kC();Nt();cv={name:"claude-code",primaryRootInstructionPath:so,generateRules:sC,generateCommands:iC,generateAgents:aC,generateSkills:lC,generateMcp:cC,generatePermissions:mC,generateHooks:pC,generateIgnore:uC,importFrom:rm},wC={rootInstructionPath:so,skillDir:".claude/skills",managedOutputs:{dirs:[".claude/agents",".claude/commands",".claude/rules",".claude/skills"],files:[".claude/CLAUDE.md",".claude/settings.json",".claudeignore",".mcp.json"]},paths:{rulePath(t,e){return `.claude/rules/${t}.md`},commandPath(t,e){return `.claude/commands/${t}.md`},agentPath(t,e){return `.claude/agents/${t}.md`}}},lv={rootInstructionPath:so,skillDir:".claude/skills",renderPrimaryRootInstruction:fC,managedOutputs:{dirs:[".claude/agents",".claude/commands",".claude/rules",".claude/skills",".claude/output-styles",".agents/skills"],files:[".claude/CLAUDE.md",".claude/settings.json",Za,En,".claudeignore"]},rewriteGeneratedPath(t){return t===Ri?Za:t},mirrorGlobalPath(t,e){return mt(t,".claude/skills",e)},paths:wC.paths},mv={rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"native"},em={id:"claude-code",generators:cv,capabilities:{rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"native"},emptyImportMessage:"No Claude Code config found (CLAUDE.md or .claude/rules/*.md).",lintRules:EC,project:wC,globalSupport:{capabilities:mv,detectionPaths:[".claude/CLAUDE.md",".claude/rules",".claude/commands",".claude/agents",".claude/skills",".claude/settings.json",".claude/hooks.json",".claude/output-styles",".claudeignore",".claude.json",".agents/skills"],layout:lv,scopeExtras:_C},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[so,HI],global:[so]},canonicalDir:qa,canonicalRootFilename:"_root.md",markAsRoot:true},{feature:"rules",mode:"directory",source:{project:[Ha],global:[Ha]},canonicalDir:qa,extensions:[".md"],map:SC}],commands:{feature:"commands",mode:"directory",source:{project:[za],global:[za]},canonicalDir:Fl,extensions:[".md"],map:CC},agents:{feature:"agents",mode:"directory",source:{project:[Va],global:[Va]},canonicalDir:vl,extensions:[".md"],map:RC},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[Ri],global:[Za]},canonicalDir:".agentsmesh",canonicalFilename:Qa},ignore:{feature:"ignore",mode:"flatFile",source:{project:[Xa],global:[Xa]},canonicalDir:".agentsmesh",canonicalFilename:zI}},buildImportPaths:td,detectionPaths:["CLAUDE.md",".claude/rules",".claude/commands"]};});function uv(t){let e=basename(t,".md");return e==="_root"?"root":e}function LC(t){let e=[],r=t.rules.find(n=>n.root);if(r){let n=r.body.trim()?r.body:"";e.push({path:ao,content:n});}for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("cline"))continue;let o=uv(n.source),i={description:n.description||void 0,paths:n.globs.length>0?n.globs:void 0};Object.keys(i).forEach(c=>{i[c]===void 0&&delete i[c];});let a=Object.keys(i).length>0?N(i,n.body.trim()||""):n.body.trim()||"";e.push({path:`${wn}/${o}.md`,content:a});}return e}function bC(t){return t.commands.map(e=>{let r=e.description.trim(),n=e.body.trim(),o=r&&n?`${r}
|
|
64
64
|
|
|
65
|
-
${n}`:r||n;return {path:`${
|
|
66
|
-
`);return [{path:
|
|
67
|
-
`)}function
|
|
65
|
+
${n}`:r||n;return {path:`${vr}/${e.name}.md`,content:o}})}function AC(t){if(!t.ignore||t.ignore.length===0)return [];let e=t.ignore.join(`
|
|
66
|
+
`);return [{path:is,content:e}]}function xC(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=JSON.stringify({mcpServers:t.mcp.mcpServers},null,2);return [{path:Ln,content:e}]}function PC(t){return t.agents.map(e=>({path:`${Kt}/${z(e.name)}/SKILL.md`,content:ce(e)}))}function dv(t){return t.replace(/[^a-zA-Z0-9]/g,"-").toLowerCase()}function Md(t){return t.replace(/[\r\n]+/g," ")}function fv(t,e,r){return ["#!/usr/bin/env bash",`# agentsmesh-event: ${Md(t)}`,`# agentsmesh-matcher: ${Md(r)}`,`# agentsmesh-command: ${Md(e)}`,"set -eu",e,""].join(`
|
|
67
|
+
`)}function TC(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=[];for(let[r,n]of Object.entries(t.hooks)){if(!Array.isArray(n))continue;let o=0;for(let i of n)hn(i)&&(e.push({path:`${as}/${dv(r)}-${o}.sh`,content:fv(r,i.command,i.matcher)}),o++);}return e}function DC(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=N(n,r.body.trim()||"");e.push({path:`${Kt}/${r.name}/SKILL.md`,content:o});for(let i of r.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");e.push({path:`${Kt}/${r.name}/${a}`,content:i.content});}}return e}var NC=d(()=>{qe();v();ht();ve();s(uv,"ruleSlug");s(LC,"generateRules");s(bC,"generateCommands");s(AC,"generateIgnore");s(xC,"generateMcp");s(PC,"generateAgents");s(dv,"safeEventName");s(Md,"safeShellLine");s(fv,"buildHookScript");s(TC,"generateHooks");s(DC,"generateSkills");});async function vC(t,e,r){if(t==="workflows"||t.startsWith("workflows/"))return null;let n=t.replace(/\\/g,"/");if(n==="_root.md")return null;let o=join(e,n),{frontmatter:i,body:a}=E(r(o)),c=Cn(i.paths??i.globs),l={root:false,description:typeof i.description=="string"?i.description:void 0,globs:c.length>0?c:void 0};return Object.keys(l).forEach(m=>{l[m]===void 0&&delete l[m];}),{destPath:o,toPath:`${co}/${n}`,feature:"rules",content:await G(o,l,a)}}async function MC(t,e,r){let n=join(e,t),{frontmatter:o,body:i}=E(r(n)),a=Object.prototype.hasOwnProperty.call(o,"description"),c=a&&typeof o.description=="string"?o.description:"",l=a,m=i;if(!l){let p=i.indexOf(`
|
|
68
68
|
|
|
69
69
|
`);if(p>0){let u=i.slice(0,p).trim();u&&!u.includes(`
|
|
70
|
-
`)&&(c=u,l=true,m=i.slice(p+2));}}return {destPath:n,toPath:`${
|
|
71
|
-
`)),e.push({fromTool:"cline",fromPath:o,toPath:
|
|
70
|
+
`)&&(c=u,l=true,m=i.slice(p+2));}}return {destPath:n,toPath:`${Ml}/${t}`,feature:"commands",content:await it(n,{description:c,hasDescription:l,allowedTools:[],hasAllowedTools:Object.prototype.hasOwnProperty.call(o,"allowedTools")||Object.prototype.hasOwnProperty.call(o,"allowed-tools")},m)}}var $d=d(()=>{v();nt();nr();ve();s(vC,"mapClineRuleFile");s(MC,"mapClineWorkflowFile");});async function $C(t,e,r){let n=join(t,co),o=join(t,wn),i=join(t,wn),a=false;try{a=(await stat(i)).isFile();}catch{}if(a){let p=await y(i);if(p!==null){await O(n);let u=join(n,"_root.md"),{frontmatter:f,body:g}=E(r(p,i,u)),R=f.root===true?f:{...f,root:true},S=await G(u,R,g);await C(u,S),e.push({fromTool:"cline",fromPath:i,toPath:`${co}/_root.md`,feature:"rules"});}return a}let c=null,l=join(o,"_root.md"),m=await y(l);if(m===null){let p=join(t,ao),u=await y(p);if(u!==null){c=p,await O(n);let f=join(n,"_root.md"),{frontmatter:g,body:h}=E(r(u,p,f)),S=g.root===true?g:{...g,root:true},_=await G(f,S,h);await C(f,_),e.push({fromTool:"cline",fromPath:p,toPath:`${co}/_root.md`,feature:"rules"});}else {let h=(await D(o)).filter(R=>R.endsWith(".md")&&!R.includes("/workflows/")).sort()[0];if(h){let R=await y(h);if(R!==null){c=h,await O(n);let S=join(n,"_root.md"),{frontmatter:_,body:k}=E(r(R,h,S)),P=_.root===true?_:{..._,root:true},A=await G(S,P,k);await C(S,A),e.push({fromTool:"cline",fromPath:h,toPath:`${co}/_root.md`,feature:"rules"});}}}}else {c=l,await O(n);let p=join(n,"_root.md"),{frontmatter:u,body:f}=E(r(m,l,p)),h=u.root===true?u:{...u,root:true},R=await G(p,h,f);await C(p,R),e.push({fromTool:"cline",fromPath:l,toPath:`${co}/_root.md`,feature:"rules"});}return e.push(...await dt({srcDir:o,destDir:n,extensions:[".md"],fromTool:"cline",normalize:r,mapEntry:s(async({srcPath:p,relativePath:u,normalizeTo:f})=>p===c?null:vC(u,n,f),"mapEntry")})),a}var GC=d(()=>{b();v();nt();or();$d();ve();s($C,"importClineRules");});function hv(t){if(!t||typeof t!="object")return null;let e=t,r=typeof e.command=="string"?e.command:"";if(!r)return null;let n=typeof e.type=="string"?e.type:typeof e.transportType=="string"?e.transportType:"stdio",o=Array.isArray(e.args)?e.args.filter(l=>typeof l=="string"):[],i=e.env,a=i!==null&&typeof i=="object"&&!Array.isArray(i)?Object.fromEntries(Object.entries(i).filter(l=>typeof l[1]=="string")):{},c=typeof e.description=="string"?e.description:void 0;return {...c!==void 0&&{description:c},type:n,command:r,args:o,env:a}}async function jC(t,e){let r=[Ln,JI].map(l=>join(t,l)),n=null,o=null;for(let l of r){let m=await y(l);if(m!==null){n=l,o=m;break}}if(o===null)return;let i=n??r[0],a;try{a=JSON.parse(o);}catch{}let c=a?.mcpServers;if(c!==void 0&&typeof c=="object"&&c!==null&&Object.keys(c).length>0){let l={};for(let[m,p]of Object.entries(c)){let u=hv(p);u&&(l[m]=u);}Object.keys(l).length>0&&(await O(join(t,".agentsmesh")),await C(join(t,nd),JSON.stringify({mcpServers:l},null,2)),e.push({fromTool:io,fromPath:i,toPath:nd,feature:"mcp"}));}}var UC=d(()=>{b();ve();s(hv,"mapClineServerToCanonical");s(jC,"importClineMcp");});function WC(t){return yv.some(e=>e.test(t))}var yv,KC=d(()=>{yv=[/^\./,/^_ab-agent-/,/^_ab-command-/,/\.fixture\./,/\.test\./];s(WC,"isReservedArtifactName");});async function Iv(t){let e=await D(t).catch(()=>[]),r=[];for(let n of e){let o=relative(t,n).replace(/\\/g,"/"),i=basename(o);if(WC(i))continue;let a=await y(n);a!==null&&r.push({absolutePath:n,relativePath:o,content:a});}return r}async function Qr(t,e,r){let n=await Iv(e),o=join(r.projectRoot,r.destCanonicalSkillsDir,t);for(let i of n){let a=join(o,i.relativePath);await O(dirname(a));let c=r.normalize(i.content,i.absolutePath,a);if(i.relativePath==="SKILL.md"){let{frontmatter:l,body:m}=E(c),p=await Tr(a,{...l,name:t},m);await C(a,p);}else await C(a,c);r.results.push({fromTool:r.targetName,fromPath:i.absolutePath,toPath:`${r.destCanonicalSkillsDir}/${t}/${i.relativePath}`,feature:"skills"});}}async function HC(t,e,r,n){let o=join(n.projectRoot,n.destCanonicalSkillsDir,t);await O(o);let i=join(o,"SKILL.md"),a=n.normalize(r,e,i),{frontmatter:c,body:l}=E(a),m=await Tr(i,{...c,name:t},l);await C(i,m),n.results.push({fromTool:n.targetName,fromPath:e,toPath:`${n.destCanonicalSkillsDir}/${t}/SKILL.md`,feature:"skills"});}async function xo(t){let e=new Map;try{let n=(await D(t)).filter(o=>basename(o)==="SKILL.md");for(let o of n){let i=dirname(o),a=basename(i);e.set(a,i);}}catch{}return e}var Bi=d(()=>{b();v();nt();KC();s(Iv,"readNativeSkill");s(Qr,"importDirectorySkill");s(HC,"importFlatSkill");s(xo,"findDirectorySkills");});async function zC(t,e,r,n=Kt){let o=join(t,n),i=await xo(o),a={projectRoot:t,sourceSkillsDir:n,destCanonicalSkillsDir:YI,targetName:"cline",normalize:r,results:e};for(let[c,l]of i){let m=join(l,"SKILL.md"),p=await y(m);if(!p)continue;let u=E(p),f=Pr(u.frontmatter,c);if(f){let g=join(t,od);await O(g);let h=join(g,`${f.name}.md`);await C(h,Ae(f,r(u.body,m,h))),e.push({fromTool:"cline",fromPath:m,toPath:`${od}/${f.name}.md`,feature:"agents"});continue}await Qr(c,l,a);}}var VC=d(()=>{b();v();ht();Bi();ve();s(zC,"importClineSkills");});function Ud(t,e){return t.match(new RegExp(`^# agentsmesh-${e}:\\s*(.+)$`,"m"))?.[1]?.trim()??null}async function JC(t,e){let n=(await D(t).catch(()=>[])).filter(o=>basename(o).endsWith(".sh")&&dirname(o)===t);for(let o of n){let i=await y(o);if(!i)continue;let a=Ud(i,"event"),c=Ud(i,"command");if(!a||!c)continue;let l=Ud(i,"matcher")??"*";e[a]||(e[a]=[]),e[a].push({matcher:l,command:c});}}async function XC(t,e){let r={};if(await JC(join(t,as),r),await JC(join(t,ms),r),Object.keys(r).length===0)return;let n=join(t,ed);await O(dirname(n)),await C(n,stringify(r)),e.push({fromTool:io,fromPath:join(t,ms),toPath:ed,feature:"hooks"});}var ZC=d(()=>{b();ve();s(Ud,"extractMeta");s(JC,"loadHooksFromDir");s(XC,"importClineHooks");});async function im(t){let e=[],r=await H(io,t),n=await $C(t,e,r),o=join(t,is),i=await y(o);if(i!==null&&i.trim()){let c=i.split(/\r?\n/),l=[];for(let m of c){let p=m.trim();p&&!p.startsWith("#")&&l.push(p);}if(l.length>0){await O(join(t,".agentsmesh"));let m=join(t,rd);await C(m,l.join(`
|
|
71
|
+
`)),e.push({fromTool:"cline",fromPath:o,toPath:rd,feature:"ignore"});}}await jC(t,e);let a=join(t,Ml);return n||e.push(...await dt({srcDir:join(t,vr),destDir:a,extensions:[".md"],fromTool:"cline",normalize:r,mapEntry:s(({relativePath:c,normalizeTo:l})=>MC(c,a,l),"mapEntry")})),await zC(t,e,r),await XC(t,e),e}var Wd=d(()=>{Ot();b();or();$d();GC();ve();UC();VC();ZC();s(im,"importFromCline");});function qC(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(i=>({...i,target:io}))}var QC=d(()=>{Wt();ve();s(qC,"lintRules");});function tR(t){return t.commands.filter(e=>e.description.length>0||e.allowedTools.length>0).map(e=>j(e.source,"cline","cline workflow files are plain Markdown; command description and allowed-tools metadata are not projected."))}function eR(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","cline","cline hooks are emitted as .clinerules/hooks/*.sh wrapper scripts with a `#!/usr/bin/env bash` header; they require a POSIX shell (git-bash or WSL) to execute on Windows.")]:[]:[]}var rR=d(()=>{Tt();s(tR,"lintCommands");s(eR,"lintHooks");});var Rv,Ov,Ev,kv,nR,oR=d(()=>{NC();ts();ve();Wd();QC();rR();Nt();ui();ht();Rv={name:"cline",primaryRootInstructionPath:ao,generateRules:LC,generateCommands:bC,generateAgents:PC,generateSkills:DC,generateMcp:xC,generateHooks:TC,generateIgnore:AC,importFrom:im},Ov={rootInstructionPath:ao,skillDir:".cline/skills",managedOutputs:{dirs:[".cline/skills",".clinerules",".clinerules/hooks",".clinerules/workflows"],files:["AGENTS.md",".cline/cline_mcp_settings.json",".clineignore",".clinerules/typescript.md"]},paths:{rulePath(t,e){return `${wn}/${t}.md`},commandPath(t,e){return `${vr}/${t}.md`},agentPath(t,e){return be(e,"cline")?`.cline/skills/${z(t)}/SKILL.md`:null}}},Ev={skillDir:Kt,managedOutputs:{dirs:[cs,ls,ms,Kt,".agents/skills"],files:[Ln,is]},rewriteGeneratedPath(t){return t===ao?null:t.startsWith(`${as}/`)?`${ms}/${t.slice(as.length+1)}`:t.startsWith(`${vr}/`)?`${ls}/${t.slice(vr.length+1)}`:t.startsWith(`${wn}/`)?`${cs}/${t.slice(wn.length+1)}`:t},mirrorGlobalPath(t,e){return t.startsWith(`${Kt}/`)?`.agents/skills/${t.slice(Kt.length+1)}`:null},paths:{rulePath(t,e){return `${cs}/${t}.md`},commandPath(t,e){return `${ls}/${t}.md`},agentPath(t,e){return be(e,"cline")?`.cline/skills/${z(t)}/SKILL.md`:null}}},kv={rules:"native",additionalRules:"native",commands:er("native","workflows"),agents:"embedded",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"none"},nR={id:"cline",generators:Rv,capabilities:{rules:"native",additionalRules:"native",commands:er("native","workflows"),agents:"embedded",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"none"},emptyImportMessage:"No Cline config found (.clinerules, .clineignore, .cline/cline_mcp_settings.json, or .cline/skills).",supportsConversion:{agents:true},lintRules:qC,lint:{commands:tR,hooks:eR},project:Ov,globalSupport:{capabilities:kv,detectionPaths:[cs,ls,ms,Kt,Ln,is],layout:Ev},buildImportPaths:sd,detectionPaths:[".clinerules",".cline"]};});var Bt,sR,Wn,Ds,iR,Sr,aR,am,Ns,tn,Fs,Kn,Kd,Hi,Rc,Bd,cR,Hd,lR,mR,zd,Vd,Jd,Zt=d(()=>{Bt="codex-cli",sR="codex.md",Wn="AGENTS.md",Ds=".codex/AGENTS.md",iR=".codex/AGENTS.override.md",Sr=".agents/skills",aR=".codex/skills",am=".codex/config.toml",Ns=".codex/instructions",tn=".codex/rules",Fs=".codex/agents",Kn=".agentsmesh/rules",Kd=".agentsmesh/commands",Hi=".agentsmesh/agents",Rc=".agentsmesh/skills",Bd=".agentsmesh/mcp.json",cR="am-codex-rule:v1",Hd="# am-json: ",lR="# am-body-b64-begin",mR="# am-body-b64-end",zd="# am64:",Vd="<!-- agentsmesh:codex-rule-index:start -->",Jd="<!-- agentsmesh:codex-rule-index:end -->";});function Yd(t){return basename(t,".md")}function Oc(t){return `${Ns}/${Yd(t.source)}.md`}function pR(t){let e={root:t.root,description:t.description||void 0,globs:t.globs.length>0?t.globs:void 0,targets:t.targets.length>0?t.targets:void 0,codex_emit:t.codexEmit||void 0,codex_instruction:t.codexInstructionVariant&&t.codexInstructionVariant!=="default"?t.codexInstructionVariant:void 0};return Object.keys(e).forEach(r=>{e[r]===void 0&&delete e[r];}),N(e,t.body.trim()||"")}function Lv(t){let e=[];return t.root?e.push("Applies to the whole project."):t.globs.length>0?e.push(`Applies to ${t.globs.map(r=>`\`${r}\``).join(", ")}.`):e.push("General guidance with no file glob restriction."),t.codexInstructionVariant==="override"&&e.push("Override guidance when this rule conflicts with broader instructions."),t.codexEmit==="execution"&&e.push(`Enforced in \`${tn}/${Yd(t.source)}.rules\`.`),t.targets.length>0&&e.push(`Targeted to ${t.targets.map(r=>`\`${r}\``).join(", ")}.`),e.join(" ")}function uR(t,e){let r=t.trim(),n=e.filter(a=>!a.root);if(n.length===0)return r;let o=n.map(a=>`- [${a.description||Yd(a.source)}](${Oc(a)}): ${Lv(a)}`),i=[Vd,"## Additional Rule Files",...o,Jd].join(`
|
|
72
72
|
`);return r?`${r}
|
|
73
73
|
|
|
74
|
-
${i}`:i}function
|
|
75
|
-
`).trim()}var
|
|
74
|
+
${i}`:i}function dR(t){let e=Vd.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),r=Jd.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");return t.replace(new RegExp(`\\n?${e}[\\s\\S]*?${r}\\n?`,"g"),`
|
|
75
|
+
`).trim()}var cm=d(()=>{v();Zt();s(Yd,"ruleSlug");s(Oc,"codexInstructionMirrorPath");s(pR,"serializeCodexInstructionMirror");s(Lv,"summarizeRule");s(uR,"appendCodexRuleIndex");s(dR,"stripCodexRuleIndex");});function Av(t){return /(^|\n)\s*[A-Za-z_][A-Za-z0-9_]*\s*\(/.test(t)}function xv(t){return t.split(`
|
|
76
76
|
`).map(e=>e.length>0?`# ${e}`:"#").join(`
|
|
77
|
-
`)}function
|
|
78
|
-
`:`${["# agentsmesh: canonical execution rule body is not Codex DSL","# The original body is preserved below as comments.","# Replace with Codex rules DSL (for example prefix_rule(...)) to enforce behavior.","#",...
|
|
77
|
+
`)}function Pv(t){let e=t.trim();return e?Av(e)?`${e}
|
|
78
|
+
`:`${["# agentsmesh: canonical execution rule body is not Codex DSL","# The original body is preserved below as comments.","# Replace with Codex rules DSL (for example prefix_rule(...)) to enforce behavior.","#",...xv(e).split(`
|
|
79
79
|
`),"#","# Example template:","# prefix_rule(",'# pattern = ["git", "status"],','# decision = "allow",','# justification = "Allow safe status checks",',"# )"].join(`
|
|
80
80
|
`)}
|
|
81
|
-
`:""}function
|
|
81
|
+
`:""}function Xd(t){let e=t.rules.find(n=>n.root),r=[];e&&r.push({path:Wn,content:uR(e.body,t.rules)});for(let n of t.rules){if(n.root)continue;let o=basename(n.source,".md");n.targets.length>0&&!n.targets.includes("codex-cli")||(n.codexEmit==="execution"&&r.push({path:`${tn}/${o}.rules`,content:Pv(n.body)}),r.push({path:Oc(n),content:pR(n)}));}return r}function Zd(t){let e=t.rules.find(n=>n.root),r=t.rules.filter(n=>n.root||n.codexEmit==="execution"?false:n.targets.length===0||n.targets.includes("codex-cli"));return xt(e?.body.trim()??"",r)}var fR=d(()=>{xe();Zt();cm();s(Av,"looksLikeCodexRulesDsl");s(xv,"toCodexRulesComments");s(Pv,"toSafeCodexRulesContent");s(Xd,"generateRules");s(Zd,"renderCodexGlobalInstructions");});function qd(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=N(n,r.body.trim()||"");e.push({path:`${Sr}/${r.name}/SKILL.md`,content:o});for(let i of r.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");e.push({path:`${Sr}/${r.name}/${a}`,content:i.content});}}return e}function Tv(t){return {path:`${Sr}/${at(t.name)}/SKILL.md`,content:xr(t)}}function Qd(t){return t.commands.map(Tv)}var gR=d(()=>{v();Zt();ae();s(qd,"generateSkills");s(Tv,"commandToSkillOutput");s(Qd,"generateCommands");});function tf(t){return t.agents.map(e=>({path:`${Fs}/${e.name}.toml`,content:Dv(e)}))}function Dv(t){let e=[];e.push(`name = ${JSON.stringify(t.name)}`),t.description&&e.push(`description = ${JSON.stringify(t.description)}`),t.model&&e.push(`model = ${JSON.stringify(t.model)}`),t.permissionMode==="read-only"||t.permissionMode==="deny"?e.push('sandbox_mode = "read-only"'):t.permissionMode==="allow"&&e.push('sandbox_mode = "workspace-write"');let r=t.body.trim()||"";if(r.includes("'''")){let n=r.replace(/\\/g,"\\\\").replace(/"/g,'\\"');e.push(`developer_instructions = """
|
|
82
82
|
${n}
|
|
83
83
|
"""`);}else e.push(`developer_instructions = '''
|
|
84
84
|
${r}
|
|
85
85
|
'''`);return e.join(`
|
|
86
86
|
`)+`
|
|
87
|
-
`}var
|
|
87
|
+
`}var hR=d(()=>{Zt();s(tf,"generateAgents");s(Dv,"serializeAgentToCodexToml");});function lm(t){return "command"in t}function yR(t){return "url"in t}var mm=d(()=>{s(lm,"isStdioMcpServer");s(yR,"isUrlMcpServer");});function ef(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=Object.fromEntries(Object.entries(t.mcp.mcpServers).flatMap(([n,o])=>lm(o)?[[n,o]]:[]));if(Object.keys(e).length===0)return [];let r=Nv(e);return [{path:am,content:r}]}function Nv(t){let e=[];for(let[r,n]of Object.entries(t)){let o=_R(r)?`"${r}"`:r,i=[];i.push(`[mcp_servers.${o}]`),i.push(`command = ${JSON.stringify(n.command)}`);let a="["+n.args.map(l=>JSON.stringify(l)).join(", ")+"]";i.push(`args = ${a}`);let c=Object.entries(n.env);if(c.length>0){let l=c.map(([m,p])=>`${_R(m)?JSON.stringify(m):m} = ${JSON.stringify(p)}`).join(", ");i.push(`env = { ${l} }`);}e.push(i.join(`
|
|
88
88
|
`));}return e.join(`
|
|
89
89
|
|
|
90
90
|
`)+`
|
|
91
|
-
`}function
|
|
92
|
-
`).find(l=>l.startsWith(
|
|
93
|
-
`)){let m=l.trimEnd();if(m===vS){c=true;continue}if(m===MS){c=false;continue}c&&m.startsWith(Td)&&a.push(m.slice(Td.length));}if(a.length===0)return null;try{let l=Buffer$1.from(a.join(""),"base64").toString("utf8");return {meta:{description:o,globs:i},body:l}}catch{return null}}var rR=d(()=>{Vt();s(eR,"tryParseEmbeddedCanonicalFromCodexRules");});async function oR(t,e,r){let n=[],o=join(t,Yr);try{let i=await N(o),a=i.filter(l=>l.endsWith(".md"));for(let l of a){let m=await y(l);if(!m)continue;let p=relative(o,l).replace(/\\/g,"/"),u=join(e,p),{frontmatter:f,body:g}=w(r(m,l,u));await O(e);let h=f.root===!0?f:{...f,root:!1},R=await j(u,h,g);await S(u,R),n.push({fromTool:jt,fromPath:l,toPath:`${Mn}/${p}`,feature:"rules"});}let c=i.filter(l=>l.endsWith(".rules"));for(let l of c){let m=await y(l);if(!m)continue;let p=relative(o,l).replace(/\\/g,"/").replace(/\.rules$/i,".md"),u=join(e,p);await O(e);let f=eR(m);if(f){let g=await j(u,{description:f.meta.description,globs:f.meta.globs,root:!1},r(f.body,l,u));await S(u,g);}else {let g=await j(u,{root:!1,description:"",globs:[],codex_emit:"execution"},r(m.trim(),l,u));await S(u,g);}n.push({fromTool:jt,fromPath:l,toPath:`${Mn}/${p}`,feature:"rules"});}}catch{}return n}var sR=d(()=>{A();M();et();Vt();rR();s(oR,"importCodexNonRootRuleFiles");});async function aR(t,e,r,n,o){let i=join(t,TS),a=join(t,vn),c=join(t,DS),l=join(t,Es),m=o==="global"?await y(c):null,p=o==="global"?await y(l):null,u=o==="project"?await y(a):null,f=o==="project"?await y(i):null,g=m!==null?c:p!==null?l:u!==null?a:i,h=join(t,Mn),R=m??p??u??f;if(R!==null){await O(h);let C=join(h,"_root.md"),_=g===a||g===l||g===c?jS(R):R,E=await Vr({content:_,projectRoot:t,rulesDir:Mn,sourcePath:g,fromTool:"codex-cli",normalize:r});e.push(...E.results);let T=r(g===a||g===l||g===c?n(E.rootContent,g,C):E.rootContent,g,C),{frontmatter:D,body:x}=w(T),Z=D.root===true?D:{...D,root:true},B=await j(C,Z,x);await S(C,B),e.push({fromTool:"codex-cli",fromPath:g,toPath:`${Mn}/_root.md`,feature:"rules"});}await rv(t,h,e,r),e.push(...await oR(t,h,r)),o!=="global"&&e.push(...await mt({srcDir:t,destDir:h,extensions:["AGENTS.md","AGENTS.override.md"],fromTool:"codex-cli",normalize:r,mapEntry:s(async({srcPath:C,normalizeTo:_})=>{let E=relative(t,dirname(C)).replace(/\\/g,"/"),T=basename(C),D=T==="AGENTS.override.md";if(!E||E==="."||!D&&T!=="AGENTS.md")return null;let x=E.replace(/\//g,"-");if(!Rl(E))return await Ee(join(h,`${x}.md`)),null;let Z=join(h,`${x}.md`),{frontmatter:B,body:J}=w(_(Z));return {destPath:Z,toPath:`${Mn}/${x}.md`,feature:"rules",content:await j(Z,{...B,root:false,globs:[`${E}/**`],...D?{codex_instruction:"override"}:{}},J)}},"mapEntry")}));}async function rv(t,e,r,n){try{let i=(await N(join(t,Ls))).filter(c=>c.endsWith(".md")),a=join(t,Ls);for(let c of i){let l=relative(a,c).replace(/\\/g,"/");if(l==="_root.md")continue;let m=await y(c);if(!m)continue;let p=join(e,l),{frontmatter:u,body:f}=w(n(m,c,p));await O(e);let g=u.root===!0?u:{...u,root:!1},h=await j(p,g,f);await S(p,h),r.push({fromTool:jt,fromPath:c,toPath:`${Mn}/${l}`,feature:"rules"});}}catch{}}var cR=d(()=>{A();M();et();vi();tr();mi();Vt();sR();tm();s(aR,"importCodexRules");s(rv,"importInstructionMirrors");});async function nm(t,e){let r=e?.scope??"project",n=[],o=await z(jt,t,r),i=await z("windsurf",t,r);return await aR(t,n,o,i,r),await ZS(t,n,o),await QS(t,n,o),await YS(t,n),n}var Bd=d(()=>{It();Vt();XS();qS();tR();cR();s(nm,"importFromCodex");});function lR(t,e,r){let{rules:n}=t;return n.length===0?[]:n.some(i=>i.root)?[]:[{level:"warning",file:relative(e,n[0].source),target:jt,message:"Codex needs a root rule to generate AGENTS.md. Add root: true to a rule."}]}var mR=d(()=>{Vt();s(lR,"lintRules");});function pR(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=[];for(let[r,n]of Object.entries(t.mcp.mcpServers))if(typeof n.description=="string"&&n.description&&e.push(U(".agentsmesh/mcp.json","codex-cli",`MCP server "${r}" has a description, but codex-cli does not project MCP descriptions into .codex/config.toml.`)),"url"in n||"type"in n){let o="type"in n?n.type:"url";e.push(U(".agentsmesh/mcp.json","codex-cli",`MCP server "${r}" uses ${o} transport; codex-cli only generates stdio MCP servers.`));}return e}var uR=d(()=>{bt();s(pR,"lintMcp");});function dR(t){return _c(t)}var fR=d(()=>{tm();s(dR,"codexAdvisoryInstructionPath");});var ov,sv,iv,av,hR,yR=d(()=>{JS();Vt();Bd();mR();uR();xt();si();fR();ne();ov={name:"codex-cli",primaryRootInstructionPath:vn,generateRules:vd,generateCommands:Gd,generateAgents:jd,generateSkills:$d,generateMcp:Ud,importFrom:nm},sv={rootInstructionPath:vn,extraRuleOutputPaths(t){if(t.root||t.codexEmit!=="execution")return [];let e=basename(t.source,".md");return [`${Yr}/${e}.rules`]},skillDir:".agents/skills",managedOutputs:{dirs:[".agents/skills",".codex/agents",".codex/instructions"],files:["AGENTS.md",".codex/config.toml"]},paths:{rulePath(t,e){return dR(e)},commandPath(t,e){return oi(e,"codex-cli")?`${hr}/${st(t)}/SKILL.md`:null},agentPath(t,e){return `${bs}/${t}.toml`}}},iv={rootInstructionPath:Es,renderPrimaryRootInstruction:Md,extraRuleOutputPaths(t){if(t.root||t.codexEmit!=="execution")return [];let e=basename(t.source,".md");return [`${Yr}/${e}.rules`]},skillDir:hr,managedOutputs:{dirs:[".agents/skills",".codex/agents",".codex/rules"],files:[Es,".codex/config.toml"]},rewriteGeneratedPath(t){return t===vn?Es:t.startsWith(`${Ls}/`)?null:t},paths:{rulePath(t,e){return e.codexEmit==="execution"?`${Yr}/${t}.rules`:Es},commandPath(t,e){return oi(e,"codex-cli")?`${hr}/${st(t)}/SKILL.md`:null},agentPath(t,e){return `${bs}/${t}.toml`}}},av={rules:"native",additionalRules:"embedded",commands:"embedded",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},hR={id:"codex-cli",generators:ov,capabilities:{rules:"native",additionalRules:"native",commands:"embedded",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},emptyImportMessage:"No Codex config found (codex.md or AGENTS.md).",supportsConversion:{commands:true},lintRules:lR,lint:{mcp:pR},project:sv,globalSupport:{capabilities:av,detectionPaths:[".codex/AGENTS.md",".codex/AGENTS.override.md",".codex/config.toml",".codex/agents",".codex/rules",".agents/skills"],layout:iv},buildImportPaths:Vu,sharedArtifacts:{".agents/skills/":"owner"},detectionPaths:["codex.md","AGENTS.md","AGENTS.override.md",".codex/config.toml",".codex/agents",".codex/rules"]};});function lv(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"&&e.length>0):typeof t=="string"&&t.length>0?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function _R(t){return `${Tr}/${t}.md`}function IR(t){let e={description:t.description||void 0,"x-agentsmesh-kind":"command","x-agentsmesh-name":t.name,"x-agentsmesh-allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return e.description===void 0&&delete e.description,e["x-agentsmesh-allowed-tools"]===void 0&&delete e["x-agentsmesh-allowed-tools"],F(e,t.body.trim()||"")}function CR(t,e){let r=basename(e,".md");return {name:((typeof t["x-agentsmesh-name"]=="string"?t["x-agentsmesh-name"]:"")||r).trim(),description:typeof t.description=="string"?t.description:"",allowedTools:lv(t["x-agentsmesh-allowed-tools"])}}function SR(t,e){let r={description:t.description||void 0,"allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return r.description===void 0&&delete r.description,r["allowed-tools"]===void 0&&delete r["allowed-tools"],F(r,e.trim()||"")}var om=d(()=>{M();Dr();s(lv,"toStringArray");s(_R,"continueCommandRulePath");s(IR,"serializeCommandRule");s(CR,"parseCommandRuleFrontmatter");s(SR,"serializeImportedCommand");});function RR(t){let e=[],r=t.rules.find(n=>n.root);if(r){let n={};r.description&&(n.description=r.description),e.push({path:Rn,content:F(n,r.body.trim()||"")});}for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("continue"))continue;let o=basename(n.source,".md"),i={};n.description&&(i.description=n.description),n.globs.length>0&&(i.globs=n.globs),e.push({path:`${nr}/${o}.md`,content:F(i,n.body.trim()||"")});}return e}function kR(t){return t.commands.map(e=>({path:`${Tr}/${e.name}.md`,content:IR(e)}))}function OR(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:xl,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function wR(t){return t.agents.map(e=>({path:`${de}/${V(e.name)}/SKILL.md`,content:oe(e)}))}function ER(t){return St(t,de)}var LR=d(()=>{_t();dt();M();om();Dr();s(RR,"generateRules");s(kR,"generateCommands");s(OR,"generateMcp");s(wR,"generateAgents");s(ER,"generateSkills");});function dv(t,e){let n=(e===".json"?JSON.parse(t):parse(t)??{}).mcpServers;if(!n||typeof n!="object"||Array.isArray(n))return {};let o={};for(let[i,a]of Object.entries(n)){if(!a||typeof a!="object"||Array.isArray(a))continue;let c=a;typeof c.command=="string"&&(o[i]={type:typeof c.type=="string"?c.type:"stdio",command:c.command,args:pi(c.args),env:ui(c.env),description:typeof c.description=="string"?c.description:void 0});}return o}async function fv(t,e){let r=(await N(join(t,Ju))).filter(i=>[".json",".yaml",".yml"].includes(extname(i))),n={},o=[];for(let i of r){let a=await y(i);a&&(Object.assign(n,dv(a,extname(i))),o.push(i));}if(Object.keys(n).length!==0){await Ht(t,Xu,n);for(let i of o)e.push({fromTool:hi,fromPath:i,toPath:Xu,feature:"mcp"});}}async function sm(t){let e=[],r=await z(hi,t);return e.push(...await Q(im,t,"project",{normalize:r})),await yt(t,de,hi,e,r),await fv(t,e),e}var Hd=d(()=>{It();A();_t();Mt();fn();Qe();Dr();zd();s(dv,"readMcpServers");s(fv,"importMcp");s(sm,"importFromContinue");});function gv(t){return t==="general.md"||t==="_root.md"}var AR,xR,PR=d(()=>{M();et();om();Dr();s(gv,"isContinueRootRulePath");AR=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=gv(t),o=n?"_root.md":t,i=join(r,o),{frontmatter:a,body:c}=w(e(i)),l={description:typeof a.description=="string"?a.description:void 0,globs:Array.isArray(a.globs)?a.globs:void 0,root:n};return l.description===void 0&&delete l.description,l.globs===void 0&&delete l.globs,{destPath:i,toPath:`${Pl}/${o}`,content:await j(i,l,c)}},"continueRuleMapper"),xR=s(async({absolutePath:t,relativePath:e,normalizeTo:r,destDir:n})=>{let o=join(n,e),{frontmatter:i,body:a}=w(r(o)),c=CR(i,t),l=c.name||e.replace(/\.md$/,"").replace(/^.*\//,""),m=e.includes("/")?e.slice(0,e.lastIndexOf("/")):"",p=m?`${m}/${l}.md`:`${l}.md`,u=join(n,p),f=await ot(u,{description:c.description,hasDescription:!!c.description,allowedTools:c.allowedTools,hasAllowedTools:c.allowedTools.length>0},w(SR(c,a)).body);return {destPath:u,toPath:`${Tl}/${p}`,content:f}},"continueCommandMapper");});function TR(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:hi}))}var DR=d(()=>{$t();Dr();s(TR,"lintRules");});function NR(t){return t.commands.filter(e=>e.allowedTools.length>0).map(e=>U(e.source,"continue","Continue invokable prompt rules do not natively enforce canonical allowed-tools metadata."))}var FR=d(()=>{bt();s(NR,"lintCommands");});function Iv(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var vR,MR=d(()=>{A();Dr();s(Iv,"computeStatus");vR=s(async(t,e,r,n)=>{if(r!=="global")return [];let o=n.has("rules"),i=n.has("commands"),a=n.has("mcp");if(!(o&&t.rules.length>0||i&&t.commands.length>0||a&&t.mcp!==null&&Object.keys(t.mcp.mcpServers).length>0))return [];let l={name:"agentsmesh",version:1,schema:"v1"};if(o&&t.rules.length>0&&(l.rules=t.rules.map(u=>({name:u.description||basename(u.source,".md"),rule:u.body.trim()}))),i&&t.commands.length>0&&(l.prompts=t.commands.map(u=>{let f={name:u.name};return u.description&&(f.description=u.description),f.prompt=u.body.trim(),f})),a&&t.mcp!==null){let u=Object.entries(t.mcp.mcpServers);u.length>0&&(l.mcpServers=u.map(([f,g])=>({name:f,...g})));}let m=stringify(l),p=await y(join(e,Ya));return [{target:"continue",path:Ya,content:m,currentContent:p??void 0,status:Iv(p,m)}]},"generateContinueGlobalConfig");});function Sv(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var $R,GR=d(()=>{A();Dr();MR();s(Sv,"computeStatus");$R=s(async(t,e,r,n)=>{let o=await vR(t,e,r,n);if(r!=="global"||!n.has("rules"))return o;let i=t.rules.find(l=>l.root);if(!i)return o;let a=i.body.trim(),c=await y(join(e,yi));return [...o,{target:"continue",path:yi,content:a,currentContent:c??void 0,status:Sv(c,a)}]},"generateContinueScopeExtras");});var Rv,kv,Ov,wv,im,zd=d(()=>{dt();LR();Dr();Hd();PR();DR();FR();om();xt();GR();Rv={name:"continue",primaryRootInstructionPath:Rn,generateRules:RR,generateCommands:kR,generateAgents:wR,generateSkills:ER,generateMcp:OR,importFrom:sm},kv={rootInstructionPath:Rn,skillDir:".continue/skills",managedOutputs:{dirs:[".continue/prompts",".continue/rules",".continue/skills"],files:[".continue/mcpServers/agentsmesh.json"]},paths:{rulePath(t,e){return `${nr}/${t}.md`},commandPath(t,e){return _R(t)},agentPath(t){return `${de}/${V(t)}/SKILL.md`}}},Ov={rootInstructionPath:Rn,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[yi]}],skillDir:de,managedOutputs:{dirs:[nr,Tr,de,".agents/skills"],files:[xl,yi,Ya]},mirrorGlobalPath(t,e){return t.startsWith(`${de}/`)?`.agents/skills/${t.slice(de.length+1)}`:null},paths:{rulePath(t,e){return `${nr}/${t}.md`},commandPath(t,e){return `${Tr}/${t}.md`},agentPath(t){return `${de}/${V(t)}/SKILL.md`}}},wv={rules:"native",additionalRules:"native",commands:"native",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},im={id:"continue",generators:Rv,capabilities:{rules:"native",additionalRules:"native",commands:"embedded",agents:"none",skills:"embedded",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},emptyImportMessage:"No Continue config found (.continue/rules/*.md, .continue/skills, or .continue/mcpServers/*).",supportsConversion:{agents:true},lintRules:TR,lint:{commands:NR},project:kv,globalSupport:{capabilities:wv,detectionPaths:[nr,Tr,".continue/mcpServers",de],layout:Ov,scopeExtras:$R},importer:{rules:{feature:"rules",mode:"directory",source:{project:[nr],global:[nr]},canonicalDir:Pl,extensions:[".md"],map:AR},commands:{feature:"commands",mode:"directory",source:{project:[Tr],global:[Tr]},canonicalDir:Tl,extensions:[".md"],map:xR}},buildImportPaths:Zu,detectionPaths:[".continue/rules",".continue/skills",".continue/mcpServers"]};});var $n,As,jR,xs,Eo,Zr,qr,Ps,Ts,am,cm,UR,Jd,KR,Lo,Gi,Gn,ji,Ds,Yd,Xd,ve=d(()=>{$n="copilot",As=".github/copilot-instructions.md",jR=".github/copilot",xs=".github/instructions",Eo=".github/prompts",Zr=".github/hooks",qr=".github/skills",Ps=".github/agents",Ts=".agentsmesh/rules",am=".agentsmesh/commands",cm=".agentsmesh/agents",UR=".agentsmesh/skills",Jd=".agentsmesh/hooks.yaml",KR=".github/copilot-hooks",Lo=".copilot/copilot-instructions.md",Gi=".copilot/agents",Gn=".copilot/skills",ji=".copilot/prompts",Ds=".copilot/AGENTS.md",Yd=".claude/skills",Xd=".agents/skills";});function WR(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"&&e.length>0):typeof t=="string"&&t.length>0?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function lm(t){return `${Eo}/${t}.prompt.md`}function BR(t){let e={agent:"agent",description:t.description||void 0,"x-agentsmesh-kind":"command","x-agentsmesh-name":t.name,"x-agentsmesh-allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return e.description===void 0&&delete e.description,e["x-agentsmesh-allowed-tools"]===void 0&&delete e["x-agentsmesh-allowed-tools"],F(e,t.body.trim()||"")}function HR(t,e){let n=((typeof t["x-agentsmesh-name"]=="string"?t["x-agentsmesh-name"]:"")||basename(e,".prompt.md")).trim(),o=WR(t["x-agentsmesh-allowed-tools"]),i=o.length>0?o:WR(t.tools);return {name:n,description:typeof t.description=="string"?t.description:"",allowedTools:i}}var mm=d(()=>{M();ve();s(WR,"toStringArray");s(lm,"commandPromptPath");s(BR,"serializeCommandPrompt");s(HR,"parseCommandPromptFrontmatter");});function pm(t){return mn(t)}var Zd=d(()=>{Je();s(pm,"hasHookCommand");});function bv(t){let e=basename(t,".md");return e==="_root"?"root":e}function Av(t){switch(t){case "PreToolUse":return "preToolUse";case "PostToolUse":return "postToolUse";case "Notification":return "notification";case "UserPromptSubmit":return "userPromptSubmitted";default:return null}}function zR(t){let e=[],r=t.rules.find(n=>n.root);r?.body.trim()&&e.push(r.body.trim());for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("copilot"))continue;let o=n.body.trim();if(!o)continue;let i=n.description?`## ${n.description}`:null;i?e.push(`${i}
|
|
91
|
+
`}function _R(t){return !/^[A-Za-z0-9_-]+$/.test(t)}var IR=d(()=>{mm();Zt();s(ef,"generateMcp");s(Nv,"serializeMcpToToml");s(_R,"needsTomlQuoting");});var SR=d(()=>{fR();gR();hR();IR();});var CR=d(()=>{SR();});function Mv(t){if(!t||typeof t!="object"||Array.isArray(t))return null;let e=t,r=typeof e.command=="string"?e.command:"";if(!r)return null;let n=Array.isArray(e.args)?e.args.filter(a=>typeof a=="string"):[],o=e.env,i=o!==null&&typeof o=="object"&&!Array.isArray(o)?Object.fromEntries(Object.entries(o).filter(a=>typeof a[1]=="string")):{};return {type:"stdio",command:r,args:n,env:i}}async function RR(t,e){let r=join(t,am),n=await y(r);if(n===null)return;let o;try{o=parse$1(n);}catch{return}let i=o.mcp_servers;if(!i||typeof i!="object"||Array.isArray(i)||Object.keys(i).length===0)return;let a={};for(let[c,l]of Object.entries(i)){let m=Mv(l);m&&(a[c]=m);}Object.keys(a).length!==0&&(await Yt(t,Bd,a),e.push({fromTool:Bt,fromPath:r,toPath:Bd,feature:"mcp"}));}var OR=d(()=>{b();Sn();Zt();s(Mv,"mapTomlServerToCanonical");s(RR,"importMcp");});async function ER(t,e,r){let n={projectRoot:t,sourceSkillsDir:Sr,destCanonicalSkillsDir:Rc,targetName:Bt,normalize:r,results:e};for(let o of [Sr,aR]){let i=join(t,o),a=await readdir(i,{encoding:"utf8",withFileTypes:true}).catch(()=>null);if(a===null)continue;let c=false;for(let l of a){if(!l.isDirectory()&&!l.isSymbolicLink())continue;let m=join(i,l.name),p=join(m,"SKILL.md"),u=await y(p);if(!u)continue;c=true;let f=l.name,g=join(t,Rc,f,"SKILL.md"),h=r(u,p,g),{frontmatter:R,body:S}=E(h),_=kl(R,l.name);if(_){await Pe(join(t,Rc,f));let T=join(t,Kd);await O(T);let P=join(T,`${_.name}.md`);await C(P,wl(_,r(S,p,P))),e.push({fromTool:Bt,fromPath:p,toPath:`${Kd}/${_.name}.md`,feature:"commands"});continue}let k=Pr(R,l.name);if(k){await Pe(join(t,Rc,f));let T=join(t,Hi);await O(T);let P=join(T,`${k.name}.md`);await C(P,Ae(k,r(S,p,P))),e.push({fromTool:Bt,fromPath:p,toPath:`${Hi}/${k.name}.md`,feature:"agents"});continue}await Qr(f,m,n);}if(c)return}}var kR=d(()=>{b();v();ae();ht();yi();Bi();Zt();s(ER,"importSkills");});async function wR(t,e,r){let n=join(t,Fs),o=join(t,Hi);try{let a=(await D(n)).filter(c=>c.endsWith(".toml"));for(let c of a){let l=await y(c);if(!l)continue;let m=parse$1(l);if(!m||typeof m!="object")continue;let p=typeof m.name=="string"?m.name:basename(c,".toml"),u=typeof m.description=="string"?m.description:"",f=typeof m.developer_instructions=="string"?m.developer_instructions.trim():"",g=typeof m.model=="string"?m.model:"",h=typeof m.sandbox_mode=="string"?m.sandbox_mode:"",R=h==="read-only"?"read-only":h==="workspace-write"?"allow":"",S=Array.isArray(m.mcp_servers)?m.mcp_servers.filter(A=>typeof A=="string"):[];await O(o);let _=join(o,`${p}.md`),k=r(f,c,_),P=Ae({name:p,description:u,tools:[],disallowedTools:[],model:g,permissionMode:R,maxTurns:0,mcpServers:S,hooks:{},skills:[],memory:""},k);await C(_,P),e.push({fromTool:Bt,fromPath:c,toPath:`${Hi}/${p}.md`,feature:"agents"});}}catch{}}var LR=d(()=>{b();ht();Zt();s(wR,"importCodexAgentsFromToml");});function bR(t){if(!t.includes(cR))return null;let e=t.split(`
|
|
92
|
+
`).find(l=>l.startsWith(Hd));if(!e)return null;let r;try{r=JSON.parse(e.slice(Hd.length));}catch{return null}if(!r||typeof r!="object")return null;let n=r,o=typeof n.description=="string"?n.description:"",i=Array.isArray(n.globs)?n.globs.filter(l=>typeof l=="string"):[],a=[],c=false;for(let l of t.split(`
|
|
93
|
+
`)){let m=l.trimEnd();if(m===lR){c=true;continue}if(m===mR){c=false;continue}c&&m.startsWith(zd)&&a.push(m.slice(zd.length));}if(a.length===0)return null;try{let l=Buffer$1.from(a.join(""),"base64").toString("utf8");return {meta:{description:o,globs:i},body:l}}catch{return null}}var AR=d(()=>{Zt();s(bR,"tryParseEmbeddedCanonicalFromCodexRules");});async function PR(t,e,r){let n=[],o=join(t,tn);try{let i=await D(o),a=i.filter(l=>l.endsWith(".md"));for(let l of a){let m=await y(l);if(!m)continue;let p=relative(o,l).replace(/\\/g,"/"),u=join(e,p),{frontmatter:f,body:g}=E(r(m,l,u));await O(e);let h=f.root===!0?f:{...f,root:!1},R=await G(u,h,g);await C(u,R),n.push({fromTool:Bt,fromPath:l,toPath:`${Kn}/${p}`,feature:"rules"});}let c=i.filter(l=>l.endsWith(".rules"));for(let l of c){let m=await y(l);if(!m)continue;let p=relative(o,l).replace(/\\/g,"/").replace(/\.rules$/i,".md"),u=join(e,p);await O(e);let f=bR(m);if(f){let g=await G(u,{description:f.meta.description,globs:f.meta.globs,root:!1},r(f.body,l,u));await C(u,g);}else {let g=await G(u,{root:!1,description:"",globs:[],codex_emit:"execution"},r(m.trim(),l,u));await C(u,g);}n.push({fromTool:Bt,fromPath:l,toPath:`${Kn}/${p}`,feature:"rules"});}}catch{}return n}var TR=d(()=>{b();v();nt();Zt();AR();s(PR,"importCodexNonRootRuleFiles");});async function NR(t,e,r,n,o){let i=join(t,sR),a=join(t,Wn),c=join(t,iR),l=join(t,Ds),m=o==="global"?await y(c):null,p=o==="global"?await y(l):null,u=o==="project"?await y(a):null,f=o==="project"?await y(i):null,g=m!==null?c:p!==null?l:u!==null?a:i,h=join(t,Kn),R=m??p??u??f;if(R!==null){await O(h);let S=join(h,"_root.md"),_=g===a||g===l||g===c?dR(R):R,k=await qr({content:_,projectRoot:t,rulesDir:Kn,sourcePath:g,fromTool:"codex-cli",normalize:r});e.push(...k.results);let T=r(g===a||g===l||g===c?n(k.rootContent,g,S):k.rootContent,g,S),{frontmatter:P,body:A}=E(T),Z=P.root===true?P:{...P,root:true},B=await G(S,Z,A);await C(S,B),e.push({fromTool:"codex-cli",fromPath:g,toPath:`${Kn}/_root.md`,feature:"rules"});}await Bv(t,h,e,r),e.push(...await PR(t,h,r)),o!=="global"&&e.push(...await dt({srcDir:t,destDir:h,extensions:["AGENTS.md","AGENTS.override.md"],fromTool:"codex-cli",normalize:r,mapEntry:s(async({srcPath:S,normalizeTo:_})=>{let k=relative(t,dirname(S)).replace(/\\/g,"/"),T=basename(S),P=T==="AGENTS.override.md";if(!k||k==="."||!P&&T!=="AGENTS.md")return null;let A=k.replace(/\//g,"-");if(!xl(k))return await Pe(join(h,`${A}.md`)),null;let Z=join(h,`${A}.md`),{frontmatter:B,body:V}=E(_(Z));return {destPath:Z,toPath:`${Kn}/${A}.md`,feature:"rules",content:await G(Z,{...B,root:false,globs:[`${k}/**`],...P?{codex_instruction:"override"}:{}},V)}},"mapEntry")}));}async function Bv(t,e,r,n){try{let i=(await D(join(t,Ns))).filter(c=>c.endsWith(".md")),a=join(t,Ns);for(let c of i){let l=relative(a,c).replace(/\\/g,"/");if(l==="_root.md")continue;let m=await y(c);if(!m)continue;let p=join(e,l),{frontmatter:u,body:f}=E(n(m,c,p));await O(e);let g=u.root===!0?u:{...u,root:!1},h=await G(p,g,f);await C(p,h),r.push({fromTool:Bt,fromPath:c,toPath:`${Kn}/${l}`,feature:"rules"});}}catch{}}var FR=d(()=>{b();v();nt();Ki();or();yi();Zt();TR();cm();s(NR,"importCodexRules");s(Bv,"importInstructionMirrors");});async function pm(t,e){let r=e?.scope??"project",n=[],o=await H(Bt,t,r),i=await H("windsurf",t,r);return await NR(t,n,o,i,r),await ER(t,n,o),await wR(t,n,o),await RR(t,n),n}var of=d(()=>{Ot();Zt();OR();kR();LR();FR();s(pm,"importFromCodex");});function vR(t,e,r){let{rules:n}=t;return n.length===0?[]:n.some(i=>i.root)?[]:[{level:"warning",file:relative(e,n[0].source),target:Bt,message:"Codex needs a root rule to generate AGENTS.md. Add root: true to a rule."}]}var MR=d(()=>{Zt();s(vR,"lintRules");});function $R(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=[];for(let[r,n]of Object.entries(t.mcp.mcpServers))if(typeof n.description=="string"&&n.description&&e.push(j(".agentsmesh/mcp.json","codex-cli",`MCP server "${r}" has a description, but codex-cli does not project MCP descriptions into .codex/config.toml.`)),"url"in n||"type"in n){let o="type"in n?n.type:"url";e.push(j(".agentsmesh/mcp.json","codex-cli",`MCP server "${r}" uses ${o} transport; codex-cli only generates stdio MCP servers.`));}return e}var GR=d(()=>{Tt();s($R,"lintMcp");});function jR(t){return Oc(t)}var UR=d(()=>{cm();s(jR,"codexAdvisoryInstructionPath");});var zv,Vv,Jv,Yv,KR,BR=d(()=>{CR();Zt();of();MR();GR();Nt();ui();UR();ae();zv={name:"codex-cli",primaryRootInstructionPath:Wn,generateRules:Xd,generateCommands:Qd,generateAgents:tf,generateSkills:qd,generateMcp:ef,importFrom:pm},Vv={rootInstructionPath:Wn,extraRuleOutputPaths(t){if(t.root||t.codexEmit!=="execution")return [];let e=basename(t.source,".md");return [`${tn}/${e}.rules`]},skillDir:".agents/skills",managedOutputs:{dirs:[".agents/skills",".codex/agents",".codex/instructions"],files:["AGENTS.md",".codex/config.toml"]},paths:{rulePath(t,e){return jR(e)},commandPath(t,e){return pi(e,"codex-cli")?`${Sr}/${at(t)}/SKILL.md`:null},agentPath(t,e){return `${Fs}/${t}.toml`}}},Jv={rootInstructionPath:Ds,renderPrimaryRootInstruction:Zd,extraRuleOutputPaths(t){if(t.root||t.codexEmit!=="execution")return [];let e=basename(t.source,".md");return [`${tn}/${e}.rules`]},skillDir:Sr,managedOutputs:{dirs:[".agents/skills",".codex/agents",".codex/rules"],files:[Ds,".codex/config.toml"]},rewriteGeneratedPath(t){return t===Wn?Ds:t.startsWith(`${Ns}/`)?null:t},paths:{rulePath(t,e){return e.codexEmit==="execution"?`${tn}/${t}.rules`:Ds},commandPath(t,e){return pi(e,"codex-cli")?`${Sr}/${at(t)}/SKILL.md`:null},agentPath(t,e){return `${Fs}/${t}.toml`}}},Yv={rules:"native",additionalRules:"embedded",commands:"embedded",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},KR={id:"codex-cli",generators:zv,capabilities:{rules:"native",additionalRules:"native",commands:"embedded",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},emptyImportMessage:"No Codex config found (codex.md or AGENTS.md).",supportsConversion:{commands:true},lintRules:vR,lint:{mcp:$R},project:Vv,globalSupport:{capabilities:Yv,detectionPaths:[".codex/AGENTS.md",".codex/AGENTS.override.md",".codex/config.toml",".codex/agents",".codex/rules",".agents/skills"],layout:Jv},buildImportPaths:id,sharedArtifacts:{".agents/skills/":"owner"},detectionPaths:["codex.md","AGENTS.md","AGENTS.override.md",".codex/config.toml",".codex/agents",".codex/rules"]};});function Zv(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"&&e.length>0):typeof t=="string"&&t.length>0?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function HR(t){return `${Mr}/${t}.md`}function zR(t){let e={description:t.description||void 0,"x-agentsmesh-kind":"command","x-agentsmesh-name":t.name,"x-agentsmesh-allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return e.description===void 0&&delete e.description,e["x-agentsmesh-allowed-tools"]===void 0&&delete e["x-agentsmesh-allowed-tools"],N(e,t.body.trim()||"")}function VR(t,e){let r=basename(e,".md");return {name:((typeof t["x-agentsmesh-name"]=="string"?t["x-agentsmesh-name"]:"")||r).trim(),description:typeof t.description=="string"?t.description:"",allowedTools:Zv(t["x-agentsmesh-allowed-tools"])}}function JR(t,e){let r={description:t.description||void 0,"allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return r.description===void 0&&delete r.description,r["allowed-tools"]===void 0&&delete r["allowed-tools"],N(r,e.trim()||"")}var um=d(()=>{v();$r();s(Zv,"toStringArray");s(HR,"continueCommandRulePath");s(zR,"serializeCommandRule");s(VR,"parseCommandRuleFrontmatter");s(JR,"serializeImportedCommand");});function YR(t){let e=[],r=t.rules.find(n=>n.root);if(r){let n={};r.description&&(n.description=r.description),e.push({path:bn,content:N(n,r.body.trim()||"")});}for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("continue"))continue;let o=basename(n.source,".md"),i={};n.description&&(i.description=n.description),n.globs.length>0&&(i.globs=n.globs),e.push({path:`${ar}/${o}.md`,content:N(i,n.body.trim()||"")});}return e}function XR(t){return t.commands.map(e=>({path:`${Mr}/${e.name}.md`,content:zR(e)}))}function ZR(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:$l,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function qR(t){return t.agents.map(e=>({path:`${ye}/${z(e.name)}/SKILL.md`,content:ce(e)}))}function QR(t){return kt(t,ye)}var tO=d(()=>{Rt();ht();v();um();$r();s(YR,"generateRules");s(XR,"generateCommands");s(ZR,"generateMcp");s(qR,"generateAgents");s(QR,"generateSkills");});function eM(t,e){let n=(e===".json"?JSON.parse(t):parse(t)??{}).mcpServers;if(!n||typeof n!="object"||Array.isArray(n))return {};let o={};for(let[i,a]of Object.entries(n)){if(!a||typeof a!="object"||Array.isArray(a))continue;let c=a;typeof c.command=="string"&&(o[i]={type:typeof c.type=="string"?c.type:"stdio",command:c.command,args:_i(c.args),env:Ii(c.env),description:typeof c.description=="string"?c.description:void 0});}return o}async function rM(t,e){let r=(await D(join(t,ad))).filter(i=>[".json",".yaml",".yml"].includes(extname(i))),n={},o=[];for(let i of r){let a=await y(i);a&&(Object.assign(n,eM(a,extname(i))),o.push(i));}if(Object.keys(n).length!==0){await Yt(t,ld,n);for(let i of o)e.push({fromTool:Oi,fromPath:i,toPath:ld,feature:"mcp"});}}async function dm(t){let e=[],r=await H(Oi,t);return e.push(...await tt(fm,t,"project",{normalize:r})),await Ct(t,ye,Oi,e,r),await rM(t,e),e}var sf=d(()=>{Ot();b();Rt();Ut();Sn();nr();$r();af();s(eM,"readMcpServers");s(rM,"importMcp");s(dm,"importFromContinue");});function nM(t){return t==="general.md"||t==="_root.md"}var rO,nO,oO=d(()=>{v();nt();um();$r();s(nM,"isContinueRootRulePath");rO=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=nM(t),o=n?"_root.md":t,i=join(r,o),{frontmatter:a,body:c}=E(e(i)),l={description:typeof a.description=="string"?a.description:void 0,globs:Array.isArray(a.globs)?a.globs:void 0,root:n};return l.description===void 0&&delete l.description,l.globs===void 0&&delete l.globs,{destPath:i,toPath:`${Gl}/${o}`,content:await G(i,l,c)}},"continueRuleMapper"),nO=s(async({absolutePath:t,relativePath:e,normalizeTo:r,destDir:n})=>{let o=join(n,e),{frontmatter:i,body:a}=E(r(o)),c=VR(i,t),l=c.name||e.replace(/\.md$/,"").replace(/^.*\//,""),m=e.includes("/")?e.slice(0,e.lastIndexOf("/")):"",p=m?`${m}/${l}.md`:`${l}.md`,u=join(n,p),f=await it(u,{description:c.description,hasDescription:!!c.description,allowedTools:c.allowedTools,hasAllowedTools:c.allowedTools.length>0},E(JR(c,a)).body);return {destPath:u,toPath:`${jl}/${p}`,content:f}},"continueCommandMapper");});function sO(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:Oi}))}var iO=d(()=>{Wt();$r();s(sO,"lintRules");});function aO(t){return t.commands.filter(e=>e.allowedTools.length>0).map(e=>j(e.source,"continue","Continue invokable prompt rules do not natively enforce canonical allowed-tools metadata."))}var cO=d(()=>{Tt();s(aO,"lintCommands");});function aM(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var lO,mO=d(()=>{b();$r();s(aM,"computeStatus");lO=s(async(t,e,r,n)=>{if(r!=="global")return [];let o=n.has("rules"),i=n.has("commands"),a=n.has("mcp");if(!(o&&t.rules.length>0||i&&t.commands.length>0||a&&t.mcp!==null&&Object.keys(t.mcp.mcpServers).length>0))return [];let l={name:"agentsmesh",version:1,schema:"v1"};if(o&&t.rules.length>0&&(l.rules=t.rules.map(u=>({name:u.description||basename(u.source,".md"),rule:u.body.trim()}))),i&&t.commands.length>0&&(l.prompts=t.commands.map(u=>{let f={name:u.name};return u.description&&(f.description=u.description),f.prompt=u.body.trim(),f})),a&&t.mcp!==null){let u=Object.entries(t.mcp.mcpServers);u.length>0&&(l.mcpServers=u.map(([f,g])=>({name:f,...g})));}let m=stringify(l),p=await y(join(e,tc));return [{target:"continue",path:tc,content:m,currentContent:p??void 0,status:aM(p,m)}]},"generateContinueGlobalConfig");});function lM(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var pO,uO=d(()=>{b();$r();mO();s(lM,"computeStatus");pO=s(async(t,e,r,n)=>{let o=await lO(t,e,r,n);if(r!=="global"||!n.has("rules"))return o;let i=t.rules.find(l=>l.root);if(!i)return o;let a=i.body.trim(),c=await y(join(e,Ei));return [...o,{target:"continue",path:Ei,content:a,currentContent:c??void 0,status:lM(c,a)}]},"generateContinueScopeExtras");});var mM,pM,uM,dM,fm,af=d(()=>{ht();tO();$r();sf();oO();iO();cO();um();Nt();uO();mM={name:"continue",primaryRootInstructionPath:bn,generateRules:YR,generateCommands:XR,generateAgents:qR,generateSkills:QR,generateMcp:ZR,importFrom:dm},pM={rootInstructionPath:bn,skillDir:".continue/skills",managedOutputs:{dirs:[".continue/prompts",".continue/rules",".continue/skills"],files:[".continue/mcpServers/agentsmesh.json"]},paths:{rulePath(t,e){return `${ar}/${t}.md`},commandPath(t,e){return HR(t)},agentPath(t){return `${ye}/${z(t)}/SKILL.md`}}},uM={rootInstructionPath:bn,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[Ei]}],skillDir:ye,managedOutputs:{dirs:[ar,Mr,ye,".agents/skills"],files:[$l,Ei,tc]},mirrorGlobalPath(t,e){return t.startsWith(`${ye}/`)?`.agents/skills/${t.slice(ye.length+1)}`:null},paths:{rulePath(t,e){return `${ar}/${t}.md`},commandPath(t,e){return `${Mr}/${t}.md`},agentPath(t){return `${ye}/${z(t)}/SKILL.md`}}},dM={rules:"native",additionalRules:"native",commands:"native",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},fm={id:"continue",generators:mM,capabilities:{rules:"native",additionalRules:"native",commands:"embedded",agents:"none",skills:"embedded",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},emptyImportMessage:"No Continue config found (.continue/rules/*.md, .continue/skills, or .continue/mcpServers/*).",supportsConversion:{agents:true},lintRules:sO,lint:{commands:aO},project:pM,globalSupport:{capabilities:dM,detectionPaths:[ar,Mr,".continue/mcpServers",ye],layout:uM,scopeExtras:pO},importer:{rules:{feature:"rules",mode:"directory",source:{project:[ar],global:[ar]},canonicalDir:Gl,extensions:[".md"],map:rO},commands:{feature:"commands",mode:"directory",source:{project:[Mr],global:[Mr]},canonicalDir:jl,extensions:[".md"],map:nO}},buildImportPaths:md,detectionPaths:[".continue/rules",".continue/skills",".continue/mcpServers"]};});var Bn,vs,dO,Ms,Po,rn,nn,$s,Gs,gm,hm,fO,lf,gO,To,zi,Hn,Vi,js,mf,pf,Ue=d(()=>{Bn="copilot",vs=".github/copilot-instructions.md",dO=".github/copilot",Ms=".github/instructions",Po=".github/prompts",rn=".github/hooks",nn=".github/skills",$s=".github/agents",Gs=".agentsmesh/rules",gm=".agentsmesh/commands",hm=".agentsmesh/agents",fO=".agentsmesh/skills",lf=".agentsmesh/hooks.yaml",gO=".github/copilot-hooks",To=".copilot/copilot-instructions.md",zi=".copilot/agents",Hn=".copilot/skills",Vi=".copilot/prompts",js=".copilot/AGENTS.md",mf=".claude/skills",pf=".agents/skills";});function hO(t){return Array.isArray(t)?t.filter(e=>typeof e=="string"&&e.length>0):typeof t=="string"&&t.length>0?t.split(",").map(e=>e.trim()).filter(Boolean):[]}function ym(t){return `${Po}/${t}.prompt.md`}function yO(t){let e={agent:"agent",description:t.description||void 0,"x-agentsmesh-kind":"command","x-agentsmesh-name":t.name,"x-agentsmesh-allowed-tools":t.allowedTools.length>0?t.allowedTools:void 0};return e.description===void 0&&delete e.description,e["x-agentsmesh-allowed-tools"]===void 0&&delete e["x-agentsmesh-allowed-tools"],N(e,t.body.trim()||"")}function _O(t,e){let n=((typeof t["x-agentsmesh-name"]=="string"?t["x-agentsmesh-name"]:"")||basename(e,".prompt.md")).trim(),o=hO(t["x-agentsmesh-allowed-tools"]),i=o.length>0?o:hO(t.tools);return {name:n,description:typeof t.description=="string"?t.description:"",allowedTools:i}}var _m=d(()=>{v();Ue();s(hO,"toStringArray");s(ym,"commandPromptPath");s(yO,"serializeCommandPrompt");s(_O,"parseCommandPromptFrontmatter");});function Im(t){return hn(t)}var uf=d(()=>{qe();s(Im,"hasHookCommand");});function hM(t){let e=basename(t,".md");return e==="_root"?"root":e}function yM(t){switch(t){case "PreToolUse":return "preToolUse";case "PostToolUse":return "postToolUse";case "Notification":return "notification";case "UserPromptSubmit":return "userPromptSubmitted";default:return null}}function IO(t){let e=[],r=t.rules.find(n=>n.root);r?.body.trim()&&e.push(r.body.trim());for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("copilot"))continue;let o=n.body.trim();if(!o)continue;let i=n.description?`## ${n.description}`:null;i?e.push(`${i}
|
|
94
94
|
|
|
95
95
|
${o}`):e.push(o);}return e.join(`
|
|
96
96
|
|
|
97
|
-
`)}function
|
|
98
|
-
`)}async function
|
|
99
|
-
`,`set -
|
|
97
|
+
`)}function SO(t){let e=t.rules.find(n=>n.root),r=[];e&&r.push({path:vs,content:e.body.trim()||""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("copilot")||n.globs.length===0)continue;let o=hM(n.source),i={description:n.description||void 0,applyTo:n.globs.length===1?n.globs[0]:n.globs};Object.keys(i).forEach(c=>{i[c]===void 0&&delete i[c];});let a=N(i,n.body.trim()||"");r.push({path:`${Ms}/${o}.instructions.md`,content:a});}return r}function CO(t){return t.commands.map(e=>({path:ym(e.name),content:yO(e)}))}function RO(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=N(n,r.body.trim()||"");e.push({path:`${nn}/${r.name}/SKILL.md`,content:o});for(let i of r.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");e.push({path:`${nn}/${r.name}/${a}`,content:i.content});}}return e}function OO(t){return t.agents.map(e=>{let r={name:e.name,description:e.description,tools:e.tools.length>0?e.tools:void 0,model:e.model||void 0,"mcp-servers":e.mcpServers.length>0?e.mcpServers:void 0,skills:e.skills.length>0?e.skills:void 0};Object.keys(r).forEach(o=>{r[o]===void 0&&delete r[o];});let n=N(r,e.body.trim()||"");return {path:`${$s}/${e.name}.agent.md`,content:n}})}function EO(t){if(!t.hooks)return [];let e=Object.fromEntries(Object.entries(t.hooks).flatMap(([r,n])=>{let o=yM(r);if(!o||!Array.isArray(n))return [];let i=n.filter(a=>typeof a=="object"&&a!==null&&Im(a)).map((a,c)=>{let m={type:"command",bash:`./scripts/${r.replace(/[^a-zA-Z0-9]/g,"-").toLowerCase()}-${c}.sh`,comment:`Matcher: ${a.matcher}`};return a.timeout!==void 0&&(m.timeoutSec=Math.ceil(a.timeout/1e3)),m});return i.length>0?[[o,i]]:[]}));return Object.keys(e).length===0?[]:[{path:`${rn}/agentsmesh.json`,content:JSON.stringify({version:1,hooks:e},null,2)}]}var kO=d(()=>{v();Ue();_m();uf();s(hM,"ruleSlug");s(yM,"mapHookEvent");s(IO,"renderCopilotGlobalInstructions");s(SO,"generateRules");s(CO,"generateCommands");s(RO,"generateSkills");s(OO,"generateAgents");s(EO,"generateHooks");});function IM(t){switch(t){case "preToolUse":return "PreToolUse";case "postToolUse":return "PostToolUse";case "notification":return "Notification";case "userPromptSubmitted":return "UserPromptSubmit";default:return null}}function SM(t){return typeof t!="string"?"*":t.match(/^Matcher:\s*(.+)$/)?.[1]?.trim()||"*"}function bO(t){let e=t.match(/^# agentsmesh-command:\s*(.+)$/m);return e?.[1]?e[1].trim():t.replace(/^#!.*\n/,"").replace(/^#.*\n/gm,"").replace(/^HOOK_DIR=.*\n/gm,"").replace(/^set -e[u]?\n?/m,"").trim()}async function AO(t,e){let r=join(t,rn),o=(await D(r).catch(()=>[])).filter(p=>p.endsWith(".json")),i={};for(let p of o){let u=await y(p);if(!u)continue;let f;try{f=JSON.parse(u);}catch{continue}if(!(!f||typeof f.hooks!="object"||f.hooks===null))for(let[g,h]of Object.entries(f.hooks)){let R=IM(g);if(!(!R||!Array.isArray(h)))for(let S of h){if(!S||typeof S!="object")continue;let _=S,k=typeof _.bash=="string"?_.bash:"";if(!k)continue;let T=join(r,k.replace(/^\.\//,"")),P=await y(T);if(!P)continue;let A=bO(P);A&&(i[R]||(i[R]=[]),i[R].push({matcher:SM(_.comment),command:A,type:"command"}));}}}let a=join(t,gO),l=(await D(a).catch(()=>[])).filter(p=>dirname(p)===a&&/^[^-]+-\d+\.sh$/i.test(basename(p)));for(let p of l){let u=await y(p);if(!u)continue;let f=basename(p,".sh"),g=f.lastIndexOf("-"),h=g>0?f.slice(0,g):f;i[h]||(i[h]=[]),i[h].push({matcher:"*",command:bO(u),type:"command"});}if(Object.keys(i).length===0)return;let m=join(t,lf);await O(dirname(m)),await C(m,stringify(i)),e.push({fromTool:Bn,fromPath:join(t,rn),toPath:lf,feature:"hooks"});}var xO=d(()=>{b();Ue();s(IM,"mapCopilotHookEvent");s(SM,"extractMatcher");s(bO,"extractWrapperCommand");s(AO,"importHooks");});async function PO(t,e,r,n=nn){let o=join(t,n),i=await xo(o),a={projectRoot:t,sourceSkillsDir:n,destCanonicalSkillsDir:fO,targetName:Bn,normalize:r,results:e};for(let[c,l]of i)await Qr(c,l,a);}var TO=d(()=>{Bi();Ue();s(PO,"importSkills");});async function Sm(t,e={}){let r=e.scope??"project",n=[],o=await H(Bn,t,r);return n.push(...await tt(Cm,t,r,{normalize:o})),await PO(t,n,o,r==="global"?Hn:nn),r==="project"&&await AO(t,n),n}var df=d(()=>{Ot();Ut();Ue();xO();TO();ff();s(Sm,"importFromCopilot");});function DO(t){for(let e of Object.keys(t))t[e]===void 0&&delete t[e];return t}var NO,FO,vO,MO,$O=d(()=>{v();nt();nr();_m();Ue();s(DO,"pruneUndefined");NO=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=t.replace(/\.instructions\.md$/i,".md"),o=join(r,n),{frontmatter:i,body:a}=E(e(o)),c=Cn(i.globs),l=DO({root:false,description:typeof i.description=="string"?i.description:void 0,globs:c.length>0?c:void 0});return {destPath:o,toPath:`${Gs}/${n}`,content:await G(o,l,a)}},"copilotLegacyRuleMapper"),FO=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=t.endsWith(".instructions.md")?t.replace(/\.instructions\.md$/i,".md"):t,o=join(r,n),{frontmatter:i,body:a}=E(e(o)),c=Cn(i.applyTo!==void 0?i.applyTo:i.globs),l=DO({root:false,description:typeof i.description=="string"?i.description:void 0,globs:c.length>0?c:void 0});return {destPath:o,toPath:`${Gs}/${n}`,content:await G(o,l,a)}},"copilotNewRuleMapper"),vO=s(async({absolutePath:t,relativePath:e,normalizeTo:r,destDir:n})=>{let o=e.replace(/\.prompt\.md$/i,".md"),i=join(n,o),{frontmatter:a,body:c}=E(r(i)),l=_O(a,t),m=o.includes("/")?o.slice(0,o.lastIndexOf("/")):"",p=`${l.name}.md`,u=m?`${m}/${p}`:p,f=join(n,u);return {destPath:f,toPath:`${gm}/${u}`,content:await it(f,{description:l.description,hasDescription:Object.prototype.hasOwnProperty.call(a,"description"),allowedTools:l.allowedTools,hasAllowedTools:Object.prototype.hasOwnProperty.call(a,"tools")||Object.prototype.hasOwnProperty.call(a,"x-agentsmesh-allowed-tools")},c)}},"copilotCommandMapper"),MO=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{if(!t.endsWith(".agent.md"))return null;let n=t.replace(/\.agent\.md$/i,".md"),o=basename(n,".md"),i=join(r,n),{frontmatter:a,body:c}=E(e(i));return {destPath:i,toPath:`${hm}/${n}`,content:await Pt(i,{...a,name:typeof a.name=="string"?a.name:o},c)}},"copilotAgentMapper");});function GO(t,e,r,n){let i=q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(c=>({...c,target:Bn})),a=t.rules.filter(c=>!c.root&&c.globs.length===0);return [...i,...a.map(c=>({level:"warning",file:c.source,target:Bn,message:"Copilot path-specific instructions require applyTo globs; non-root rules without globs are not generated."}))]}var jO=d(()=>{Wt();Ue();s(GO,"lintRules");});function UO(t){return t.commands.filter(e=>e.allowedTools.length>0).map(e=>j(e.source,"copilot","Copilot prompt files do not enforce canonical allowed-tools natively."))}function WO(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=["PreToolUse","PostToolUse","Notification","UserPromptSubmit"],r=new Set(e),n=Object.keys(t.hooks).filter(i=>!r.has(i)).map(i=>Si(i,"copilot",e,{unsupportedBy:"Copilot hooks"}));return Object.values(t.hooks).some(i=>Array.isArray(i)&&i.length>0)&&n.push(j(".agentsmesh/hooks.yaml","copilot","copilot hooks are emitted as .github/hooks/scripts/*.sh wrapper scripts with a `#!/usr/bin/env bash` header; they require a POSIX shell (git-bash or WSL) to execute on Windows.")),n}var KO=d(()=>{Tt();s(UO,"lintCommands");s(WO,"lintHooks");});function kM(t){return t.replace(/[^a-zA-Z0-9]/g,"-").toLowerCase()}function wM(t,e){let r=relative(t,e).replace(/\\/g,"/");return !r||r.startsWith("../")?null:r}function LM(t,e){let r=t.match(HO);if(!r?.groups)return t;let n=r.groups.prefix??"",o=r.groups.suffix??"";return `${n}"$HOOK_DIR/${e}"${o}`}async function bM(t,e){let n=e.match(HO)?.groups?.path;if(!n)return null;let o=join(t,n),i=await y(o);if(i===null)return null;let a=wM(t,o);return a?{assetPath:`${rn}/scripts/${a}`,content:i,rewrittenCommand:LM(e,a)}:null}function AM(t,e){return `${rn}/scripts/${kM(t)}-${e}.sh`}function BO(t){return t.replace(/[\r\n]+/g," ")}function xM(t,e){return ["#!/usr/bin/env bash",`# agentsmesh-matcher: ${BO(e)}`,`# agentsmesh-command: ${BO(t)}`,"set -eu",t,""].join(`
|
|
98
|
+
`)}async function zO(t,e,r){if(!e.hooks)return r;let n=[],o=new Map;for(let[i,a]of Object.entries(e.hooks)){if(!Array.isArray(a))continue;let c=0;for(let l of a){if(!Im(l))continue;let m=AM(i,c),p=l.command,u=await bM(t,l.command);u&&(p=u.rewrittenCommand,o.has(u.assetPath)||o.set(u.assetPath,{path:u.assetPath,content:u.content}));let f=xM(p,l.matcher).replace(`set -eu
|
|
99
|
+
`,`set -eu
|
|
100
100
|
HOOK_DIR="$(cd "$(dirname "\${BASH_SOURCE[0]}")" && pwd)"
|
|
101
|
-
`);n.push({path:m,content:f}),c++;}}return [...r,...n,...o.values()]}var
|
|
101
|
+
`);n.push({path:m,content:f}),c++;}}return [...r,...n,...o.values()]}var HO,VO=d(()=>{b();Ue();uf();HO=/^(?<prefix>\s*(?:(?:bash|sh|zsh)\s+)?)["']?(?<path>(?:\.\.\/|\.\/|[^/\s"'`]+\/)[^\s"'`]+)["']?(?<suffix>(?:\s.*)?)$/;s(kM,"safePhaseName");s(wM,"toRepoRelative");s(LM,"rewriteWrapperCommand");s(bM,"buildAssetOutput");s(AM,"wrapperPath");s(BO,"safeShellLine");s(xM,"buildWrapper");s(zO,"addHookScriptAssets");});function TM(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var JO,YO=d(()=>{b();Ue();s(TM,"computeStatus");JO=s(async(t,e,r,n)=>{if(r!=="global"||!n.has("rules"))return [];let o=t.rules.find(c=>c.root);if(!o)return [];let i=o.body.trim(),a=await y(join(e,js));return [{target:"copilot",path:js,content:i,currentContent:a??void 0,status:TM(a,i)}]},"generateCopilotGlobalExtras");});var NM,FM,vM,MM,Cm,ff=d(()=>{kO();Ue();df();$O();jO();Nt();_m();KO();VO();YO();NM={name:"copilot",primaryRootInstructionPath:vs,generateRules:SO,generateCommands:CO,generateAgents:OO,generateSkills:RO,generateHooks:EO,importFrom:Sm},FM={rootInstructionPath:vs,outputFamilies:[{id:"instructions",kind:"additional",pathPrefix:".github/instructions/"}],extraRuleOutputPaths(t){if(t.root||t.globs.length===0)return [];let e=basename(t.source,".md");return [`${Ms}/${e}.instructions.md`]},skillDir:".github/skills",managedOutputs:{dirs:[".github/agents",".github/instructions",".github/prompts",".github/skills",".github/hooks/scripts"],files:[".github/copilot-instructions.md",".github/hooks/agentsmesh.json"]},paths:{rulePath(t,e){return `${Ms}/${t}.instructions.md`},commandPath(t,e){return ym(t)},agentPath(t,e){return `${$s}/${t}.agent.md`}}},vM={rootInstructionPath:To,renderPrimaryRootInstruction:IO,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[js]}],skillDir:Hn,managedOutputs:{dirs:[zi,Hn,Vi,pf,mf],files:[To,js]},rewriteGeneratedPath(t){return t===vs?To:t.startsWith(`${Ms}/`)?To:t.startsWith(`${Po}/`)?t.replace(`${Po}/`,`${Vi}/`):t.startsWith(`${$s}/`)?t.replace(`${$s}/`,`${zi}/`):t.startsWith(`${nn}/`)?t.replace(`${nn}/`,`${Hn}/`):t.startsWith(`${rn}/`)?null:t},mirrorGlobalPath(t,e){if(t.startsWith(`${Hn}/`)&&!e.includes("codex-cli")){let r=t.slice(Hn.length+1);return [`.agents/skills/${r}`,`${mf}/${r}`]}return null},paths:{rulePath(t,e){return To},commandPath(t,e){return `${Vi}/${t}.prompt.md`},agentPath(t,e){return `${zi}/${t}.agent.md`}}},MM={rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"none",hooks:"none",ignore:"none",permissions:"none"},Cm={id:"copilot",generators:NM,capabilities:{rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"none",hooks:"partial",ignore:"none",permissions:"none"},emptyImportMessage:"No Copilot config found (.github/copilot-instructions.md, .github/copilot or .github/instructions, .github/prompts, .github/skills, .github/agents, or .github/hooks).",lintRules:GO,lint:{commands:UO,hooks:WO},postProcessHookOutputs:s(async(t,e,r)=>zO(t,e,[...r]),"postProcessHookOutputs"),project:FM,globalSupport:{capabilities:MM,detectionPaths:[To,js,zi,Hn,Vi,pf],layout:vM,scopeExtras:JO},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[vs],global:[To]},canonicalDir:Gs,canonicalRootFilename:"_root.md",markAsRoot:true},{feature:"rules",mode:"directory",source:{project:[dO]},canonicalDir:Gs,extensions:[".instructions.md"],map:NO},{feature:"rules",mode:"directory",source:{project:[Ms]},canonicalDir:Gs,extensions:[".instructions.md",".md"],map:FO}],commands:{feature:"commands",mode:"directory",source:{project:[Po],global:[Vi]},canonicalDir:gm,extensions:[".prompt.md"],map:vO},agents:{feature:"agents",mode:"directory",source:{project:[$s],global:[zi]},canonicalDir:hm,extensions:[".agent.md"],map:MO}},buildImportPaths:pd,detectionPaths:[".github/copilot-instructions.md",".github/copilot",".github/instructions",".github/prompts",".github/skills",".github/agents",".github/hooks"]};});function gf(t){let e=[],r=t.rules.find(i=>i.root);if(r){let i=r.body.trim()?r.body:"";e.push({path:lo,content:i});let a={alwaysApply:true};r.description&&(a.description=r.description);let c=N(a,i);e.push({path:An,content:c});}let n=t.rules.filter(i=>!i.root&&(i.targets.length===0||i.targets.includes("cursor")));for(let i of n){let a=basename(i.source,".md"),l={alwaysApply:i.trigger==="always_on"};i.description&&(l.description=i.description),i.globs.length>0&&(l.globs=i.globs);let m=N(l,i.body.trim()||"");e.push({path:`${Me}/${a}.mdc`,content:m});}let o=XO(t);return o.trim()&&e.push({path:lr,content:o}),e}function XO(t){let e=t.rules.find(o=>o.root),r=t.rules.filter(o=>!o.root&&(o.targets.length===0||o.targets.includes("cursor"))),n=[];return e?.body.trim()?n.push(xt(e.body,r)):r.length>0&&n.push(xt("",r)),n.filter(Boolean).join(`
|
|
102
102
|
|
|
103
|
-
`)}var
|
|
104
|
-
`);return [{path:
|
|
103
|
+
`)}var ZO=d(()=>{v();xe();wt();s(gf,"generateRules");s(XO,"renderCursorGlobalUserRules");});function hf(t){return t.commands.map(e=>({path:`${$e}/${e.name}.md`,content:e.body.trim()||""}))}var qO=d(()=>{wt();s(hf,"generateCommands");});function yf(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=JSON.stringify({mcpServers:t.mcp.mcpServers},null,2);return [{path:jr,content:e}]}var QO=d(()=>{wt();s(yf,"generateMcp");});function _f(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=N(n,r.body.trim()||"");e.push({path:`${Gr}/${r.name}/SKILL.md`,content:o});for(let i of r.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");e.push({path:`${Gr}/${r.name}/${a}`,content:i.content});}}return e}var tE=d(()=>{v();wt();s(_f,"generateSkills");});function If(t){return t.agents.map(e=>{let r={name:e.name,description:e.description,tools:e.tools.length>0?e.tools:void 0,disallowedTools:e.disallowedTools.length>0?e.disallowedTools:void 0,model:e.model||void 0,permissionMode:e.permissionMode||void 0,maxTurns:e.maxTurns>0?e.maxTurns:void 0,mcpServers:e.mcpServers.length>0?e.mcpServers:void 0,hooks:Object.keys(e.hooks).length>0?e.hooks:void 0,skills:e.skills.length>0?e.skills:void 0,memory:e.memory||void 0};Object.keys(r).forEach(o=>{r[o]===void 0&&delete r[o];});let n=N(r,e.body.trim()||"");return {path:`${ki}/${e.name}.md`,content:n}})}var eE=d(()=>{v();wt();s(If,"generateAgents");});function Sf(t){return []}var rE=d(()=>{s(Sf,"generatePermissions");});function GM(t){let e={};for(let[r,n]of Object.entries(t)){if(!Array.isArray(n))continue;let o=[];for(let i of n){if(!Ar(i))continue;let a=At(i),c=Qt(i),l=i.type==="prompt"?c||a:a||c,m={type:i.type==="prompt"?"prompt":"command",[i.type==="prompt"?"prompt":"command"]:l};i.timeout!==void 0&&(m.timeout=i.timeout),o.push({matcher:i.matcher,hooks:[m]});}o.length>0&&(e[r]=o);}return e}function Cf(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=GM(t.hooks);if(Object.keys(e).length===0)return [];let r=JSON.stringify({version:1,hooks:e},null,2);return [{path:Ur,content:r}]}var nE=d(()=>{qe();wt();s(GM,"toCursorHooks");s(Cf,"generateHooks");});function Rf(t){if(!t.ignore||t.ignore.length===0)return [];let e=t.ignore.join(`
|
|
104
|
+
`);return [{path:cr,content:e}]}var oE=d(()=>{wt();s(Rf,"generateIgnore");});var sE=d(()=>{ZO();qO();QO();tE();eE();rE();nE();oE();});var iE=d(()=>{sE();});async function Om(t,e,r,n){let o=t.replace(/\.mdc$/i,".md"),i=join(e,o),c=E(r(i)).frontmatter.alwaysApply===true,l=c?join(e,"_root.md"):i,{frontmatter:m,body:p}=E(r(l));c&&n();let u={...m,root:c};if(delete u.alwaysApply,!c){let f=jM(m);f!==null&&(u.trigger=f);}return {destPath:l,toPath:`${Wr}/${c?"_root.md":o}`,feature:"rules",content:await G(l,u,p)}}function jM(t){return t.alwaysApply!==false?null:(Array.isArray(t.globs)?t.globs:[]).length>0?"glob":(typeof t.description=="string"?t.description:"").trim().length>0?"model_decision":"manual"}async function aE(t,e,r){let n=join(e,t),{frontmatter:o,body:i}=E(r(n)),a=Fe(o.allowedTools),c=a.length>0?a:Fe(o["allowed-tools"]);return {destPath:n,toPath:`${uo}/${t}`,feature:"commands",content:await it(n,{description:typeof o.description=="string"?o.description:"",hasDescription:Object.prototype.hasOwnProperty.call(o,"description"),allowedTools:c,hasAllowedTools:Object.prototype.hasOwnProperty.call(o,"allowedTools")||Object.prototype.hasOwnProperty.call(o,"allowed-tools")},i)}}async function cE(t,e,r){let n=join(e,t),{frontmatter:o,body:i}=E(r(n));return {destPath:n,toPath:`${fo}/${t}`,feature:"agents",content:await Pt(n,o,i)}}var Of=d(()=>{v();nt();nr();wt();s(Om,"mapCursorRuleFile");s(jM,"deriveCursorTrigger");s(aE,"mapCursorCommandFile");s(cE,"mapCursorAgentFile");});async function Ji(t){let e=join(t.projectRoot,Wr);await O(e);let r=join(e,"_root.md"),n=await qr({content:t.content,projectRoot:t.projectRoot,rulesDir:Wr,sourcePath:t.sourcePath,fromTool:"cursor",normalize:t.normalize});t.results.push(...n.results);let o=t.normalize(n.rootContent,t.sourcePath,r);if(!o.trim()&&n.results.length>0)return true;let{frontmatter:i,body:a}=E(o),c=i.root===true?i:{...i,root:true},l=await G(r,c,a);return await C(r,l),t.results.push({fromTool:"cursor",fromPath:t.sourcePath,toPath:`${Wr}/_root.md`,feature:"rules"}),true}var Ef=d(()=>{b();v();Ki();nt();wt();s(Ji,"importCursorRootFile");});async function mE(t,e,r){let n=join(t,Wr),o=false,i=join(t,Me);if(e.push(...await dt({srcDir:i,destDir:n,extensions:[".mdc"],fromTool:"cursor",normalize:r,mapEntry:s(async({srcPath:a,relativePath:c,normalizeTo:l})=>{if(o){let m=await y(a);if(m!==null){let{frontmatter:p}=E(m);if(p.alwaysApply===true)return null}}return Om(c,n,l,()=>{o=true;})},"mapEntry")})),!o){let a=join(t,lo),c=await y(a);c!==null&&(o=await Ji({projectRoot:t,results:e,sourcePath:a,content:c,normalize:r}));}if(!o){let a=join(t,eS),c=await y(a);c!==null&&await Ji({projectRoot:t,results:e,sourcePath:a,content:c,normalize:r});}}var pE=d(()=>{b();v();or();Of();Ef();wt();s(mE,"importCursorRules");});function uE(t){let e={};for(let[r,n]of Object.entries(t)){if(!Array.isArray(n))continue;let o=[];for(let i of n){if(!i||typeof i!="object")continue;let a=i,c=typeof a.matcher=="string"?a.matcher:"";if(!c)continue;let l=Array.isArray(a.hooks)?a.hooks:[];for(let m of l){let p=m.type==="prompt"?"prompt":"command";if(!Ar({...m,type:p}))continue;let u=p==="prompt"?Qt(m)||At(m):At(m)||Qt(m),f={matcher:c,type:p,command:u};typeof m.timeout=="number"&&(f.timeout=m.timeout),o.push(f);}}o.length>0&&(e[r]=o);}return e}async function wm(t,e){let r=false,n=join(t,Ur),o=await y(n);if(o)try{let p=JSON.parse(o);if(p.hooks&&typeof p.hooks=="object"){let u=uE(p.hooks);if(Object.keys(u).length>0){let f=stringify(u),g=join(t,rc);await O(dirname(g)),await C(g,f),e.push({fromTool:"cursor",fromPath:n,toPath:rc,feature:"hooks"}),r=!0;}}}catch{}let i=join(t,Wl),a=await y(i);if(!a)return;let c;try{c=JSON.parse(a);}catch{return}let l=c.permissions;if(l&&typeof l=="object"&&!Array.isArray(l)){let p=l,u=Array.isArray(p.allow)?p.allow.filter(g=>typeof g=="string"):[],f=Array.isArray(p.deny)?p.deny.filter(g=>typeof g=="string"):[];if(u.length>0||f.length>0){let g=stringify({allow:u,deny:f}),h=join(t,dd);await O(dirname(h)),await C(h,g),e.push({fromTool:"cursor",fromPath:i,toPath:dd,feature:"permissions"});}}let m=r?void 0:c.hooks;if(m&&typeof m=="object"&&!Array.isArray(m)){let p=uE(m);if(Object.keys(p).length>0){let u=stringify(p),f=join(t,rc);await O(dirname(f)),await C(f,u),e.push({fromTool:"cursor",fromPath:i,toPath:rc,feature:"hooks"});}}}async function Lm(t,e){let r=[{path:join(t,cr),label:cr},{path:join(t,ud),label:ud}],n=[],o=[];for(let a of r){let c=await y(a.path);if(c!==null){o.push(a.label);for(let l of c.split(/\r?\n/)){let m=l.trim();m&&!n.includes(m)&&n.push(m);}}}if(n.length===0)return;let i=join(t,fd);await O(dirname(i)),await C(i,n.join(`
|
|
105
105
|
`)+`
|
|
106
|
-
`),e.push({fromTool:"cursor",fromPath:join(t,o[0]),toPath:
|
|
106
|
+
`),e.push({fromTool:"cursor",fromPath:join(t,o[0]),toPath:fd,feature:"ignore"});}var wf=d(()=>{qe();b();wt();s(uE,"cursorHooksToCanonical");s(wm,"importSettings");s(Lm,"importIgnore");});async function bm(t,e,r,n=Gr){let o=join(t,n),i=await xo(o),a={projectRoot:t,sourceSkillsDir:n,destCanonicalSkillsDir:rS,targetName:"cursor",normalize:r,results:e};for(let[p,u]of i)await Qr(p,u,a);let c=await D(o).catch(()=>[]),l=c.filter(p=>p.endsWith(".md")),m=new Set(Array.from(i.values()).flatMap(p=>c.filter(u=>u.startsWith(p))));for(let p of l){if(m.has(p))continue;let u=await y(p);if(!u)continue;let f=basename(p,".md");await HC(f,p,u,a);}}var Lf=d(()=>{b();Bi();wt();s(bm,"importSkills");});async function dE(t){if(await F(join(t,Me)))return true;let e=[join(t,lr),join(t,wi),join(t,ec),join(t,Ur),join(t,cr),join(t,mo),join(t,po),join(t,$e)];for(let i of e){let a=await y(i);if(a!==null&&a.trim()!=="")return true}return !!((await D(join(t,mo))).some(i=>i.endsWith(".md"))||(await D(join(t,po))).some(i=>i.endsWith(".md"))||(await D(join(t,$e))).some(i=>i.endsWith(".md")))}async function fE(t,e,r){let n=join(t,Wr),o=false,i=join(t,Me),a=await dt({srcDir:i,destDir:n,extensions:[".mdc"],fromTool:Yi,normalize:r,mapEntry:s(async({srcPath:c,relativePath:l,normalizeTo:m})=>{if(o){let p=await y(c);if(p!==null){let{frontmatter:u}=E(p);if(u.alwaysApply===true)return null}}return Om(l,n,m,()=>{o=true;})},"mapEntry")});return e.push(...a),o}async function gE(t,e,r){let n=join(t,wi),o=await y(n);return o===null||o.trim()===""?false:Ji({projectRoot:t,results:e,sourcePath:n,content:o.trim(),normalize:r})}async function hE(t,e,r){let n=join(t,lr),o=await y(n);return o===null||o.trim()===""?false:Ji({projectRoot:t,results:e,sourcePath:n,content:o.trim(),normalize:r})}async function yE(t,e){let r=join(t,ec),n=await y(r);if(n===null||n.trim()==="")return;let o;try{o=JSON.parse(n);}catch{return}if(!o||typeof o!="object"||!("mcpServers"in o))return;let i=join(t,Li);await O(dirname(i)),await C(i,n),e.push({fromTool:Yi,fromPath:r,toPath:Li,feature:"mcp"});}async function _E(t,e,r){let n=join(t,po),o=join(t,fo);e.push(...await dt({srcDir:n,destDir:o,extensions:[".md"],fromTool:Yi,normalize:r,mapEntry:s(({relativePath:i,normalizeTo:a})=>cE(i,o,a),"mapEntry")}));}async function IE(t,e,r){let n=join(t,$e),o=join(t,uo);e.push(...await dt({srcDir:n,destDir:o,extensions:[".md"],fromTool:Yi,normalize:r,mapEntry:s(({relativePath:i,normalizeTo:a})=>aE(i,o,a),"mapEntry")}));}var Yi,SE=d(()=>{b();v();or();wt();Ef();Of();Yi="cursor";s(dE,"hasGlobalCursorArtifacts");s(fE,"importGlobalCursorRulesFromDir");s(gE,"importGlobalUserRules");s(hE,"importGlobalDotCursorAgents");s(yE,"importGlobalMcp");s(_E,"importGlobalAgents");s(IE,"importGlobalCommands");});async function CE(t){if(!await dE(t))return [];let e=[],r=await H(Yi,t,"global"),n=await fE(t,e,r);return n||(n=await gE(t,e,r)),n||await hE(t,e,r),await yE(t,e),await bm(t,e,r,mo),await _E(t,e,r),await IE(t,e,r),await wm(t,e),await Lm(t,e),e}var RE=d(()=>{Ot();wt();Lf();wf();SE();s(CE,"importFromCursorGlobalExports");});async function HM(t,e){let r=join(t,jr),n=await y(r);if(!n)return;let o;try{o=JSON.parse(n);}catch{return}if(!o||typeof o!="object"||!("mcpServers"in o))return;let i=o.mcpServers;await Yt(t,Li,i),e.push({fromTool:"cursor",fromPath:r,toPath:Li,feature:"mcp"});}async function Am(t,e={}){if(e.scope==="global")return CE(t);let r=[],n=await H("cursor",t);return await mE(t,r,n),r.push(...await tt(xm,t,"project",{normalize:n})),await bm(t,r,n),await HM(t,r),await wm(t,r),await Lm(t,r),r}var bf=d(()=>{Ot();b();Ut();Sn();pE();wf();Lf();RE();wt();Af();s(HM,"importMcp");s(Am,"importFromCursor");});var EE,kE,wE=d(()=>{v();nt();nr();wt();EE=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n)),a=Fe(o.allowedTools),c=a.length>0?a:Fe(o["allowed-tools"]);return {destPath:n,toPath:`${uo}/${t}`,content:await it(n,{description:typeof o.description=="string"?o.description:"",hasDescription:Object.prototype.hasOwnProperty.call(o,"description"),allowedTools:c,hasAllowedTools:Object.prototype.hasOwnProperty.call(o,"allowedTools")||Object.prototype.hasOwnProperty.call(o,"allowed-tools")},i)}},"cursorCommandMapper"),kE=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${fo}/${t}`,content:await Pt(n,o,i)}},"cursorAgentMapper");});function LE(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(i=>({...i,target:tS}))}var bE=d(()=>{Wt();wt();s(LE,"lintRules");});function AE(t){return t.commands.filter(e=>e.description.length>0||e.allowedTools.length>0).map(e=>j(e.source,"cursor","Cursor command files are plain Markdown; command description and allowed-tools metadata are not projected."))}function xE(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=[];for(let[r,n]of Object.entries(t.mcp.mcpServers)){let o=n.env&&Object.keys(n.env).length>0,i="url"in n,a="headers"in n;(o||i||a)&&e.push(j(".agentsmesh/mcp.json","cursor",`MCP server "${r}" uses env vars or URL/header interpolation; Cursor handling may differ from canonical MCP.`));}return e}function PE(t){if(!t.permissions)return [];let e=t.permissions.ask?.length??0;return t.permissions.allow.length>0||t.permissions.deny.length>0||e>0?[j(".agentsmesh/permissions.yaml","cursor","Cursor permissions are partial; tool-level allow/deny may lose fidelity.")]:[]}var TE=d(()=>{Tt();s(AE,"lintCommands");s(xE,"lintMcp");s(PE,"lintPermissions");});var zM,VM,JM,YM,xm,Af=d(()=>{iE();wt();he();bf();wE();bE();Nt();TE();zM={name:"cursor",primaryRootInstructionPath:An,generateRules:gf,generateCommands:hf,generateAgents:If,generateSkills:_f,generateMcp:yf,generatePermissions:Sf,generateHooks:Cf,generateIgnore:Rf,importFrom:Am},VM={rootInstructionPath:An,outputFamilies:[{id:"root-mirrors",kind:"additional",explicitPaths:[lo,lr]}],skillDir:".cursor/skills",managedOutputs:{dirs:[".cursor/agents",".cursor/commands",".cursor/rules",".cursor/skills"],files:[".cursor/hooks.json",".cursor/mcp.json",".cursorignore","AGENTS.md"]},paths:{rulePath(t,e){return `.cursor/rules/${t}.mdc`},commandPath(t,e){return `.cursor/commands/${t}.md`},agentPath(t,e){return `.cursor/agents/${t}.md`}}},JM={rootInstructionPath:An,outputFamilies:[{id:"root-mirrors",kind:"additional",explicitPaths:[lo,lr]}],skillDir:mo,managedOutputs:{dirs:[Me,$e,po,mo],files:[An,lr,ec,Ur,cr,wi]},rewriteGeneratedPath(t){return t===lo?null:t===lr||t===An||t.startsWith(`${Me}/`)||t.startsWith(`${$e}/`)||t.startsWith(`${ki}/`)||t.startsWith(`${Gr}/`)||t===jr||t===Ur||t===cr?t:t===Wl?null:t},mirrorGlobalPath(t,e){return mt(t,Gr,e)},paths:{rulePath(t,e){return `${Me}/${t}.mdc`},commandPath(t,e){return `${$e}/${t}.md`},agentPath(t,e){return `${po}/${t}.md`}}},YM={rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"none"},xm={id:"cursor",generators:zM,capabilities:{rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"partial"},emptyImportMessage:"No Cursor config found (AGENTS.md or .cursor/rules/*.mdc; with --global: ~/.cursor/{rules/*.mdc,AGENTS.md,mcp.json,hooks.json,cursorignore,skills/,agents/,commands/} and legacy ~/.agentsmesh-exports/cursor/user-rules.md).",lintRules:LE,lint:{commands:AE,mcp:xE,permissions:PE},project:VM,globalSupport:{capabilities:YM,detectionPaths:[An,lr,jr,Ur,cr,Gr,po,$e,wi],layout:JM},importer:{commands:{feature:"commands",mode:"directory",source:{project:[$e]},canonicalDir:uo,extensions:[".md"],map:EE},agents:{feature:"agents",mode:"directory",source:{project:[ki]},canonicalDir:fo,extensions:[".md"],map:kE}},buildImportPaths:gd,detectionPaths:[".cursor/rules",".cursor/mcp.json"],preservesManualActivation:true};});var Do,We,on,DE,NE,Ie,Pm,Us,Tm,wc,No,FE,vE,Fo,Dm,Lc,bc,xf,Pf,Xi,Tf,Zi,qi,Nm,Qi,Ws,Ac,Ft=d(()=>{Do="gemini-cli",We="GEMINI.md",on="AGENTS.md",DE=".gemini/rules",NE=".gemini/GEMINI.md",Ie=".gemini/commands",Pm=".gemini/policies",Us=".gemini/settings.json",Tm=".geminiignore",wc=".gemini/skills",No=".gemini/agents",FE=".gemini/system.md",vE=`${Pm}/permissions.toml`,Fo=".agentsmesh/rules",Dm=".agentsmesh/commands",Lc=".agentsmesh/agents",bc=".agentsmesh/skills",xf=".agentsmesh/mcp.json",Pf=".agentsmesh/hooks.yaml",Xi=".agentsmesh/ignore",Tf=".agentsmesh/permissions.yaml",Zi=".gemini/GEMINI.md",qi=".gemini/AGENTS.md",Nm=".gemini/settings.json",Qi=".gemini/commands",Ws=".gemini/skills",Ac=".gemini/agents";});function Df(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>!(i.root||i.targets.length>0&&!i.targets.includes("gemini-cli")));if(!e&&r.length===0)return [];let n=xt(e?.body.trim()??"",r),o=[{path:We,content:n}];if(e){let i=e.body.trim().replace(/\.agentsmesh\/skills\//g,".agents/skills/");o.push({path:on,content:i});}return o}var ME=d(()=>{xe();Ft();s(Df,"generateRules");});function $E(t,e){let r=t.split(":").filter(Boolean),n=r.length>0?r.pop():t;return [e,...r,`${n}.toml`].join("/")}var GE=d(()=>{s($E,"canonicalCommandNameToGeminiTomlPath");});function XM(t){let e=t.replace(/\r\n/g,`
|
|
107
107
|
`);return e.includes('"""')?JSON.stringify(e):`"""
|
|
108
108
|
${e}
|
|
109
|
-
"""`}function
|
|
109
|
+
"""`}function ZM(t){return [`description = ${JSON.stringify(t.description||t.name)}`,`prompt = ${XM(t.body.trim()||"")}`].join(`
|
|
110
110
|
`)+`
|
|
111
|
-
`}function
|
|
112
|
-
`)}]}var
|
|
113
|
-
`)}function
|
|
114
|
-
`)}]}var
|
|
111
|
+
`}function Nf(t){return t.commands.map(e=>({path:$E(e.name,Ie),content:ZM(e)}))}var jE=d(()=>{Ft();GE();s(XM,"serializeTomlMultilineLiteral");s(ZM,"serializeGeminiCommand");s(Nf,"generateCommands");});function Ff(t){return t.agents.map(e=>{let r={name:e.name,kind:"local",description:e.description||void 0,tools:e.tools.length>0?e.tools:void 0,model:e.model||void 0,maxTurns:e.maxTurns>0?e.maxTurns:void 0,permissionMode:e.permissionMode||void 0,disallowedTools:e.disallowedTools.length>0?e.disallowedTools:void 0};Object.keys(r).forEach(o=>{r[o]===void 0&&delete r[o];});let n=N(r,e.body.trim()||"");return {path:`${No}/${e.name}.md`,content:n}})}var UE=d(()=>{v();Ft();s(Ff,"generateAgents");});function vf(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=N(n,r.body.trim()||"");e.push({path:`${wc}/${r.name}/SKILL.md`,content:o});for(let i of r.supportingFiles){let a=i.relativePath.replace(/\\/g,"/");e.push({path:`${wc}/${r.name}/${a}`,content:i.content});}}return e}var WE=d(()=>{v();Ft();s(vf,"generateSkills");});function qM(t){switch(t){case "PreToolUse":return "BeforeTool";case "PostToolUse":return "AfterTool";case "Notification":return "Notification";default:return null}}function Mf(t){let e={},r=false;if(t.mcp&&Object.keys(t.mcp.mcpServers).length>0&&(e.mcpServers=t.mcp.mcpServers,r=true),t.agents.length>0&&(e.experimental={enableAgents:true},r=true),t.hooks){let n=Object.entries(t.hooks).flatMap(([o,i])=>{let a=qM(o);if(!a||!Array.isArray(i))return [];let c=i.filter(l=>typeof l=="object"&&l!==null&&hn(l)).map((l,m)=>({matcher:l.matcher,hooks:[{name:`${a}-${m+1}`,type:"command",command:At(l),timeout:l.timeout}]}));return c.length>0?[[a,c]]:[]});n.length>0&&(e.hooks=Object.fromEntries(n),r=true);}return r&&(e.context={fileName:[We,on]}),Object.keys(e).length===0?[]:[{path:Us,content:JSON.stringify(e,null,2)}]}var $f=d(()=>{qe();Ft();s(qM,"mapHookEvent");s(Mf,"generateGeminiSettingsFiles");});function Gf(t){return !t.ignore||t.ignore.length===0?[]:[{path:Tm,content:t.ignore.join(`
|
|
112
|
+
`)}]}var KE=d(()=>{Ft();s(Gf,"generateIgnore");});var BE=d(()=>{ME();jE();UE();WE();$f();KE();});var HE=d(()=>{BE();});function Ks(t){return JSON.stringify(t)}function QM(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function t$(t){let e=t.match(/^Bash\((.*)\)$/);if(e&&typeof e[1]=="string")return {kind:"bash",prefix:e[1]};let r=t.match(/^Read\((.*)\)$/);return r&&typeof r[1]=="string"?{kind:"read",path:r[1]}:t==="Read"||t==="Grep"||t==="LS"||t==="WebFetch"?{kind:"tool",tool:t}:{kind:"unknown",raw:t}}function Fm(t,e,r){return ["[[rule]]",`decision = ${Ks(t)}`,`priority = ${e}`,...r,""].join(`
|
|
113
|
+
`)}function zE(t,e,r){let n=t$(t),o={Read:"read_file",Grep:"grep_search",LS:"list_directory",WebFetch:"web_fetch",Bash:"run_shell_command"};if(n.kind==="tool"){let i=o[n.tool]??n.tool;return Fm(e,r,[`toolName = ${Ks(i)}`])}if(n.kind==="bash"){let i=n.prefix.replace(/:\*$/u,"").replace(/\*$/u,"").trim();return Fm(e,r,[`toolName = ${Ks(o.Bash)}`,`commandPrefix = ${Ks(i)}`])}return n.kind==="read"?Fm(e,r,[`toolName = ${Ks(o.Read)}`,`argsPattern = ${Ks(QM(n.path))}`]):Fm(e,r,[`toolName = ${Ks(n.raw)}`])}function VE(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions;if(e.length+r.length===0)return [];let o=[];return e.forEach((i,a)=>{let c=zE(i,"allow",100+a);c&&o.push(c);}),r.forEach((i,a)=>{let c=zE(i,"deny",200+a);c&&o.push(c);}),o.length===0?[]:[{path:vE,content:o.join(`
|
|
114
|
+
`)}]}var JE=d(()=>{Ft();s(Ks,"escapeTomlBasicString");s(QM,"escapeRegexLiteral");s(t$,"parsePermissionExpr");s(Fm,"ruleForDecision");s(zE,"permissionExprToGeminiRule");s(VE,"generateGeminiPermissionsPolicies");});function jf(t){switch(t){case "BeforeTool":case "preToolUse":return "PreToolUse";case "AfterTool":case "postToolUse":return "PostToolUse";case "Notification":case "notification":return "Notification";default:return null}}function vm(t){let e=t.indexOf("---"),r=t.indexOf("+++");if(e===0&&(r===-1||e<=r))return E(t);if(r===0){let n=t.indexOf("+++",3);if(n!==-1)try{let o=t.slice(3,n).trim(),i=t.slice(n+3).trim();return {frontmatter:o===""?{}:parse$1(o)??{},body:i}}catch{return {frontmatter:{},body:t.trim()}}}return {frontmatter:{},body:t.trim()}}var Uf=d(()=>{v();s(jf,"mapGeminiHookEvent");s(vm,"parseFlexibleFrontmatter");});async function Wf(t,e){let r=join(t,Us),n=await y(r);if(n===null)return;let o;try{o=JSON.parse(n);}catch{}if(!o)return;let i=o.mcpServers;if(i!==void 0&&typeof i=="object"&&i!==null&&Object.keys(i).length>0){let l=join(t,xf);await O(join(t,".agentsmesh")),await C(l,JSON.stringify({mcpServers:i},null,2)),e.push({fromTool:"gemini-cli",fromPath:r,toPath:xf,feature:"mcp"});}let a=o.ignorePatterns;if(Array.isArray(a)&&a.length>0&&a.every(l=>typeof l=="string")){let l=join(t,Xi);await O(join(t,".agentsmesh")),await C(l,a.join(`
|
|
115
115
|
`)+`
|
|
116
|
-
`),e.push({fromTool:"gemini-cli",fromPath:r,toPath:
|
|
116
|
+
`),e.push({fromTool:"gemini-cli",fromPath:r,toPath:Xi,feature:"ignore"});}let c=o.hooks;if(c!==void 0&&typeof c=="object"&&c!==null){let l=Object.entries(c).flatMap(([m,p])=>{let u=jf(m);if(!u||!Array.isArray(p))return [];let f=p.filter(g=>g!==null&&typeof g=="object"&&typeof g.matcher=="string"&&Array.isArray(g.hooks)).flatMap(g=>g.hooks.filter(h=>h!==null&&typeof h=="object"&&hn(h)).map(h=>({matcher:g.matcher,command:At(h),type:"command",timeout:typeof h.timeout=="number"?h.timeout:void 0})));if(f.length===0){let g=p.filter(h=>h!==null&&typeof h=="object"&&typeof h.matcher=="string"&&hn(h)).map(h=>({matcher:h.matcher,command:At(h),type:"command"}));return g.length>0?[[u,g]]:[]}return f.length>0?[[u,f]]:[]});if(l.length>0){let m=Object.fromEntries(l),p=join(t,Pf);await O(join(t,".agentsmesh")),await C(p,stringify(m,{lineWidth:0}).trimEnd()),e.push({fromTool:"gemini-cli",fromPath:r,toPath:Pf,feature:"hooks"});}}}var YE=d(()=>{qe();b();Ft();Uf();s(Wf,"importGeminiSettings");});async function XE(t,e){let r=join(t,Tm),n=await y(r);if(n!==null&&n.trim()){let o=n.split(/\r?\n/).map(i=>i.trim()).filter(i=>i&&!i.startsWith("#"));if(o.length>0){await O(join(t,".agentsmesh"));let i=join(t,Xi);await C(i,o.join(`
|
|
117
117
|
`)+`
|
|
118
|
-
`),e.push({fromTool:"gemini-cli",fromPath:r,toPath:
|
|
119
|
-
`),e.push({fromTool:bo,fromPath:join(t,km),toPath:_f,feature:"permissions"}),e}var OO=d(()=>{A();Pt();s(yM,"unescapeRegexLiteral");s(_M,"toolNameToPermissionBase");s(IM,"commandPrefixToBashExpr");s(CM,"argsPatternToReadExpr");s(kO,"importGeminiPolicies");});function Pf(t,e){let r=new Set([e,e.replace(/\\/g,"/"),e.replace(/\//g,"\\")]);try{r.add(realpathSync(e)),r.add(realpathSync.native(e));}catch{}return Array.from(r).reduce((o,i)=>{let a=i.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");return o.replace(new RegExp(`${a}[/\\\\]\\.agentsmesh[/\\\\]`,"g"),".agentsmesh/").replaceAll(`${i}/.agentsmesh`,".agentsmesh").replaceAll(`${i}\\.agentsmesh`,".agentsmesh")},t).replace(/(?:[A-Za-z]:)?[^\s"'`()<>]+[/\\]\.agentsmesh[/\\]/g,".agentsmesh/")}var EO=d(()=>{s(Pf,"stripProjectRootCanonicalPrefix");});async function bO(t,e,r){let n=join(t,Sc),i=(await N(n)).filter(c=>basename(c)==="SKILL.md");for(let c of i){let l=await y(c);if(!l)continue;let m=basename(c.slice(0,-9)),p=w(l),u=Er(p.frontmatter,m);if(u){let E=join(t,Rc);await O(E);let T=join(E,`${u.name}.md`);await S(T,Oe(u,r(p.body,c,T))),e.push({fromTool:"gemini-cli",fromPath:c,toPath:`${Rc}/${u.name}.md`,feature:"agents"});continue}let f=join(t,kc,m,"SKILL.md"),g=r(l,c,f),h=join(t,kc,m);await O(h);let{frontmatter:R,body:C}=w(g);await S(f,await Lr(f,{...R,name:m},C)),e.push({fromTool:"gemini-cli",fromPath:c,toPath:`${kc}/${m}/SKILL.md`,feature:"skills"});let _=await N(dirname(c));for(let E of _){if(E===c)continue;let T=await y(E);if(T===null)continue;let D=relative(dirname(c),E).replace(/\\/g,"/"),x=join(h,D);await O(dirname(x)),await S(x,r(T,E,x)),e.push({fromTool:"gemini-cli",fromPath:E,toPath:`${kc}/${m}/${D}`,feature:"skills"});}}let a=join(t,Ao);try{let l=(await N(a)).filter(m=>m.endsWith(".md"));for(let m of l){let p=await y(m);if(!p)continue;let{frontmatter:u,body:f}=w(p),h=relative(a,m).replace(/\\/g,"/").replace(/\.md$/i,".md"),R=join(t,Rc);await O(R);let C=join(R,h),_=r(f,m,C);await S(C,await Lt(C,{...u,name:typeof u.name=="string"?u.name:basename(h,".md"),maxTurns:u.maxTurns??u["max-turns"]??u.max_turns,permissionMode:u.permissionMode??u["permission-mode"]??u.permission_mode,disallowedTools:u.disallowedTools??u["disallowed-tools"]??u.disallowed_tools},_)),e.push({fromTool:"gemini-cli",fromPath:m,toPath:`${Rc}/${h}`,feature:"agents"});}}catch{}}var AO=d(()=>{A();M();et();dt();Pt();s(bO,"importGeminiSkillsAndAgents");});async function SM(t,e,r){let n=await z("codex-cli",t),o=join(t,xo),i=join(t,Qr),a=join(t,iO),c=[i,a,join(t,Me),join(t,aO)],l=null,m=c[c.length-1];for(let D of c){let x=await y(D);if(x!==null){l=x,m=D;break}}if(l===null)return;await O(o);let p=join(o,"_root.md"),u=m===i||m===a?n(l,m,p):l,f=await Vr({content:u,projectRoot:t,rulesDir:xo,sourcePath:m,fromTool:bo,normalize:r});e.push(...f.results);let g=r(f.rootContent,m,p),h=Pf(g.replace(/\.agents\/skills\//g,".agentsmesh/skills/").replace(/\.agents\\skills\\/g,".agentsmesh/skills/"),t),{frontmatter:R,body:C}=w(h),E=R.root===true?R:{...R,root:true},T=Pf(await j(p,E,C),t);await S(p,T),e.push({fromTool:bo,fromPath:m,toPath:`${xo}/_root.md`,feature:"rules"});}async function xm(t){let e=[],r=await z(bo,t);return await SM(t,e,r),e.push(...await Q(Pm,t,"project",{normalize:r})),await bO(t,e,r),await bf(t,e),await RO(t,e),e.push(...await kO(t)),e}var Nf=d(()=>{It();A();M();et();vi();Mt();Pt();Ff();xf();OO();EO();AO();s(SM,"importRootRule");s(xm,"importFromGemini");});async function PO(t,e,r){let n=t.replace(/\\/g,"/"),o=join(e,n),{frontmatter:i,body:a}=bm(r(o)),c=gn(i.globs),l={root:false,description:typeof i.description=="string"?i.description:void 0,globs:c.length>0?c:void 0};return Object.keys(l).forEach(m=>{l[m]===void 0&&delete l[m];}),{destPath:o,toPath:`${xo}/${n}`,feature:"rules",content:await j(o,l,a)}}async function TO(t,e,r){let n=t.replace(/\.(toml|md)$/i,".md").replace(/\\/g,"/"),o=join(e,n),i=r(o),{frontmatter:a,body:c}=t.endsWith(".toml")?kM(i):bm(i),l=xe(a.allowedTools),m=xe(a["allowed-tools"]),p=l.length>0?l:m;return {destPath:o,toPath:`${wm}/${n}`,feature:"commands",content:await ot(o,{description:typeof a.description=="string"?a.description:"",hasDescription:Object.prototype.hasOwnProperty.call(a,"description"),allowedTools:p,hasAllowedTools:Object.prototype.hasOwnProperty.call(a,"allowedTools")||Object.prototype.hasOwnProperty.call(a,"allowed-tools")},c)}}function kM(t){try{let e=parse$1(t);return {frontmatter:e,body:typeof e.prompt=="string"?e.prompt:""}}catch{return {frontmatter:{},body:t.trim()}}}var DO=d(()=>{et();Qe();xf();Pt();s(PO,"mapGeminiRuleFile");s(TO,"mapGeminiCommandFile");s(kM,"parseTomlCommand");});var NO,FO,vO=d(()=>{DO();NO=s(({relativePath:t,destDir:e,normalizeTo:r})=>PO(t,e,r),"geminiRuleMapper"),FO=s(({relativePath:t,destDir:e,normalizeTo:r})=>TO(t,e,r),"geminiCommandMapper");});function MO(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(i=>({...i,target:bo}))}var $O=d(()=>{$t();Pt();s(MO,"lintRules");});function GO(t){return t.commands.filter(e=>e.allowedTools.length>0).map(e=>U(e.source,"gemini-cli","Gemini TOML command files do not project canonical allowed-tools metadata."))}function jO(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=["PreToolUse","PostToolUse","Notification"],r=new Set(e);return Object.keys(t.hooks).filter(n=>!r.has(n)).map(n=>di(n,"gemini-cli",e))}var UO=d(()=>{bt();s(GO,"lintCommands");s(jO,"lintHooks");});function KO(t,e){return e==="project"&&Po("gemini-cli",e)?.ignore.flavor!=="settings-embedded"?[]:kf(t)}var WO=d(()=>{ut();Of();s(KO,"emitScopedGeminiSettings");});function HO(t){try{let e=JSON.parse(t);return e!==null&&typeof e=="object"&&!Array.isArray(e)?e:{}}catch{return {}}}function zO(t,e){let r=HO(t),n=OM.parse(JSON.parse(e)),o={...r};n.permissions!==void 0&&(o.permissions=n.permissions),n.hooks!==void 0&&(o.hooks=n.hooks);let i=o.permissions;return i&&typeof i=="object"&&!Array.isArray(i)&&!("ask"in i)&&(i.ask=[]),JSON.stringify(o,null,2)}function VO(t,e){let r=HO(t),n=wM.parse(JSON.parse(e)),o={...r};return n.mcpServers!==void 0&&(o.mcpServers=n.mcpServers),n.hooks!==void 0&&(o.hooks=n.hooks),n.experimental!==void 0&&(o.experimental=n.experimental),n.context!==void 0&&(o.context=n.context),JSON.stringify(o,null,2)}var BO,OM,wM,vf=d(()=>{BO=[".claude/settings.json",".gemini/settings.json"],OM=z$1.object({permissions:z$1.object({allow:z$1.array(z$1.string()).optional(),deny:z$1.array(z$1.string()).optional()}).passthrough().optional(),hooks:z$1.record(z$1.string(),z$1.unknown()).optional()}).passthrough(),wM=z$1.object({mcpServers:z$1.record(z$1.string(),z$1.unknown()).optional(),hooks:z$1.record(z$1.string(),z$1.unknown()).optional(),experimental:z$1.record(z$1.string(),z$1.unknown()).optional(),context:z$1.record(z$1.string(),z$1.unknown()).optional()}).passthrough();s(HO,"parseJsonObject");s(zO,"mergeSettingsJson");s(VO,"mergeGeminiSettingsJson");});var EM,LM,bM,AM,Pm,Ff=d(()=>{yO();Vo();CO();Pt();Nf();vO();$O();xt();si();dt();UO();WO();ue();vf();EM={name:"gemini-cli",primaryRootInstructionPath:Me,generateRules:If,generateCommands:Cf,generateAgents:Sf,generateSkills:Rf,generateIgnore:wf,generatePermissions:IO,importFrom:xm},LM={rootInstructionPath:Me,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[Qr]}],extraRuleOutputPaths(){return [Qr]},skillDir:".gemini/skills",managedOutputs:{dirs:[".gemini/agents",".gemini/commands",".gemini/skills",".agents/skills"],files:["AGENTS.md","GEMINI.md",".gemini/settings.json",".gemini/policies/permissions.toml",".geminiignore"]},mirrorGlobalPath(t,e){return at(t,".gemini/skills",e)},paths:{rulePath(t,e){return Me},commandPath(t,e){if(t.includes(":")){let r=t.split(":").filter(Boolean),n=r.pop()??t;return `${ge}/${r.join("/")}/${n}.toml`}return `${ge}/${t}.toml`},agentPath(t,e){return ke(e,"gemini-cli")?`.gemini/skills/${V(t)}/SKILL.md`:`${Ao}/${t}.md`}}},bM={rootInstructionPath:Bi,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[Hi]}],extraRuleOutputPaths(){return [Hi]},skillDir:Fs,managedOutputs:{dirs:[zi,Fs,Oc],files:[Bi,Hi,Em]},rewriteGeneratedPath(t){return t===Me?Bi:t===Qr?Hi:t===Ns?Em:t.startsWith(`${ge}/`)?t.replace(`${ge}/`,`${zi}/`):t.startsWith(".gemini/skills/")?t.replace(".gemini/skills/",`${Fs}/`):t.startsWith(`${Ao}/`)?t.replace(`${Ao}/`,`${Oc}/`):t.startsWith(".gemini/policies/")||t===".geminiignore"?null:t},mirrorGlobalPath(t,e){return at(t,Fs,e)},paths:{rulePath(t,e){return Bi},commandPath(t,e){if(t.includes(":")){let r=t.split(":").filter(Boolean),n=r.pop()??t;return `${zi}/${r.join("/")}/${n}.toml`}return `${zi}/${t}.toml`},agentPath(t,e){return ke(e,"gemini-cli")?`${Fs}/${V(t)}/SKILL.md`:`${Oc}/${t}.md`}}},AM={rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"partial",ignore:"none",permissions:"none"},Pm={id:"gemini-cli",generators:EM,capabilities:{rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"partial",ignore:Ze("native","settings-embedded"),permissions:"partial"},emptyImportMessage:"No Gemini CLI config found (GEMINI.md or .gemini/rules, .gemini/commands, .gemini/settings.json).",lintRules:MO,lint:{commands:GO,hooks:jO},emitScopedSettings:KO,mergeGeneratedOutputContent(t,e,r,n){let o=e?.content??t;return o!==null&&n===Ns?VO(o,r):null},project:LM,globalSupport:{capabilities:AM,detectionPaths:[Bi,Hi,Em,zi,Fs,Oc],layout:bM},importer:{rules:{feature:"rules",mode:"directory",source:{project:[sO]},canonicalDir:xo,extensions:[".md"],map:NO},commands:{feature:"commands",mode:"directory",source:{project:[ge]},canonicalDir:wm,extensions:[".md",".toml"],map:FO}},buildImportPaths:nd,detectionPaths:["GEMINI.md",".gemini"]};});function JO(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes($r)),n=e?.body.trim()??"",o=Et(n,r);return o?[{path:Ne,content:o}]:[]}function YO(t){return St(t,Zt)}function XO(t){return t.commands.map(e=>({path:`${Zt}/${st(e.name)}/SKILL.md`,content:wr(e)}))}function ZO(t){return t.agents.map(e=>({path:`${Zt}/${V(e.name)}/SKILL.md`,content:oe(e)}))}function qO(t){return t.ignore.length===0?[]:[{path:On,content:t.ignore.join(`
|
|
120
|
-
`)}]}var
|
|
121
|
-
`)}]}function
|
|
122
|
-
`)}]}function
|
|
118
|
+
`),e.push({fromTool:"gemini-cli",fromPath:r,toPath:Xi,feature:"ignore"});}}}var Bf=d(()=>{b();Ft();Uf();YE();s(XE,"importGeminiIgnore");});function s$(t){return t.replace(/\\(.)/g,"$1")}function i$(t){switch(t){case "read_file":return "Read";case "grep_search":return "Grep";case "list_directory":return "LS";case "web_fetch":return "WebFetch";case "run_shell_command":return "Bash";default:return null}}function a$(t){return `Bash(${t}:*)`}function c$(t){return `Read(${s$(t)})`}async function ZE(t){let e=[],r=join(t,Pm),n;try{n=await D(r);}catch{return e}let o=n.filter(u=>u.endsWith(".toml"));if(o.length===0)return e;let i=[],a=[],c=new Set,l=new Set;for(let u of o){let f=await y(u);if(!f)continue;let g;try{g=parse$1(f);}catch{continue}let h=g&&typeof g=="object"&&"rule"in g?g.rule:void 0;if(Array.isArray(h))for(let R of h){if(!R||typeof R!="object")continue;let S=R,_=typeof S.toolName=="string"?S.toolName:null,k=typeof S.decision=="string"?S.decision:null;if(!_||!k)continue;let T=i$(_);if(!T)continue;let P=null;T==="Bash"?typeof S.commandPrefix=="string"&&S.commandPrefix.trim()&&(P=a$(S.commandPrefix.trim())):T==="Read"?typeof S.argsPattern=="string"&&S.argsPattern.trim()?P=c$(S.argsPattern.trim()):P="Read":P=T,P&&(k==="allow"?c.has(P)||(c.add(P),i.push(P)):k==="deny"&&(l.has(P)||(l.add(P),a.push(P))));}}if(i.length===0&&a.length===0)return e;await O(join(t,".agentsmesh"));let m=join(t,Tf),p=stringify({allow:i,deny:a});return await C(m,p.trimEnd()+`
|
|
119
|
+
`),e.push({fromTool:Do,fromPath:join(t,Pm),toPath:Tf,feature:"permissions"}),e}var qE=d(()=>{b();Ft();s(s$,"unescapeRegexLiteral");s(i$,"toolNameToPermissionBase");s(a$,"commandPrefixToBashExpr");s(c$,"argsPatternToReadExpr");s(ZE,"importGeminiPolicies");});function Hf(t,e){let r=new Set([e,e.replace(/\\/g,"/"),e.replace(/\//g,"\\")]);try{r.add(realpathSync(e)),r.add(realpathSync.native(e));}catch{}return Array.from(r).reduce((o,i)=>{let a=i.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");return o.replace(new RegExp(`${a}[/\\\\]\\.agentsmesh[/\\\\]`,"g"),".agentsmesh/").replaceAll(`${i}/.agentsmesh`,".agentsmesh").replaceAll(`${i}\\.agentsmesh`,".agentsmesh")},t).replace(/(?:[A-Za-z]:)?[^\s"'`()<>]+[/\\]\.agentsmesh[/\\]/g,".agentsmesh/")}var tk=d(()=>{s(Hf,"stripProjectRootCanonicalPrefix");});async function rk(t,e,r){let n=join(t,wc),i=(await D(n)).filter(c=>basename(c)==="SKILL.md");for(let c of i){let l=await y(c);if(!l)continue;let m=basename(c.slice(0,-9)),p=E(l),u=Pr(p.frontmatter,m);if(u){let k=join(t,Lc);await O(k);let T=join(k,`${u.name}.md`);await C(T,Ae(u,r(p.body,c,T))),e.push({fromTool:"gemini-cli",fromPath:c,toPath:`${Lc}/${u.name}.md`,feature:"agents"});continue}let f=join(t,bc,m,"SKILL.md"),g=r(l,c,f),h=join(t,bc,m);await O(h);let{frontmatter:R,body:S}=E(g);await C(f,await Tr(f,{...R,name:m},S)),e.push({fromTool:"gemini-cli",fromPath:c,toPath:`${bc}/${m}/SKILL.md`,feature:"skills"});let _=await D(dirname(c));for(let k of _){if(k===c)continue;let T=await y(k);if(T===null)continue;let P=relative(dirname(c),k).replace(/\\/g,"/"),A=join(h,P);await O(dirname(A)),await C(A,r(T,k,A)),e.push({fromTool:"gemini-cli",fromPath:k,toPath:`${bc}/${m}/${P}`,feature:"skills"});}}let a=join(t,No);try{let l=(await D(a)).filter(m=>m.endsWith(".md"));for(let m of l){let p=await y(m);if(!p)continue;let{frontmatter:u,body:f}=E(p),h=relative(a,m).replace(/\\/g,"/").replace(/\.md$/i,".md"),R=join(t,Lc);await O(R);let S=join(R,h),_=r(f,m,S);await C(S,await Pt(S,{...u,name:typeof u.name=="string"?u.name:basename(h,".md"),maxTurns:u.maxTurns??u["max-turns"]??u.max_turns,permissionMode:u.permissionMode??u["permission-mode"]??u.permission_mode,disallowedTools:u.disallowedTools??u["disallowed-tools"]??u.disallowed_tools},_)),e.push({fromTool:"gemini-cli",fromPath:m,toPath:`${Lc}/${h}`,feature:"agents"});}}catch{}}var nk=d(()=>{b();v();nt();ht();Ft();s(rk,"importGeminiSkillsAndAgents");});async function l$(t,e,r){let n=await H("codex-cli",t),o=join(t,Fo),i=join(t,on),a=join(t,NE),c=[i,a,join(t,We),join(t,FE)],l=null,m=c[c.length-1];for(let P of c){let A=await y(P);if(A!==null){l=A,m=P;break}}if(l===null)return;await O(o);let p=join(o,"_root.md"),u=m===i||m===a?n(l,m,p):l,f=await qr({content:u,projectRoot:t,rulesDir:Fo,sourcePath:m,fromTool:Do,normalize:r});e.push(...f.results);let g=r(f.rootContent,m,p),h=Hf(g.replace(/\.agents\/skills\//g,".agentsmesh/skills/").replace(/\.agents\\skills\\/g,".agentsmesh/skills/"),t),{frontmatter:R,body:S}=E(h),k=R.root===true?R:{...R,root:true},T=Hf(await G(p,k,S),t);await C(p,T),e.push({fromTool:Do,fromPath:m,toPath:`${Fo}/_root.md`,feature:"rules"});}async function $m(t){let e=[],r=await H(Do,t);return await l$(t,e,r),e.push(...await tt(Gm,t,"project",{normalize:r})),await rk(t,e,r),await Wf(t,e),await XE(t,e),e.push(...await ZE(t)),e}var Jf=d(()=>{Ot();b();v();nt();Ki();Ut();Ft();Yf();Bf();qE();tk();nk();s(l$,"importRootRule");s($m,"importFromGemini");});async function sk(t,e,r){let n=t.replace(/\\/g,"/"),o=join(e,n),{frontmatter:i,body:a}=vm(r(o)),c=Cn(i.globs),l={root:false,description:typeof i.description=="string"?i.description:void 0,globs:c.length>0?c:void 0};return Object.keys(l).forEach(m=>{l[m]===void 0&&delete l[m];}),{destPath:o,toPath:`${Fo}/${n}`,feature:"rules",content:await G(o,l,a)}}async function ik(t,e,r){let n=t.replace(/\.(toml|md)$/i,".md").replace(/\\/g,"/"),o=join(e,n),i=r(o),{frontmatter:a,body:c}=t.endsWith(".toml")?p$(i):vm(i),l=Fe(a.allowedTools),m=Fe(a["allowed-tools"]),p=l.length>0?l:m;return {destPath:o,toPath:`${Dm}/${n}`,feature:"commands",content:await it(o,{description:typeof a.description=="string"?a.description:"",hasDescription:Object.prototype.hasOwnProperty.call(a,"description"),allowedTools:p,hasAllowedTools:Object.prototype.hasOwnProperty.call(a,"allowedTools")||Object.prototype.hasOwnProperty.call(a,"allowed-tools")},c)}}function p$(t){try{let e=parse$1(t);return {frontmatter:e,body:typeof e.prompt=="string"?e.prompt:""}}catch{return {frontmatter:{},body:t.trim()}}}var ak=d(()=>{nt();nr();Bf();Ft();s(sk,"mapGeminiRuleFile");s(ik,"mapGeminiCommandFile");s(p$,"parseTomlCommand");});var ck,lk,mk=d(()=>{ak();ck=s(({relativePath:t,destDir:e,normalizeTo:r})=>sk(t,e,r),"geminiRuleMapper"),lk=s(({relativePath:t,destDir:e,normalizeTo:r})=>ik(t,e,r),"geminiCommandMapper");});function pk(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(i=>({...i,target:Do}))}var uk=d(()=>{Wt();Ft();s(pk,"lintRules");});function dk(t){return t.commands.filter(e=>e.allowedTools.length>0).map(e=>j(e.source,"gemini-cli","Gemini TOML command files do not project canonical allowed-tools metadata."))}function fk(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=["PreToolUse","PostToolUse","Notification"],r=new Set(e);return Object.keys(t.hooks).filter(n=>!r.has(n)).map(n=>Si(n,"gemini-cli",e))}var gk=d(()=>{Tt();s(dk,"lintCommands");s(fk,"lintHooks");});function hk(t,e){return e==="project"&&vo("gemini-cli",e)?.ignore.flavor!=="settings-embedded"?[]:Mf(t)}var yk=d(()=>{gt();$f();s(hk,"emitScopedGeminiSettings");});function Ik(t){try{let e=JSON.parse(t);return e!==null&&typeof e=="object"&&!Array.isArray(e)?e:{}}catch{return {}}}function Sk(t,e){let r=Ik(t),n=u$.parse(JSON.parse(e)),o={...r};n.permissions!==void 0&&(o.permissions=n.permissions),n.hooks!==void 0&&(o.hooks=n.hooks);let i=o.permissions;return i&&typeof i=="object"&&!Array.isArray(i)&&!("ask"in i)&&(i.ask=[]),JSON.stringify(o,null,2)}function Ck(t,e){let r=Ik(t),n=d$.parse(JSON.parse(e)),o={...r};return n.mcpServers!==void 0&&(o.mcpServers=n.mcpServers),n.hooks!==void 0&&(o.hooks=n.hooks),n.experimental!==void 0&&(o.experimental=n.experimental),n.context!==void 0&&(o.context=n.context),JSON.stringify(o,null,2)}var _k,u$,d$,Xf=d(()=>{_k=[".claude/settings.json",".gemini/settings.json"],u$=z$1.object({permissions:z$1.object({allow:z$1.array(z$1.string()).optional(),deny:z$1.array(z$1.string()).optional()}).passthrough().optional(),hooks:z$1.record(z$1.string(),z$1.unknown()).optional()}).passthrough(),d$=z$1.object({mcpServers:z$1.record(z$1.string(),z$1.unknown()).optional(),hooks:z$1.record(z$1.string(),z$1.unknown()).optional(),experimental:z$1.record(z$1.string(),z$1.unknown()).optional(),context:z$1.record(z$1.string(),z$1.unknown()).optional()}).passthrough();s(Ik,"parseJsonObject");s(Sk,"mergeSettingsJson");s(Ck,"mergeGeminiSettingsJson");});var f$,g$,h$,y$,Gm,Yf=d(()=>{HE();ts();JE();Ft();Jf();mk();uk();Nt();ui();ht();gk();yk();he();Xf();f$={name:"gemini-cli",primaryRootInstructionPath:We,generateRules:Df,generateCommands:Nf,generateAgents:Ff,generateSkills:vf,generateIgnore:Gf,generatePermissions:VE,importFrom:$m},g$={rootInstructionPath:We,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[on]}],extraRuleOutputPaths(){return [on]},skillDir:".gemini/skills",managedOutputs:{dirs:[".gemini/agents",".gemini/commands",".gemini/skills",".agents/skills"],files:["AGENTS.md","GEMINI.md",".gemini/settings.json",".gemini/policies/permissions.toml",".geminiignore"]},mirrorGlobalPath(t,e){return mt(t,".gemini/skills",e)},paths:{rulePath(t,e){return We},commandPath(t,e){if(t.includes(":")){let r=t.split(":").filter(Boolean),n=r.pop()??t;return `${Ie}/${r.join("/")}/${n}.toml`}return `${Ie}/${t}.toml`},agentPath(t,e){return be(e,"gemini-cli")?`.gemini/skills/${z(t)}/SKILL.md`:`${No}/${t}.md`}}},h$={rootInstructionPath:Zi,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[qi]}],extraRuleOutputPaths(){return [qi]},skillDir:Ws,managedOutputs:{dirs:[Qi,Ws,Ac],files:[Zi,qi,Nm]},rewriteGeneratedPath(t){return t===We?Zi:t===on?qi:t===Us?Nm:t.startsWith(`${Ie}/`)?t.replace(`${Ie}/`,`${Qi}/`):t.startsWith(".gemini/skills/")?t.replace(".gemini/skills/",`${Ws}/`):t.startsWith(`${No}/`)?t.replace(`${No}/`,`${Ac}/`):t.startsWith(".gemini/policies/")||t===".geminiignore"?null:t},mirrorGlobalPath(t,e){return mt(t,Ws,e)},paths:{rulePath(t,e){return Zi},commandPath(t,e){if(t.includes(":")){let r=t.split(":").filter(Boolean),n=r.pop()??t;return `${Qi}/${r.join("/")}/${n}.toml`}return `${Qi}/${t}.toml`},agentPath(t,e){return be(e,"gemini-cli")?`${Ws}/${z(t)}/SKILL.md`:`${Ac}/${t}.md`}}},y$={rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"partial",ignore:"none",permissions:"none"},Gm={id:"gemini-cli",generators:f$,capabilities:{rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"partial",ignore:er("native","settings-embedded"),permissions:"partial"},emptyImportMessage:"No Gemini CLI config found (GEMINI.md or .gemini/rules, .gemini/commands, .gemini/settings.json).",lintRules:pk,lint:{commands:dk,hooks:fk},emitScopedSettings:hk,mergeGeneratedOutputContent(t,e,r,n){let o=e?.content??t;return o!==null&&n===Us?Ck(o,r):null},project:g$,globalSupport:{capabilities:y$,detectionPaths:[Zi,qi,Nm,Qi,Ws,Ac],layout:h$},importer:{rules:{feature:"rules",mode:"directory",source:{project:[DE]},canonicalDir:Fo,extensions:[".md"],map:ck},commands:{feature:"commands",mode:"directory",source:{project:[Ie]},canonicalDir:Dm,extensions:[".md",".toml"],map:lk}},buildImportPaths:hd,detectionPaths:["GEMINI.md",".gemini"]};});function Rk(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes(Kr)),n=e?.body.trim()??"",o=xt(n,r);return o?[{path:Ge,content:o}]:[]}function Ok(t){return kt(t,ee)}function Ek(t){return t.commands.map(e=>({path:`${ee}/${at(e.name)}/SKILL.md`,content:xr(e)}))}function kk(t){return t.agents.map(e=>({path:`${ee}/${z(e.name)}/SKILL.md`,content:ce(e)}))}function wk(t){return t.ignore.length===0?[]:[{path:xn,content:t.ignore.join(`
|
|
120
|
+
`)}]}var Lk=d(()=>{Rt();xe();ht();ae();bi();s(Rk,"generateRules");s(Ok,"generateSkills");s(Ek,"generateCommands");s(kk,"generateAgents");s(wk,"generateIgnore");});async function bk(t,e={}){let r=e.scope??"project",n=[],o=await H(Kr,t,r);return n.push(...await tt(jm,t,r,{normalize:o})),await Ct(t,r==="global"?je:ee,Kr,n,o),n}var Ak=d(()=>{Ot();Rt();Ut();bi();Zf();s(bk,"importFromGoose");});function xk(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:Kr}))}var Pk=d(()=>{Wt();bi();s(xk,"lintRules");});function Tk(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","goose","Goose has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function Dk(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[j(".agentsmesh/permissions.yaml","goose","Goose permissions are managed at runtime via permission.yaml in ~/.config/goose/; canonical permissions are not projected.")]}function Nk(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[j(".agentsmesh/mcp.json","goose","Goose MCP extensions are configured globally in ~/.config/goose/config.yaml; project-level MCP is not projected.")]}var Fk=d(()=>{Tt();s(Tk,"lintHooks");s(Dk,"lintPermissions");s(Nk,"lintMcp");});var _$,I$,S$,vk,jm,Zf=d(()=>{ae();ht();Lk();he();Ak();Pk();Fk();Nt();bi();_$={name:Kr,primaryRootInstructionPath:Ge,generateRules:Rk,generateCommands:Ek,generateAgents:kk,generateSkills:Ok,generateIgnore:wk,importFrom:bk},I$={rootInstructionPath:Ge,skillDir:ee,managedOutputs:{dirs:[ee],files:[Ge,xn]},paths:{rulePath(t){return Ge},commandPath(t){return `${ee}/${at(t)}/SKILL.md`},agentPath(t){return `${ee}/${z(t)}/SKILL.md`}}},S$={rootInstructionPath:Pn,skillDir:je,managedOutputs:{dirs:[je],files:[Pn,ps]},rewriteGeneratedPath(t){return t===Ge?Pn:t===xn?ps:(t.startsWith(`${ee}/`),t)},mirrorGlobalPath(t,e){return mt(t,je,e)},paths:{rulePath(t){return Pn},commandPath(t){return `${je}/${at(t)}/SKILL.md`},agentPath(t){return `${je}/${z(t)}/SKILL.md`}}},vk={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"native",mcp:"none",hooks:"none",ignore:"native",permissions:"none"},jm={id:Kr,generators:_$,capabilities:vk,emptyImportMessage:"No Goose config found (.goosehints, .agents/skills, or .gooseignore).",lintRules:xk,lint:{hooks:Tk,permissions:Dk,mcp:Nk},supportsConversion:{commands:true,agents:true},project:I$,globalSupport:{capabilities:vk,detectionPaths:[Pn,ps,je],layout:S$},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[Ge],global:[Pn]},canonicalDir:iS,canonicalRootFilename:"_root.md",markAsRoot:true},ignore:{feature:"ignore",mode:"flatFile",source:{project:[xn],global:[ps]},canonicalDir:".agentsmesh",canonicalFilename:aS}},sharedArtifacts:{".agents/skills/":"consumer"},buildImportPaths:yd,detectionPaths:[Ge,xn]};});function Mk(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:Br,content:r.body.trim()||""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("junie"))continue;let o=basename(n.source,".md");e.push({path:`${oc}/${o}.md`,content:n.body.trim()||""});}return e}function R$(t){let e={};return t.description&&(e.description=t.description),t.type!=="stdio"&&(e.type=t.type),lm(t)?(e.command=t.command,e.args=t.args):(e.url=t.url,Object.keys(t.headers).length>0&&(e.headers=t.headers)),Object.keys(t.env).length>0&&(e.env=t.env),e}function $k(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=Object.fromEntries(Object.entries(t.mcp.mcpServers).map(([r,n])=>[r,R$(n)]));return [{path:nc,content:JSON.stringify({mcpServers:e},null,2)}]}function Gk(t){return t.commands.map(e=>{let r={description:e.description||void 0};return r.description===void 0&&delete r.description,{path:`${Ai}/${e.name}.md`,content:N(r,e.body.trim()||"")}})}function jk(t){return t.agents.map(e=>{let r={name:e.name,description:e.description||void 0,tools:e.tools.length>0?e.tools:void 0,disallowedTools:e.disallowedTools.length>0?e.disallowedTools:void 0,model:e.model||void 0,skills:e.skills.length>0?e.skills:void 0};return Object.keys(r).forEach(n=>{r[n]===void 0&&delete r[n];}),{path:`${xi}/${e.name}.md`,content:N(r,e.body.trim()||"")}})}function Uk(t){return t.ignore.length===0?[]:[{path:sc,content:t.ignore.join(`
|
|
121
|
+
`)}]}function Wk(t){return kt(t,ds)}function Kk(t){let e=t.rules.find(n=>n.root),r=t.rules.filter(n=>n.root?false:n.targets.length===0||n.targets.includes("junie"));return xt(e?.body.trim()??"",r)}var Bk=d(()=>{mm();Rt();xe();v();Pi();s(Mk,"generateRules");s(R$,"toJunieMcpServer");s($k,"generateMcp");s(Gk,"generateCommands");s(jk,"generateAgents");s(Uk,"generateIgnore");s(Wk,"generateSkills");s(Kk,"renderJunieGlobalInstructions");});async function O$(t,e,r){let n=[Br,Kl,lS,mS],o=join(t,_d);for(let i of n){let a=join(t,i),c=await y(a);if(c===null)continue;let l=await qr({content:c,projectRoot:t,rulesDir:Hl,sourcePath:a,fromTool:us,normalize:r});e.push(...l.results);let{frontmatter:m,body:p}=E(r(l.rootContent,a,o)),u=await G(o,{root:true,description:typeof m.description=="string"?m.description:void 0,globs:Array.isArray(m.globs)?m.globs:void 0},p);await C(o,u),e.push({fromTool:us,fromPath:a,toPath:_d,feature:"rules"});return}}async function Um(t){let e=[],r=await H(us,t);return await O$(t,e,r),e.push(...await tt(Wm,t,"project",{normalize:r})),await Ct(t,ds,us,e,r),e}var qf=d(()=>{Ot();b();v();Rt();Ki();nt();Ut();Pi();Qf();s(O$,"importRootRule");s(Um,"importFromJunie");});function zk(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:us}))}var Vk=d(()=>{Wt();Pi();s(zk,"lintRules");});function Jk(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=[];for(let[r,n]of Object.entries(t.mcp.mcpServers))yR(n)&&e.push(j(".agentsmesh/mcp.json","junie",`MCP server "${r}" uses ${n.type} transport; Junie project mcp.json currently documents stdio MCP servers only.`));return e}var Yk=d(()=>{mm();Tt();s(Jk,"lintMcp");});var E$,k$,w$,L$,Wm,Qf=d(()=>{Bk();Pi();he();qf();Vk();Yk();Nt();E$={name:"junie",primaryRootInstructionPath:Br,generateRules:Mk,generateCommands:Gk,generateAgents:jk,generateSkills:Wk,generateMcp:$k,generateIgnore:Uk,importFrom:Um},k$={rootInstructionPath:Br,skillDir:".junie/skills",managedOutputs:{dirs:[".junie/agents",".junie/commands",".junie/rules",".junie/skills"],files:[".aiignore",".junie/AGENTS.md",".junie/mcp/mcp.json"]},paths:{rulePath(t,e){return `${oc}/${t}.md`},commandPath(t,e){return `${Ai}/${t}.md`},agentPath(t,e){return `${xi}/${t}.md`}}},w$={rootInstructionPath:fs,renderPrimaryRootInstruction:Kk,skillDir:ac,managedOutputs:{dirs:[ac,cc,lc,pS],files:[fs,Bl]},rewriteGeneratedPath(t){return t===Br?fs:t.startsWith(`${oc}/`)?fs:t.startsWith(`${ds}/`)?t.replace(`${ds}/`,`${ac}/`):t.startsWith(`${Ai}/`)?t.replace(`${Ai}/`,`${lc}/`):t.startsWith(`${xi}/`)?t.replace(`${xi}/`,`${cc}/`):t===nc?Bl:t===sc?null:t},mirrorGlobalPath(t,e){return mt(t,".junie/skills",e)},paths:{rulePath(t,e){return fs},commandPath(t,e){return `${lc}/${t}.md`},agentPath(t,e){return `${cc}/${t}.md`}}},L$={rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},Wm={id:"junie",generators:E$,capabilities:{rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},emptyImportMessage:"No Junie config found (.junie/guidelines.md, .junie/AGENTS.md, .junie/skills, .junie/mcp/mcp.json, or .aiignore).",lintRules:zk,lint:{mcp:Jk},project:k$,globalSupport:{capabilities:L$,detectionPaths:[fs,ac,cc,lc,Bl],layout:w$},importer:{rules:{feature:"rules",mode:"directory",source:{project:[".junie/rules"]},canonicalDir:Hl,extensions:[".md"],preset:"rule"},commands:{feature:"commands",mode:"directory",source:{project:[".junie/commands"]},canonicalDir:uS,extensions:[".md"],preset:"command"},agents:{feature:"agents",mode:"directory",source:{project:[".junie/agents"]},canonicalDir:dS,extensions:[".md"],preset:"agent"},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[nc]},canonicalDir:".agentsmesh",canonicalFilename:fS},ignore:{feature:"ignore",mode:"flatFile",source:{project:[sc]},canonicalDir:".agentsmesh",canonicalFilename:gS}},buildImportPaths:Id,detectionPaths:[".junie/guidelines.md",".junie/AGENTS.md",".junie/skills",".junie/mcp/mcp.json",".aiignore"]};});function Zk(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:Hr,content:r.body.trim()?r.body:""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes(re))continue;let o=basename(n.source,".md"),i={};n.description&&(i.description=n.description),n.globs.length>0&&(i.globs=n.globs);let a=Object.keys(i).length>0?N(i,n.body.trim()||""):n.body.trim()||"";e.push({path:`${Tn}/${o}.md`,content:a});}return e}function qk(t){return t.commands.map(e=>{let r={};return e.description&&(r.description=e.description),{path:`${Dn}/${e.name}.md`,content:N(r,e.body.trim()||"")}})}function Qk(t){return t.agents.map(e=>{let r=basename(e.source,".md"),n={mode:"subagent"};return e.description&&(n.description=e.description),e.model&&(n.model=e.model),e.tools.length>0&&(n.tools=e.tools),e.disallowedTools.length>0&&(n.disallowedTools=e.disallowedTools),{path:`${Nn}/${r}.md`,content:N(n,e.body.trim()||"")}})}function tw(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:ho,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function ew(t){return t.ignore.length===0?[]:[{path:Ti,content:t.ignore.join(`
|
|
122
|
+
`)}]}function rw(t){return kt(t,mr)}var nw=d(()=>{Rt();v();Cs();s(Zk,"generateRules");s(qk,"generateCommands");s(Qk,"generateAgents");s(tw,"generateMcp");s(ew,"generateIgnore");s(rw,"generateSkills");});var Km,Bm,ow,eg=d(()=>{v();nt();Cs();Km=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${Io}/${t}`,content:await G(n,{root:false,description:typeof o.description=="string"?o.description:void 0,globs:Array.isArray(o.globs)?o.globs:void 0},i)}},"kiloNonRootRuleMapper"),Bm=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${vi}/${t}`,content:await it(n,{hasDescription:Object.prototype.hasOwnProperty.call(o,"description"),description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"kiloCommandMapper"),ow=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${Ss}/${t}`,content:await Pt(n,o,i)}},"kiloAgentMapper");});async function sw(t){try{return await stat(t),!0}catch{return false}}async function x$(t,e,r){let n=join(t,gs);if(!await sw(n))return;let o=join(t,Io),i=join(n,ng),c=e.some(l=>l.toPath===rg)?null:await y(i);if(c!==null){let l=join(t,rg),m=r(c,i,l),{body:p}=E(m),u=await G(l,{root:true},p);await C(l,u),e.push({feature:"rules",fromTool:re,fromPath:`${gs}/${ng}`,toPath:rg});}e.push(...await dt({srcDir:n,destDir:o,extensions:[".md"],fromTool:re,normalize:r,mapEntry:s(async({srcPath:l,relativePath:m,content:p,normalizeTo:u})=>{let f=await Km({absolutePath:l,relativePath:m,content:p,destDir:o,normalizeTo:u});return m===ng||!f?null:{...f,feature:"rules"}},"mapEntry")}));}async function P$(t,e,r){let n=join(t,Di);if(!await sw(n))return;let o=join(t,vi);e.push(...await dt({srcDir:n,destDir:o,extensions:[".md"],fromTool:re,normalize:r,mapEntry:s(async({srcPath:i,relativePath:a,content:c,normalizeTo:l})=>{let m=await Bm({absolutePath:i,relativePath:a,content:c,destDir:o,normalizeTo:l});return m?{...m,feature:"commands"}:null},"mapEntry")}));}async function T$(t,e,r){let n=join(t,Vl),o=await y(n);if(o===null)return;let i;try{i=parse(o);}catch{return}if(!(!i||!Array.isArray(i.customModes)))for(let a of i.customModes){if(!a||typeof a!="object")continue;let c=a;if(typeof c.slug!="string"||c.slug.length===0)continue;let l=c.slug,m=join(t,Ss,`${l}.md`),p=typeof c.description=="string"?c.description:"",u=typeof c.roleDefinition=="string"?c.roleDefinition.trim():"",f=typeof c.whenToUse=="string"?c.whenToUse.trim():"",g=f?`${u}
|
|
123
123
|
|
|
124
124
|
## When to use
|
|
125
125
|
|
|
126
|
-
${f}`:u,h={};p&&(h.description=p),typeof c.name=="string"&&c.name.length>0&&(h.name=c.name);let R=await
|
|
127
|
-
`)}]}var Xw=d(()=>{_t();ne();M();zf();Ti();s(t$,"steeringFrontmatter");s(Ww,"generateRules");s(Bw,"generateCommands");s(Hw,"generateSkills");s(zw,"generateMcp");s(Vw,"generateHooks");s(Jw,"generateAgents");s(Yw,"generateIgnore");});function r$(t){let e=typeof t.inclusion=="string"?t.inclusion:"",r={root:false,description:typeof t.description=="string"?t.description:void 0,globs:gn(t.fileMatchPattern)};return e==="manual"&&(r.trigger="manual"),e==="auto"&&(r.trigger="model_decision"),e==="fileMatch"&&(r.trigger="glob"),r}async function n$(t,e,r,n){let o=n==="global"?[mr,ar]:[ar,mr];for(let i of o){let a=join(t,i),c=await y(a);if(c===null)continue;let l=join(t,cd),{frontmatter:m,body:p}=w(r(c,a,l));await S(l,await j(l,{...m,root:true},p)),e.push({fromTool:fe,fromPath:a,toPath:cd,feature:"rules"});return}}async function o$(t,e,r){let n=join(t,ld);e.push(...await mt({srcDir:join(t,cr),destDir:n,extensions:[".md"],fromTool:fe,normalize:r,mapEntry:s(async({relativePath:o,normalizeTo:i})=>{if(basename(o)==="AGENTS.md")return null;let a=join(n,o),{frontmatter:c,body:l}=w(i(a));return {destPath:a,toPath:`${ld}/${o}`,feature:"rules",content:await j(a,r$(c),l)}},"mapEntry")}));}async function s$(t,e){let r={};for(let o of await N(join(t,go))){if(!o.endsWith(".kiro.hook"))continue;let i=Uw(await y(o)??"");i&&(r[i.event]??=[],r[i.event].push(i.entry));}if(Object.keys(r).length===0)return;let n=join(t,md);await O(join(t,".agentsmesh")),await S(n,Kw(r)),e.push({fromTool:fe,fromPath:join(t,go),toPath:md,feature:"hooks"});}async function Gm(t,e={}){let r=e.scope??"project",n=[],o=await z(fe,t,r);return await n$(t,n,o,r),await o$(t,n,o),n.push(...await Q(jm,t,r,{normalize:o})),await yt(t,Qt,fe,n,o),r==="project"&&await s$(t,n),n}var Vf=d(()=>{It();_t();tr();Mt();et();Qe();A();M();zf();Ti();Jf();s(r$,"canonicalRuleMeta");s(n$,"importRoot");s(o$,"importNonRootRules");s(s$,"importHooks");s(Gm,"importFromKiro");});function Zw(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:fe}))}var qw=d(()=>{$t();Ti();s(Zw,"lintRules");});function Qw(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=["PreToolUse","PostToolUse","UserPromptSubmit","SubagentStop"],r=new Set(e);return Object.keys(t.hooks).filter(n=>!r.has(n)).map(n=>di(n,"kiro",e,{unsupportedBy:"Kiro hooks"}))}var tE=d(()=>{bt();s(Qw,"lintHooks");});var i$,a$,c$,l$,jm,Jf=d(()=>{ne();Xw();ue();Vf();qw();tE();xt();Ti();i$={name:fe,primaryRootInstructionPath:ar,generateRules:Ww,generateCommands:Bw,generateAgents:Jw,generateSkills:Hw,generateMcp:zw,generateHooks:Vw,generateIgnore:Yw,importFrom:Gm},a$={rootInstructionPath:ar,skillDir:Qt,managedOutputs:{dirs:[".kiro/hooks",".kiro/skills",".kiro/steering",".kiro/agents"],files:["AGENTS.md",".kiro/settings/mcp.json",".kiroignore"]},paths:{rulePath(t,e){return `${cr}/${t}.md`},commandPath(t){return `${Qt}/${st(t)}/SKILL.md`},agentPath(t,e){return `${lr}/${t}.md`}}},c$={rootInstructionPath:mr,skillDir:ho,managedOutputs:{dirs:[gs,ho,hs,YI],files:[mr,cc,lc]},rewriteGeneratedPath(t){return t===ar?mr:t.startsWith(`${cr}/`)?t.replace(`${cr}/`,`${gs}/`):t.startsWith(`${Qt}/`)?t.replace(`${Qt}/`,`${ho}/`):t.startsWith(`${lr}/`)?t.replace(`${lr}/`,`${hs}/`):t===xi?cc:t===Pi?lc:t.startsWith(`${go}/`)?null:t},mirrorGlobalPath(t,e){return at(t,".kiro/skills",e)},paths:{rulePath(t,e){return `${gs}/${t}.md`},commandPath(t){return `${Qt}/${st(t)}/SKILL.md`},agentPath(t,e){return `${hs}/${t}.md`}}},l$={rules:"native",additionalRules:"native",commands:"none",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},jm={id:fe,generators:i$,capabilities:{rules:"native",additionalRules:"native",commands:"none",agents:"native",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"none"},emptyImportMessage:"No Kiro config found (AGENTS.md, .kiro/steering, .kiro/skills, .kiro/agents, .kiro/hooks, .kiro/settings/mcp.json, or .kiroignore).",supportsConversion:{commands:true},lintRules:Zw,lint:{hooks:Qw},project:a$,globalSupport:{capabilities:l$,detectionPaths:[gs,mr,ho,hs,cc,lc],layout:c$},importer:{agents:{feature:"agents",mode:"directory",source:{project:[lr],global:[lr]},canonicalDir:XI,extensions:[".md"],preset:"agent"},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[xi],global:[cc]},canonicalDir:".agentsmesh",canonicalFilename:ZI},ignore:{feature:"ignore",mode:"flatFile",source:{project:[Pi],global:[lc]},canonicalDir:".agentsmesh",canonicalFilename:qI}},buildImportPaths:pd,detectionPaths:[cr,Qt,lr,go,xi,Pi]};});function rE(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:Ur,content:r.body.trim()?r.body:""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes(pr))continue;let o=basename(n.source,".md"),i={};n.description&&(i.description=n.description),n.globs.length>0&&(i.globs=n.globs);let a=Object.keys(i).length>0?F(i,n.body.trim()||""):n.body.trim()||"";e.push({path:`${An}/${o}.md`,content:a});}return e}function nE(t){return t.commands.map(e=>{let r={};return e.description&&(r.description=e.description),{path:`${xn}/${e.name}.md`,content:F(r,e.body.trim()||"")}})}function oE(t){return t.agents.map(e=>{let r=basename(e.source,".md"),n={mode:"subagent"};return e.description&&(n.description=e.description),e.model&&(n.model=e.model),e.tools.length>0&&(n.tools=e.tools),e.disallowedTools.length>0&&(n.disallowedTools=e.disallowedTools),{path:`${Pn}/${r}.md`,content:F(n,e.body.trim()||"")}})}function m$(t){if("url"in t){let r={type:"remote",url:t.url};return Object.keys(t.headers).length>0&&(r.headers=t.headers),t.description&&(r.description=t.description),r}let e={type:"local",command:[t.command,...t.args]};return Object.keys(t.env).length>0&&(e.environment=t.env),t.description&&(e.description=t.description),e}function sE(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e={};for(let[r,n]of Object.entries(t.mcp.mcpServers))e[r]=m$(n);return [{path:Kr,content:JSON.stringify({mcp:e},null,2)}]}function iE(t){return St(t,ur)}var aE=d(()=>{_t();M();Cs();s(rE,"generateRules");s(nE,"generateCommands");s(oE,"generateAgents");s(m$,"toOpenCodeMcpServer");s(sE,"generateMcp");s(iE,"generateSkills");});function Yf(t){if(!t||typeof t!="object"||Array.isArray(t))return {};let e={};for(let[r,n]of Object.entries(t))typeof n=="string"&&(e[r]=n);return e}function u$(t){let e;try{e=JSON.parse(t);}catch{return {}}if(!e||typeof e!="object"||Array.isArray(e))return {};let r=e.mcp;if(!r||typeof r!="object"||Array.isArray(r))return {};let n={};for(let[o,i]of Object.entries(r)){if(!i||typeof i!="object"||Array.isArray(i))continue;let a=i;if(typeof a.url=="string"){n[o]={type:"url",url:a.url,headers:Yf(a.headers),env:Yf(a.environment),...typeof a.description=="string"?{description:a.description}:{}};continue}if(Array.isArray(a.command)&&a.command.length>0){let c=a.command,l=c[0];if(l===void 0)continue;let m=c.slice(1);n[o]={type:"stdio",command:l,args:m,env:Yf(a.environment),...typeof a.description=="string"?{description:a.description}:{}};}}return n}async function d$(t,e,r){let o=join(t,e==="global"?Io:Kr),i=await y(o);if(i===null)return;let a=u$(i);Object.keys(a).length!==0&&(await Ht(t,ud,a),r.push({feature:"mcp",fromTool:pr,fromPath:o,toPath:ud}));}async function cE(t,e={}){let r=e.scope??"project",n=[],o=await z(pr,t,r);return n.push(...await Q(Um,t,r,{normalize:o})),await yt(t,ur,pr,n,o),await d$(t,r,n),n}var lE=d(()=>{It();_t();Mt();fn();A();Cs();Xf();s(Yf,"toStringRecord");s(u$,"parseOpenCodeMcp");s(d$,"importMcp");s(cE,"importFromOpenCode");});var mE,pE,uE,dE=d(()=>{M();et();Cs();mE=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=w(e(n));return {destPath:n,toPath:`${mc}/${t}`,content:await j(n,{root:false,description:typeof o.description=="string"?o.description:void 0,globs:Array.isArray(o.globs)?o.globs:void 0},i)}},"opencodeNonRootRuleMapper"),pE=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=w(e(n));return {destPath:n,toPath:`${Kl}/${t}`,content:await ot(n,{hasDescription:Object.prototype.hasOwnProperty.call(o,"description"),description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"opencodeCommandMapper"),uE=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=w(e(n));return {destPath:n,toPath:`${Wl}/${t}`,content:await Lt(n,o,i)}},"opencodeAgentMapper");});function fE(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:pr}))}var gE=d(()=>{$t();Cs();s(fE,"lintRules");});function hE(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[U(".agentsmesh/hooks.yaml","opencode","opencode hooks are plugin-based (TypeScript/JavaScript); canonical config hooks are not projected.")]:[]:[]}function yE(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[U(".agentsmesh/permissions.yaml","opencode","opencode permissions live in opencode.json, which agentsmesh does not generate in v1; canonical permissions are not projected.")]}function _E(t){return t.ignore.length===0?[]:[U(".agentsmesh/ignore","opencode","opencode has no dedicated ignore file; canonical ignore patterns are not projected. Configure watcher.ignore in opencode.json manually.")]}var IE=d(()=>{bt();s(hE,"lintHooks");s(yE,"lintPermissions");s(_E,"lintIgnore");});var f$,g$,h$,CE,Um,Xf=d(()=>{aE();Cs();ue();lE();dE();gE();IE();xt();f$={name:pr,primaryRootInstructionPath:Ur,generateRules:rE,generateCommands:nE,generateAgents:oE,generateSkills:iE,generateMcp:sE,importFrom:cE},g$={rootInstructionPath:Ur,skillDir:ur,managedOutputs:{dirs:[An,xn,Pn,ur],files:[Ur,Kr]},paths:{rulePath(t){return `${An}/${t}.md`},commandPath(t){return `${xn}/${t}.md`},agentPath(t){return `${Pn}/${t}.md`}}},h$={rootInstructionPath:yo,skillDir:_o,managedOutputs:{dirs:[ys,_s,Is,_o,tC],files:[yo,Io]},rewriteGeneratedPath(t){return t===Ur?yo:t===Kr?Io:t},mirrorGlobalPath(t,e){return at(t,_o,e)},paths:{rulePath(t){return `${ys}/${t}.md`},commandPath(t){return `${_s}/${t}.md`},agentPath(t){return `${Is}/${t}.md`}}},CE={rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},Um={id:pr,generators:f$,capabilities:CE,emptyImportMessage:"No OpenCode config found (AGENTS.md, .opencode/rules, .opencode/commands, .opencode/agents, .opencode/skills, or opencode.json).",lintRules:fE,lint:{hooks:hE,permissions:yE,ignore:_E},project:g$,globalSupport:{capabilities:CE,detectionPaths:[yo,ys,_s,Is,_o,Io],layout:h$},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[Ur],global:[yo]},canonicalDir:mc,canonicalRootFilename:"_root.md",markAsRoot:true},{feature:"rules",mode:"directory",source:{project:[An],global:[ys]},canonicalDir:mc,extensions:[".md"],map:mE}],commands:{feature:"commands",mode:"directory",source:{project:[xn],global:[_s]},canonicalDir:Kl,extensions:[".md"],map:pE},agents:{feature:"agents",mode:"directory",source:{project:[Pn],global:[Is]},canonicalDir:Wl,extensions:[".md"],map:uE}},buildImportPaths:dd,detectionPaths:[An,xn,Pn,ur,Kr,"opencode.jsonc"]};});function RE(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:dr,content:r.body.trim()||""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes(Co))continue;let o=basename(n.source,".md");e.push({path:`${Tn}/${o}.md`,content:n.body.trim()||""});}return e}function kE(t){return t.commands.map(e=>{let r={};return e.description&&(r.description=e.description),{path:`${Dn}/${e.name}.md`,content:F(r,e.body.trim()||"")}})}function OE(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:uc,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function wE(t){return t.ignore.length===0?[]:[{path:dc,content:t.ignore.join(`
|
|
128
|
-
`)}]}function EE(t){return St(t,Wr)}function LE(t){if(t.agents.length===0)return [];let e=t.agents.map(r=>{let o={slug:basename(r.source,".md"),name:r.name};return r.description&&(o.description=r.description),r.body.trim()&&(o.roleDefinition=r.body.trim()),o});return [{path:Ni,content:stringify({customModes:e})}]}var bE=d(()=>{_t();M();Os();s(RE,"generateRules");s(kE,"generateCommands");s(OE,"generateMcp");s(wE,"generateIgnore");s(EE,"generateSkills");s(LE,"generateAgents");});var Km,xE,qf=d(()=>{M();et();Os();Km=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{if(t==="00-root.md")return null;let n=join(r,t),{frontmatter:o,body:i}=w(e(n));return {destPath:n,toPath:`${ks}/${t}`,content:await j(n,{root:false,description:typeof o.description=="string"?o.description:void 0,globs:Array.isArray(o.globs)?o.globs:void 0},i)}},"rooNonRootRuleMapper"),xE=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=w(e(n));return {destPath:n,toPath:`${Hl}/${t}`,content:await ot(n,{hasDescription:true,description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"rooCommandMapper");});async function I$(t,e,r){let n=join(t,Ss),o;try{o=await readdir(n,{withFileTypes:!0});}catch{return}let i=o.filter(c=>c.isDirectory()&&c.name.startsWith("rules-")).map(c=>c.name),a=join(t,ks);for(let c of i)e.push(...await mt({srcDir:join(n,c),destDir:a,extensions:[".md"],fromTool:Co,normalize:r,mapEntry:s(async({srcPath:l,relativePath:m,content:p,normalizeTo:u})=>{let f=await Km({absolutePath:l,relativePath:m,content:p,destDir:a,normalizeTo:u});return f?{...f,feature:"rules"}:null},"mapEntry")}));}async function PE(t,e={}){let r=e.scope??"project",n=[],o=await z(Co,t,r);return n.push(...await Q(Wm,t,r,{normalize:o})),await I$(t,n,o),await yt(t,Wr,Co,n,o),n}var TE=d(()=>{It();_t();tr();Mt();qf();Os();tg();s(I$,"importPerModeRules");s(PE,"importFromRooCode");});function DE(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:Co}))}var NE=d(()=>{$t();Os();s(DE,"lintRules");});function w$(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var k$,O$,E$,L$,b$,Wm,tg=d(()=>{A();bE();Os();ue();TE();qf();NE();xt();k$={name:"roo-code",primaryRootInstructionPath:dr,generateRules:RE,generateCommands:kE,generateSkills:EE,generateMcp:OE,generateIgnore:wE,generateAgents:LE,importFrom:PE},O$={rootInstructionPath:dr,skillDir:".roo/skills",managedOutputs:{dirs:[".roo/rules",".roo/commands",".roo/skills"],files:[".roo/mcp.json",".rooignore",".roorules",Ni]},paths:{rulePath(t,e){return `${Tn}/${t}.md`},commandPath(t,e){return `${Dn}/${t}.md`},agentPath(t,e){return null}}};s(w$,"computeStatus");E$=s(async(t,e,r,n)=>{if(r!=="global")return [];if(!n.has("agents")||t.agents.length===0)return [];let o=t.agents.map(c=>{let m={slug:basename(c.source,".md"),name:c.name};return c.description&&(m.description=c.description),c.body.trim()&&(m.roleDefinition=c.body.trim()),m}),i=stringify({customModes:o}),a=await y(join(e,fc));return [{target:"roo-code",path:fc,content:i,currentContent:a??void 0,status:w$(a,i)}]},"generateRooGlobalExtras"),L$={rootInstructionPath:ko,skillDir:Nn,managedOutputs:{dirs:[So,Ro,Nn,rC],files:[ko,Rs,gc,fc]},rewriteGeneratedPath(t){return t===dr?ko:t===Ni?null:t.startsWith(`${Tn}/`)?t.replace(`${Tn}/`,`${So}/`):t.startsWith(`${Dn}/`)?t.replace(`${Dn}/`,`${Ro}/`):t.startsWith(`${Wr}/`)?t.replace(`${Wr}/`,`${Nn}/`):t===uc?Rs:t===dc?gc:t},mirrorGlobalPath(t,e){return at(t,Nn,e)},paths:{rulePath(t,e){return `${So}/${t}.md`},commandPath(t,e){return `${Ro}/${t}.md`},agentPath(t,e){return null}}},b$={rules:"native",additionalRules:"native",commands:"native",agents:"partial",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},Wm={id:"roo-code",generators:k$,capabilities:{rules:"native",additionalRules:"native",commands:"native",agents:"partial",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},emptyImportMessage:"No Roo Code config found (.roo/rules, .roo/commands, .roo/skills, .roo/mcp.json, .rooignore, or .roorules).",lintRules:DE,project:O$,globalSupport:{capabilities:b$,detectionPaths:[So,Ro,Nn,Rs,gc,ko,fc],layout:L$,scopeExtras:E$},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[dr,pc],global:[ko,dr,pc]},canonicalDir:ks,canonicalRootFilename:"_root.md",markAsRoot:true,frontmatterRemap:s(({description:t,globs:e})=>({description:typeof t=="string"?t:void 0,globs:Array.isArray(e)?e:void 0}),"frontmatterRemap")},{feature:"rules",mode:"directory",source:{project:[Tn],global:[So]},canonicalDir:ks,extensions:[".md"],map:Km}],commands:{feature:"commands",mode:"directory",source:{project:[Dn],global:[Ro]},canonicalDir:Hl,extensions:[".md"],map:xE},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[uc],global:[Rs]},canonicalDir:".agentsmesh",canonicalFilename:nC},ignore:{feature:"ignore",mode:"flatFile",source:{project:[dc],global:[gc]},canonicalDir:".agentsmesh",canonicalFilename:oC}},buildImportPaths:fd,detectionPaths:[".roo/rules",".roo/commands",".roo/skills",".roo/mcp.json",".rooignore",".roorules",Ni]};});function FE(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes(Br)),n=e?.body.trim()??"",o=Et(n,r);return o?[{path:fr,content:o}]:[]}function vE(t){return St(t,zt)}function ME(t){return t.commands.map(e=>({path:`${zt}/${st(e.name)}/SKILL.md`,content:wr(e)}))}function $E(t){return t.agents.map(e=>({path:`${zt}/${V(e.name)}/SKILL.md`,content:oe(e)}))}function GE(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=JSON.stringify({mcpServers:t.mcp.mcpServers},null,2);return [{path:Oo,content:e}]}var jE=d(()=>{_t();we();dt();ne();Fi();s(FE,"generateRules");s(vE,"generateSkills");s(ME,"generateCommands");s($E,"generateAgents");s(GE,"generateMcp");});async function UE(t,e={}){let r=e.scope??"project",n=[],o=await z(Br,t,r);return n.push(...await Q(Bm,t,r,{normalize:o})),await yt(t,r==="global"?se:zt,Br,n,o),n}var KE=d(()=>{It();_t();Mt();Fi();eg();s(UE,"importFromWarp");});function WE(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:Br}))}var BE=d(()=>{$t();Fi();s(WE,"lintRules");});function HE(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[U(".agentsmesh/hooks.yaml","warp","Warp has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function zE(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[U(".agentsmesh/permissions.yaml","warp","Warp permissions are UI-managed; canonical permissions are not projected.")]}function VE(t){return t.ignore.length===0?[]:[U(".agentsmesh/ignore","warp","Warp has no dedicated ignore file and relies on .gitignore; canonical ignore patterns are not projected.")]}var JE=d(()=>{bt();s(HE,"lintHooks");s(zE,"lintPermissions");s(VE,"lintIgnore");});var A$,x$,P$,T$,D$,Bm,eg=d(()=>{ne();dt();jE();ue();KE();BE();JE();xt();Fi();A$={name:Br,primaryRootInstructionPath:fr,generateRules:FE,generateCommands:ME,generateAgents:$E,generateSkills:vE,generateMcp:GE,importFrom:UE},x$={rootInstructionPath:fr,skillDir:zt,managedOutputs:{dirs:[zt],files:[fr,Oo]},paths:{rulePath(t){return fr},commandPath(t){return `${zt}/${st(t)}/SKILL.md`},agentPath(t){return `${zt}/${V(t)}/SKILL.md`}}},P$={rootInstructionPath:void 0,skillDir:se,managedOutputs:{dirs:[se],files:[]},rewriteGeneratedPath(t){return t.startsWith(`${zt}/`)?t.replace(`${zt}/`,`${se}/`):t},mirrorGlobalPath(t,e){return at(t,se,e)},paths:{rulePath(){return se},commandPath(t){return `${se}/${st(t)}/SKILL.md`},agentPath(t){return `${se}/${V(t)}/SKILL.md`}}},T$={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},D$={rules:"none",additionalRules:"none",commands:"none",agents:"none",skills:"native",mcp:"none",hooks:"none",ignore:"none",permissions:"none"},Bm={id:Br,generators:A$,capabilities:T$,emptyImportMessage:"No Warp config found (WARP.md, AGENTS.md, .warp/skills, or .mcp.json).",lintRules:WE,lint:{hooks:HE,permissions:zE,ignore:VE},supportsConversion:{commands:true,agents:true},project:x$,globalSupport:{capabilities:D$,detectionPaths:[se],layout:P$},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[gd,fr]},canonicalDir:iC,canonicalRootFilename:"_root.md",markAsRoot:true},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[Oo]},canonicalDir:".agentsmesh",canonicalFilename:"mcp.json"}},buildImportPaths:hd,detectionPaths:[fr,gd,Oo]};});var tn,rg,Do,YE,Ji,en,Yi,Xi,XE,No,_r,Zi,ng,og,sg,ig,ag,cg,qi,Qi,wc,Hm,zm,Vm,ZE,te=d(()=>{tn="windsurf",rg=".windsurfrules",Do=".windsurf/rules",YE=".windsurfignore",Ji=".codeiumignore",en="AGENTS.md",Yi=".windsurf/hooks.json",Xi=".windsurf/mcp_config.example.json",XE=".windsurf/mcp_config.json",No=".windsurf/workflows",_r=".windsurf/skills",Zi=".agentsmesh/rules",ng=".agentsmesh/commands",og=".agentsmesh/agents",sg=".agentsmesh/skills",ig=".agentsmesh/ignore",ag=".agentsmesh/hooks.yaml",cg=".agentsmesh/mcp.json",qi=".codeium/windsurf/memories/global_rules.md",Qi=".codeium/windsurf/skills",wc=".codeium/windsurf/global_workflows",Hm=".codeium/windsurf/hooks.json",zm=".codeium/windsurf/mcp_config.json",Vm=".codeium/.codeiumignore",ZE=".agents/skills";});function F$(t){let e=basename(t,".md");return e==="_root"?"root":e}function v$(t){if(t.length===0)return null;let e=t.map(r=>r.split("/")[0]??"").filter(r=>/^[A-Za-z0-9._-]+$/.test(r));return e.length!==t.length?null:e.every(r=>r===e[0])?e[0]:null}function lg(t){let e=[],r=t.rules.find(n=>n.root);if(!r)return [];e.push({path:en,content:r.body.trim()});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("windsurf"))continue;let o=F$(n.source),i=n.trigger||(n.globs.length>0?"glob":void 0),a={description:n.description||void 0,trigger:i,glob:n.globs.length===1?n.globs[0]:void 0,globs:n.globs.length>1?n.globs:void 0};Object.keys(a).forEach(m=>{a[m]===void 0&&delete a[m];});let c=Object.keys(a).length>0?F(a,n.body.trim()||""):n.body.trim()||"";e.push({path:`${Do}/${o}.md`,content:c});let l=v$(n.globs);l&&(l!==o&&e.push({path:`${Do}/${l}.md`,content:c}),e.push({path:`${l}/AGENTS.md`,content:n.body.trim()||""}));}return e}var qE=d(()=>{M();te();s(F$,"ruleSlug");s(v$,"directoryScopedRuleDir");s(lg,"generateRules");});function mg(t){return !t.ignore||t.ignore.length===0?[]:[{path:Ji,content:t.ignore.join(`
|
|
129
|
-
`)}]}var
|
|
130
|
-
`)),n.push({fromTool:"windsurf",fromPath:p,toPath:ig,feature:"ignore"});}}return await cL(t,n,o),await mL(t,n,o),await dL(t,n),await fL(t,n),n}var yg=d(()=>{It();A();M();et();tr();mi();te();lL();pL();gL();s(Ym,"importFromWindsurf");});function hL(t,e,r){let n=[],{rules:o}=t;o.length>0&&(o.some(c=>c.root)||n.push({level:"warning",file:relative(e,o[0].source),target:tn,message:"Windsurf needs a root rule to generate AGENTS.md. Add root: true to a rule."}));let i=[];return t.permissions&&(t.permissions.allow.length>0||t.permissions.deny.length>0)&&i.push("permissions"),i.length>0&&n.push({level:"warning",file:".agentsmesh",target:tn,message:`Windsurf cannot project these features yet: ${i.join(", ")}.`}),n}var yL=d(()=>{te();s(hL,"lintRules");});function _L(t){return t.commands.filter(e=>e.description.length>0||e.allowedTools.length>0).map(e=>U(e.source,"windsurf","windsurf workflow files are plain Markdown; command description and allowed-tools metadata are not projected."))}function IL(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[U(".agentsmesh/mcp.json","windsurf","Windsurf MCP is partial; generated .windsurf/mcp_config.example.json is a reference artifact and may require manual setup.")]}var CL=d(()=>{bt();s(_L,"lintCommands");s(IL,"lintMcp");});function V$(t){if(t.length===0)return null;let e=t.map(r=>r.split("/")[0]??"").filter(r=>/^[A-Za-z0-9._-]+$/.test(r));return e.length!==t.length?null:e.every(r=>r===e[0])?e[0]:null}var J$,Y$,X$,Z$,SL,RL=d(()=>{iL();Vo();te();ue();yg();yL();CL();xt();si();dt();s(V$,"directoryScopedRuleDir");J$={name:"windsurf",primaryRootInstructionPath:en,generateRules:lg,generateCommands:pg,generateAgents:ug,generateSkills:gg,generateMcp:dg,generateHooks:fg,generateIgnore:mg,importFrom:Ym},Y$={rootInstructionPath:en,extraRuleOutputPaths(t){if(t.root)return [en];let e=V$(t.globs);return e!==null?[`${e}/AGENTS.md`]:[]},skillDir:_r,managedOutputs:{dirs:[".windsurf/rules",".windsurf/skills",".windsurf/workflows"],files:["AGENTS.md",".codeiumignore",".windsurf/hooks.json",".windsurf/mcp_config.example.json"]},paths:{rulePath(t,e){return `${Do}/${t}.md`},commandPath(t,e){return `${No}/${t}.md`},agentPath(t,e){return ke(e,"windsurf")?`.windsurf/skills/${V(t)}/SKILL.md`:null}}},X$={rootInstructionPath:qi,skillDir:Qi,managedOutputs:{dirs:[Qi,wc,ZE],files:[qi,Hm,zm,Vm]},rewriteGeneratedPath(t){return t===en?qi:t.startsWith(`${Do}/`)||/\/AGENTS\.md$/.test(t)?null:t.startsWith(`${_r}/`)?t.replace(`${_r}/`,`${Qi}/`):t.startsWith(`${No}/`)?t.replace(`${No}/`,`${wc}/`):t===Yi?Hm:t===Xi?zm:t===Ji?Vm:t},mirrorGlobalPath(t,e){return at(t,".codeium/windsurf/skills",e)},paths:{rulePath(t,e){return qi},commandPath(t,e){return `${wc}/${t}.md`},agentPath(t,e){return ke(e,"windsurf")?`${Qi}/${V(t)}/SKILL.md`:null}}},Z$={rules:"native",additionalRules:"partial",commands:Ze("native","workflows"),agents:"embedded",skills:"native",mcp:"partial",hooks:"native",ignore:"native",permissions:"none"},SL={id:"windsurf",generators:J$,capabilities:{rules:"native",additionalRules:"native",commands:Ze("native","workflows"),agents:"embedded",skills:"native",mcp:"partial",hooks:"native",ignore:"native",permissions:"none"},emptyImportMessage:"No Windsurf config found (.windsurfrules, .windsurf/rules, .windsurfignore, or .codeiumignore).",supportsConversion:{agents:true},lintRules:hL,lint:{commands:_L,mcp:IL},project:Y$,globalSupport:{capabilities:Z$,detectionPaths:[qi,Qi,wc,Hm,zm,Vm],layout:X$},buildImportPaths:yd,detectionPaths:[".windsurfrules",".windsurf"]};});function kL(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes("zed")),n=e?.body.trim()??"",o=Et(n,r);return o?[{path:gr,content:o}]:[]}var OL=d(()=>{we();ws();s(kL,"generateRules");});async function EL(t,e,r){let n=await y(join(t,e));if(n===null)return;let o;try{o=JSON.parse(n);}catch{return}if(o===null||typeof o!="object"||Array.isArray(o))return;let a=o.context_servers;if(a==null||typeof a!="object"||Array.isArray(a)||Object.keys(a).length===0)return;let c={};for(let[l,m]of Object.entries(a)){if(!m||typeof m!="object"||Array.isArray(m))continue;let p={...m};delete p.source,c[l]=p;}Object.keys(c).length!==0&&(await Ht(t,wL,c),r.push({fromTool:"zed",fromPath:e,toPath:wL,feature:"mcp"}));}var wL,LL=d(()=>{A();fn();ws();wL=".agentsmesh/mcp.json";s(EL,"importZedMcp");});async function bL(t,e={}){let r=e.scope??"project",n=[],o=await z("zed",t,r);return n.push(...await Q(Xm,t,r,{normalize:o})),await EL(t,r==="global"?zr:Hr,n),n}var AL=d(()=>{It();Mt();LL();ws();_g();s(bL,"importFromZed");});function xL(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:"zed"}))}var PL=d(()=>{$t();ws();s(xL,"lintRules");});function TL(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[U(".agentsmesh/hooks.yaml","zed","Zed has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function DL(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[U(".agentsmesh/permissions.yaml","zed","Zed permissions are managed via agent.tool_permissions in settings.json; canonical permissions are not projected.")]}function NL(t){return t.ignore.length===0?[]:[U(".agentsmesh/ignore","zed","Zed has no dedicated ignore file and relies on file_scan_exclusions in settings.json; canonical ignore patterns are not projected.")]}var FL=d(()=>{bt();s(TL,"lintHooks");s(DL,"lintPermissions");s(NL,"lintIgnore");});function oG(t,e){if(t===null)return e;let r;try{let i=JSON.parse(t);r=i!==null&&typeof i=="object"&&!Array.isArray(i)?i:{};}catch{r={};}let n=JSON.parse(e);if(n===null||typeof n!="object"||Array.isArray(n))return t;let o=n;return o.context_servers!==void 0&&(r.context_servers=o.context_servers),JSON.stringify(r,null,2)}var Q$,tG,eG,rG,nG,Xm,_g=d(()=>{OL();AL();PL();FL();xt();ws();Q$={name:"zed",primaryRootInstructionPath:gr,generateRules:kL,importFrom:bL},tG={rootInstructionPath:gr,managedOutputs:{dirs:[],files:[gr,Hr]},paths:{rulePath(t){return gr},commandPath(){return null},agentPath(){return null}}},eG={rootInstructionPath:void 0,managedOutputs:{dirs:[],files:[zr]},rewriteGeneratedPath(t){return t===Hr?zr:t},paths:{rulePath(){return zr},commandPath(){return null},agentPath(){return null}}},rG={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"none",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},nG={rules:"none",additionalRules:"none",commands:"none",agents:"none",skills:"none",mcp:"native",hooks:"none",ignore:"none",permissions:"none"};s(oG,"mergeZedSettings");Xm={id:"zed",generators:Q$,capabilities:rG,emptyImportMessage:"No Zed config found (.rules or .zed/settings.json).",lintRules:xL,lint:{hooks:TL,permissions:DL,ignore:NL},project:tG,globalSupport:{capabilities:nG,detectionPaths:[zr],layout:eG},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[gr],global:[]},canonicalDir:lC,canonicalRootFilename:"_root.md",markAsRoot:true}},emitScopedSettings(t,e){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let r={};for(let[n,o]of Object.entries(t.mcp.mcpServers))r[n]=o;return [{path:Hr,content:JSON.stringify({context_servers:r},null,2)}]},mergeGeneratedOutputContent(t,e,r,n){return n===Hr||n===zr?oG(t,r):null},buildImportPaths:_d,detectionPaths:[gr,Hr]};});var dI={};Yp(dI,{BUILTIN_TARGETS:()=>Ft,TARGET_IDS:()=>it,getBuiltinTargetDefinition:()=>$e,getEffectiveTargetSupportLevel:()=>Zm,getTargetCapabilities:()=>Po,getTargetDetectionPaths:()=>Cg,getTargetLayout:()=>Tt,getTargetManagedOutputs:()=>Sg,getTargetPrimaryRootInstructionPath:()=>iG,getTargetSkillDir:()=>Lc,isBuiltinTargetId:()=>He,resolveTargetFeatureGenerator:()=>ta,rewriteGeneratedOutputPath:()=>Rg});function sG(){return Ig||(R_(Ft),Ig=new Map(Ft.map(t=>[t.id,t]))),Ig}function $e(t){return sG().get(t)}function Po(t,e="project"){let r=$e(t)??tt(t);if(!r)return;let n=e==="global"?r.globalSupport?.capabilities??r.capabilities:r.capabilities;return C_(n)}function Cg(t,e="project"){let r=$e(t)??tt(t);return r?e==="global"?r.globalSupport?.detectionPaths??[]:r.detectionPaths:[]}function Tt(t,e="project"){let r=$e(t)??tt(t);if(r)return e==="global"?r.globalSupport?.layout:r.project}function iG(t,e="project"){return Tt(t,e)?.rootInstructionPath}function Lc(t,e="project"){return Tt(t,e)?.skillDir}function Sg(t,e="project"){return Tt(t,e)?.managedOutputs}function Rg(t,e,r="project"){let n=Tt(t,r);return n?n.rewriteGeneratedPath?n.rewriteGeneratedPath(e):e:null}function vL(t,e,r,n){return !t||!r?false:e==="commands"&&t.supportsConversion?.commands?!oi(r,t.id,true,n):e==="agents"&&t.supportsConversion?.agents?!ke(r,t.id,true,n):false}function aG(t,e,r,n){return !t||!r?false:e==="commands"&&t.supportsConversion?.commands?oi(r,t.id,true,n):e==="agents"&&t.supportsConversion?.agents?ke(r,t.id,true,n):false}function Zm(t,e,r,n="project"){let o=Po(t,n)?.[e]?.level??"none",i=$e(t)??tt(t);return o==="none"&&aG(i,e,r,n)?"embedded":o!=="embedded"?o:vL(i,e,r,n)?"none":o}function ta(t,e,r,n="project"){let o=$e(t)??tt(t);if(!o?.generators||vL(o,e,r,n))return;let i=cG[e];return i===null?void 0:i(o.generators)}var Ft,Ig,cG,ut=d(()=>{si();Vo();ye();Iu();ze();Pu();Cd();Rd();PS();yR();zd();Qd();gf();Ff();Mf();Gf();Hf();Jf();Xf();tg();eg();RL();_g();Ft=[kl,zl,Vl,xS,hR,im,dm,Rm,Pm,Tm,Nm,$m,jm,Um,Wm,Bm,SL,Xm];s(sG,"builtinTargetsMap");s($e,"getBuiltinTargetDefinition");s(Po,"getTargetCapabilities");s(Cg,"getTargetDetectionPaths");s(Tt,"getTargetLayout");s(iG,"getTargetPrimaryRootInstructionPath");s(Lc,"getTargetSkillDir");s(Sg,"getTargetManagedOutputs");s(Rg,"rewriteGeneratedOutputPath");s(vL,"isFeatureSuppressedByConversion");s(aG,"isConversionUpgrading");s(Zm,"getEffectiveTargetSupportLevel");cG={rules:s(t=>t.generateRules,"rules"),additionalRules:null,commands:s(t=>t.generateCommands,"commands"),agents:s(t=>t.generateAgents,"agents"),skills:s(t=>t.generateSkills,"skills"),mcp:s(t=>t.generateMcp,"mcp"),permissions:s(t=>t.generatePermissions,"permissions"),hooks:s(t=>t.generateHooks,"hooks"),ignore:s(t=>t.generateIgnore,"ignore")};s(ta,"resolveTargetFeatureGenerator");});function gG(t){return typeof t=="string"?t:t.level}function ML(t){return fG.includes(t)}function $L(t,e,r,n){for(let o of dG){let i=gG(e[o.feature]);if(i==="none")continue;let a=typeof t.generators[o.generator]=="function",c=ML(o.feature)&&typeof t.emitScopedSettings=="function";a||c||r.addIssue({code:"custom",path:[...n,o.feature],message:`Capability "${o.feature}" is "${i}" but generators.${o.generator}`+(ML(o.feature)?" or emitScopedSettings":"")+" is missing."});}}function qm(t){return yG.parse(t)}var Wn,GL,lG,mG,jL,pG,uG,dG,fG,hG,yG,kg=d(()=>{Wn=z$1.union([z$1.enum(["native","embedded","partial","none"]),z$1.object({level:z$1.enum(["native","embedded","partial","none"]),flavor:z$1.string().optional()})]),GL=z$1.object({rules:Wn,additionalRules:Wn,commands:Wn,agents:Wn,skills:Wn,mcp:Wn,hooks:Wn,ignore:Wn,permissions:Wn}),lG=z$1.object({name:z$1.string(),generateRules:z$1.function(),importFrom:z$1.function(),generateCommands:z$1.function().optional(),generateAgents:z$1.function().optional(),generateSkills:z$1.function().optional(),generateMcp:z$1.function().optional(),generatePermissions:z$1.function().optional(),generateHooks:z$1.function().optional(),generateIgnore:z$1.function().optional(),lint:z$1.function().optional()}).passthrough(),mG=z$1.object({rulePath:z$1.function(),commandPath:z$1.function(),agentPath:z$1.function()}),jL=z$1.object({paths:mG}).passthrough(),pG=z$1.object({capabilities:GL,detectionPaths:z$1.array(z$1.string()),layout:jL,scopeExtras:z$1.function().optional()}).passthrough(),uG=["global","globalCapabilities","globalDetectionPaths","generateScopeExtras"],dG=[{feature:"commands",generator:"generateCommands"},{feature:"agents",generator:"generateAgents"},{feature:"skills",generator:"generateSkills"},{feature:"mcp",generator:"generateMcp"},{feature:"hooks",generator:"generateHooks"},{feature:"ignore",generator:"generateIgnore"},{feature:"permissions",generator:"generatePermissions"}],fG=["mcp","hooks","ignore","permissions"];s(gG,"capabilityLevel");s(ML,"canUseScopedSettings");s($L,"validateCapabilityImplementations");hG=z$1.object({id:z$1.string().regex(/^[a-z][a-z0-9-]*$/,"Target id must be lowercase with hyphens"),generators:lG,capabilities:GL,emptyImportMessage:z$1.string(),lintRules:z$1.union([z$1.function(),z$1.null()]),project:jL,globalSupport:pG.optional(),buildImportPaths:z$1.function(),detectionPaths:z$1.array(z$1.string())}).passthrough(),yG=hG.superRefine((t,e)=>{for(let r of uG)r in t&&e.addIssue({code:"custom",path:[r],message:`Use globalSupport instead of legacy field "${r}".`});$L(t,t.capabilities,e,["capabilities"]),t.globalSupport!==void 0&&$L(t,t.globalSupport.capabilities,e,["globalSupport","capabilities"]);});s(qm,"validateDescriptor");});function _G(){return Og||(Og=new Map(Ft.map(t=>[t.id,t]))),Og}function Qm(t){let e=qm(t);wg.set(e.id,e);}function tt(t){return wg.get(t)??_G().get(t)}function tp(){return [...wg.values()]}var wg,Og,ye=d(()=>{ut();kg();wg=new Map;s(_G,"builtinDescriptors");s(Qm,"registerTargetDescriptor");s(tt,"getDescriptor");s(tp,"getAllDescriptors");});async function UL(t,e,r="project"){let n=new Map,o=tt(t);return o&&await o.buildImportPaths(n,e,r),n}var KL=d(()=>{ye();s(UL,"buildImportReferenceMap");});function SG(t){let e=[t.project,t.globalSupport?.layout].filter(o=>o!==void 0),r=[...t.detectionPaths,...e.flatMap(o=>o.managedOutputs?.dirs??[]),...e.flatMap(o=>o.managedOutputs?.files??[])],n=new Set;for(let o of r){let i=o.split("/")[0];i&&i.startsWith(".")&&i.length>1&&n.add(`${i}/`);}return n}function RG(){let t=new Set([".agentsmesh/"]);for(let e of Ft)for(let r of SG(e))t.add(r);return Array.from(t)}function kG(){let t=new Set([...RG(),...Eg.rootRelativePrefixes]),e=new Set([...CG,...Eg.meshRootSegments]);return {protectedSchemes:[...IG,...Eg.protectedSchemes],rootRelativePrefixes:Array.from(t),meshRootSegments:e}}function ep(){return Lg||(Lg=kG()),Lg}var IG,CG,Eg,Lg,WL=d(()=>{ut();IG=[/\b[A-Za-z][A-Za-z0-9+.-]+:[^\s<>()\]]+/g,/\b[\w.-]+@[\w.-]+:[^\s<>()\]]+/g,/\b[\w.+-]+@[\w.-]+\.[A-Za-z]{2,}\b/g,/\/\/[A-Za-z0-9][\w.-]*\.[A-Za-z]{2,}[^\s<>()\]]*/g],CG=new Set(["skills","rules","commands","agents","packs"]),Eg={protectedSchemes:[],rootRelativePrefixes:[],meshRootSegments:[]};s(SG,"topLevelDotfilePrefixes");s(RG,"buildDefaultRootRelativePrefixes");s(kG,"rebuild");s(ep,"getLinkFormatRegistry");});function Ir(t){let e=pt(t);return ep().rootRelativePrefixes.some(r=>e.startsWith(r))}function wG(t){let e=pt(t).replace(/^\.\//,"");if(e.startsWith("../")||e.startsWith("/")||Ye.test(e)||/^[a-zA-Z]:/.test(e)||Ir(e))return false;let r=e.split("/").filter(n=>n.length>0)[0];return r!==void 0&&ep().meshRootSegments.has(r)}function bc(t,e,r){let n=Y(e),o=K(e,e),i=K(e,r),a=pt(t);if(Ye.test(t)){let c=K(e,t);return n===win32||c.startsWith(`${o}${n.sep}`)?[c]:[c]}if(n.isAbsolute(t)){let c=K(e,t);return c.startsWith(o)||existsSync(t)?[c]:[K(e,n.join(e,t))]}if(a.startsWith("./")||a.startsWith("../")){let c=K(e,n.join(n.dirname(i),a)),l=h_(a,o);return l&&l!==c?[c,l]:[c]}if(Ir(a))return [K(e,n.join(o,a))];if(a.includes("/")){let c=K(e,n.join(o,".agentsmesh")),l=wG(a)?K(e,n.join(c,a)):null,m=K(e,n.join(o,a)),p=K(e,n.join(n.dirname(i),a));return l!==null?[l,m,p]:[m,p]}return EG.has(a)?[]:a.includes(".")?[K(e,n.join(n.dirname(i),a))]:[]}function Ac(t,e){let r=[e];if(!g_(t,e)||!existsSync(e))return r;try{let n=[realpathSync(e),realpathSync.native(e)];for(let o of n)o!==e&&!r.includes(o)&&r.push(o);}catch{}return r}function VL(t,e,r){let n=e>0?t.at(e-1):"",o=r<t.length?t.at(r):"";return n==="*"||o==="*"}function rp(t){let e=[];for(let r of ep().protectedSchemes){let n=r.flags.includes("g")?r:new RegExp(r.source,`${r.flags}g`);for(let o of t.matchAll(n))e.push([o.index??0,(o.index??0)+o[0].length]);}for(let r of t.matchAll(LG))e.push([r.index??0,(r.index??0)+r[0].length]);for(let r of t.matchAll(bG))e.push([r.index??0,(r.index??0)+r[0].length]);for(let r of t.matchAll(AG))e.push([r.index??0,(r.index??0)+r[0].length]);return e}var EG,LG,bG,AG,zL,ea,Fo=d(()=>{Wt();WL();s(Ir,"isRootRelativePathToken");s(wG,"isMeshRootRelativePathToken");EG=new Set(["AGENTS.md","CLAUDE.md","GEMINI.md","codex.md",".windsurfrules",".cursorrules"]),LG=/^(?:```|~~~)[^\n]*\n[\s\S]*?^(?:```|~~~)/gm,bG=/<!-- agentsmesh:root-generation-contract:start -->[\s\S]*?<!-- agentsmesh:root-generation-contract:end -->/g,AG=/<!-- agentsmesh:embedded-rules:start -->[\s\S]*?<!-- agentsmesh:embedded-rules:end -->/g,zL=/(?:\.\.[\\/]|\.\/|\.\\|\/[A-Za-z0-9._-]|[A-Za-z]:[\\/][A-Za-z0-9._-]|\.agentsmesh[\\/]|\.claude[\\/]|\.cursor[\\/]|\.github[\\/]|\.continue[\\/]|\.junie[\\/]|\.kiro[\\/]|\.gemini[\\/]|\.clinerules[\\/]|\.cline[\\/]|\.codex[\\/]|\.agents[\\/]|\.windsurf[\\/]|\.roo[\\/]|(?:[A-Za-z0-9._-]+[\\/])+|[A-Za-z0-9._-]+\.[A-Za-z0-9._-]+)[A-Za-z0-9._@%+~:\\/-]*/g,ea=/(?::(\d+)){1,2}$/;s(bc,"resolveProjectPath");s(Ac,"expandResolvedPaths");s(VL,"isGlobAdjacent");s(rp,"protectedRanges");});function xG(t){return t===void 0||t.role==="inline-code"||t.role==="bracketed"||t.role==="quoted"||t.role==="at-prefix"||t.role==="bracket-label"||t.role==="bare-prose"}function JL(t){return xG(t.tokenContext)}function bg(t,e){let r=Y(t),n=K(t,t),o=K(t,e);if(o===n)return true;let i=n.endsWith(r.sep)?n:`${n}${r.sep}`;return o.startsWith(i)}function YL(t){let e=Y(t);return K(t,e.join(t,".agentsmesh"))}function Cr(t,e){let r=Y(t),n=YL(t),o=K(t,e);if(o===n)return true;let i=n.endsWith(r.sep)?n:`${n}${r.sep}`;return o.startsWith(i)}function XL(t,e,r){let n=Y(t),o=YL(t),i=K(t,e);if(!Cr(t,i))return null;let a=n.relative(o,i).replace(/\\/g,"/");return a.startsWith("..")||a.length===0?null:r&&!a.endsWith("/")?`${a}/`:a}function Ag(t,e,r){let o=Y(t).relative(K(t,t),K(t,e)).replace(/\\/g,"/");if(o.startsWith(".."))return null;let i=o.length>0?o:".";return r&&!i.endsWith("/")?`${i}/`:i}function ra(t,e,r){let n=Ag(t,e,r);return n===null?null:{kind:"projectRoot",rest:n,text:n}}function xg(t,e,r,n,o){let i=Y(t),a=K(t,t),c=K(t,e),l=K(t,r);if(!bg(t,l))return ra(t,l,n)?.text??null;let m=K(t,i.dirname(c));if(!bg(t,m)&&m!==a)return ra(t,l,n)?.text??null;let p=i.relative(m,l).replace(/\\/g,"/");if(i.isAbsolute(p)||Ye.test(p))return Ag(t,l,n);let u=K(t,i.join(m,p));return bg(t,u)?(p===""||p==="."?p=".":o.explicitCurrentDirLinks===true&&m!==a&&!p.startsWith("../")&&!p.startsWith("./")&&(p=`./${p}`),n&&!p.endsWith("/")?`${p}/`:p):Ag(t,l,n)}var Pg=d(()=>{Wt();s(xG,"isReadingContext");s(JL,"isReadingContextOptions");s(bg,"isUnderProjectRoot");s(YL,"agentsMeshRoot");s(Cr,"isUnderAgentsMesh");s(XL,"toAgentsMeshRootRelative");s(Ag,"toProjectRootRelative");s(ra,"toProjectRootReference");s(xg,"formatLinkPathForDestinationLegacy");});function ZL(t,e,r,n,o={}){let i=o.scope??"project",a=K(t,r);if(JL(o)&&Cr(t,e)&&Cr(t,a)){let m=Y(t),p=K(t,t),u=m.relative(p,a).replace(/\\/g,"/");if(!u.startsWith("..")&&u.length>0)return n&&!u.endsWith("/")?`${u}/`:u}if(o.forceRelative)return xg(t,e,r,n,o);if(i==="global"&&!Cr(t,e))return ra(t,a,n)?.text??null;let c=(()=>{if(Cr(t,a))return a;let m=o.logicalMeshSourceAbsolute;return m&&Cr(t,K(t,m))?K(t,m):null})();if(!c)return ra(t,a,n)?.text??null;if(n||(o.pathIsDirectory?.(a)??false)){let m=XL(t,c,n);return m!==null?m:ra(t,c,n)?.text??null}return xg(t,e,r,n,o)}var qL=d(()=>{Fo();Wt();Pg();Pg();s(ZL,"formatLinkPathForDestination");});function QL(t,e,r,n){let o=Y(e),i=pt(t);if(!Ir(i))return null;let a=i.split("/").filter(m=>m.length>0);if(a.length<3)return null;let c=K(e,r),l=o.dirname(c);for(let m=1;m<=a.length-1;m++){let p=a.slice(m).join("/"),u=K(e,o.join(l,p));if(u!==c&&n(u))return u}return null}var tb=d(()=>{Wt();Fo();s(QL,"resolveByDestinationSuffixStrip");});function eb(t){let e=null,r=false,n=null,o=null,i=null;for(let l of bc(t.candidate,t.projectRoot,t.sourceFile)){let m=null,p=null;for(let u of Ac(t.projectRoot,l)){let f=K(t.projectRoot,u),g=K(t.projectRoot,t.translatePath(f)),h=t.pathExists(f),R=t.pathExists(g);if(R&&g!==f){e=g,n=f,r=true;break}(h||R)&&m===null&&(m=g,p=f),e===null&&(e=g);}if(!r&&m!==null&&o===null&&(o=m,i=p),r)break}if(!r){let l=QL(t.candidate,t.projectRoot,t.destinationFile,t.pathExists);l!==null&&(e=l,r=true);}!r&&o!==null&&(e=o,i!==null&&(n=i),r=true);let a=pt(t.destinationFile),c=a.includes("/.agentsmesh/")||a.startsWith(".agentsmesh/");return !r&&e!==null&&pt(t.rawToken).startsWith(".agentsmesh/")&&c&&(r=true),{translatedPath:e,resolvedBeforeTranslate:n,matchedPath:r}}var rb=d(()=>{Wt();Fo();tb();s(eb,"resolveLinkTarget");});function nb(t,e,r){return e>=2&&t[e-2]==="~"&&t[e-1]==="/"?true:e>=1&&t[e-1]==="~"&&r.startsWith("/")}function ob(t,e,r){if(e<=0||t[e-1]!=="(")return false;let n=e+r.length,o=t[n];return o!==")"&&o!=="#"&&o!=="?"&&o!==" "&&o!==" "?false:t[e-2]==="]"}function sb(t){let e=pt(t);return e.startsWith("./")||e.startsWith("../")?true:e.startsWith("/")||Ye.test(e)||Ir(e)?false:e.includes("/")}var ib=d(()=>{Wt();Fo();s(nb,"isTildeHomeRelativePathToken");s(ob,"isMarkdownLinkDestinationToken");s(sb,"isRelativePathToken");});function PG(t,e,r){let n=e+r.length;if(t[n]!=="]"||t[n+1]!=="(")return false;let o=n+2,i="";for(;o<t.length;){let a=t[o];if(a===")"||a==="#"||a==="?"||a===" "||a===" "||a===`
|
|
131
|
-
`)break;i+=a,o++;}return i===r}function
|
|
126
|
+
${f}`:u,h={};p&&(h.description=p),typeof c.name=="string"&&c.name.length>0&&(h.name=c.name);let R=await Pt(m,h,g),S=r(R,n,m);await C(m,S),e.push({feature:"agents",fromTool:re,fromPath:n,toPath:`${Ss}/${l}.md`});}}async function Hm(t,e={}){let r=e.scope??"project",n=[],o=await H(re,t,r);return n.push(...await tt(zm,t,r,{normalize:o})),await Ct(t,mr,re,n,o),r==="project"&&(await x$(t,n,o),await P$(t,n,o),await T$(t,n,o),await Ct(t,hs,re,n,o)),n}var rg,ng,og=d(()=>{Ot();Rt();or();Ut();b();nt();v();eg();Cs();sg();rg=`${Io}/_root.md`,ng="00-root.md";s(sw,"pathExists");s(x$,"importLegacyRules");s(P$,"importLegacyWorkflows");s(T$,"importLegacyModes");s(Hm,"importFromKiloCode");});function iw(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:re}))}var aw=d(()=>{Wt();Cs();s(iw,"lintRules");});function cw(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","kilo-code","kilo-code does not support user-defined lifecycle hooks; canonical hooks are not projected.")]:[]:[]}function lw(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[j(".agentsmesh/permissions.yaml","kilo-code","kilo-code permissions live in kilo.jsonc, which agentsmesh does not generate in v1; canonical permissions are not projected.")]}var mw=d(()=>{Tt();s(cw,"lintHooks");s(lw,"lintPermissions");});var D$,N$,F$,pw,zm,sg=d(()=>{nw();Cs();he();og();eg();aw();mw();Nt();D$={name:re,primaryRootInstructionPath:Hr,generateRules:Zk,generateCommands:qk,generateAgents:Qk,generateSkills:rw,generateMcp:tw,generateIgnore:ew,importFrom:Hm},N$={rootInstructionPath:Hr,skillDir:mr,managedOutputs:{dirs:[Tn,Dn,Nn,mr],files:[Hr,ho,Ti]},paths:{rulePath(t,e){return `${Tn}/${t}.md`},commandPath(t,e){return `${Dn}/${t}.md`},agentPath(t,e){return `${Nn}/${t}.md`}}},F$={rootInstructionPath:yo,skillDir:_o,managedOutputs:{dirs:[ys,_s,Is,_o,yS],files:[yo,Fi,Jl]},rewriteGeneratedPath(t){return t===Hr?yo:t},mirrorGlobalPath(t,e){return mt(t,_o,e)},paths:{rulePath(t,e){return `${ys}/${t}.md`},commandPath(t,e){return `${_s}/${t}.md`},agentPath(t,e){return `${Is}/${t}.md`}}},pw={rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},zm={id:re,generators:D$,capabilities:pw,emptyImportMessage:"No Kilo Code config found (AGENTS.md, .kilo/rules, .kilo/commands, .kilo/agents, .kilo/skills, .kilo/mcp.json, .kilocodeignore, .kilocode/, or .kilocodemodes).",lintRules:iw,lint:{hooks:cw,permissions:lw},project:N$,globalSupport:{capabilities:pw,detectionPaths:[yo,ys,_s,Is,_o,Fi,Jl],layout:F$},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[Hr],global:[yo]},canonicalDir:Io,canonicalRootFilename:"_root.md",markAsRoot:true},{feature:"rules",mode:"directory",source:{project:[Tn],global:[ys]},canonicalDir:Io,extensions:[".md"],map:Km}],commands:{feature:"commands",mode:"directory",source:{project:[Dn],global:[_s]},canonicalDir:vi,extensions:[".md"],map:Bm},agents:{feature:"agents",mode:"directory",source:{project:[Nn],global:[Is]},canonicalDir:Ss,extensions:[".md"],map:ow},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[ho,pc],global:[Fi]},canonicalDir:".agentsmesh",canonicalFilename:_S},ignore:{feature:"ignore",mode:"flatFile",source:{project:[Ti],global:[Jl]},canonicalDir:".agentsmesh",canonicalFilename:IS}},buildImportPaths:Sd,detectionPaths:[Tn,Dn,Nn,mr,ho,gs,Di,hs,pc,Vl,Ti,"kilo.jsonc","kilo.json"]};});function uw(t){return t.replace(/([a-z0-9])([A-Z])/g,"$1-$2").replace(/_/g,"-").toLowerCase()}function $$(t){return t.type==="prompt"?t.prompt:t.command}function G$(t,e){let r=dw[t];return t==="PreToolUse"||t==="PostToolUse"?{type:r,tools:[e||"*"]}:{type:r}}function fw(t){let e=[];for(let[r,n]of Object.entries(t)){let o=r;if(!(o in dw)||!Array.isArray(n))continue;let i=1;for(let a of n){let c=$$(a);if(!c)continue;let l={name:`${uw(r)} ${i}`,version:"1",when:G$(o,a.matcher),then:a.type==="prompt"?{type:"askAgent",prompt:c}:{type:"shellCommand",command:c}};e.push({name:`${uw(r)}-${i}.kiro.hook`,content:JSON.stringify(l,null,2)}),i+=1;}}return e}function j$(t){let e=M$.get(t.when.type);if(!e)return null;let r=t.when.tools?.[0]??t.when.patterns?.[0]??"*";return t.then.type==="askAgent"&&typeof t.then.prompt=="string"?{event:e,entry:{matcher:r,command:t.then.prompt,prompt:t.then.prompt,type:"prompt"}}:t.then.type==="shellCommand"&&typeof t.then.command=="string"?{event:e,entry:{matcher:r,command:t.then.command,type:"command"}}:null}function gw(t){let e;try{e=JSON.parse(t);}catch{return null}if(!e||typeof e!="object"||Array.isArray(e))return null;let r=e;return !r.when||!r.then||typeof r.when.type!="string"?null:j$(r)}function hw(t){return stringify(t).trimEnd()}var dw,M$,ig=d(()=>{dw={UserPromptSubmit:"promptSubmit",SubagentStop:"agentStop",PreToolUse:"preToolUse",PostToolUse:"postToolUse"},M$=new Map([["promptSubmit","UserPromptSubmit"],["agentStop","SubagentStop"],["preToolUse","PreToolUse"],["postToolUse","PostToolUse"]]);s(uw,"toKebab");s($$,"hookText");s(G$,"toWhen");s(fw,"generateKiroHooks");s(j$,"toCanonicalEntry");s(gw,"parseKiroHookFile");s(hw,"serializeCanonicalHooks");});function W$(t){let e={};return t.globs.length>0?(e.inclusion="fileMatch",e.fileMatchPattern=t.globs.length===1?t.globs[0]:t.globs):t.trigger==="manual"?e.inclusion="manual":t.trigger==="model_decision"?e.inclusion="auto":e.inclusion="always",t.description&&(e.description=t.description),e}function yw(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:pr,content:r.body.trim()||""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes(_e))continue;let o=basename(n.source,".md");e.push({path:`${ur}/${o}.md`,content:N(W$(n),n.body.trim()||"")});}return e}function _w(t){return t.commands.map(e=>({path:`${ne}/${at(e.name)}/SKILL.md`,content:xr(e)}))}function Iw(t){return kt(t,ne)}function Sw(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:Mi,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function Cw(t){return !t.hooks||Object.keys(t.hooks).length===0?[]:fw(t.hooks).map(e=>({path:`${So}/${e.name}`,content:e.content}))}function Rw(t){return t.agents.map(e=>{let r={name:e.name,description:e.description,tools:e.tools.length>0?e.tools:void 0,model:e.model||void 0};Object.keys(r).forEach(o=>{r[o]===void 0&&delete r[o];});let n=N(r,e.body.trim()||"");return {path:`${dr}/${e.name}.md`,content:n}})}function Ow(t){return t.ignore.length===0?[]:[{path:$i,content:t.ignore.join(`
|
|
127
|
+
`)}]}var Ew=d(()=>{Rt();ae();v();ig();Gi();s(W$,"steeringFrontmatter");s(yw,"generateRules");s(_w,"generateCommands");s(Iw,"generateSkills");s(Sw,"generateMcp");s(Cw,"generateHooks");s(Rw,"generateAgents");s(Ow,"generateIgnore");});function B$(t){let e=typeof t.inclusion=="string"?t.inclusion:"",r={root:false,description:typeof t.description=="string"?t.description:void 0,globs:Cn(t.fileMatchPattern)};return e==="manual"&&(r.trigger="manual"),e==="auto"&&(r.trigger="model_decision"),e==="fileMatch"&&(r.trigger="glob"),r}async function H$(t,e,r,n){let o=n==="global"?[fr,pr]:[pr,fr];for(let i of o){let a=join(t,i),c=await y(a);if(c===null)continue;let l=join(t,Cd),{frontmatter:m,body:p}=E(r(c,a,l));await C(l,await G(l,{...m,root:true},p)),e.push({fromTool:_e,fromPath:a,toPath:Cd,feature:"rules"});return}}async function z$(t,e,r){let n=join(t,Rd);e.push(...await dt({srcDir:join(t,ur),destDir:n,extensions:[".md"],fromTool:_e,normalize:r,mapEntry:s(async({relativePath:o,normalizeTo:i})=>{if(basename(o)==="AGENTS.md")return null;let a=join(n,o),{frontmatter:c,body:l}=E(i(a));return {destPath:a,toPath:`${Rd}/${o}`,feature:"rules",content:await G(a,B$(c),l)}},"mapEntry")}));}async function V$(t,e){let r={};for(let o of await D(join(t,So))){if(!o.endsWith(".kiro.hook"))continue;let i=gw(await y(o)??"");i&&(r[i.event]??=[],r[i.event].push(i.entry));}if(Object.keys(r).length===0)return;let n=join(t,Od);await O(join(t,".agentsmesh")),await C(n,hw(r)),e.push({fromTool:_e,fromPath:join(t,So),toPath:Od,feature:"hooks"});}async function Vm(t,e={}){let r=e.scope??"project",n=[],o=await H(_e,t,r);return await H$(t,n,o,r),await z$(t,n,o),n.push(...await tt(Jm,t,r,{normalize:o})),await Ct(t,ne,_e,n,o),r==="project"&&await V$(t,n),n}var ag=d(()=>{Ot();Rt();or();Ut();nt();nr();b();v();ig();Gi();cg();s(B$,"canonicalRuleMeta");s(H$,"importRoot");s(z$,"importNonRootRules");s(V$,"importHooks");s(Vm,"importFromKiro");});function kw(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:_e}))}var ww=d(()=>{Wt();Gi();s(kw,"lintRules");});function Lw(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=["PreToolUse","PostToolUse","UserPromptSubmit","SubagentStop"],r=new Set(e);return Object.keys(t.hooks).filter(n=>!r.has(n)).map(n=>Si(n,"kiro",e,{unsupportedBy:"Kiro hooks"}))}var bw=d(()=>{Tt();s(Lw,"lintHooks");});var J$,Y$,X$,Z$,Jm,cg=d(()=>{ae();Ew();he();ag();ww();bw();Nt();Gi();J$={name:_e,primaryRootInstructionPath:pr,generateRules:yw,generateCommands:_w,generateAgents:Rw,generateSkills:Iw,generateMcp:Sw,generateHooks:Cw,generateIgnore:Ow,importFrom:Vm},Y$={rootInstructionPath:pr,skillDir:ne,managedOutputs:{dirs:[".kiro/hooks",".kiro/skills",".kiro/steering",".kiro/agents"],files:["AGENTS.md",".kiro/settings/mcp.json",".kiroignore"]},paths:{rulePath(t,e){return `${ur}/${t}.md`},commandPath(t){return `${ne}/${at(t)}/SKILL.md`},agentPath(t,e){return `${dr}/${t}.md`}}},X$={rootInstructionPath:fr,skillDir:Co,managedOutputs:{dirs:[Rs,Co,Os,RS],files:[fr,dc,fc]},rewriteGeneratedPath(t){return t===pr?fr:t.startsWith(`${ur}/`)?t.replace(`${ur}/`,`${Rs}/`):t.startsWith(`${ne}/`)?t.replace(`${ne}/`,`${Co}/`):t.startsWith(`${dr}/`)?t.replace(`${dr}/`,`${Os}/`):t===Mi?dc:t===$i?fc:t.startsWith(`${So}/`)?null:t},mirrorGlobalPath(t,e){return mt(t,".kiro/skills",e)},paths:{rulePath(t,e){return `${Rs}/${t}.md`},commandPath(t){return `${ne}/${at(t)}/SKILL.md`},agentPath(t,e){return `${Os}/${t}.md`}}},Z$={rules:"native",additionalRules:"native",commands:"none",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},Jm={id:_e,generators:J$,capabilities:{rules:"native",additionalRules:"native",commands:"none",agents:"native",skills:"native",mcp:"native",hooks:"native",ignore:"native",permissions:"none"},emptyImportMessage:"No Kiro config found (AGENTS.md, .kiro/steering, .kiro/skills, .kiro/agents, .kiro/hooks, .kiro/settings/mcp.json, or .kiroignore).",supportsConversion:{commands:true},lintRules:kw,lint:{hooks:Lw},project:Y$,globalSupport:{capabilities:Z$,detectionPaths:[Rs,fr,Co,Os,dc,fc],layout:X$},importer:{agents:{feature:"agents",mode:"directory",source:{project:[dr],global:[dr]},canonicalDir:OS,extensions:[".md"],preset:"agent"},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[Mi],global:[dc]},canonicalDir:".agentsmesh",canonicalFilename:ES},ignore:{feature:"ignore",mode:"flatFile",source:{project:[$i],global:[fc]},canonicalDir:".agentsmesh",canonicalFilename:kS}},buildImportPaths:Ed,detectionPaths:[ur,ne,dr,So,Mi,$i]};});function xw(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:zr,content:r.body.trim()?r.body:""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes(gr))continue;let o=basename(n.source,".md"),i={};n.description&&(i.description=n.description),n.globs.length>0&&(i.globs=n.globs);let a=Object.keys(i).length>0?N(i,n.body.trim()||""):n.body.trim()||"";e.push({path:`${Fn}/${o}.md`,content:a});}return e}function Pw(t){return t.commands.map(e=>{let r={};return e.description&&(r.description=e.description),{path:`${vn}/${e.name}.md`,content:N(r,e.body.trim()||"")}})}function Tw(t){return t.agents.map(e=>{let r=basename(e.source,".md"),n={mode:"subagent"};return e.description&&(n.description=e.description),e.model&&(n.model=e.model),e.tools.length>0&&(n.tools=e.tools),e.disallowedTools.length>0&&(n.disallowedTools=e.disallowedTools),{path:`${Mn}/${r}.md`,content:N(n,e.body.trim()||"")}})}function q$(t){if("url"in t){let r={type:"remote",url:t.url};return Object.keys(t.headers).length>0&&(r.headers=t.headers),t.description&&(r.description=t.description),r}let e={type:"local",command:[t.command,...t.args]};return Object.keys(t.env).length>0&&(e.environment=t.env),t.description&&(e.description=t.description),e}function Dw(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e={};for(let[r,n]of Object.entries(t.mcp.mcpServers))e[r]=q$(n);return [{path:Vr,content:JSON.stringify({mcp:e},null,2)}]}function Nw(t){return kt(t,hr)}var Fw=d(()=>{Rt();v();Ls();s(xw,"generateRules");s(Pw,"generateCommands");s(Tw,"generateAgents");s(q$,"toOpenCodeMcpServer");s(Dw,"generateMcp");s(Nw,"generateSkills");});function lg(t){if(!t||typeof t!="object"||Array.isArray(t))return {};let e={};for(let[r,n]of Object.entries(t))typeof n=="string"&&(e[r]=n);return e}function tG(t){let e;try{e=JSON.parse(t);}catch{return {}}if(!e||typeof e!="object"||Array.isArray(e))return {};let r=e.mcp;if(!r||typeof r!="object"||Array.isArray(r))return {};let n={};for(let[o,i]of Object.entries(r)){if(!i||typeof i!="object"||Array.isArray(i))continue;let a=i;if(typeof a.url=="string"){n[o]={type:"url",url:a.url,headers:lg(a.headers),env:lg(a.environment),...typeof a.description=="string"?{description:a.description}:{}};continue}if(Array.isArray(a.command)&&a.command.length>0){let c=a.command,l=c[0];if(l===void 0)continue;let m=c.slice(1);n[o]={type:"stdio",command:l,args:m,env:lg(a.environment),...typeof a.description=="string"?{description:a.description}:{}};}}return n}async function eG(t,e,r){let o=join(t,e==="global"?Eo:Vr),i=await y(o);if(i===null)return;let a=tG(i);Object.keys(a).length!==0&&(await Yt(t,kd,a),r.push({feature:"mcp",fromTool:gr,fromPath:o,toPath:kd}));}async function vw(t,e={}){let r=e.scope??"project",n=[],o=await H(gr,t,r);return n.push(...await tt(Ym,t,r,{normalize:o})),await Ct(t,hr,gr,n,o),await eG(t,r,n),n}var Mw=d(()=>{Ot();Rt();Ut();Sn();b();Ls();mg();s(lg,"toStringRecord");s(tG,"parseOpenCodeMcp");s(eG,"importMcp");s(vw,"importFromOpenCode");});var $w,Gw,jw,Uw=d(()=>{v();nt();Ls();$w=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${gc}/${t}`,content:await G(n,{root:false,description:typeof o.description=="string"?o.description:void 0,globs:Array.isArray(o.globs)?o.globs:void 0},i)}},"opencodeNonRootRuleMapper"),Gw=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${Xl}/${t}`,content:await it(n,{hasDescription:Object.prototype.hasOwnProperty.call(o,"description"),description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"opencodeCommandMapper"),jw=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${Zl}/${t}`,content:await Pt(n,o,i)}},"opencodeAgentMapper");});function Ww(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:gr}))}var Kw=d(()=>{Wt();Ls();s(Ww,"lintRules");});function Bw(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","opencode","opencode hooks are plugin-based (TypeScript/JavaScript); canonical config hooks are not projected.")]:[]:[]}function Hw(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[j(".agentsmesh/permissions.yaml","opencode","opencode permissions live in opencode.json, which agentsmesh does not generate in v1; canonical permissions are not projected.")]}function zw(t){return t.ignore.length===0?[]:[j(".agentsmesh/ignore","opencode","opencode has no dedicated ignore file; canonical ignore patterns are not projected. Configure watcher.ignore in opencode.json manually.")]}var Vw=d(()=>{Tt();s(Bw,"lintHooks");s(Hw,"lintPermissions");s(zw,"lintIgnore");});var rG,nG,oG,Jw,Ym,mg=d(()=>{Fw();Ls();he();Mw();Uw();Kw();Vw();Nt();rG={name:gr,primaryRootInstructionPath:zr,generateRules:xw,generateCommands:Pw,generateAgents:Tw,generateSkills:Nw,generateMcp:Dw,importFrom:vw},nG={rootInstructionPath:zr,skillDir:hr,managedOutputs:{dirs:[Fn,vn,Mn,hr],files:[zr,Vr]},paths:{rulePath(t){return `${Fn}/${t}.md`},commandPath(t){return `${vn}/${t}.md`},agentPath(t){return `${Mn}/${t}.md`}}},oG={rootInstructionPath:Ro,skillDir:Oo,managedOutputs:{dirs:[Es,ks,ws,Oo,LS],files:[Ro,Eo]},rewriteGeneratedPath(t){return t===zr?Ro:t===Vr?Eo:t},mirrorGlobalPath(t,e){return mt(t,Oo,e)},paths:{rulePath(t){return `${Es}/${t}.md`},commandPath(t){return `${ks}/${t}.md`},agentPath(t){return `${ws}/${t}.md`}}},Jw={rules:"native",additionalRules:"native",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},Ym={id:gr,generators:rG,capabilities:Jw,emptyImportMessage:"No OpenCode config found (AGENTS.md, .opencode/rules, .opencode/commands, .opencode/agents, .opencode/skills, or opencode.json).",lintRules:Ww,lint:{hooks:Bw,permissions:Hw,ignore:zw},project:nG,globalSupport:{capabilities:Jw,detectionPaths:[Ro,Es,ks,ws,Oo,Eo],layout:oG},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[zr],global:[Ro]},canonicalDir:gc,canonicalRootFilename:"_root.md",markAsRoot:true},{feature:"rules",mode:"directory",source:{project:[Fn],global:[Es]},canonicalDir:gc,extensions:[".md"],map:$w}],commands:{feature:"commands",mode:"directory",source:{project:[vn],global:[ks]},canonicalDir:Xl,extensions:[".md"],map:Gw},agents:{feature:"agents",mode:"directory",source:{project:[Mn],global:[ws]},canonicalDir:Zl,extensions:[".md"],map:jw}},buildImportPaths:wd,detectionPaths:[Fn,vn,Mn,hr,Vr,"opencode.jsonc"]};});function Xw(t){let e=[],r=t.rules.find(n=>n.root);r&&e.push({path:yr,content:r.body.trim()||""});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes(ko))continue;let o=basename(n.source,".md");e.push({path:`${$n}/${o}.md`,content:n.body.trim()||""});}return e}function Zw(t){return t.commands.map(e=>{let r={};return e.description&&(r.description=e.description),{path:`${Gn}/${e.name}.md`,content:N(r,e.body.trim()||"")}})}function qw(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:yc,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function Qw(t){return t.ignore.length===0?[]:[{path:_c,content:t.ignore.join(`
|
|
128
|
+
`)}]}function tL(t){return kt(t,Jr)}function eL(t){if(t.agents.length===0)return [];let e=t.agents.map(r=>{let o={slug:basename(r.source,".md"),name:r.name};return r.description&&(o.description=r.description),r.body.trim()&&(o.roleDefinition=r.body.trim()),o});return [{path:Ui,content:stringify({customModes:e})}]}var rL=d(()=>{Rt();v();Ps();s(Xw,"generateRules");s(Zw,"generateCommands");s(qw,"generateMcp");s(Qw,"generateIgnore");s(tL,"generateSkills");s(eL,"generateAgents");});var Xm,oL,ug=d(()=>{v();nt();Ps();Xm=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{if(t==="00-root.md")return null;let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${xs}/${t}`,content:await G(n,{root:false,description:typeof o.description=="string"?o.description:void 0,globs:Array.isArray(o.globs)?o.globs:void 0},i)}},"rooNonRootRuleMapper"),oL=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=join(r,t),{frontmatter:o,body:i}=E(e(n));return {destPath:n,toPath:`${Ql}/${t}`,content:await it(n,{hasDescription:true,description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"rooCommandMapper");});async function aG(t,e,r){let n=join(t,bs),o;try{o=await readdir(n,{withFileTypes:!0});}catch{return}let i=o.filter(c=>c.isDirectory()&&c.name.startsWith("rules-")).map(c=>c.name),a=join(t,xs);for(let c of i)e.push(...await dt({srcDir:join(n,c),destDir:a,extensions:[".md"],fromTool:ko,normalize:r,mapEntry:s(async({srcPath:l,relativePath:m,content:p,normalizeTo:u})=>{let f=await Xm({absolutePath:l,relativePath:m,content:p,destDir:a,normalizeTo:u});return f?{...f,feature:"rules"}:null},"mapEntry")}));}async function sL(t,e={}){let r=e.scope??"project",n=[],o=await H(ko,t,r);return n.push(...await tt(Zm,t,r,{normalize:o})),await aG(t,n,o),await Ct(t,Jr,ko,n,o),n}var iL=d(()=>{Ot();Rt();or();Ut();ug();Ps();fg();s(aG,"importPerModeRules");s(sL,"importFromRooCode");});function aL(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:ko}))}var cL=d(()=>{Wt();Ps();s(aL,"lintRules");});function dG(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var pG,uG,fG,gG,hG,Zm,fg=d(()=>{b();rL();Ps();he();iL();ug();cL();Nt();pG={name:"roo-code",primaryRootInstructionPath:yr,generateRules:Xw,generateCommands:Zw,generateSkills:tL,generateMcp:qw,generateIgnore:Qw,generateAgents:eL,importFrom:sL},uG={rootInstructionPath:yr,skillDir:".roo/skills",managedOutputs:{dirs:[".roo/rules",".roo/commands",".roo/skills"],files:[".roo/mcp.json",".rooignore",".roorules",Ui]},paths:{rulePath(t,e){return `${$n}/${t}.md`},commandPath(t,e){return `${Gn}/${t}.md`},agentPath(t,e){return null}}};s(dG,"computeStatus");fG=s(async(t,e,r,n)=>{if(r!=="global")return [];if(!n.has("agents")||t.agents.length===0)return [];let o=t.agents.map(c=>{let m={slug:basename(c.source,".md"),name:c.name};return c.description&&(m.description=c.description),c.body.trim()&&(m.roleDefinition=c.body.trim()),m}),i=stringify({customModes:o}),a=await y(join(e,Ic));return [{target:"roo-code",path:Ic,content:i,currentContent:a??void 0,status:dG(a,i)}]},"generateRooGlobalExtras"),gG={rootInstructionPath:bo,skillDir:jn,managedOutputs:{dirs:[wo,Lo,jn,AS],files:[bo,As,Sc,Ic]},rewriteGeneratedPath(t){return t===yr?bo:t===Ui?null:t.startsWith(`${$n}/`)?t.replace(`${$n}/`,`${wo}/`):t.startsWith(`${Gn}/`)?t.replace(`${Gn}/`,`${Lo}/`):t.startsWith(`${Jr}/`)?t.replace(`${Jr}/`,`${jn}/`):t===yc?As:t===_c?Sc:t},mirrorGlobalPath(t,e){return mt(t,jn,e)},paths:{rulePath(t,e){return `${wo}/${t}.md`},commandPath(t,e){return `${Lo}/${t}.md`},agentPath(t,e){return null}}},hG={rules:"native",additionalRules:"native",commands:"native",agents:"partial",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},Zm={id:"roo-code",generators:pG,capabilities:{rules:"native",additionalRules:"native",commands:"native",agents:"partial",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},emptyImportMessage:"No Roo Code config found (.roo/rules, .roo/commands, .roo/skills, .roo/mcp.json, .rooignore, or .roorules).",lintRules:aL,project:uG,globalSupport:{capabilities:hG,detectionPaths:[wo,Lo,jn,As,Sc,bo,Ic],layout:gG,scopeExtras:fG},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[yr,hc],global:[bo,yr,hc]},canonicalDir:xs,canonicalRootFilename:"_root.md",markAsRoot:true,frontmatterRemap:s(({description:t,globs:e})=>({description:typeof t=="string"?t:void 0,globs:Array.isArray(e)?e:void 0}),"frontmatterRemap")},{feature:"rules",mode:"directory",source:{project:[$n],global:[wo]},canonicalDir:xs,extensions:[".md"],map:Xm}],commands:{feature:"commands",mode:"directory",source:{project:[Gn],global:[Lo]},canonicalDir:Ql,extensions:[".md"],map:oL},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[yc],global:[As]},canonicalDir:".agentsmesh",canonicalFilename:xS},ignore:{feature:"ignore",mode:"flatFile",source:{project:[_c],global:[Sc]},canonicalDir:".agentsmesh",canonicalFilename:PS}},buildImportPaths:Ld,detectionPaths:[".roo/rules",".roo/commands",".roo/skills",".roo/mcp.json",".rooignore",".roorules",Ui]};});function lL(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes(Yr)),n=e?.body.trim()??"",o=xt(n,r);return o?[{path:_r,content:o}]:[]}function mL(t){return kt(t,Xt)}function pL(t){return t.commands.map(e=>({path:`${Xt}/${at(e.name)}/SKILL.md`,content:xr(e)}))}function uL(t){return t.agents.map(e=>({path:`${Xt}/${z(e.name)}/SKILL.md`,content:ce(e)}))}function dL(t){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let e=JSON.stringify({mcpServers:t.mcp.mcpServers},null,2);return [{path:Ao,content:e}]}var fL=d(()=>{Rt();xe();ht();ae();Wi();s(lL,"generateRules");s(mL,"generateSkills");s(pL,"generateCommands");s(uL,"generateAgents");s(dL,"generateMcp");});async function gL(t,e={}){let r=e.scope??"project",n=[],o=await H(Yr,t,r);return n.push(...await tt(qm,t,r,{normalize:o})),await Ct(t,r==="global"?le:Xt,Yr,n,o),n}var hL=d(()=>{Ot();Rt();Ut();Wi();gg();s(gL,"importFromWarp");});function yL(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:Yr}))}var _L=d(()=>{Wt();Wi();s(yL,"lintRules");});function IL(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","warp","Warp has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function SL(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[j(".agentsmesh/permissions.yaml","warp","Warp permissions are UI-managed; canonical permissions are not projected.")]}function CL(t){return t.ignore.length===0?[]:[j(".agentsmesh/ignore","warp","Warp has no dedicated ignore file and relies on .gitignore; canonical ignore patterns are not projected.")]}var RL=d(()=>{Tt();s(IL,"lintHooks");s(SL,"lintPermissions");s(CL,"lintIgnore");});var yG,_G,IG,SG,CG,qm,gg=d(()=>{ae();ht();fL();he();hL();_L();RL();Nt();Wi();yG={name:Yr,primaryRootInstructionPath:_r,generateRules:lL,generateCommands:pL,generateAgents:uL,generateSkills:mL,generateMcp:dL,importFrom:gL},_G={rootInstructionPath:_r,skillDir:Xt,managedOutputs:{dirs:[Xt],files:[_r,Ao]},paths:{rulePath(t){return _r},commandPath(t){return `${Xt}/${at(t)}/SKILL.md`},agentPath(t){return `${Xt}/${z(t)}/SKILL.md`}}},IG={rootInstructionPath:void 0,skillDir:le,managedOutputs:{dirs:[le],files:[]},rewriteGeneratedPath(t){return t.startsWith(`${Xt}/`)?t.replace(`${Xt}/`,`${le}/`):t},mirrorGlobalPath(t,e){return mt(t,le,e)},paths:{rulePath(){return le},commandPath(t){return `${le}/${at(t)}/SKILL.md`},agentPath(t){return `${le}/${z(t)}/SKILL.md`}}},SG={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},CG={rules:"none",additionalRules:"none",commands:"none",agents:"none",skills:"native",mcp:"none",hooks:"none",ignore:"none",permissions:"none"},qm={id:Yr,generators:yG,capabilities:SG,emptyImportMessage:"No Warp config found (WARP.md, AGENTS.md, .warp/skills, or .mcp.json).",lintRules:yL,lint:{hooks:IL,permissions:SL,ignore:CL},supportsConversion:{commands:true,agents:true},project:_G,globalSupport:{capabilities:CG,detectionPaths:[le],layout:IG},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[bd,_r]},canonicalDir:DS,canonicalRootFilename:"_root.md",markAsRoot:true},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[Ao]},canonicalDir:".agentsmesh",canonicalFilename:"mcp.json"}},buildImportPaths:Ad,detectionPaths:[_r,bd,Ao]};});var sn,hg,$o,OL,ea,an,ra,na,EL,Go,Rr,oa,yg,_g,Ig,Sg,Cg,Rg,sa,ia,xc,Qm,tp,ep,kL,oe=d(()=>{sn="windsurf",hg=".windsurfrules",$o=".windsurf/rules",OL=".windsurfignore",ea=".codeiumignore",an="AGENTS.md",ra=".windsurf/hooks.json",na=".windsurf/mcp_config.example.json",EL=".windsurf/mcp_config.json",Go=".windsurf/workflows",Rr=".windsurf/skills",oa=".agentsmesh/rules",yg=".agentsmesh/commands",_g=".agentsmesh/agents",Ig=".agentsmesh/skills",Sg=".agentsmesh/ignore",Cg=".agentsmesh/hooks.yaml",Rg=".agentsmesh/mcp.json",sa=".codeium/windsurf/memories/global_rules.md",ia=".codeium/windsurf/skills",xc=".codeium/windsurf/global_workflows",Qm=".codeium/windsurf/hooks.json",tp=".codeium/windsurf/mcp_config.json",ep=".codeium/.codeiumignore",kL=".agents/skills";});function OG(t){let e=basename(t,".md");return e==="_root"?"root":e}function EG(t){if(t.length===0)return null;let e=t.map(r=>r.split("/")[0]??"").filter(r=>/^[A-Za-z0-9._-]+$/.test(r));return e.length!==t.length?null:e.every(r=>r===e[0])?e[0]:null}function Og(t){let e=[],r=t.rules.find(n=>n.root);if(!r)return [];e.push({path:an,content:r.body.trim()});for(let n of t.rules){if(n.root||n.targets.length>0&&!n.targets.includes("windsurf"))continue;let o=OG(n.source),i=n.trigger||(n.globs.length>0?"glob":void 0),a={description:n.description||void 0,trigger:i,glob:n.globs.length===1?n.globs[0]:void 0,globs:n.globs.length>1?n.globs:void 0};Object.keys(a).forEach(m=>{a[m]===void 0&&delete a[m];});let c=Object.keys(a).length>0?N(a,n.body.trim()||""):n.body.trim()||"";e.push({path:`${$o}/${o}.md`,content:c});let l=EG(n.globs);l&&(l!==o&&e.push({path:`${$o}/${l}.md`,content:c}),e.push({path:`${l}/AGENTS.md`,content:n.body.trim()||""}));}return e}var wL=d(()=>{v();oe();s(OG,"ruleSlug");s(EG,"directoryScopedRuleDir");s(Og,"generateRules");});function Eg(t){return !t.ignore||t.ignore.length===0?[]:[{path:ea,content:t.ignore.join(`
|
|
129
|
+
`)}]}var LL=d(()=>{oe();s(Eg,"generateIgnore");});function kg(t){return t.commands.map(e=>{let r={description:e.description.trim()||void 0,allowedTools:e.allowedTools.length>0?e.allowedTools:void 0};Object.keys(r).forEach(o=>{r[o]===void 0&&delete r[o];});let n=Object.keys(r).length>0?N(r,e.body.trim()||""):e.body.trim();return {path:`${Go}/${e.name}.md`,content:n}})}var bL=d(()=>{v();oe();s(kg,"generateCommands");});function wg(t){return t.agents.map(e=>({path:`${Rr}/${z(e.name)}/SKILL.md`,content:ce(e)}))}var AL=d(()=>{ht();oe();s(wg,"generateAgents");});function Lg(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[{path:na,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}var xL=d(()=>{oe();s(Lg,"generateMcp");});function kG(t){let e={PreToolUse:"pre_tool_use",PostToolUse:"post_tool_use",Notification:"notification",UserPromptSubmit:"user_prompt_submit",SubagentStart:"subagent_start",SubagentStop:"subagent_stop"};return e[t]?e[t]:t.replace(/([a-z0-9])([A-Z])/g,"$1_$2").replace(/[-\s]+/g,"_").toLowerCase()}function wG(t){let e={};for(let[r,n]of Object.entries(t)){if(!Array.isArray(n))continue;let o=[];for(let i of n){if(!Ar(i))continue;let a=At(i),c=Qt(i),l=i.type==="prompt"?c||a:a||c;l&&o.push({command:l,show_output:true});}o.length>0&&(e[kG(r)]=o);}return e}function bg(t){if(!t.hooks||Object.keys(t.hooks).length===0)return [];let e=wG(t.hooks);return Object.keys(e).length===0?[]:[{path:ra,content:JSON.stringify({hooks:e},null,2)}]}var PL=d(()=>{qe();oe();s(kG,"windsurfEventName");s(wG,"toWindsurfHooks");s(bg,"generateHooks");});function Ag(t){let e=[];for(let r of t.skills){let n={name:r.name,description:r.description||void 0};n.description===void 0&&delete n.description;let o=Object.keys(n).length>0?N(n,r.body.trim()||""):r.body.trim()||"";e.push({path:`${Rr}/${r.name}/SKILL.md`,content:o});for(let i of r.supportingFiles)e.push({path:`${Rr}/${r.name}/${i.relativePath}`,content:i.content});}return e}var TL=d(()=>{v();oe();s(Ag,"generateSkills");});var DL=d(()=>{wL();LL();bL();AL();xL();PL();TL();});var NL=d(()=>{DL();});function FL(t){return Array.isArray(t)?t.filter(e=>typeof e=="string").map(e=>e.trim()).filter(Boolean):typeof t=="string"?t.split(",").map(e=>e.trim()).filter(Boolean):[]}async function vL(t,e,r){let n=join(t,Go),i=(await D(n)).filter(c=>c.endsWith(".md")),a=join(t,yg);for(let c of i){let l=await y(c);if(!l)continue;let m=relative(n,c).replace(/\\/g,"/");await O(a);let p=join(a,m),u=r(l,c,p),{frontmatter:f,body:g}=E(u),h=await it(p,{description:typeof f.description=="string"?f.description:"",hasDescription:Object.prototype.hasOwnProperty.call(f,"description"),allowedTools:(()=>{let R=FL(f.allowedTools);return R.length>0?R:FL(f["allowed-tools"])})(),hasAllowedTools:Object.prototype.hasOwnProperty.call(f,"allowedTools")||Object.prototype.hasOwnProperty.call(f,"allowed-tools")},g);await C(p,h),e.push({fromTool:sn,fromPath:c,toPath:`${yg}/${m}`,feature:"commands"});}}var ML=d(()=>{b();v();nt();oe();s(FL,"toStringArray");s(vL,"importWorkflows");});async function $L(t,e,r,n=Rr){let o=join(t,n),i=await xo(o),a={projectRoot:t,sourceSkillsDir:n,destCanonicalSkillsDir:Ig,targetName:"windsurf",normalize:r,results:e};for(let[c,l]of i){let m=join(l,"SKILL.md"),p=await y(m);if(!p)continue;let u=E(p),f=Pr(u.frontmatter,c);if(f){await Pe(join(t,Ig,c));let g=join(t,_g);await O(g);let h=join(g,`${f.name}.md`);await C(h,Ae(f,r(u.body,m,h))),e.push({fromTool:"windsurf",fromPath:m,toPath:`${_g}/${f.name}.md`,feature:"agents"});continue}await Qr(c,l,a);}}var GL=d(()=>{b();v();ht();yi();Bi();oe();s($L,"importSkills");});async function UL(t,e){let r=join(t,ra),n=await y(r);if(n)try{let o=JSON.parse(n);if(!o.hooks||typeof o.hooks!="object"||Array.isArray(o.hooks))return;let i=xG(o.hooks);if(Object.keys(i).length===0)return;let a=join(t,Cg);await O(dirname(a)),await C(a,stringify(i)),e.push({fromTool:sn,fromPath:r,toPath:Cg,feature:"hooks"});}catch{}}function AG(t){return {pre_tool_use:"PreToolUse",post_tool_use:"PostToolUse",notification:"Notification",user_prompt_submit:"UserPromptSubmit",subagent_start:"SubagentStart",subagent_stop:"SubagentStop"}[t]??t}function xG(t){let e={};for(let[r,n]of Object.entries(t)){if(!Array.isArray(n))continue;let o=AG(r),i=[];for(let a of n){if(!a||typeof a!="object")continue;let c=a;if(typeof c.command=="string"&&c.command.trim()){i.push({matcher:".*",type:"command",command:c.command});continue}let l=typeof c.matcher=="string"&&c.matcher.trim()?c.matcher:".*",m=Array.isArray(c.hooks)?c.hooks:[];for(let p of m){if(!p||typeof p!="object")continue;let u=p,f=typeof u.command=="string"?u.command:typeof u.prompt=="string"?u.prompt:"";if(!f.trim())continue;let g={matcher:l,type:u.type==="prompt"?"prompt":"command",command:f};typeof u.timeout=="number"&&(g.timeout=u.timeout),i.push(g);}}i.length>0&&(e[o]=i);}return e}async function WL(t,e){let r=[na,EL];for(let n of r){let o=join(t,n),i=await y(o);if(i)try{let a=JSON.parse(i);if(!a.mcpServers||typeof a.mcpServers!="object")continue;let c=join(t,Rg);await O(dirname(c)),await C(c,JSON.stringify({mcpServers:a.mcpServers},null,2)),e.push({fromTool:sn,fromPath:o,toPath:Rg,feature:"mcp"});return}catch{}}}var KL=d(()=>{b();oe();s(UL,"importWindsurfHooks");s(AG,"canonicalHookEventName");s(xG,"windsurfHooksToCanonical");s(WL,"importWindsurfMcp");});async function np(t,e){let r=e?.scope??"project",n=[],o=await H(sn,t),i=await H("codex-cli",t),a=join(t,oa),c=join(t,hg),l=await y(c);if(l!==null){await O(a);let f=join(a,"_root.md"),g=o(l,c,f).trim(),h=await G(f,{root:true},g);await C(f,h),n.push({fromTool:"windsurf",fromPath:c,toPath:`${oa}/_root.md`,feature:"rules"});}if(l===null){let f=join(t,an),g=await y(f);if(g!==null){await O(a);let h=join(a,"_root.md"),R=o(i(g,f,h),f,h).trim(),S=await G(h,{root:true},R);await C(h,S),n.push({fromTool:"windsurf",fromPath:f,toPath:`${oa}/_root.md`,feature:"rules"});}}r!=="global"&&n.push(...await dt({srcDir:t,destDir:a,extensions:["AGENTS.md"],fromTool:"windsurf",normalize:o,mapEntry:s(async({srcPath:f,normalizeTo:g})=>{let h=relative(t,dirname(f)).replace(/\\/g,"/");if(!h||h==="."||basename(f)!=="AGENTS.md")return null;let R=h.replace(/\//g,"-");if(!xl(h))return await Pe(join(a,`${R}.md`)),null;let S=join(a,`${R}.md`);return {destPath:S,toPath:`${oa}/${R}.md`,feature:"rules",content:await G(S,{root:false,globs:[`${h}/**`]},g(S))}},"mapEntry")}));let m=join(t,$o);n.push(...await dt({srcDir:m,destDir:a,extensions:[".md"],fromTool:"windsurf",normalize:o,mapEntry:s(async({relativePath:f,normalizeTo:g})=>{if(f==="_root.md"&&l!==null)return null;let h=join(a,f),{frontmatter:R,body:S}=E(g(h)),_={...R};return typeof _.glob=="string"&&_.glob.trim()&&(_.globs=[_.glob],delete _.glob),{destPath:h,toPath:`${oa}/${f}`,feature:"rules",content:await G(h,{..._,root:false},S)}},"mapEntry")}));let p=join(t,OL),u=await y(p);if((u===null||!u.trim())&&(p=join(t,ea),u=await y(p)),u!==null&&u.trim()){let f=u.split(/\r?\n/),g=[];for(let h of f){let R=h.trim();R&&!R.startsWith("#")&&g.push(R);}if(g.length>0){await O(join(t,".agentsmesh"));let h=join(t,Sg);await C(h,g.join(`
|
|
130
|
+
`)),n.push({fromTool:"windsurf",fromPath:p,toPath:Sg,feature:"ignore"});}}return await vL(t,n,o),await $L(t,n,o),await UL(t,n),await WL(t,n),n}var Pg=d(()=>{Ot();b();v();nt();or();yi();oe();ML();GL();KL();s(np,"importFromWindsurf");});function BL(t,e,r){let n=[],{rules:o}=t;o.length>0&&(o.some(c=>c.root)||n.push({level:"warning",file:relative(e,o[0].source),target:sn,message:"Windsurf needs a root rule to generate AGENTS.md. Add root: true to a rule."}));let i=[];return t.permissions&&(t.permissions.allow.length>0||t.permissions.deny.length>0)&&i.push("permissions"),i.length>0&&n.push({level:"warning",file:".agentsmesh",target:sn,message:`Windsurf cannot project these features yet: ${i.join(", ")}.`}),n}var HL=d(()=>{oe();s(BL,"lintRules");});function zL(t){return t.commands.filter(e=>e.description.length>0||e.allowedTools.length>0).map(e=>j(e.source,"windsurf","windsurf workflow files are plain Markdown; command description and allowed-tools metadata are not projected."))}function VL(t){return !t.mcp||Object.keys(t.mcp.mcpServers).length===0?[]:[j(".agentsmesh/mcp.json","windsurf","Windsurf MCP is partial; generated .windsurf/mcp_config.example.json is a reference artifact and may require manual setup.")]}var JL=d(()=>{Tt();s(zL,"lintCommands");s(VL,"lintMcp");});function FG(t){if(t.length===0)return null;let e=t.map(r=>r.split("/")[0]??"").filter(r=>/^[A-Za-z0-9._-]+$/.test(r));return e.length!==t.length?null:e.every(r=>r===e[0])?e[0]:null}var vG,MG,$G,GG,YL,XL=d(()=>{NL();ts();oe();he();Pg();HL();JL();Nt();ui();ht();s(FG,"directoryScopedRuleDir");vG={name:"windsurf",primaryRootInstructionPath:an,generateRules:Og,generateCommands:kg,generateAgents:wg,generateSkills:Ag,generateMcp:Lg,generateHooks:bg,generateIgnore:Eg,importFrom:np},MG={rootInstructionPath:an,extraRuleOutputPaths(t){if(t.root)return [an];let e=FG(t.globs);return e!==null?[`${e}/AGENTS.md`]:[]},skillDir:Rr,managedOutputs:{dirs:[".windsurf/rules",".windsurf/skills",".windsurf/workflows"],files:["AGENTS.md",".codeiumignore",".windsurf/hooks.json",".windsurf/mcp_config.example.json"]},paths:{rulePath(t,e){return `${$o}/${t}.md`},commandPath(t,e){return `${Go}/${t}.md`},agentPath(t,e){return be(e,"windsurf")?`.windsurf/skills/${z(t)}/SKILL.md`:null}}},$G={rootInstructionPath:sa,skillDir:ia,managedOutputs:{dirs:[ia,xc,kL],files:[sa,Qm,tp,ep]},rewriteGeneratedPath(t){return t===an?sa:t.startsWith(`${$o}/`)||/\/AGENTS\.md$/.test(t)?null:t.startsWith(`${Rr}/`)?t.replace(`${Rr}/`,`${ia}/`):t.startsWith(`${Go}/`)?t.replace(`${Go}/`,`${xc}/`):t===ra?Qm:t===na?tp:t===ea?ep:t},mirrorGlobalPath(t,e){return mt(t,".codeium/windsurf/skills",e)},paths:{rulePath(t,e){return sa},commandPath(t,e){return `${xc}/${t}.md`},agentPath(t,e){return be(e,"windsurf")?`${ia}/${z(t)}/SKILL.md`:null}}},GG={rules:"native",additionalRules:"partial",commands:er("native","workflows"),agents:"embedded",skills:"native",mcp:"partial",hooks:"native",ignore:"native",permissions:"none"},YL={id:"windsurf",generators:vG,capabilities:{rules:"native",additionalRules:"native",commands:er("native","workflows"),agents:"embedded",skills:"native",mcp:"partial",hooks:"native",ignore:"native",permissions:"none"},emptyImportMessage:"No Windsurf config found (.windsurfrules, .windsurf/rules, .windsurfignore, or .codeiumignore).",supportsConversion:{agents:true},lintRules:BL,lint:{commands:zL,mcp:VL},project:MG,globalSupport:{capabilities:GG,detectionPaths:[sa,ia,xc,Qm,tp,ep],layout:$G},buildImportPaths:xd,detectionPaths:[".windsurfrules",".windsurf"]};});function ZL(t){let e=t.rules.find(i=>i.root),r=t.rules.filter(i=>i.root?false:i.targets.length===0||i.targets.includes("zed")),n=e?.body.trim()??"",o=xt(n,r);return o?[{path:Ir,content:o}]:[]}var qL=d(()=>{xe();Ts();s(ZL,"generateRules");});async function tb(t,e,r){let n=await y(join(t,e));if(n===null)return;let o;try{o=JSON.parse(n);}catch{return}if(o===null||typeof o!="object"||Array.isArray(o))return;let a=o.context_servers;if(a==null||typeof a!="object"||Array.isArray(a)||Object.keys(a).length===0)return;let c={};for(let[l,m]of Object.entries(a)){if(!m||typeof m!="object"||Array.isArray(m))continue;let p={...m};delete p.source,c[l]=p;}Object.keys(c).length!==0&&(await Yt(t,QL,c),r.push({fromTool:"zed",fromPath:e,toPath:QL,feature:"mcp"}));}var QL,eb=d(()=>{b();Sn();Ts();QL=".agentsmesh/mcp.json";s(tb,"importZedMcp");});async function rb(t,e={}){let r=e.scope??"project",n=[],o=await H("zed",t,r);return n.push(...await tt(op,t,r,{normalize:o})),await tb(t,r==="global"?Zr:Xr,n),n}var nb=d(()=>{Ot();Ut();eb();Ts();Tg();s(rb,"importFromZed");});function ob(t,e,r,n){return q(t,e,r,{checkGlobMatches:n?.scope!=="global"}).map(o=>({...o,target:"zed"}))}var sb=d(()=>{Wt();Ts();s(ob,"lintRules");});function ib(t){return t.hooks?Object.values(t.hooks).some(r=>Array.isArray(r)&&r.length>0)?[j(".agentsmesh/hooks.yaml","zed","Zed has no lifecycle hook system; canonical hooks are not projected.")]:[]:[]}function ab(t){if(!t.permissions)return [];let{allow:e,deny:r}=t.permissions,n=t.permissions.ask??[];return e.length===0&&r.length===0&&n.length===0?[]:[j(".agentsmesh/permissions.yaml","zed","Zed permissions are managed via agent.tool_permissions in settings.json; canonical permissions are not projected.")]}function cb(t){return t.ignore.length===0?[]:[j(".agentsmesh/ignore","zed","Zed has no dedicated ignore file and relies on file_scan_exclusions in settings.json; canonical ignore patterns are not projected.")]}var lb=d(()=>{Tt();s(ib,"lintHooks");s(ab,"lintPermissions");s(cb,"lintIgnore");});function zG(t,e){if(t===null)return e;let r;try{let i=JSON.parse(t);r=i!==null&&typeof i=="object"&&!Array.isArray(i)?i:{};}catch{r={};}let n=JSON.parse(e);if(n===null||typeof n!="object"||Array.isArray(n))return t;let o=n;return o.context_servers!==void 0&&(r.context_servers=o.context_servers),JSON.stringify(r,null,2)}var UG,WG,KG,BG,HG,op,Tg=d(()=>{qL();nb();sb();lb();Nt();Ts();UG={name:"zed",primaryRootInstructionPath:Ir,generateRules:ZL,importFrom:rb},WG={rootInstructionPath:Ir,managedOutputs:{dirs:[],files:[Ir,Xr]},paths:{rulePath(t){return Ir},commandPath(){return null},agentPath(){return null}}},KG={rootInstructionPath:void 0,managedOutputs:{dirs:[],files:[Zr]},rewriteGeneratedPath(t){return t===Xr?Zr:t},paths:{rulePath(){return Zr},commandPath(){return null},agentPath(){return null}}},BG={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"none",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},HG={rules:"none",additionalRules:"none",commands:"none",agents:"none",skills:"none",mcp:"native",hooks:"none",ignore:"none",permissions:"none"};s(zG,"mergeZedSettings");op={id:"zed",generators:UG,capabilities:BG,emptyImportMessage:"No Zed config found (.rules or .zed/settings.json).",lintRules:ob,lint:{hooks:ib,permissions:ab,ignore:cb},project:WG,globalSupport:{capabilities:HG,detectionPaths:[Zr],layout:KG},importer:{rules:{feature:"rules",mode:"singleFile",source:{project:[Ir],global:[]},canonicalDir:vS,canonicalRootFilename:"_root.md",markAsRoot:true}},emitScopedSettings(t,e){if(!t.mcp||Object.keys(t.mcp.mcpServers).length===0)return [];let r={};for(let[n,o]of Object.entries(t.mcp.mcpServers))r[n]=o;return [{path:Xr,content:JSON.stringify({context_servers:r},null,2)}]},mergeGeneratedOutputContent(t,e,r,n){return n===Xr||n===Zr?zG(t,r):null},buildImportPaths:Pd,detectionPaths:[Ir,Xr]};});var jI={};iu(jI,{BUILTIN_TARGETS:()=>Gt,TARGET_IDS:()=>lt,getBuiltinTargetDefinition:()=>Ke,getEffectiveTargetSupportLevel:()=>sp,getTargetCapabilities:()=>vo,getTargetDetectionPaths:()=>Ng,getTargetLayout:()=>vt,getTargetManagedOutputs:()=>Fg,getTargetPrimaryRootInstructionPath:()=>JG,getTargetSkillDir:()=>Tc,isBuiltinTargetId:()=>Ye,resolveTargetFeatureGenerator:()=>aa,rewriteGeneratedOutputPath:()=>vg});function VG(){return Dg||(Y_(Gt),Dg=new Map(Gt.map(t=>[t.id,t]))),Dg}function Ke(t){return VG().get(t)}function vo(t,e="project"){let r=Ke(t)??et(t);if(!r)return;let n=e==="global"?r.globalSupport?.capabilities??r.capabilities:r.capabilities;return V_(n)}function Ng(t,e="project"){let r=Ke(t)??et(t);return r?e==="global"?r.globalSupport?.detectionPaths??[]:r.detectionPaths:[]}function vt(t,e="project"){let r=Ke(t)??et(t);if(r)return e==="global"?r.globalSupport?.layout:r.project}function JG(t,e="project"){return vt(t,e)?.rootInstructionPath}function Tc(t,e="project"){return vt(t,e)?.skillDir}function Fg(t,e="project"){return vt(t,e)?.managedOutputs}function vg(t,e,r="project"){let n=vt(t,r);return n?n.rewriteGeneratedPath?n.rewriteGeneratedPath(e):e:null}function mb(t,e,r,n){return !t||!r?false:e==="commands"&&t.supportsConversion?.commands?!pi(r,t.id,true,n):e==="agents"&&t.supportsConversion?.agents?!be(r,t.id,true,n):false}function YG(t,e,r,n){return !t||!r?false:e==="commands"&&t.supportsConversion?.commands?pi(r,t.id,true,n):e==="agents"&&t.supportsConversion?.agents?be(r,t.id,true,n):false}function sp(t,e,r,n="project"){let o=vo(t,n)?.[e]?.level??"none",i=Ke(t)??et(t);return o==="none"&&YG(i,e,r,n)?"embedded":o!=="embedded"?o:mb(i,e,r,n)?"none":o}function aa(t,e,r,n="project"){let o=Ke(t)??et(t);if(!o?.generators||mb(o,e,r,n))return;let i=XG[e];return i===null?void 0:i(o.generators)}var Gt,Dg,XG,gt=d(()=>{ui();ts();Ce();Tu();Xe();Bu();Dd();Fd();oR();BR();af();ff();Af();Yf();Zf();Qf();sg();cg();mg();fg();gg();XL();Tg();Gt=[Pl,tm,em,nR,KR,fm,Cm,xm,Gm,jm,Wm,zm,Jm,Ym,Zm,qm,YL,op];s(VG,"builtinTargetsMap");s(Ke,"getBuiltinTargetDefinition");s(vo,"getTargetCapabilities");s(Ng,"getTargetDetectionPaths");s(vt,"getTargetLayout");s(JG,"getTargetPrimaryRootInstructionPath");s(Tc,"getTargetSkillDir");s(Fg,"getTargetManagedOutputs");s(vg,"rewriteGeneratedOutputPath");s(mb,"isFeatureSuppressedByConversion");s(YG,"isConversionUpgrading");s(sp,"getEffectiveTargetSupportLevel");XG={rules:s(t=>t.generateRules,"rules"),additionalRules:null,commands:s(t=>t.generateCommands,"commands"),agents:s(t=>t.generateAgents,"agents"),skills:s(t=>t.generateSkills,"skills"),mcp:s(t=>t.generateMcp,"mcp"),permissions:s(t=>t.generatePermissions,"permissions"),hooks:s(t=>t.generateHooks,"hooks"),ignore:s(t=>t.generateIgnore,"ignore")};s(aa,"resolveTargetFeatureGenerator");});function nj(t){return typeof t=="string"?t:t.level}function pb(t){return rj.includes(t)}function ub(t,e,r,n){for(let o of ej){let i=nj(e[o.feature]);if(i==="none")continue;let a=typeof t.generators[o.generator]=="function",c=pb(o.feature)&&typeof t.emitScopedSettings=="function";a||c||r.addIssue({code:"custom",path:[...n,o.feature],message:`Capability "${o.feature}" is "${i}" but generators.${o.generator}`+(pb(o.feature)?" or emitScopedSettings":"")+" is missing."});}}function ip(t){return sj.parse(t)}var Yn,db,ZG,qG,fb,QG,tj,ej,rj,oj,sj,Mg=d(()=>{Yn=z$1.union([z$1.enum(["native","embedded","partial","none"]),z$1.object({level:z$1.enum(["native","embedded","partial","none"]),flavor:z$1.string().optional()})]),db=z$1.object({rules:Yn,additionalRules:Yn,commands:Yn,agents:Yn,skills:Yn,mcp:Yn,hooks:Yn,ignore:Yn,permissions:Yn}),ZG=z$1.object({name:z$1.string(),generateRules:z$1.function(),importFrom:z$1.function(),generateCommands:z$1.function().optional(),generateAgents:z$1.function().optional(),generateSkills:z$1.function().optional(),generateMcp:z$1.function().optional(),generatePermissions:z$1.function().optional(),generateHooks:z$1.function().optional(),generateIgnore:z$1.function().optional(),lint:z$1.function().optional()}).passthrough(),qG=z$1.object({rulePath:z$1.function(),commandPath:z$1.function(),agentPath:z$1.function()}),fb=z$1.object({paths:qG}).passthrough(),QG=z$1.object({capabilities:db,detectionPaths:z$1.array(z$1.string()),layout:fb,scopeExtras:z$1.function().optional()}).passthrough(),tj=["global","globalCapabilities","globalDetectionPaths","generateScopeExtras"],ej=[{feature:"commands",generator:"generateCommands"},{feature:"agents",generator:"generateAgents"},{feature:"skills",generator:"generateSkills"},{feature:"mcp",generator:"generateMcp"},{feature:"hooks",generator:"generateHooks"},{feature:"ignore",generator:"generateIgnore"},{feature:"permissions",generator:"generatePermissions"}],rj=["mcp","hooks","ignore","permissions"];s(nj,"capabilityLevel");s(pb,"canUseScopedSettings");s(ub,"validateCapabilityImplementations");oj=z$1.object({id:z$1.string().regex(/^[a-z][a-z0-9-]*$/,"Target id must be lowercase with hyphens"),generators:ZG,capabilities:db,emptyImportMessage:z$1.string(),lintRules:z$1.union([z$1.function(),z$1.null()]),project:fb,globalSupport:QG.optional(),buildImportPaths:z$1.function(),detectionPaths:z$1.array(z$1.string())}).passthrough(),sj=oj.superRefine((t,e)=>{for(let r of tj)r in t&&e.addIssue({code:"custom",path:[r],message:`Use globalSupport instead of legacy field "${r}".`});ub(t,t.capabilities,e,["capabilities"]),t.globalSupport!==void 0&&ub(t,t.globalSupport.capabilities,e,["globalSupport","capabilities"]);});s(ip,"validateDescriptor");});function ij(){return $g||($g=new Map(Gt.map(t=>[t.id,t]))),$g}function ap(t){let e=ip(t);Gg.set(e.id,e);}function et(t){return Gg.get(t)??ij().get(t)}function cp(){return [...Gg.values()]}var Gg,$g,Ce=d(()=>{gt();Mg();Gg=new Map;s(ij,"builtinDescriptors");s(ap,"registerTargetDescriptor");s(et,"getDescriptor");s(cp,"getAllDescriptors");});async function gb(t,e,r="project"){let n=new Map,o=et(t);return o&&await o.buildImportPaths(n,e,r),n}var hb=d(()=>{Ce();s(gb,"buildImportReferenceMap");});function lj(t){let e=[t.project,t.globalSupport?.layout].filter(o=>o!==void 0),r=[...t.detectionPaths,...e.flatMap(o=>o.managedOutputs?.dirs??[]),...e.flatMap(o=>o.managedOutputs?.files??[])],n=new Set;for(let o of r){let i=o.split("/")[0];i&&i.startsWith(".")&&i.length>1&&n.add(`${i}/`);}return n}function mj(){let t=new Set([".agentsmesh/"]);for(let e of Gt)for(let r of lj(e))t.add(r);return Array.from(t)}function pj(){let t=new Set([...mj(),...jg.rootRelativePrefixes]),e=new Set([...cj,...jg.meshRootSegments]);return {protectedSchemes:[...aj,...jg.protectedSchemes],rootRelativePrefixes:Array.from(t),meshRootSegments:e}}function lp(){return Ug||(Ug=pj()),Ug}var aj,cj,jg,Ug,yb=d(()=>{gt();aj=[/\b[A-Za-z][A-Za-z0-9+.-]+:[^\s<>()\]]+/g,/\b[\w.-]+@[\w.-]+:[^\s<>()\]]+/g,/\b[\w.+-]+@[\w.-]+\.[A-Za-z]{2,}\b/g,/\/\/[A-Za-z0-9][\w.-]*\.[A-Za-z]{2,}[^\s<>()\]]*/g],cj=new Set(["skills","rules","commands","agents","packs"]),jg={protectedSchemes:[],rootRelativePrefixes:[],meshRootSegments:[]};s(lj,"topLevelDotfilePrefixes");s(mj,"buildDefaultRootRelativePrefixes");s(pj,"rebuild");s(lp,"getLinkFormatRegistry");});function Or(t){let e=ft(t);return lp().rootRelativePrefixes.some(r=>e.startsWith(r))}function dj(t){let e=ft(t).replace(/^\.\//,"");if(e.startsWith("../")||e.startsWith("/")||Qe.test(e)||/^[a-zA-Z]:/.test(e)||Or(e))return false;let r=e.split("/").filter(n=>n.length>0)[0];return r!==void 0&&lp().meshRootSegments.has(r)}function Dc(t,e,r){let n=J(e),o=U(e,e),i=U(e,r),a=ft(t);if(Qe.test(t)){let c=U(e,t);return n===win32||c.startsWith(`${o}${n.sep}`)?[c]:[c]}if(n.isAbsolute(t)){let c=U(e,t);return c.startsWith(o)||existsSync(t)?[c]:[U(e,n.join(e,t))]}if(a.startsWith("./")||a.startsWith("../")){let c=U(e,n.join(n.dirname(i),a)),l=K_(a,o);return l&&l!==c?[c,l]:[c]}if(Or(a))return [U(e,n.join(o,a))];if(a.includes("/")){let c=U(e,n.join(o,".agentsmesh")),l=dj(a)?U(e,n.join(c,a)):null,m=U(e,n.join(o,a)),p=U(e,n.join(n.dirname(i),a));return l!==null?[l,m,p]:[m,p]}return fj.has(a)?[]:a.includes(".")?[U(e,n.join(n.dirname(i),a))]:[]}function Nc(t,e){let r=[e];if(!W_(t,e)||!existsSync(e))return r;try{let n=[realpathSync(e),realpathSync.native(e)];for(let o of n)o!==e&&!r.includes(o)&&r.push(o);}catch{}return r}function Cb(t,e,r){let n=e>0?t.at(e-1):"",o=r<t.length?t.at(r):"";return n==="*"||o==="*"}function mp(t){let e=[];for(let r of lp().protectedSchemes){let n=r.flags.includes("g")?r:new RegExp(r.source,`${r.flags}g`);for(let o of t.matchAll(n))e.push([o.index??0,(o.index??0)+o[0].length]);}for(let r of t.matchAll(gj))e.push([r.index??0,(r.index??0)+r[0].length]);for(let r of t.matchAll(hj))e.push([r.index??0,(r.index??0)+r[0].length]);for(let r of t.matchAll(yj))e.push([r.index??0,(r.index??0)+r[0].length]);return e}var fj,gj,hj,yj,Sb,ca,jo=d(()=>{Vt();yb();s(Or,"isRootRelativePathToken");s(dj,"isMeshRootRelativePathToken");fj=new Set(["AGENTS.md","CLAUDE.md","GEMINI.md","codex.md",".windsurfrules",".cursorrules"]),gj=/^(?:```|~~~)[^\n]*\n[\s\S]*?^(?:```|~~~)/gm,hj=/<!-- agentsmesh:root-generation-contract:start -->[\s\S]*?<!-- agentsmesh:root-generation-contract:end -->/g,yj=/<!-- agentsmesh:embedded-rules:start -->[\s\S]*?<!-- agentsmesh:embedded-rules:end -->/g,Sb=/(?:\.\.[\\/]|\.\/|\.\\|\/[A-Za-z0-9._-]|[A-Za-z]:[\\/][A-Za-z0-9._-]|\.agentsmesh[\\/]|\.claude[\\/]|\.cursor[\\/]|\.github[\\/]|\.continue[\\/]|\.junie[\\/]|\.kiro[\\/]|\.gemini[\\/]|\.clinerules[\\/]|\.cline[\\/]|\.codex[\\/]|\.agents[\\/]|\.windsurf[\\/]|\.roo[\\/]|(?:[A-Za-z0-9._-]+[\\/])+|[A-Za-z0-9._-]+\.[A-Za-z0-9._-]+)[A-Za-z0-9._@%+~:\\/-]*/g,ca=/(?::(\d+)){1,2}$/;s(Dc,"resolveProjectPath");s(Nc,"expandResolvedPaths");s(Cb,"isGlobAdjacent");s(mp,"protectedRanges");});function _j(t){return t===void 0||t.role==="inline-code"||t.role==="bracketed"||t.role==="quoted"||t.role==="at-prefix"||t.role==="bracket-label"||t.role==="bare-prose"}function Rb(t){return _j(t.tokenContext)}function Wg(t,e){let r=J(t),n=U(t,t),o=U(t,e);if(o===n)return true;let i=n.endsWith(r.sep)?n:`${n}${r.sep}`;return o.startsWith(i)}function Ob(t){let e=J(t);return U(t,e.join(t,".agentsmesh"))}function Er(t,e){let r=J(t),n=Ob(t),o=U(t,e);if(o===n)return true;let i=n.endsWith(r.sep)?n:`${n}${r.sep}`;return o.startsWith(i)}function Eb(t,e,r){let n=J(t),o=Ob(t),i=U(t,e);if(!Er(t,i))return null;let a=n.relative(o,i).replace(/\\/g,"/");return a.startsWith("..")||a.length===0?null:r&&!a.endsWith("/")?`${a}/`:a}function Kg(t,e,r){let o=J(t).relative(U(t,t),U(t,e)).replace(/\\/g,"/");if(o.startsWith(".."))return null;let i=o.length>0?o:".";return r&&!i.endsWith("/")?`${i}/`:i}function la(t,e,r){let n=Kg(t,e,r);return n===null?null:{kind:"projectRoot",rest:n,text:n}}function Bg(t,e,r,n,o){let i=J(t),a=U(t,t),c=U(t,e),l=U(t,r);if(!Wg(t,l))return la(t,l,n)?.text??null;let m=U(t,i.dirname(c));if(!Wg(t,m)&&m!==a)return la(t,l,n)?.text??null;let p=i.relative(m,l).replace(/\\/g,"/");if(i.isAbsolute(p)||Qe.test(p))return Kg(t,l,n);let u=U(t,i.join(m,p));return Wg(t,u)?(p===""||p==="."?p=".":o.explicitCurrentDirLinks===true&&m!==a&&!p.startsWith("../")&&!p.startsWith("./")&&(p=`./${p}`),n&&!p.endsWith("/")?`${p}/`:p):Kg(t,l,n)}var Hg=d(()=>{Vt();s(_j,"isReadingContext");s(Rb,"isReadingContextOptions");s(Wg,"isUnderProjectRoot");s(Ob,"agentsMeshRoot");s(Er,"isUnderAgentsMesh");s(Eb,"toAgentsMeshRootRelative");s(Kg,"toProjectRootRelative");s(la,"toProjectRootReference");s(Bg,"formatLinkPathForDestinationLegacy");});function kb(t,e,r,n,o={}){let i=o.scope??"project",a=U(t,r);if(Rb(o)&&Er(t,e)&&Er(t,a)){let m=J(t),p=U(t,t),u=m.relative(p,a).replace(/\\/g,"/");if(!u.startsWith("..")&&u.length>0)return n&&!u.endsWith("/")?`${u}/`:u}if(o.forceRelative)return Bg(t,e,r,n,o);if(i==="global"&&!Er(t,e))return la(t,a,n)?.text??null;let c=(()=>{if(Er(t,a))return a;let m=o.logicalMeshSourceAbsolute;return m&&Er(t,U(t,m))?U(t,m):null})();if(!c)return la(t,a,n)?.text??null;if(n||(o.pathIsDirectory?.(a)??false)){let m=Eb(t,c,n);return m!==null?m:la(t,c,n)?.text??null}return Bg(t,e,r,n,o)}var wb=d(()=>{jo();Vt();Hg();Hg();s(kb,"formatLinkPathForDestination");});function Lb(t,e,r,n){let o=J(e),i=ft(t);if(!Or(i))return null;let a=i.split("/").filter(m=>m.length>0);if(a.length<3)return null;let c=U(e,r),l=o.dirname(c);for(let m=1;m<=a.length-1;m++){let p=a.slice(m).join("/"),u=U(e,o.join(l,p));if(u!==c&&n(u))return u}return null}var bb=d(()=>{Vt();jo();s(Lb,"resolveByDestinationSuffixStrip");});function Ab(t){let e=null,r=false,n=null,o=null,i=null;for(let l of Dc(t.candidate,t.projectRoot,t.sourceFile)){let m=null,p=null;for(let u of Nc(t.projectRoot,l)){let f=U(t.projectRoot,u),g=U(t.projectRoot,t.translatePath(f)),h=t.pathExists(f),R=t.pathExists(g);if(R&&g!==f){e=g,n=f,r=true;break}(h||R)&&m===null&&(m=g,p=f),e===null&&(e=g);}if(!r&&m!==null&&o===null&&(o=m,i=p),r)break}if(!r){let l=Lb(t.candidate,t.projectRoot,t.destinationFile,t.pathExists);l!==null&&(e=l,r=true);}!r&&o!==null&&(e=o,i!==null&&(n=i),r=true);let a=ft(t.destinationFile),c=a.includes("/.agentsmesh/")||a.startsWith(".agentsmesh/");return !r&&e!==null&&ft(t.rawToken).startsWith(".agentsmesh/")&&c&&(r=true),{translatedPath:e,resolvedBeforeTranslate:n,matchedPath:r}}var xb=d(()=>{Vt();jo();bb();s(Ab,"resolveLinkTarget");});function Pb(t,e,r){return e>=2&&t[e-2]==="~"&&t[e-1]==="/"?true:e>=1&&t[e-1]==="~"&&r.startsWith("/")}function Tb(t,e,r){if(e<=0||t[e-1]!=="(")return false;let n=e+r.length,o=t[n];return o!==")"&&o!=="#"&&o!=="?"&&o!==" "&&o!==" "?false:t[e-2]==="]"}function Db(t){let e=ft(t);return e.startsWith("./")||e.startsWith("../")?true:e.startsWith("/")||Qe.test(e)||Or(e)?false:e.includes("/")}var Nb=d(()=>{Vt();jo();s(Pb,"isTildeHomeRelativePathToken");s(Tb,"isMarkdownLinkDestinationToken");s(Db,"isRelativePathToken");});function Ij(t,e,r){let n=e+r.length;if(t[n]!=="]"||t[n+1]!=="(")return false;let o=n+2,i="";for(;o<t.length;){let a=t[o];if(a===")"||a==="#"||a==="?"||a===" "||a===" "||a===`
|
|
131
|
+
`)break;i+=a,o++;}return i===r}function Fb(t,e,r){let n=t.lastIndexOf(`
|
|
132
132
|
`,e-1)+1,o=t.slice(n,e);if(!/^\s*\[[^\]\n]+\]:\s*<?\s*$/.test(o))return false;let i=r<t.length?t[r]:"";return i===""||i===`
|
|
133
|
-
`||i==="\r"||i===">"||i===" "||i===" "||i==='"'||i==="'"||i===":"||i==="#"||i==="?"}function cb(t,e,r){let n=e>0?t[e-1]:"",o=r<t.length?t[r]:"";return n==="`"&&o==="`"?{role:"inline-code"}:ab(t,e,r)?{role:"markdown-link-dest"}:n==="<"&&o===">"?{role:"bracketed"}:n==="'"&&o==="'"||n==='"'&&o==='"'?{role:"quoted"}:n==="@"?{role:"at-prefix"}:n==="("&&t[e-2]==="]"?{role:"markdown-link-dest"}:n==="["&&o==="]"?{role:"bracket-label"}:{role:"bare-prose"}}function lb(t,e,r,n,o){if(e<0||r>t.length)return false;let{candidate:i}=ni(n),a=i.replace(ea,""),c=pt(a),l=e+a.length,m=t[e-1],p=t[r];return ab(t,e,l)||m==="'"&&p==="'"||m==='"'&&p==='"'||m==="`"&&p==="`"||m==="<"&&p===">"?true:m==="["&&p==="]"?!(!o&&!Ir(c)&&PG(t,e,n)):m==="@"?true:m==="("?p===")"||p==="#"||p==="?"||p===" "||p===" ":o?Ir(c)?true:c.includes("/")||c.includes("\\")?c.startsWith("./")||c.startsWith("../")?true:(c.split(/[\\/]/).filter(Boolean).at(-1)??"").includes("."):false:false}var mb=d(()=>{Wt();Fo();s(PG,"markdownBracketLabelDuplicatesDestination");s(ab,"isMarkdownReferenceDefinitionDestination");s(cb,"getTokenContext");s(lb,"shouldRewritePathToken");});function np(t){let e=new Set,r=rp(t.content);return {content:t.content.replace(zL,(o,i,a)=>{if(r.some(([Ot,ct])=>i>=Ot&&i<ct)||!lb(a,i,i+o.length,o,t.rewriteBarePathTokens===true)||nb(a,i,o)||VL(a,i,i+o.length))return o;let{candidate:c,suffix:l}=ni(o);if(!c)return o;let m=ea.exec(c),p=m?c.slice(0,m.index):c,u=m?m[0]:"";if(!p)return o;let f=cb(a,i,i+p.length);if(f.role!=="markdown-link-dest"&&Ye.test(p))return o;let{translatedPath:g,resolvedBeforeTranslate:h,matchedPath:R}=eb({candidate:p,rawToken:c,projectRoot:t.projectRoot,sourceFile:t.sourceFile,destinationFile:t.destinationFile,translatePath:t.translatePath,pathExists:t.pathExists}),C=h;if(!R||!g)return g&&e.add(g),o;let _=pt(p),E=p.endsWith("/")||t.pathIsDirectory?.(g)===true;if(E&&!_.includes("/")&&!_.includes("\\"))return o;if(C===null){let Ot=pt(c);if(Ot.startsWith("agentsmesh/")&&(Ot=`.${Ot}`),Ot.startsWith(".agentsmesh/")||Ot.includes("/.agentsmesh/")){let ct=Y(t.projectRoot),sn=K(t.projectRoot,t.projectRoot),Ke=Ot.replace(/^\.\//,"");C=K(t.projectRoot,ct.join(sn,Ke));}}let T=Y(t.projectRoot);if(t.scope==="global"){let Ot=pt(c),ct=Ot.startsWith(".agentsmesh/")||Ot.includes("/.agentsmesh/"),sn=Ir(Ot)||sb(Ot),Ke=C!==null&&Cr(t.projectRoot,C),Xn=Cr(t.projectRoot,g);if(C===g&&!Xn&&!Ke&&!ct){let fy=pt(T.relative(t.projectRoot,K(t.projectRoot,t.sourceFile))).split("/").filter(Boolean)[0]??"",sT=(C!==null?pt(T.relative(t.projectRoot,C)):"").split("/").filter(Boolean)[0]??"";if(fy.length>0&&fy===sT)return o}if(!sn&&!ct&&!Ke&&!Xn)return o}let D=K(t.projectRoot,t.destinationFile),x=K(t.projectRoot,g),Z=pt(T.relative(t.projectRoot,D)),B=pt(T.relative(t.projectRoot,x)),J=Z.split("/").filter(Boolean)[0]??"",kt=B.split("/").filter(Boolean)[0]??"",Dt=!pt(p).startsWith(".agentsmesh/")&&!E&&J.length>0&&J===kt&&J.startsWith(".")&&J!==".agentsmesh"||f.role==="markdown-link-dest"||ob(a,i,p),Rr=ZL(t.projectRoot,t.destinationFile,g,p.endsWith("/"),{explicitCurrentDirLinks:t.explicitCurrentDirLinks===true||Dt,scope:t.scope??"project",pathIsDirectory:t.pathIsDirectory,logicalMeshSourceAbsolute:E?null:C,forceRelative:Dt,tokenContext:f,originalToken:p});return Rr?`${Rr}${u}${l}`:o}),missing:[...e]}}var Tg=d(()=>{Wt();Fo();qL();rb();ib();mb();s(np,"rewriteFileLinks");});function ub(t,e){let r=[t.normalize(e)];if(!existsSync(e))return r;try{let n=[realpathSync(e),realpathSync.native(e)];for(let o of n){let i=t.normalize(o);r.includes(i)||r.push(i);}}catch{}return r}async function z(t,e,r="project"){let n=Y(e),o=new Map,i=Array.from(new Set([t,...it]));for(let l of i){let m=await UL(l,e,r);for(let[p,u]of m.entries())o.set(p,u);}let a=new Map;for(let[l,m]of o.entries()){let p=n.normalize(n.join(e,m));for(let u of ub(n,n.join(e,l)))a.set(u,p);}let c=new Set;for(let l of new Set(o.values())){let m=n.normalize(n.join(e,l));c.add(m);for(let p of ub(n,m))c.add(n.normalize(p));}return (l,m,p)=>np({content:l,projectRoot:e,sourceFile:m,destinationFile:p,translatePath:s(u=>a.get(u)??u,"translatePath"),pathExists:s(u=>{let f=n.normalize(u);return a.has(u)||a.has(f)||existsSync(u)||c.has(f)},"pathExists"),explicitCurrentDirLinks:false,rewriteBarePathTokens:true,scope:r,pathIsDirectory:s(u=>{try{return statSync(u).isDirectory()}catch{return false}},"pathIsDirectory")}).content}var It=d(()=>{Wt();KL();Tg();ze();s(ub,"pathVariants");s(z,"createImportReferenceNormalizer");});function fb(t){let e={};for(let[r,n]of Object.entries(t)){if(!Array.isArray(n))continue;let o=[];for(let i of n){if(!i||typeof i!="object")continue;let a=i,c=typeof a.matcher=="string"?a.matcher:"";if(!c)continue;let l=Array.isArray(a.hooks)?a.hooks:[];for(let m of l){let p=m.type==="prompt"?"prompt":"command";if(!Or({...m,type:p}))continue;let u=p==="prompt"?Yt(m)||wt(m):wt(m)||Yt(m),f={matcher:c,type:p,command:u};typeof m.timeout=="number"&&(f.timeout=m.timeout),o.push(f);}}o.length>0&&(e[r]=o);}return e}async function gb(t,e){let r=join(t,_n),n=await y(r);if(n===null)return false;let o;try{o=JSON.parse(n);}catch{return false}if(!o||typeof o!="object"||Array.isArray(o))return false;let i=fb(o);if(Object.keys(i).length===0)return false;let a=stringify(i),c=join(t,qo);return await O(dirname(c)),await S(c,a),e.push({fromTool:"claude-code",fromPath:r,toPath:qo,feature:"hooks"}),true}async function hb(t,e){let r=e.some(m=>m.feature==="hooks"&&m.fromPath.replace(/\\/g,"/").endsWith(_n)),n=join(t,Ba),o=await y(n);if(!o)return;let i;try{i=JSON.parse(o);}catch{return}if(!e.some(m=>m.feature==="mcp")&&i.mcpServers&&typeof i.mcpServers=="object"){let m=i.mcpServers;await Ht(t,Ja,m),e.push({fromTool:"claude-code",fromPath:n,toPath:Ja,feature:"mcp"});}let c=i.permissions;if(c&&typeof c=="object"&&!Array.isArray(c)){let m=c,p=Array.isArray(m.allow)?m.allow.filter(g=>typeof g=="string"):[],u=Array.isArray(m.deny)?m.deny.filter(g=>typeof g=="string"):[],f=Array.isArray(m.ask)?m.ask.filter(g=>typeof g=="string"):[];if(p.length>0||u.length>0||f.length>0){let g=stringify({allow:p,deny:u,ask:f}),h=join(t,ju);await O(dirname(h)),await S(h,g),e.push({fromTool:"claude-code",fromPath:n,toPath:ju,feature:"permissions"});}}let l=i.hooks;if(!r&&l&&typeof l=="object"&&!Array.isArray(l)){let m=fb(l);if(Object.keys(m).length>0){let p=stringify(m),u=join(t,qo);await O(dirname(u)),await S(u,p),e.push({fromTool:"claude-code",fromPath:n,toPath:qo,feature:"hooks"});}}}var yb=d(()=>{Je();A();fn();In();s(fb,"claudeHooksToCanonical");s(gb,"importClaudeHooksJson");s(hb,"importSettings");});async function Ib(t,e,r){let n=join(t,Wa),o=join(t,Gu),a=(await N(n)).filter(c=>c.endsWith("SKILL.md"));for(let c of a){let l=dirname(c),m=basename(l),p=join(o,m),u=await N(l);for(let f of u){let g=await y(f);if(g===null)continue;let h=relative(l,f),R=join(p,h);await O(dirname(R));let C=r(g,f,R),_=h==="SKILL.md"?w(C):null;await S(R,h==="SKILL.md"?await Lr(R,_?.frontmatter??{},_?.body??""):C);let E=`${Gu}/${m}/${h}`;e.push({fromTool:"claude-code",fromPath:f,toPath:E,feature:"skills"});}}}var Cb=d(()=>{A();M();et();In();s(Ib,"importClaudeSkills");});async function Jl(t,e={}){let r=e.scope??"project",n=[],o=await z("claude-code",t,r);return n.push(...await Q(Vl,t,r,{normalize:o})),await Ib(t,n,o),await gb(t,n),await hb(t,n),n}var kd=d(()=>{It();Mt();yb();Cb();Rd();s(Jl,"importFromClaudeCode");});async function Pc(t,e){let r=FG[e];if(!r)throw new Error(`No importer registered for native target: ${e}`);return r(t)}var FG,Fg=d(()=>{kd();ff();qd();Nf();Bd();yg();bd();Hd();$f();Vf();Bf();FG={"claude-code":Jl,cursor:Sm,copilot:um,"gemini-cli":xm,"codex-cli":nm,windsurf:Ym,cline:ql,continue:sm,junie:Dm,kiro:Gm,"kilo-code":Mm};s(Pc,"importNativeToCanonical");});async function $s(t){if(!await v(t))return false;if(await v(join(t,Mg)))return true;try{let e=await readdir(t,{withFileTypes:!0});for(let r of e)if(!(!r.isDirectory()||r.name.startsWith("."))&&await v(join(t,r.name,Mg)))return !0}catch{return false}return false}async function Tc(t){if(!await v(t))return [];if(await v(join(t,Mg))){let e=await c_(t);return e?[e]:[]}return ei(t)}var Mg,sp=d(()=>{A();ul();Mg="SKILL.md";s($s,"isSkillPackLayout");s(Tc,"loadSkillsAtExtendPath");});function GG(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}function jG(t){return t.rules.length===0&&t.commands.length===0&&t.agents.length===0&&t.skills.length===0&&t.mcp===null&&t.permissions===null&&t.hooks===null&&t.ignore.length===0}async function ip(t){if(!await v(t))throw new Error(`Path does not exist: ${t}`);let e=await stat(t);if(e.isDirectory())return {sliceRoot:t};if(!e.isFile()||!t.toLowerCase().endsWith(".md"))throw new Error(`Install path must be a directory or a .md file inside rules/, commands/, or agents/: ${t}`);let r=dirname(t),n=basename(r),i=basename(t).replace(/\.md$/i,"");if(n==="rules")return {sliceRoot:r,implicitPick:{rules:[i]}};if(n==="commands")return {sliceRoot:r,implicitPick:{commands:[i]}};if(n==="agents")return {sliceRoot:r,implicitPick:{agents:[i]}};throw new Error(`Single-file install only supports .md files under rules/, commands/, or agents/. Got: ${t}`)}async function UG(t){if(basename(t)==="rules")return Ko(t);let r=join(t,"rules");return await v(r)?Ko(r):[]}async function KG(t){if(basename(t)==="commands")return Wo(t);let r=join(t,"commands");return await v(r)?Wo(r):[]}async function WG(t){if(basename(t)==="agents")return Ho(t);let r=join(t,"agents");return await v(r)?Ho(r):[]}async function BG(t){if(await $s(t))return Tc(t);let e=join(t,"skills");return await $s(e)?Tc(e):[]}async function ap(t){let e=join(t,".agentsmesh");if(await v(e))return pe(t);let r=GG();if(r.rules=await UG(t),r.commands=await KG(t),r.agents=await WG(t),r.skills=await BG(t),jG(r))throw new Error(`No installable resources at ${t}. Expected .agentsmesh/, or rules/, commands/, agents/, or Anthropic-style skills (SKILL.md).`);return r}var $g=d(()=>{A();ml();zo();ll();cl();sp();s(GG,"emptyCanonical");s(jG,"isCanonicalSliceEmpty");s(ip,"normalizeSlicePath");s(UG,"parseRulesAt");s(KG,"parseCommandsAt");s(WG,"parseAgentsAt");s(BG,"loadSkillsForPartialSlice");s(ap,"loadCanonicalSliceAtPath");});function HG(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function Sb(t){let e=t.resolvedPath;if(!t.path){let o=join(e,".agentsmesh");if(!await v(o)){if(await $s(e)){let a=await Tc(e);return {...HG(),skills:a}}let i=t.target??await hl(e);if(!i)throw new Error(`Extend "${t.name}": No supported agent configuration found in ${e}.
|
|
134
|
-
Expected one of: .agentsmesh/, ${d_.join(", ")}.`);I.info(`[agentsmesh] Extend "${t.name}": ${t.target?"specified":"detected"} ${i} format, importing to .agentsmesh/...`),await Pc(e,i);}return pe(e)}let r=join(e,t.path);if(!await v(r))throw new Error(`Extend "${t.name}": path does not exist: ${r}`);if(t.target){let o=join(e,".agentsmesh");return await v(o)||(I.info(`[agentsmesh] Extend "${t.name}": path "${t.path}" with target "${t.target}" \u2014 importing at extend root, then loading canonical.`),await Pc(e,t.target)),pe(e)}let{sliceRoot:n}=await ip(r);try{return await ap(n)}catch(o){let i=o instanceof Error?o.message:String(o),a=new Error(`Extend "${t.name}": ${i}`);throw o instanceof Error&&(a.cause=o),a}}var Rb=d(()=>{_u();A();nt();zo();Fg();sp();$g();s(HG,"emptyCanonical");s(Sb,"loadCanonicalForExtend");});function cp(t,e,r,n){if(!r)return t;let o={...t};if(r.skills?.length&&e.includes("skills")){let i=new Set(r.skills),a=o.skills;o={...o,skills:a.filter(c=>i.has(c.name))};for(let c of r.skills)a.some(l=>l.name===c)||I.warn(`[agentsmesh] pick name "${c}" not found in skills from extend "${n}".`);}if(r.commands?.length&&e.includes("commands")){let i=new Set(r.commands),a=o.commands;o={...o,commands:a.filter(c=>i.has(c.name))};for(let c of r.commands)a.some(l=>l.name===c)||I.warn(`[agentsmesh] pick name "${c}" not found in commands from extend "${n}".`);}if(r.agents?.length&&e.includes("agents")){let i=new Set(r.agents),a=o.agents;o={...o,agents:a.filter(c=>i.has(c.name))};for(let c of r.agents)a.some(l=>l.name===c)||I.warn(`[agentsmesh] pick name "${c}" not found in agents from extend "${n}".`);}if(r.rules?.length&&e.includes("rules")){let i=new Set(r.rules),a=o.rules,c=s(l=>basename(l).replace(/\.md$/i,""),"stem");o={...o,rules:a.filter(l=>i.has(c(l.source)))};for(let l of r.rules)a.some(m=>c(m.source)===l)||I.warn(`[agentsmesh] pick name "${l}" not found in rules from extend "${n}".`);}return o}var jg=d(()=>{nt();s(cp,"applyExtendPick");});var JG,na,lp=d(()=>{JG=["rules","commands","agents","skills"],na=z$1.enum(JG);});var YG,kb,Ob=d(()=>{ln();lp();YG=z$1.enum(["github","gitlab","git","local"]),kb=z$1.object({name:z$1.string().min(1),source:z$1.string().min(1),version:z$1.string().optional(),source_kind:YG,installed_at:z$1.string(),updated_at:z$1.string(),features:z$1.array(Zs).min(1),pick:Oa.optional(),target:Re.optional(),path:z$1.string().optional(),paths:z$1.array(z$1.string().min(1)).min(1).optional(),as:na.optional(),content_hash:z$1.string()});});function wb(t){let e=Uo(t);return e?e.kind==="github"?`github:${e.org}/${e.repo}`:e.kind==="gitlab"?`gitlab:${e.namespace}/${e.project}`:`git+${e.url}`:t.trim()}function ZG(t,e){return e?t.length===e.length&&[...t].sort().every((r,n)=>r===[...e].sort()[n]):true}async function mp(t){let e=join(t,"pack.yaml"),r=await y(e);if(r===null)return null;try{let n=parse(r);return kb.parse(n)}catch{return null}}async function Lb(t,e,r){if(!await v(t))return null;let n=wb(e),o;try{o=await readdir(t,{withFileTypes:!0});}catch{return null}for(let i of o){if(!i.isDirectory())continue;let a=join(t,i.name),c=await mp(a);if(c&&wb(c.source)===n&&c.target===r.target&&c.as===r.as&&ZG(c.features,r.features))return {meta:c,packDir:a,name:c.name}}return null}async function pp(t){if(!await v(t))return [];let e;try{e=await readdir(t,{withFileTypes:!0});}catch{return []}let r=[];for(let n of e){if(!n.isDirectory())continue;let o=join(t,n.name),i=await mp(o);i&&r.push({meta:i,packDir:o,name:i.name});}return r}var up=d(()=>{A();Ob();La();s(wb,"sourceIdentity");s(ZG,"sameFeatures");s(mp,"readPackMetadata");s(Lb,"findExistingPack");s(pp,"listPacks");});function bb(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function qG(t){let[e,r,n,o,i,a,c,l]=await Promise.all([Ko(join(t,"rules")),Wo(join(t,"commands")),Ho(join(t,"agents")),ei(join(t,"skills")),Ve(join(t,"mcp.json")),dl(join(t,"permissions.yaml")),fl(join(t,"hooks.yaml")),gl(join(t,"ignore"))]);return {...bb(),rules:e,commands:r,agents:n,skills:o,mcp:i,permissions:a,hooks:c,ignore:l}}async function Ab(t){let e=join(t,"packs"),r=await pp(e),n=bb();for(let{meta:o,packDir:i}of r){let a=await qG(i),c=Kg(a,o.features),l=cp(c,o.features,o.pick,o.name);n=ri(n,l);}return n}var xb=d(()=>{cl();ll();ml();ul();Aa();uu();fu();gu();yu();nn();jg();up();s(bb,"emptyCanonical");s(qG,"loadPackCanonical");s(Ab,"loadPacksCanonical");});function Kg(t,e){if(e.length===0)return Pb();let r=new Set(e.flatMap(n=>tj[n]??[]));return {rules:r.has("rules")?t.rules:[],commands:r.has("commands")?t.commands:[],agents:r.has("agents")?t.agents:[],skills:r.has("skills")?t.skills:[],mcp:r.has("mcp")?t.mcp:null,permissions:r.has("permissions")?t.permissions:null,hooks:r.has("hooks")?t.hooks:null,ignore:r.has("ignore")?t.ignore:[]}}function Pb(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function ee(t,e,r={},n=join(e,".agentsmesh")){let o=await ti(t,e,{refreshCache:r.refreshRemoteCache===true}),i=Pb();for(let l of o){let m=await Sb(l),p=Kg(m,l.features),u=cp(p,l.features,l.pick,l.name);i=ri(i,u);}let a=await Ab(n);i=ri(i,a);let c=await pe(n);return i=ri(i,c),{canonical:i,resolvedExtends:o}}var tj,nn=d(()=>{al();zo();yu();Rb();jg();xb();tj={rules:["rules"],commands:["commands"],agents:["agents"],skills:["skills"],mcp:["mcp"],permissions:["permissions"],hooks:["hooks"],ignore:["ignore"]};s(Kg,"filterCanonicalByFeatures");s(Pb,"emptyCanonical");s(ee,"loadCanonicalWithExtends");});function Jj(t,e){let r=join(e,"node_modules",t),n=join(r,"package.json");if(!existsSync(n))throw new Error(`Cannot find package '${t}' in ${join(e,"node_modules")}`);let o=JSON.parse(readFileSync(n,"utf-8")),i=(typeof o.exports=="string"?o.exports:null)??(typeof o.main=="string"?o.main:null)??"index.js",a=resolve(r,i);if(!existsSync(a))throw new Error(`Package '${t}' entry '${i}' does not exist at ${a}`);return a}function Yj(t){return t.startsWith("file:")||t.startsWith("./")||t.startsWith("../")||t.startsWith("/")||/^[A-Za-z]:[/\\]/.test(t)}async function Xj(t,e){let{source:r}=t,n;if(Yj(r)){let i=r.startsWith("file:")?fileURLToPath(r):r,a=resolve(e,i);n=pathToFileURL(a).href;}else {let i=Jj(r,e);n=pathToFileURL(i).href;}return await import(n)}function Zj(t){return "descriptor"in t?[t.descriptor]:"descriptors"in t&&Array.isArray(t.descriptors)?t.descriptors:"default"in t?[t.default]:[]}async function Op(t,e){let r;try{r=await Xj(t,e);}catch(i){throw new Error(`Plugin '${t.source}' failed to import: ${i instanceof Error?i.message:String(i)}`,{cause:i})}let n=Zj(r),o=[];for(let i of n)try{let a=qm(i);Qm(a),o.push(a);}catch(a){throw new Error(`Plugin '${t.source}' exported an invalid descriptor: ${a instanceof Error?a.message:String(a)}`,{cause:a})}return {entry:t,descriptors:o}}async function pA(t,e){let r=[];return await Promise.all(t.map(async n=>{try{let o=await Op(n,e);r.push(o);}catch(o){I.warn(`Plugin '${n.source}' failed to load: ${o instanceof Error?o.message:String(o)}`);}})),r}var qg=d(()=>{kg();ye();nt();s(Jj,"resolveNpmSpecifier");s(Yj,"isLocalSource");s(Xj,"importPluginModule");s(Zj,"extractDescriptors");s(Op,"loadPlugin");s(pA,"loadAllPlugins");});async function Jt(t,e){t.plugins.length!==0&&await pA(t.plugins,e);}var Vn=d(()=>{qg();s(Jt,"bootstrapPlugins");});function eh(t,e,r="project"){let n=[],o=[...t.targets,...t.pluginTargets??[]];for(let i of t.features){let a,c;switch(i){case "rules":c=e.rules.length,a="rules";break;case "commands":c=e.commands.length,a=c>0?`commands (${c})`:"commands";break;case "agents":c=e.agents.length,a=c>0?`agents (${c})`:"agents";break;case "skills":c=e.skills.length,a=c>0?`skills (${c})`:"skills";break;case "mcp":c=e.mcp?Object.keys(e.mcp.mcpServers).length:0,a=c>0?`mcp (${c} servers)`:"mcp";break;case "hooks":c=CU(e.hooks),a=c>0?`hooks (${c})`:"hooks";break;case "ignore":c=e.ignore.length>0?1:0,a="ignore";break;case "permissions":c=e.permissions&&(e.permissions.allow.length>0||e.permissions.deny.length>0)?1:0,a="permissions";break;default:continue}let l={};for(let m of o)l[m]=Zm(m,i,t,r);if(n.push({feature:a,count:c,support:l}),i==="rules"){let m=e.rules.filter(p=>!p.root);if(m.length>0){let p={};for(let u of o)p[u]=Zm(u,"additionalRules",t,r);n.push({feature:`additional rules (${m.length})`,count:m.length,support:p});}}}return n}function CU(t){if(!t)return 0;let e=0;for(let r of Object.values(t))Array.isArray(r)&&(e+=r.length);return e}var SA=d(()=>{ut();s(eh,"buildCompatibilityMatrix");s(CU,"countHooks");});function RA(t){return SU[t]??t}var SU,kA=d(()=>{SU={"claude-code":"Claude"};s(RA,"matrixColumnLabel");});function OA(t){return Object.fromEntries(RU.map(e=>[e,Object.fromEntries(it.map(r=>{let o=Po(r,t)?.[e];return [r,o??{level:"none"}]}))]))}function kU(){return process.env.NO_COLOR!==void 0&&process.env.NO_COLOR!==""}function OU(t,e){return kU()?e:`${t}${e}${$c.reset}`}function EA(t){let e=rh[t];return OU(wU[t],e)}var RU,wA,rh,$c,wU,nh=d(()=>{ze();ut();RU=["rules","additionalRules","commands","agents","skills","mcp","hooks","ignore","permissions"];s(OA,"buildSupportMatrix");wA=OA("project"),OA("global"),rh={native:"\u2713",embedded:"\u25C6",partial:"\u25D0",none:"\u2013"},$c={green:"\x1B[32m",blue:"\x1B[34m",yellow:"\x1B[33m",dim:"\x1B[2m",cyan:"\x1B[36m",magenta:"\x1B[35m",bold:"\x1B[1m",reset:"\x1B[0m"};s(kU,"noColor");s(OU,"colorize");wU={native:$c.green,embedded:$c.blue,partial:$c.yellow,none:$c.dim};s(EA,"coloredSymbol");});function oh(t,e){let r=process.env.NO_COLOR!==void 0&&process.env.NO_COLOR!=="",n={cyan:"\x1B[36m",magenta:"\x1B[35m",bold:"\x1B[1m",dim:"\x1B[2m",green:"\x1B[32m",blue:"\x1B[34m",yellow:"\x1B[33m",reset:"\x1B[0m"},o=s((B,J)=>r?J:`${B}${J}${n.reset}`,"c"),i=s(B=>B.replace(/\u001b\[[0-9;]*m/g,"").length,"visibleLength"),a=s((B,J)=>{let kt=i(B),Ct=Math.max(0,J-kt);return B+" ".repeat(Ct)},"padWithColor"),c=Math.max(12,...e.map(B=>B.length)),l=e.map(B=>RA(B)),m=Math.max(8,c),p=Math.max(12,...t.map(B=>B.feature.length)),u=s(B=>o(n.dim,"\u250C"+B.map(J=>"\u2500".repeat(J)).join("\u252C")+"\u2510"),"border"),f=s(B=>o(n.dim,"\u251C"+B.map(J=>"\u2500".repeat(J)).join("\u253C")+"\u2524"),"sep"),g=s(B=>o(n.dim,"\u2514"+B.map(J=>"\u2500".repeat(J)).join("\u2534")+"\u2518"),"bottom"),h=[p,...e.map(()=>m)],R=u(h),C=[a(o(n.bold+n.cyan,"Feature"),p),...l.map(B=>a(o(n.bold+n.magenta,B),m))],_=o(n.dim,"\u2502")+C.join(o(n.dim,"\u2502"))+o(n.dim,"\u2502"),E=f(h),T=t.map(B=>{let J=[a(o(n.cyan,B.feature),p)];for(let kt of e){let Ct=B.support[kt]??"none",Sr=r?rh[Ct]:EA(Ct);J.push(a(` ${Sr} `,m));}return o(n.dim,"\u2502")+J.join(o(n.dim,"\u2502"))+o(n.dim,"\u2502")}),D=g(h),x=[R,_,E,...T,D];x.push("");let Z=[o(n.green,"\u2713")+" = native",o(n.blue,"\u25C6")+" = embedded",o(n.yellow,"\u25D0")+" = partial",o(n.dim,"\u2013")+" = not supported"];return x.push(o(n.bold,"Legend: ")+Z.join(" ")),x.join(`
|
|
135
|
-
`)
|
|
133
|
+
`||i==="\r"||i===">"||i===" "||i===" "||i==='"'||i==="'"||i===":"||i==="#"||i==="?"}function vb(t,e,r){let n=e>0?t[e-1]:"",o=r<t.length?t[r]:"";return n==="`"&&o==="`"?{role:"inline-code"}:Fb(t,e,r)?{role:"markdown-link-dest"}:n==="<"&&o===">"?{role:"bracketed"}:n==="'"&&o==="'"||n==='"'&&o==='"'?{role:"quoted"}:n==="@"?{role:"at-prefix"}:n==="("&&t[e-2]==="]"?{role:"markdown-link-dest"}:n==="["&&o==="]"?{role:"bracket-label"}:{role:"bare-prose"}}function Mb(t,e,r,n,o){if(e<0||r>t.length)return false;let{candidate:i}=mi(n),a=i.replace(ca,""),c=ft(a),l=e+a.length,m=t[e-1],p=t[r];return Fb(t,e,l)||m==="'"&&p==="'"||m==='"'&&p==='"'||m==="`"&&p==="`"||m==="<"&&p===">"?true:m==="["&&p==="]"?!(!o&&!Or(c)&&Ij(t,e,n)):m==="@"?true:m==="("?p===")"||p==="#"||p==="?"||p===" "||p===" ":o?Or(c)?true:c.includes("/")||c.includes("\\")?c.startsWith("./")||c.startsWith("../")?true:(c.split(/[\\/]/).filter(Boolean).at(-1)??"").includes("."):false:false}var $b=d(()=>{Vt();jo();s(Ij,"markdownBracketLabelDuplicatesDestination");s(Fb,"isMarkdownReferenceDefinitionDestination");s(vb,"getTokenContext");s(Mb,"shouldRewritePathToken");});function pp(t){let e=new Set,r=mp(t.content);return {content:t.content.replace(Sb,(o,i,a)=>{if(r.some(([bt,pt])=>i>=bt&&i<pt)||!Mb(a,i,i+o.length,o,t.rewriteBarePathTokens===true)||Pb(a,i,o)||Cb(a,i,i+o.length))return o;let{candidate:c,suffix:l}=mi(o);if(!c)return o;let m=ca.exec(c),p=m?c.slice(0,m.index):c,u=m?m[0]:"";if(!p)return o;let f=vb(a,i,i+p.length);if(f.role!=="markdown-link-dest"&&Qe.test(p))return o;let{translatedPath:g,resolvedBeforeTranslate:h,matchedPath:R}=Ab({candidate:p,rawToken:c,projectRoot:t.projectRoot,sourceFile:t.sourceFile,destinationFile:t.destinationFile,translatePath:t.translatePath,pathExists:t.pathExists}),S=h;if(!R||!g)return g&&e.add(g),o;let _=ft(p),k=p.endsWith("/")||t.pathIsDirectory?.(g)===true;if(k&&!_.includes("/")&&!_.includes("\\"))return o;if(S===null){let bt=ft(c);if(bt.startsWith("agentsmesh/")&&(bt=`.${bt}`),bt.startsWith(".agentsmesh/")||bt.includes("/.agentsmesh/")){let pt=J(t.projectRoot),pn=U(t.projectRoot,t.projectRoot),Ve=bt.replace(/^\.\//,"");S=U(t.projectRoot,pt.join(pn,Ve));}}let T=J(t.projectRoot);if(t.scope==="global"){let bt=ft(c),pt=bt.startsWith(".agentsmesh/")||bt.includes("/.agentsmesh/"),pn=Or(bt)||Db(bt),Ve=S!==null&&Er(t.projectRoot,S),ro=Er(t.projectRoot,g);if(S===g&&!ro&&!Ve&&!pt){let Dy=ft(T.relative(t.projectRoot,U(t.projectRoot,t.sourceFile))).split("/").filter(Boolean)[0]??"",UT=(S!==null?ft(T.relative(t.projectRoot,S)):"").split("/").filter(Boolean)[0]??"";if(Dy.length>0&&Dy===UT)return o}if(!pn&&!pt&&!Ve&&!ro)return o}let P=U(t.projectRoot,t.destinationFile),A=U(t.projectRoot,g),Z=ft(T.relative(t.projectRoot,P)),B=ft(T.relative(t.projectRoot,A)),V=Z.split("/").filter(Boolean)[0]??"",Lt=B.split("/").filter(Boolean)[0]??"",Mt=!ft(p).startsWith(".agentsmesh/")&&!k&&V.length>0&&V===Lt&&V.startsWith(".")&&V!==".agentsmesh"||f.role==="markdown-link-dest"||Tb(a,i,p),wr=kb(t.projectRoot,t.destinationFile,g,p.endsWith("/"),{explicitCurrentDirLinks:t.explicitCurrentDirLinks===true||Mt,scope:t.scope??"project",pathIsDirectory:t.pathIsDirectory,logicalMeshSourceAbsolute:k?null:S,forceRelative:Mt,tokenContext:f,originalToken:p});return wr?`${wr}${u}${l}`:o}),missing:[...e]}}var zg=d(()=>{Vt();jo();wb();xb();Nb();$b();s(pp,"rewriteFileLinks");});function jb(t,e){let r=[t.normalize(e)];if(!existsSync(e))return r;try{let n=[realpathSync(e),realpathSync.native(e)];for(let o of n){let i=t.normalize(o);r.includes(i)||r.push(i);}}catch{}return r}async function H(t,e,r="project"){let n=J(e),o=new Map,i=Array.from(new Set([t,...lt]));for(let l of i){let m=await gb(l,e,r);for(let[p,u]of m.entries())o.set(p,u);}let a=new Map;for(let[l,m]of o.entries()){let p=n.normalize(n.join(e,m));for(let u of jb(n,n.join(e,l)))a.set(u,p);}let c=new Set;for(let l of new Set(o.values())){let m=n.normalize(n.join(e,l));c.add(m);for(let p of jb(n,m))c.add(n.normalize(p));}return (l,m,p)=>pp({content:l,projectRoot:e,sourceFile:m,destinationFile:p,translatePath:s(u=>a.get(u)??u,"translatePath"),pathExists:s(u=>{let f=n.normalize(u);return a.has(u)||a.has(f)||existsSync(u)||c.has(f)},"pathExists"),explicitCurrentDirLinks:false,rewriteBarePathTokens:true,scope:r,pathIsDirectory:s(u=>{try{return statSync(u).isDirectory()}catch{return false}},"pathIsDirectory")}).content}var Ot=d(()=>{Vt();hb();zg();Xe();s(jb,"pathVariants");s(H,"createImportReferenceNormalizer");});function Wb(t){let e={};for(let[r,n]of Object.entries(t)){if(!Array.isArray(n))continue;let o=[];for(let i of n){if(!i||typeof i!="object")continue;let a=i,c=typeof a.matcher=="string"?a.matcher:"";if(!c)continue;let l=Array.isArray(a.hooks)?a.hooks:[];for(let m of l){let p=m.type==="prompt"?"prompt":"command";if(!Ar({...m,type:p}))continue;let u=p==="prompt"?Qt(m)||At(m):At(m)||Qt(m),f={matcher:c,type:p,command:u};typeof m.timeout=="number"&&(f.timeout=m.timeout),o.push(f);}}o.length>0&&(e[r]=o);}return e}async function Kb(t,e){let r=join(t,En),n=await y(r);if(n===null)return false;let o;try{o=JSON.parse(n);}catch{return false}if(!o||typeof o!="object"||Array.isArray(o))return false;let i=Wb(o);if(Object.keys(i).length===0)return false;let a=stringify(i),c=join(t,ss);return await O(dirname(c)),await C(c,a),e.push({fromTool:"claude-code",fromPath:r,toPath:ss,feature:"hooks"}),true}async function Bb(t,e){let r=e.some(m=>m.feature==="hooks"&&m.fromPath.replace(/\\/g,"/").endsWith(En)),n=join(t,Ya),o=await y(n);if(!o)return;let i;try{i=JSON.parse(o);}catch{return}if(!e.some(m=>m.feature==="mcp")&&i.mcpServers&&typeof i.mcpServers=="object"){let m=i.mcpServers;await Yt(t,Qa,m),e.push({fromTool:"claude-code",fromPath:n,toPath:Qa,feature:"mcp"});}let c=i.permissions;if(c&&typeof c=="object"&&!Array.isArray(c)){let m=c,p=Array.isArray(m.allow)?m.allow.filter(g=>typeof g=="string"):[],u=Array.isArray(m.deny)?m.deny.filter(g=>typeof g=="string"):[],f=Array.isArray(m.ask)?m.ask.filter(g=>typeof g=="string"):[];if(p.length>0||u.length>0||f.length>0){let g=stringify({allow:p,deny:u,ask:f}),h=join(t,Qu);await O(dirname(h)),await C(h,g),e.push({fromTool:"claude-code",fromPath:n,toPath:Qu,feature:"permissions"});}}let l=i.hooks;if(!r&&l&&typeof l=="object"&&!Array.isArray(l)){let m=Wb(l);if(Object.keys(m).length>0){let p=stringify(m),u=join(t,ss);await O(dirname(u)),await C(u,p),e.push({fromTool:"claude-code",fromPath:n,toPath:ss,feature:"hooks"});}}}var Hb=d(()=>{qe();b();Sn();kn();s(Wb,"claudeHooksToCanonical");s(Kb,"importClaudeHooksJson");s(Bb,"importSettings");});async function Vb(t,e,r){let n=join(t,Ja),o=join(t,qu),a=(await D(n)).filter(c=>c.endsWith("SKILL.md"));for(let c of a){let l=dirname(c),m=basename(l),p=join(o,m),u=await D(l);for(let f of u){let g=await y(f);if(g===null)continue;let h=relative(l,f),R=join(p,h);await O(dirname(R));let S=r(g,f,R),_=h==="SKILL.md"?E(S):null;await C(R,h==="SKILL.md"?await Tr(R,_?.frontmatter??{},_?.body??""):S);let k=`${qu}/${m}/${h}`;e.push({fromTool:"claude-code",fromPath:f,toPath:k,feature:"skills"});}}}var Jb=d(()=>{b();v();nt();kn();s(Vb,"importClaudeSkills");});async function rm(t,e={}){let r=e.scope??"project",n=[],o=await H("claude-code",t,r);return n.push(...await tt(em,t,r,{normalize:o})),await Vb(t,n,o),await Kb(t,n),await Bb(t,n),n}var vd=d(()=>{Ot();Ut();Hb();Jb();Fd();s(rm,"importFromClaudeCode");});async function vc(t,e){let r=Oj[e];if(!r)throw new Error(`No importer registered for native target: ${e}`);return r(t)}var Oj,Yg=d(()=>{vd();bf();df();Jf();of();Pg();Wd();sf();qf();ag();og();Oj={"claude-code":rm,cursor:Am,copilot:Sm,"gemini-cli":$m,"codex-cli":pm,windsurf:np,cline:im,continue:dm,junie:Um,kiro:Vm,"kilo-code":Hm};s(vc,"importNativeToCanonical");});async function Hs(t){if(!await F(t))return false;if(await F(join(t,Zg)))return true;try{let e=await readdir(t,{withFileTypes:!0});for(let r of e)if(!(!r.isDirectory()||r.name.startsWith("."))&&await F(join(t,r.name,Zg)))return !0}catch{return false}return false}async function Mc(t){if(!await F(t))return [];if(await F(join(t,Zg))){let e=await F_(t);return e?[e]:[]}return ci(t)}var Zg,dp=d(()=>{b();Sl();Zg="SKILL.md";s(Hs,"isSkillPackLayout");s(Mc,"loadSkillsAtExtendPath");});function Lj(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}function bj(t){return t.rules.length===0&&t.commands.length===0&&t.agents.length===0&&t.skills.length===0&&t.mcp===null&&t.permissions===null&&t.hooks===null&&t.ignore.length===0}async function fp(t){if(!await F(t))throw new Error(`Path does not exist: ${t}`);let e=await stat(t);if(e.isDirectory())return {sliceRoot:t};if(!e.isFile()||!t.toLowerCase().endsWith(".md"))throw new Error(`Install path must be a directory or a .md file inside rules/, commands/, or agents/: ${t}`);let r=dirname(t),n=basename(r),i=basename(t).replace(/\.md$/i,"");if(n==="rules")return {sliceRoot:r,implicitPick:{rules:[i]}};if(n==="commands")return {sliceRoot:r,implicitPick:{commands:[i]}};if(n==="agents")return {sliceRoot:r,implicitPick:{agents:[i]}};throw new Error(`Single-file install only supports .md files under rules/, commands/, or agents/. Got: ${t}`)}async function Aj(t){if(basename(t)==="rules")return Yo(t);let r=join(t,"rules");return await F(r)?Yo(r):[]}async function xj(t){if(basename(t)==="commands")return Xo(t);let r=join(t,"commands");return await F(r)?Xo(r):[]}async function Pj(t){if(basename(t)==="agents")return qo(t);let r=join(t,"agents");return await F(r)?qo(r):[]}async function Tj(t){if(await Hs(t))return Mc(t);let e=join(t,"skills");return await Hs(e)?Mc(e):[]}async function gp(t){let e=join(t,".agentsmesh");if(await F(e))return ge(t);let r=Lj();if(r.rules=await Aj(t),r.commands=await xj(t),r.agents=await Pj(t),r.skills=await Tj(t),bj(r))throw new Error(`No installable resources at ${t}. Expected .agentsmesh/, or rules/, commands/, agents/, or Anthropic-style skills (SKILL.md).`);return r}var qg=d(()=>{b();_l();Qo();yl();hl();dp();s(Lj,"emptyCanonical");s(bj,"isCanonicalSliceEmpty");s(fp,"normalizeSlicePath");s(Aj,"parseRulesAt");s(xj,"parseCommandsAt");s(Pj,"parseAgentsAt");s(Tj,"loadSkillsForPartialSlice");s(gp,"loadCanonicalSliceAtPath");});function Dj(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function Yb(t){let e=t.resolvedPath;if(!t.path){let o=join(e,".agentsmesh");if(!await F(o)){if(await Hs(e)){let a=await Mc(e);return {...Dj(),skills:a}}let i=t.target??await El(e);if(!i)throw new Error(`Extend "${t.name}": No supported agent configuration found in ${e}.
|
|
134
|
+
Expected one of: .agentsmesh/, ${j_.join(", ")}.`);I.info(`[agentsmesh] Extend "${t.name}": ${t.target?"specified":"detected"} ${i} format, importing to .agentsmesh/...`),await vc(e,i);}return ge(e)}let r=join(e,t.path);if(!await F(r))throw new Error(`Extend "${t.name}": path does not exist: ${r}`);if(t.target){let o=join(e,".agentsmesh");return await F(o)||(I.info(`[agentsmesh] Extend "${t.name}": path "${t.path}" with target "${t.target}" \u2014 importing at extend root, then loading canonical.`),await vc(e,t.target)),ge(e)}let{sliceRoot:n}=await fp(r);try{return await gp(n)}catch(o){let i=o instanceof Error?o.message:String(o),a=new Error(`Extend "${t.name}": ${i}`);throw o instanceof Error&&(a.cause=o),a}}var Xb=d(()=>{Pu();b();st();Qo();Yg();dp();qg();s(Dj,"emptyCanonical");s(Yb,"loadCanonicalForExtend");});function hp(t,e,r,n){if(!r)return t;let o={...t};if(r.skills?.length&&e.includes("skills")){let i=new Set(r.skills),a=o.skills;o={...o,skills:a.filter(c=>i.has(c.name))};for(let c of r.skills)a.some(l=>l.name===c)||I.warn(`[agentsmesh] pick name "${c}" not found in skills from extend "${n}".`);}if(r.commands?.length&&e.includes("commands")){let i=new Set(r.commands),a=o.commands;o={...o,commands:a.filter(c=>i.has(c.name))};for(let c of r.commands)a.some(l=>l.name===c)||I.warn(`[agentsmesh] pick name "${c}" not found in commands from extend "${n}".`);}if(r.agents?.length&&e.includes("agents")){let i=new Set(r.agents),a=o.agents;o={...o,agents:a.filter(c=>i.has(c.name))};for(let c of r.agents)a.some(l=>l.name===c)||I.warn(`[agentsmesh] pick name "${c}" not found in agents from extend "${n}".`);}if(r.rules?.length&&e.includes("rules")){let i=new Set(r.rules),a=o.rules,c=s(l=>basename(l).replace(/\.md$/i,""),"stem");o={...o,rules:a.filter(l=>i.has(c(l.source)))};for(let l of r.rules)a.some(m=>c(m.source)===l)||I.warn(`[agentsmesh] pick name "${l}" not found in rules from extend "${n}".`);}return o}var th=d(()=>{st();s(hp,"applyExtendPick");});var vj,ma,yp=d(()=>{vj=["rules","commands","agents","skills"],ma=z$1.enum(vj);});var Mj,Zb,qb=d(()=>{fn();yp();Mj=z$1.enum(["github","gitlab","git","local"]),Zb=z$1.object({name:z$1.string().min(1),source:z$1.string().min(1),version:z$1.string().optional(),source_kind:Mj,installed_at:z$1.string(),updated_at:z$1.string(),features:z$1.array(oi).min(1),pick:ba.optional(),target:Le.optional(),path:z$1.string().optional(),paths:z$1.array(z$1.string().min(1)).min(1).optional(),as:ma.optional(),content_hash:z$1.string()});});function Qb(t){let e=Jo(t);return e?e.kind==="github"?`github:${e.org}/${e.repo}`:e.kind==="gitlab"?`gitlab:${e.namespace}/${e.project}`:`git+${e.url}`:t.trim()}function Gj(t,e){return e?t.length===e.length&&[...t].sort().every((r,n)=>r===[...e].sort()[n]):true}async function _p(t){let e=join(t,"pack.yaml"),r=await y(e);if(r===null)return null;try{let n=parse(r);return Zb.parse(n)}catch{return null}}async function eA(t,e,r){if(!await F(t))return null;let n=Qb(e),o;try{o=await readdir(t,{withFileTypes:!0});}catch{return null}for(let i of o){if(!i.isDirectory())continue;let a=join(t,i.name),c=await _p(a);if(c&&Qb(c.source)===n&&c.target===r.target&&c.as===r.as&&Gj(c.features,r.features))return {meta:c,packDir:a,name:c.name}}return null}async function Ip(t){if(!await F(t))return [];let e;try{e=await readdir(t,{withFileTypes:!0});}catch{return []}let r=[];for(let n of e){if(!n.isDirectory())continue;let o=join(t,n.name),i=await _p(o);i&&r.push({meta:i,packDir:o,name:i.name});}return r}var Sp=d(()=>{b();qb();Pa();s(Qb,"sourceIdentity");s(Gj,"sameFeatures");s(_p,"readPackMetadata");s(eA,"findExistingPack");s(Ip,"listPacks");});function rA(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function jj(t){let[e,r,n,o,i,a,c,l]=await Promise.all([Yo(join(t,"rules")),Xo(join(t,"commands")),qo(join(t,"agents")),ci(join(t,"skills")),Ze(join(t,"mcp.json")),Cl(join(t,"permissions.yaml")),Rl(join(t,"hooks.yaml")),Ol(join(t,"ignore"))]);return {...rA(),rules:e,commands:r,agents:n,skills:o,mcp:i,permissions:a,hooks:c,ignore:l}}async function nA(t){let e=join(t,"packs"),r=await Ip(e),n=rA();for(let{meta:o,packDir:i}of r){let a=await jj(i),c=rh(a,o.features),l=hp(c,o.features,o.pick,o.name);n=li(n,l);}return n}var oA=d(()=>{hl();yl();_l();Sl();Na();ku();Lu();bu();xu();ln();th();Sp();s(rA,"emptyCanonical");s(jj,"loadPackCanonical");s(nA,"loadPacksCanonical");});function rh(t,e){if(e.length===0)return sA();let r=new Set(e.flatMap(n=>Wj[n]??[]));return {rules:r.has("rules")?t.rules:[],commands:r.has("commands")?t.commands:[],agents:r.has("agents")?t.agents:[],skills:r.has("skills")?t.skills:[],mcp:r.has("mcp")?t.mcp:null,permissions:r.has("permissions")?t.permissions:null,hooks:r.has("hooks")?t.hooks:null,ignore:r.has("ignore")?t.ignore:[]}}function sA(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function se(t,e,r={},n=join(e,".agentsmesh")){let o=await ai(t,e,{refreshCache:r.refreshRemoteCache===true}),i=sA();for(let l of o){let m=await Yb(l),p=rh(m,l.features),u=hp(p,l.features,l.pick,l.name);i=li(i,u);}let a=await nA(n);i=li(i,a);let c=await ge(n);return i=li(i,c),{canonical:i,resolvedExtends:o}}var Wj,ln=d(()=>{dl();Qo();xu();Xb();th();oA();Wj={rules:["rules"],commands:["commands"],agents:["agents"],skills:["skills"],mcp:["mcp"],permissions:["permissions"],hooks:["hooks"],ignore:["ignore"]};s(rh,"filterCanonicalByFeatures");s(sA,"emptyCanonical");s(se,"loadCanonicalWithExtends");});function vU(t,e){let r=join(e,"node_modules",t),n=join(r,"package.json");if(!existsSync(n))throw new Error(`Cannot find package '${t}' in ${join(e,"node_modules")}`);let o=JSON.parse(readFileSync(n,"utf-8")),i=(typeof o.exports=="string"?o.exports:null)??(typeof o.main=="string"?o.main:null)??"index.js",a=resolve(r,i);if(!existsSync(a))throw new Error(`Package '${t}' entry '${i}' does not exist at ${a}`);return a}function MU(t){return t.startsWith("file:")||t.startsWith("./")||t.startsWith("../")||t.startsWith("/")||/^[A-Za-z]:[/\\]/.test(t)}async function $U(t,e){let{source:r}=t,n;if(MU(r)){let i=r.startsWith("file:")?fileURLToPath(r):r,a=resolve(e,i);n=pathToFileURL(a).href;}else {let i=vU(r,e);n=pathToFileURL(i).href;}return await import(n)}function GU(t){return "descriptor"in t?[t.descriptor]:"descriptors"in t&&Array.isArray(t.descriptors)?t.descriptors:"default"in t?[t.default]:[]}async function Tp(t,e){let r;try{r=await $U(t,e);}catch(i){throw new Error(`Plugin '${t.source}' failed to import: ${i instanceof Error?i.message:String(i)}`,{cause:i})}let n=GU(r),o=[];for(let i of n)try{let a=ip(i);ap(a),o.push(a);}catch(a){throw new Error(`Plugin '${t.source}' exported an invalid descriptor: ${a instanceof Error?a.message:String(a)}`,{cause:a})}return {entry:t,descriptors:o}}async function GA(t,e){let r=[],n=process.env.AGENTSMESH_STRICT_PLUGINS==="1"||process.env.AGENTSMESH_STRICT_PLUGINS==="true",i=(await Promise.all(t.map(async a=>{try{let c=await Tp(a,e);return r.push(c),null}catch(c){let l=`Plugin '${a.source}' failed to load: ${c instanceof Error?c.message:String(c)}`;return a.strict===true||n?new Error(l):(I.warn(l),null)}}))).filter(a=>a!==null);if(i.length>0){let a=i.map(c=>` - ${c.message}`).join(`
|
|
135
|
+
`);throw new Error(`agentsmesh: ${i.length} plugin(s) failed strict load:
|
|
136
|
+
${a}`)}return r}var uh=d(()=>{Mg();Ce();st();s(vU,"resolveNpmSpecifier");s(MU,"isLocalSource");s($U,"importPluginModule");s(GU,"extractDescriptors");s(Tp,"loadPlugin");s(GA,"loadAllPlugins");});async function qt(t,e){t.plugins.length!==0&&await GA(t.plugins,e);}var Qn=d(()=>{uh();s(qt,"bootstrapPlugins");});function gh(t,e,r="project"){let n=[],o=[...t.targets,...t.pluginTargets??[]];for(let i of t.features){let a,c;switch(i){case "rules":c=e.rules.length,a="rules";break;case "commands":c=e.commands.length,a=c>0?`commands (${c})`:"commands";break;case "agents":c=e.agents.length,a=c>0?`agents (${c})`:"agents";break;case "skills":c=e.skills.length,a=c>0?`skills (${c})`:"skills";break;case "mcp":c=e.mcp?Object.keys(e.mcp.mcpServers).length:0,a=c>0?`mcp (${c} servers)`:"mcp";break;case "hooks":c=c0(e.hooks),a=c>0?`hooks (${c})`:"hooks";break;case "ignore":c=e.ignore.length>0?1:0,a="ignore";break;case "permissions":c=e.permissions&&(e.permissions.allow.length>0||e.permissions.deny.length>0)?1:0,a="permissions";break;default:continue}let l={};for(let m of o)l[m]=sp(m,i,t,r);if(n.push({feature:a,count:c,support:l}),i==="rules"){let m=e.rules.filter(p=>!p.root);if(m.length>0){let p={};for(let u of o)p[u]=sp(u,"additionalRules",t,r);n.push({feature:`additional rules (${m.length})`,count:m.length,support:p});}}}return n}function c0(t){if(!t)return 0;let e=0;for(let r of Object.values(t))Array.isArray(r)&&(e+=r.length);return e}var YA=d(()=>{gt();s(gh,"buildCompatibilityMatrix");s(c0,"countHooks");});function XA(t){return l0[t]??t}var l0,ZA=d(()=>{l0={"claude-code":"Claude"};s(XA,"matrixColumnLabel");});function qA(t){return Object.fromEntries(m0.map(e=>[e,Object.fromEntries(lt.map(r=>{let o=vo(r,t)?.[e];return [r,o??{level:"none"}]}))]))}function p0(){return process.env.NO_COLOR!==void 0&&process.env.NO_COLOR!==""}function u0(t,e){return p0()?e:`${t}${e}${Kc.reset}`}function tx(t){let e=hh[t];return u0(d0[t],e)}var m0,QA,hh,Kc,d0,yh=d(()=>{Xe();gt();m0=["rules","additionalRules","commands","agents","skills","mcp","hooks","ignore","permissions"];s(qA,"buildSupportMatrix");QA=qA("project"),qA("global"),hh={native:"\u2713",embedded:"\u25C6",partial:"\u25D0",none:"\u2013"},Kc={green:"\x1B[32m",blue:"\x1B[34m",yellow:"\x1B[33m",dim:"\x1B[2m",cyan:"\x1B[36m",magenta:"\x1B[35m",bold:"\x1B[1m",reset:"\x1B[0m"};s(p0,"noColor");s(u0,"colorize");d0={native:Kc.green,embedded:Kc.blue,partial:Kc.yellow,none:Kc.dim};s(tx,"coloredSymbol");});function _h(t,e){let r=process.env.NO_COLOR!==void 0&&process.env.NO_COLOR!=="",n={cyan:"\x1B[36m",magenta:"\x1B[35m",bold:"\x1B[1m",dim:"\x1B[2m",green:"\x1B[32m",blue:"\x1B[34m",yellow:"\x1B[33m",reset:"\x1B[0m"},o=s((B,V)=>r?V:`${B}${V}${n.reset}`,"c"),i=s(B=>B.replace(/\u001b\[[0-9;]*m/g,"").length,"visibleLength"),a=s((B,V)=>{let Lt=i(B),Et=Math.max(0,V-Lt);return B+" ".repeat(Et)},"padWithColor"),c=Math.max(12,...e.map(B=>B.length)),l=e.map(B=>XA(B)),m=Math.max(8,c),p=Math.max(12,...t.map(B=>B.feature.length)),u=s(B=>o(n.dim,"\u250C"+B.map(V=>"\u2500".repeat(V)).join("\u252C")+"\u2510"),"border"),f=s(B=>o(n.dim,"\u251C"+B.map(V=>"\u2500".repeat(V)).join("\u253C")+"\u2524"),"sep"),g=s(B=>o(n.dim,"\u2514"+B.map(V=>"\u2500".repeat(V)).join("\u2534")+"\u2518"),"bottom"),h=[p,...e.map(()=>m)],R=u(h),S=[a(o(n.bold+n.cyan,"Feature"),p),...l.map(B=>a(o(n.bold+n.magenta,B),m))],_=o(n.dim,"\u2502")+S.join(o(n.dim,"\u2502"))+o(n.dim,"\u2502"),k=f(h),T=t.map(B=>{let V=[a(o(n.cyan,B.feature),p)];for(let Lt of e){let Et=B.support[Lt]??"none",kr=r?hh[Et]:tx(Et);V.push(a(` ${kr} `,m));}return o(n.dim,"\u2502")+V.join(o(n.dim,"\u2502"))+o(n.dim,"\u2502")}),P=g(h),A=[R,_,k,...T,P];A.push("");let Z=[o(n.green,"\u2713")+" = native",o(n.blue,"\u25C6")+" = embedded",o(n.yellow,"\u25D0")+" = partial",o(n.dim,"\u2013")+" = not supported"];return A.push(o(n.bold,"Legend: ")+Z.join(" ")),A.join(`
|
|
137
|
+
`)}var ex=d(()=>{ZA();yh();s(_h,"formatMatrix");});function Sh(t){let e=[];if(t.rules.length>0&&e.push(`rules: ${t.rules.map(r=>basename(r.source)).join(", ")}`),t.commands.length>0&&e.push(`commands: ${t.commands.map(r=>basename(r.source)).join(", ")}`),t.agents.length>0&&e.push(`agents: ${t.agents.map(r=>basename(r.source)).join(", ")}`),t.skills.length>0&&e.push(`skills: ${t.skills.map(r=>r.name).join(", ")}`),t.mcp&&Object.keys(t.mcp.mcpServers).length>0&&e.push(`mcp: ${Object.keys(t.mcp.mcpServers).join(", ")}`),t.hooks){let r=Object.values(t.hooks).reduce((n,o)=>n+(Array.isArray(o)?o.length:0),0);r>0&&e.push(`hooks: ${r} entries in hooks.yaml`);}return t.ignore.length>0&&e.push("ignore: .agentsmesh/ignore"),t.permissions&&t.permissions.allow.length+t.permissions.deny.length>0&&e.push("permissions: .agentsmesh/permissions.yaml"),e.length===0?"":`
|
|
136
138
|
Per-file details:
|
|
137
139
|
`+e.join(`
|
|
138
140
|
`)+`
|
|
139
|
-
`}var
|
|
141
|
+
`}var rx=d(()=>{s(Sh,"formatVerboseDetails");});var Ch=d(()=>{YA();ex();rx();});var Rh={};iu(Rh,{runMatrix:()=>Bc});async function Bc(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=t.targets,i=typeof o=="string"&&o?o.split(",").map(f=>f.trim()).filter(Boolean):void 0,{config:a,context:c}=await ut(r,n);await qt(a,r);let{canonical:l}=await se(a,c.configDir,{},c.canonicalDir),m=i??[...a.targets,...a.pluginTargets??[]],p=gh(a,l,n),u=Sh(l);return {exitCode:0,data:{targets:m,features:p.map(f=>({name:f.feature,support:f.support}))},verboseDetails:u||void 0}}var Hc=d(()=>{de();ln();Ch();Qn();s(Bc,"runMatrix");});var Oh={};iu(Oh,{renderMatrix:()=>zc});function zc(t,e){if(t.data.features.length===0){I.info("No features enabled. Enable features in agentsmesh.yaml.");return}let r=t.data.features.map(o=>({feature:o.name,count:0,support:o.support})),n=_h(r,t.data.targets);process.stdout.write(n),process.stdout.write(`
|
|
140
142
|
`),e?.verbose&&t.verboseDetails&&(process.stdout.write(t.verboseDetails),process.stdout.write(`
|
|
141
|
-
`));}var
|
|
142
|
-
`)}s(
|
|
143
|
+
`));}var Vc=d(()=>{st();Ch();s(zc,"renderMatrix");});function Fy(t){let e=Object.keys(t);return {async route(r,n,o){let i=t[r];if(i){await i(n,o);return}throw new Error(`Unknown command "${r}". Available: ${e.join(", ")}`)},commands:s(()=>[...e],"commands")}}s(Fy,"createRouter");st();var Gy=[{name:"--help",description:"Show this help output and exit"},{name:"--version",description:"Print CLI version and exit"},{name:"--verbose",description:"Show full error details on failure"},{name:"--json",description:"Output machine-readable JSON (single envelope to stdout)"}],jy=[{name:"init",usage:"agentsmesh init [flags]",description:"Create agentsmesh.yaml, agentsmesh.local.yaml, and canonical .agentsmesh scaffold",flags:[{name:"--global",description:"Initialize canonical home config under ~/.agentsmesh/ (global targets include claude-code, antigravity, codex-cli, cursor, gemini-cli, kilo-code)"},{name:"--yes",description:"Auto-import detected tool configs, then add example scaffold only under empty canonical paths"}]},{name:"generate",usage:"agentsmesh generate [flags]",description:"Generate target files from canonical sources",flags:[{name:"--global",description:"Generate user-level config from ~/.agentsmesh/ (e.g. claude-code, antigravity, codex-cli, gemini-cli, kilo-code; Cursor writes ~/.cursor/rules, ~/.cursor/AGENTS.md, hooks, ignore, MCP, skills, agents, commands; legacy ~/.agentsmesh-exports/cursor/user-rules.md is import-only)"},{name:"--targets <csv>",description:"Limit generation to target IDs (comma-separated)"},{name:"--check",description:"Check drift only; exit non-zero when out of sync"},{name:"--dry-run",description:"Preview file changes without writing outputs"},{name:"--force",description:"Bypass lock-strategy blocked feature violations"},{name:"--refresh-cache",description:"Refresh remote extends cache before loading"},{name:"--no-cache",description:"Alias for --refresh-cache"}]},{name:"import",usage:"agentsmesh import --from <target> [flags]",description:"Import existing tool config into canonical .agentsmesh files",flags:[{name:"--from <target>",description:"Source tool ID to import from (required)"},{name:"--global",description:"Import from user-level paths into ~/.agentsmesh/ (claude-code, antigravity, codex-cli, gemini-cli, kilo-code; cursor reads ~/.cursor/{rules,AGENTS.md,mcp.json,hooks.json,cursorignore,skills,agents,commands} and legacy ~/.agentsmesh-exports/cursor/user-rules.md)"}]},{name:"convert",usage:"agentsmesh convert --from <target> --to <target> [flags]",description:"Convert configuration directly from one tool to another",flags:[{name:"--from <target>",description:"Source tool ID to convert from (required)"},{name:"--to <target>",description:"Destination tool ID to convert to (required)"},{name:"--global",description:"Convert user-level config (use home directory paths)"},{name:"--dry-run",description:"Preview conversion without writing files"}]},{name:"install",usage:"agentsmesh install <source> [flags]",description:"Install canonical resources from local/remote sources",flags:[{name:"<source>",description:"GitHub/GitLab/tree/blob URL, git+ URL, SSH, or local path"},{name:"--sync",description:"Reinstall missing packs recorded in .agentsmesh/installs.yaml"},{name:"--path <dir>",description:"Subdirectory inside source repo when not embedded in URL"},{name:"--target <id>",description:"Native format used for import-at-root discovery (same as extends.target)"},{name:"--as <kind>",description:"Manual collection mode: rules, commands, agents, or skills"},{name:"--name <id>",description:"Override generated install entry/pack name"},{name:"--extends",description:"Write install as extends entry instead of materialized pack"},{name:"--dry-run",description:"Preview only (no YAML write, no pack write, no generate)"},{name:"--global",description:"Install into ~/.agentsmesh/ and regenerate user-level config"},{name:"--force",description:"Non-interactive mode; include invalid resources and skip selection prompts (implied by --json)"}]},{name:"diff",usage:"agentsmesh diff [flags]",description:"Show patch-style output for what generate would change",flags:[{name:"--global",description:"Diff against outputs generated from ~/.agentsmesh/"},{name:"--targets <csv>",description:"Limit diff to target IDs (comma-separated)"}]},{name:"lint",usage:"agentsmesh lint [flags]",description:"Validate canonical files against target constraints",flags:[{name:"--global",description:"Lint canonical home config under ~/.agentsmesh/"},{name:"--targets <csv>",description:"Limit linting to target IDs (comma-separated)"}]},{name:"watch",usage:"agentsmesh watch [flags]",description:"Watch canonical files and regenerate on change",flags:[{name:"--global",description:"Watch ~/.agentsmesh/ and regenerate user-level config"},{name:"--targets <csv>",description:"Limit watched generate/matrix output to target IDs"}]},{name:"check",usage:"agentsmesh check",description:"Verify canonical files still match .agentsmesh/.lock",flags:[{name:"--global",description:"Check ~/.agentsmesh/.lock"}]},{name:"merge",usage:"agentsmesh merge",description:"Resolve .agentsmesh/.lock merge conflicts from current canonical state",flags:[{name:"--global",description:"Resolve ~/.agentsmesh/.lock conflicts"}]},{name:"matrix",usage:"agentsmesh matrix [flags]",description:"Print compatibility matrix for enabled features and targets",flags:[{name:"--global",description:"Show matrix for canonical home config under ~/.agentsmesh/"},{name:"--targets <csv>",description:"Limit matrix columns to target IDs"},{name:"--verbose",description:"Include expanded feature details in matrix output"}]},{name:"target",usage:"agentsmesh target scaffold <id> [--name <displayName>] [--force]",description:"Generate a new target skeleton (files, tests, fixture) under src/targets/<id>/.",flags:[{name:"--name <displayName>",description:"Human-readable name (defaults to id)"},{name:"--force",description:"Overwrite existing files"}]},{name:"plugin",usage:"agentsmesh plugin <add|list|remove|info> [args] [flags]",description:"Manage plugin-provided targets (npm packages exporting a TargetDescriptor).",flags:[{name:"--version <v>",description:"Pin plugin version (add)"},{name:"--id <id>",description:"Override derived plugin id (add)"}]},{name:"mcp",usage:"agentsmesh mcp",description:"Start the agentsmesh MCP server (stdio)",flags:[]}];function Uy(t,e=18){return t.length===0?" (no command-specific flags)":t.map(r=>` ${r.name.padEnd(e)}${r.description}`).join(`
|
|
144
|
+
`)}s(Uy,"formatFlags");function Wy(){let t=jy.map(e=>`- ${e.name.padEnd(8)} ${e.description}
|
|
143
145
|
Usage: ${e.usage}
|
|
144
|
-
${
|
|
146
|
+
${Uy(e.flags)}`).join(`
|
|
145
147
|
|
|
146
148
|
`);I.info(`agentsmesh <command> [flags]
|
|
147
149
|
|
|
148
150
|
Global flags:
|
|
149
|
-
${
|
|
151
|
+
${Uy(Gy)}
|
|
150
152
|
|
|
151
153
|
Commands:
|
|
152
154
|
${t}
|
|
153
155
|
|
|
154
|
-
Tip: run "agentsmesh <command> --help" for this same command reference.`);}s(
|
|
155
|
-
`);}s(
|
|
156
|
-
`);}s(
|
|
157
|
-
`):I.error(t.message),process.exit(r);}s(
|
|
156
|
+
Tip: run "agentsmesh <command> --help" for this same command reference.`);}s(Wy,"printHelp");var al;function VT(){try{let t=createRequire(import.meta.url),e=dirname(fileURLToPath(import.meta.url)),r=e.endsWith("dist")?join(e,"..","package.json"):join(e,"..","..","package.json");return t(r).version}catch{return}}s(VT,"readPackageVersion");function JT(){if(typeof __AGENTSMESH_VERSION__<"u")return __AGENTSMESH_VERSION__;let t=globalThis.__AGENTSMESH_VERSION__;return typeof t=="string"?t:"unknown"}s(JT,"getVersionFallback");function ka(){return al||(al=VT()??JT(),al)}s(ka,"getVersion");function By(){process.stdout.write(`agentsmesh v${ka()}
|
|
157
|
+
`);}s(By,"printVersion");st();function ei(t,e){let r={success:e.success,command:t};e.success?r.data=e.data:(r.error=e.error,e.data!==void 0&&(r.data=e.data)),process.stdout.write(JSON.stringify(r)+`
|
|
158
|
+
`);}s(ei,"emitJson");var Lr=class extends Error{static{s(this,"CliUsageError");}constructor(e){super(e),this.name="CliUsageError";}};function Hy(t,e){let r=t instanceof Lr?2:1;if(e?.json)return ei(e.command??"unknown",{success:false,error:t.message}),process.exit(r);e?.verbose&&t.stack?process.stderr.write(t.stack+`
|
|
159
|
+
`):I.error(t.message),process.exit(r);}s(Hy,"handleError");st();function ue(t,e,r,n){if(r.json===true){let o=e.exitCode===0;ei(t,o?{success:true,data:e.data}:{success:false,error:`Command '${t}' failed`,data:e.data}),process.exit(e.exitCode);return}n(),e.exitCode!==0&&process.exit(e.exitCode);}s(ue,"handleResult");de();ln();b();function jc(t){return createHash("sha256").update(t,"utf8").digest("hex")}s(jc,"hashContent");async function Cp(t){try{let e=await readFile(t,"utf8");return jc(e)}catch(e){if(e instanceof Error&&"code"in e&&e.code==="ENOENT")return null;throw e}}s(Cp,"hashFile");Sp();var oh=".lock",Jj=[t=>t.startsWith("rules/")&&t.endsWith(".md"),t=>t.startsWith("commands/")&&t.endsWith(".md"),t=>t.startsWith("agents/")&&t.endsWith(".md"),t=>t.match(/^skills\/[^/]+\/.+$/)!==null,t=>t==="mcp.json",t=>t==="permissions.yaml",t=>t==="hooks.yaml",t=>t==="ignore"];function Yj(t){return t.startsWith("packs/")?false:Jj.some(e=>e(t))}s(Yj,"isCanonical");var Xj={rules:s(t=>t.startsWith("rules/"),"rules"),commands:s(t=>t.startsWith("commands/"),"commands"),agents:s(t=>t.startsWith("agents/"),"agents"),skills:s(t=>/^skills\/[^/]+\/.+$/.test(t),"skills"),mcp:s(t=>t==="mcp.json","mcp"),permissions:s(t=>t==="permissions.yaml","permissions"),hooks:s(t=>t==="hooks.yaml","hooks"),ignore:s(t=>t==="ignore","ignore")};async function Rp(t){let e=join(t,oh),r=await y(e);if(r===null)return null;try{let n=parse(r);return !n||typeof n!="object"?null:{generatedAt:String(n.generated_at??""),generatedBy:String(n.generated_by??""),libVersion:String(n.lib_version??""),checksums:n.checksums&&typeof n.checksums=="object"?n.checksums:{},extends:n.extends&&typeof n.extends=="object"?n.extends:{},packs:n.packs&&typeof n.packs=="object"?n.packs:{}}}catch{return null}}s(Rp,"readLock");async function Op(t,e){let r=join(t,oh),n={generated_at:e.generatedAt,generated_by:e.generatedBy,lib_version:e.libVersion,checksums:e.checksums,extends:e.extends,packs:e.packs},o=`# Auto-generated. DO NOT EDIT MANUALLY.
|
|
158
160
|
# Tracks the state of all config files for team conflict resolution.
|
|
159
161
|
|
|
160
|
-
`+stringify(n);await
|
|
161
|
-
`),a=Fc(i),c=a.startsWith("sha256:")?a:`sha256:${a}`;e[r.name]=`local:${c}`;}return e}s(oa,"buildExtendChecksums");ut();ye();function lj(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}s(lj,"addDirectoryMapping");function Tb(t,e,r){let n=posix.dirname(e),o=posix.dirname(r);for(;n!==".agentsmesh/skills"&&n!==".";)lj(t,n,o),n=posix.dirname(n),o=posix.dirname(o);}s(Tb,"addSkillDirectoryMappings");ut();function Db(t,e,r="project"){let n=Tt(t,r);if(!n)return null;if(e.root)return n.rootInstructionPath??null;if(e.targets.length>0&&!e.targets.includes(t))return null;let o=posix.basename(e.source.replace(/\\/g,"/"),".md");return n.paths.rulePath(o,e)}s(Db,"ruleTargetPath");function Nb(t,e,r,n="project"){let o=Tt(t,n);return o?o.paths.commandPath(e,r):null}s(Nb,"commandTargetPath");function Fb(t,e,r,n="project"){let o=Tt(t,n);return o?o.paths.agentPath(e,r):null}s(Fb,"agentTargetPath");Vt();Pt();te();ut();function uj(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}s(uj,"addDirectoryMapping");function vc(t,e,r,n="project"){let o=new Map;for(let a of e.rules){let c=Db(t,a,n);c&&o.set(`.agentsmesh/rules/${basename(a.source)}`,c);}for(let a of e.commands){let c=Nb(t,a.name,r,n);c&&o.set(`.agentsmesh/commands/${a.name}.md`,c);}for(let a of e.agents){let c=Fb(t,a.name,r,n);c&&o.set(`.agentsmesh/agents/${a.name}.md`,c);}let i=Lc(t,n);if(!i)return o;for(let a of e.skills){uj(o,`.agentsmesh/skills/${a.name}`,`${i}/${a.name}`),o.set(`.agentsmesh/skills/${a.name}/SKILL.md`,`${i}/${a.name}/SKILL.md`);for(let c of a.supportingFiles){let l=c.relativePath.replace(/\\/g,"/"),m=`.agentsmesh/skills/${a.name}/${l}`,p=`${i}/${a.name}/${l}`;o.set(m,p),Tb(o,m,p);}}return o}s(vc,"buildReferenceMap");ze();var zn="AGENTS.md";function dj(t){return t.target===Ra&&t.path.endsWith(zn)}s(dj,"isCodexAgents");function vb(t){return t.target==="windsurf"&&t.path.endsWith(zn)}s(vb,"isWindsurfAgents");function Mb(t){return t.target==="cline"&&t.path.endsWith(zn)}s(Mb,"isClineAgents");function Hg(t){return t.target==="cursor"&&t.path.endsWith(zn)}s(Hg,"isCursorAgents");function zg(t){return t.target==="gemini-cli"&&t.path.endsWith(zn)}s(zg,"isGeminiAgents");function fj(t){return t.target==="kiro"&&t.path.endsWith(zn)}s(fj,"isKiroAgents");function gj(t){return t.target==="kilo-code"&&t.path.endsWith(zn)}s(gj,"isKiloCodeAgents");function $b(t){return t.target==="warp"&&t.path.endsWith(zn)}s($b,"isWarpAgents");function hj(t){return Hg(t)||zg(t)}s(hj,"isCompatibilityAgents");function Ip(t,e,r,n){let o=n.get(t);if(o)return o;let i=new Map;for(let[a,c]of vc(t,e,r))i.has(c)||i.set(c,a);return n.set(t,i),i}s(Ip,"reverseReferenceMap");function Cp(t,e){let r=[...e.entries()].sort(([o],[i])=>i.length-o.length),n=t;for(let[o,i]of r)n=n.split(o).join(i);return n}s(Cp,"normalizeContent");function yj(t,e,r,n,o){let i=Ip(t.target,r,n,o),a=Ip(e.target,r,n,o);return Cp(t.content,i)===Cp(e.content,a)}s(yj,"hasEquivalentCanonicalContent");function _j(t,e,r,n,o){let i=Ip(t.target,r,n,o),a=Ip(e.target,r,n,o),c=Cp(t.content,i).trim(),l=Cp(e.content,a).trim();return c.length>l.length&&c.includes(l)}s(_j,"hasCanonicalSupersetContent");function Gb(t,e,r){let n=new Map;for(let a of t){if(!a.path.endsWith(zn))continue;let c=n.get(a.path)??new Set;c.add(a.target),n.set(a.path,c);}let o=new Map;for(let a of t)dj(a)&&o.set(a.path,a);let i=new Map;return t.filter(a=>{if(Hg(a)){let l=n.get(a.path);if(l&&[...l].some(m=>m!=="cursor"))return false}if(zg(a)){let l=n.get(a.path);if(l&&[...l].some(m=>m!=="cursor"&&m!=="gemini-cli"))return false}if(!vb(a)&&!Mb(a)&&!Hg(a)&&!zg(a)&&!fj(a)&&!gj(a)&&!$b(a))return true;let c=o.get(a.path);return c?hj(a)||vb(a)||Mb(a)||$b(a)?false:!(yj(c,a,e,r,i)||_j(c,a,e,r,i)):true})}s(Gb,"preferEquivalentCodexAgents");Wt();Tg();Wt();Wt();ut();function Ub(t,e,r,n){let o=n.normalize(e),i=n.normalize(r);t.set(o,i),t.set(`${o}/`,`${i}/`);}s(Ub,"addPackAbsoluteDirMapping");function Ij(t){let e=new Set;for(let{relativePath:r}of t){let n=r.replace(/\\/g,"/"),o=posix.dirname(n);for(;o!=="."&&o.length>0;){e.add(o);let i=posix.dirname(o);if(i===o)break;o=i;}}return [...e]}s(Ij,"skillSupportingDirPrefixes");function Kb(t,e,r,n,o){let i=Lc(e,o);if(!i)return;let a=Y(n),c=a.join(n,".agentsmesh","packs");for(let l of r.skills){let m=a.dirname(l.source);if(!m.startsWith(c))continue;let p=a.normalize(a.join(n,i,l.name));Ub(t,m,p,a),t.set(a.normalize(l.source),a.normalize(a.join(p,"SKILL.md")));for(let u of l.supportingFiles){let f=a.normalize(a.join(p,u.relativePath));t.set(a.normalize(u.absolutePath),f);}for(let u of Ij(l.supportingFiles))Ub(t,a.join(m,u),a.join(p,u),a);}}s(Kb,"addPackSkillArtifactMappings");Wt();function Cj(t){return `.agentsmesh/rules/${basename(t.source)}`}s(Cj,"canonicalRulePath");function Sj(t){return `.github/instructions/${basename(t.source,".md")}.instructions.md`}s(Sj,"copilotInstructionsPath");function Bb(t,e,r,n,o){if(t!=="copilot"||!n?.startsWith(".github/instructions/"))return;let i=Y(r);for(let a of o.rules)a.root||a.globs.length===0||e.set(i.normalize(i.join(r,Cj(a))),i.normalize(i.join(r,Sj(a))));}s(Bb,"applyCopilotInstructionArtifactRefs");ut();function Sp(t){return t?(t.outputFamilies??[]).filter(e=>e.kind==="additional").flatMap(e=>[...e.explicitPaths??[]]):[]}s(Sp,"getAdditionalRootDecorationPaths");function Hb(t,e){for(let r of t?.outputFamilies??[])if(r.pathPrefix!==void 0&&e.startsWith(r.pathPrefix)||r.explicitPaths?.includes(e))return r.id;return "default"}s(Hb,"resolveRewriteFamilyId");function Vg(t,e){e!==void 0&&e.length>0&&!t.includes(e)&&t.push(e);}s(Vg,"pushUnique");function zb(t,e,r,n){let o=[],i=r.get(`.agentsmesh/rules/${basename(e.source)}`);Vg(o,i);let a=Tt(t,n);if(e.root)for(let c of Sp(a))Vg(o,c);for(let c of a?.extraRuleOutputPaths?.(e,{refs:r,scope:n})??[])Vg(o,c);return o}s(zb,"extraRuleOutputPaths");ut();function Vb(t,e,r,n,o,i){let a=Tt(t,e);if(!a?.mirrorGlobalPath)return;let c=a.mirrorGlobalPath(r,i??[]),l=c===null?[]:Array.isArray(c)?c:[c];for(let m of l)m!==r&&o.set(m,n);}s(Vb,"addSkillMirrorSourceEntry");function kj(t){return `.agentsmesh/commands/${t.name}.md`}s(kj,"canonicalCommandPath");function Oj(t){return `.agentsmesh/agents/${t.name}.md`}s(Oj,"canonicalAgentPath");function wj(t){return `.agentsmesh/skills/${t.name}/SKILL.md`}s(wj,"canonicalSkillPath");function Jb(t,e,r,n,o,i){let a=i?.scope??"project",c=Y(n),l=new Map([...vc(t,e,r,a)].map(([m,p])=>[c.normalize(c.join(n,m)),c.normalize(c.join(n,p))]));return Bb(t,l,n,o,e),Kb(l,t,e,n,a),l}s(Jb,"buildArtifactPathMap");function Yb(t,e,r,n="project",o){let i=vc(t,e,r,n),a=new Map;for(let c of e.rules)for(let l of zb(t,c,i,n))a.set(l,c.source);for(let c of e.commands){let l=i.get(kj(c));l&&a.set(l,c.source);}for(let c of e.agents){let l=i.get(Oj(c));l&&a.set(l,c.source);}for(let c of e.skills){let l=i.get(wj(c));l&&(a.set(l,c.source),Vb(t,n,l,c.source,a,o));for(let m of c.supportingFiles){let p=`.agentsmesh/skills/${c.name}/${m.relativePath.replace(/\\/g,"/")}`,u=i.get(p);u&&(a.set(u,m.absolutePath),Vb(t,n,u,m.absolutePath,a,o));}}return a}s(Yb,"buildOutputSourceMap");ut();ye();Iu();function bj(t,e){if(!e)return null;for(let r of e){let n=tt(r);if(n?.sharedArtifacts){for(let[o,i]of Object.entries(n.sharedArtifacts))if(i==="owner"&&t.startsWith(o))return r}}return null}s(bj,"findSharedArtifactOwner");function Xb(t,e,r){if(e==="global"){let n=bj(t.path,r);if(n)return n;let o=S_(t.path);if(o)return o}return t.target}s(Xb,"artifactMapTargetForResult");function Aj(t,e){return `${t}\0${(e??[]).join(",")}`}s(Aj,"sourceMapCacheKey");function Jg(t,e){let r=Y(t),n=new Set;for(let o of e){let i=r.join(t,o.path);n.add(i);let a=r.dirname(i);for(;a.startsWith(t)&&!n.has(a)&&(n.add(a),a!==t);)a=r.dirname(a);}return n}s(Jg,"collectPlannedPaths");function xj(t,e,r){let n=Tt(t.target,e),o=Hb(n,t.path);if(o!=="default")return `${t.target}:${o}`;let i=Xb(t,e,r);return i===t.target?t.target:`${t.target}~via~${i}`}s(xj,"artifactCacheKey");function Zb(t,e,r,n,o="project",i){let a=Jg(n,t),c=new Map,l=new Map;return t.map(m=>{let p=Aj(m.target,i),f=(l.get(p)??(()=>{let _=Yb(m.target,e,r,o,i);return l.set(p,_),_})()).get(m.path);if(!f)return m;let g=Xb(m,o,i),h=xj(m,o,i),R=c.get(h)??(()=>{let _=Jb(g,e,r,n,m.path,{scope:o});return c.set(h,_),_})(),C=np({content:m.content,projectRoot:n,sourceFile:f,destinationFile:Y(n).join(n,m.path),translatePath:s(_=>R.get(_)??_,"translatePath"),pathExists:s(_=>a.has(_)||existsSync(_),"pathExists"),explicitCurrentDirLinks:true,rewriteBarePathTokens:true,scope:o,pathIsDirectory:s(_=>{try{return statSync(_).isDirectory()}catch{return false}},"pathIsDirectory")});return C.content===m.content?m:{...m,content:C.content}})}s(Zb,"rewriteGeneratedReferences");Wt();Fo();var Tj=/!?\[[^\]]*\]\(([^)]+)\)/g,Dj=/^\s*\[[^\]\n]+\]:\s*(?:<([^>\n]*)>|(\S+))/gm;function Nj(t){return t.endsWith(".md")||t.endsWith(".mdc")}s(Nj,"isMarkdownLikeOutput");function Fj(t,e){return e.some(([r,n])=>t>=r&&t<n)}s(Fj,"isOffsetInRanges");function vj(t){let e=t.trim(),r=/^(.*?)\s+(["'])([\s\S]*?)\2\s*$/.exec(e);return r?.[1]!==void 0&&(e=r[1].trim()),e.startsWith("<")&&e.endsWith(">")&&(e=e.slice(1,-1).trim()),e}s(vj,"parseMarkdownLinkDestination");function Mj(t){let e=t.trim();return !e||e.startsWith("#")||/^https?:\/\//i.test(e)||/^mailto:/i.test(e)||/^data:/i.test(e)||/^javascript:/i.test(e)||/^ftp:/i.test(e)?true:/^[a-zA-Z]:[\\/]/.test(e)?false:!!/^[a-zA-Z][a-zA-Z0-9+.-]*:/.test(e)}s(Mj,"shouldSkipLocalValidation");function $j(t,e){if(e.has(t))return true;try{let r=statSync(t);return r.isFile()||r.isDirectory()}catch{return false}}s($j,"pathExistsForGenerate");function Gj(t,e,r){let o=vj(t).split("#")[0]??"",{candidate:i}=ni(o),a=i,c=ea.exec(a);c&&(a=a.slice(0,c.index));let l;try{l=decodeURIComponent(a);}catch{l=a;}if(Mj(l))return [];let m=bc(l,e,r);if(m.length===0){let u=Y(e),f=K(e,r);m=[K(e,u.join(u.dirname(f),l)),K(e,u.join(e,l))];}let p=[];for(let u of m)for(let f of Ac(e,u)){let g=K(e,f);p.includes(g)||p.push(g);}return p}s(Gj,"resolveMarkdownLinkTargets");function jj(t,e){let r=Jg(e,t),n=[];for(let o of t){if(!Nj(o.path))continue;let i=K(e,Y(e).join(e,o.path)),a=rp(o.content),c=s((l,m)=>{if(Fj(m,a))return;let p=Gj(l,e,i);p.length!==0&&(p.some(u=>$j(u,r))||n.push({generatePath:o.path,target:o.target,rawLink:l.trim(),checkedPaths:p}));},"visitDestination");for(let l of o.content.matchAll(Tj)){let m=l[1];m!==void 0&&c(m,l.index??0);}for(let l of o.content.matchAll(Dj)){let m=(l[1]??l[2]??"").trim();m&&c(m,l.index??0);}}return n}s(jj,"findBrokenMarkdownLinks");function qb(t,e){let r=jj(t,e);if(r.length===0)return;let n=r.map(o=>` ${o.generatePath} (${o.target}): "${o.rawLink}" \u2192 not found (tried: ${o.checkedPaths.join(", ")})`);throw new Error(`Generated markdown contains broken local links:
|
|
162
|
+
`+stringify(n);await C(r,o);}s(Op,"writeLock");async function Zn(t){if(!await F(t))return {};let e=await D(t),r={};for(let n of e){let o=relative(t,n).replace(/\\/g,"/");if(o===oh||!Yj(o))continue;let i=await Cp(n);i!==null&&(r[o]=i.startsWith("sha256:")?i:`sha256:${i}`);}return r}s(Zn,"buildChecksums");function Ep(t,e,r){if(r.length===0)return [];let n=r.map(a=>Xj[a]).filter(a=>a!==void 0);if(n.length===0)return [];let o=new Set([...Object.keys(t),...Object.keys(e)]),i=[];for(let a of o)n.some(c=>c(a))&&t[a]!==e[a]&&i.push(a);return i}s(Ep,"detectLockedFeatureViolations");async function kp(t){let e=await Ip(t),r={};for(let{meta:n}of e)r[n.name]=n.content_hash;return r}s(kp,"buildPackChecksums");async function pa(t){let e={};for(let r of t){if(r.version!==void 0){e[r.name]=r.version;continue}let n=join(r.resolvedPath,".agentsmesh"),o=await Zn(n),i=Object.keys(o).sort().map(l=>`${l}:${o[l]}`).join(`
|
|
163
|
+
`),a=jc(i),c=a.startsWith("sha256:")?a:`sha256:${a}`;e[r.name]=`local:${c}`;}return e}s(pa,"buildExtendChecksums");gt();Ce();function Zj(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}s(Zj,"addDirectoryMapping");function iA(t,e,r){let n=posix.dirname(e),o=posix.dirname(r);for(;n!==".agentsmesh/skills"&&n!==".";)Zj(t,n,o),n=posix.dirname(n),o=posix.dirname(o);}s(iA,"addSkillDirectoryMappings");gt();function aA(t,e,r="project"){let n=vt(t,r);if(!n)return null;if(e.root)return n.rootInstructionPath??null;if(e.targets.length>0&&!e.targets.includes(t))return null;let o=posix.basename(e.source.replace(/\\/g,"/"),".md");return n.paths.rulePath(o,e)}s(aA,"ruleTargetPath");function cA(t,e,r,n="project"){let o=vt(t,n);return o?o.paths.commandPath(e,r):null}s(cA,"commandTargetPath");function lA(t,e,r,n="project"){let o=vt(t,n);return o?o.paths.agentPath(e,r):null}s(lA,"agentTargetPath");Zt();Ft();oe();gt();function tU(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}s(tU,"addDirectoryMapping");function Uc(t,e,r,n="project"){let o=new Map;for(let a of e.rules){let c=aA(t,a,n);c&&o.set(`.agentsmesh/rules/${basename(a.source)}`,c);}for(let a of e.commands){let c=cA(t,a.name,r,n);c&&o.set(`.agentsmesh/commands/${a.name}.md`,c);}for(let a of e.agents){let c=lA(t,a.name,r,n);c&&o.set(`.agentsmesh/agents/${a.name}.md`,c);}let i=Tc(t,n);if(!i)return o;for(let a of e.skills){tU(o,`.agentsmesh/skills/${a.name}`,`${i}/${a.name}`),o.set(`.agentsmesh/skills/${a.name}/SKILL.md`,`${i}/${a.name}/SKILL.md`);for(let c of a.supportingFiles){let l=c.relativePath.replace(/\\/g,"/"),m=`.agentsmesh/skills/${a.name}/${l}`,p=`${i}/${a.name}/${l}`;o.set(m,p),iA(o,m,p);}}return o}s(Uc,"buildReferenceMap");Xe();var qn="AGENTS.md";function eU(t){return t.target===wa&&t.path.endsWith(qn)}s(eU,"isCodexAgents");function mA(t){return t.target==="windsurf"&&t.path.endsWith(qn)}s(mA,"isWindsurfAgents");function pA(t){return t.target==="cline"&&t.path.endsWith(qn)}s(pA,"isClineAgents");function sh(t){return t.target==="cursor"&&t.path.endsWith(qn)}s(sh,"isCursorAgents");function ih(t){return t.target==="gemini-cli"&&t.path.endsWith(qn)}s(ih,"isGeminiAgents");function rU(t){return t.target==="kiro"&&t.path.endsWith(qn)}s(rU,"isKiroAgents");function nU(t){return t.target==="kilo-code"&&t.path.endsWith(qn)}s(nU,"isKiloCodeAgents");function uA(t){return t.target==="warp"&&t.path.endsWith(qn)}s(uA,"isWarpAgents");function oU(t){return sh(t)||ih(t)}s(oU,"isCompatibilityAgents");function Lp(t,e,r,n){let o=n.get(t);if(o)return o;let i=new Map;for(let[a,c]of Uc(t,e,r))i.has(c)||i.set(c,a);return n.set(t,i),i}s(Lp,"reverseReferenceMap");function bp(t,e){let r=[...e.entries()].sort(([o],[i])=>i.length-o.length),n=t;for(let[o,i]of r)n=n.split(o).join(i);return n}s(bp,"normalizeContent");function sU(t,e,r,n,o){let i=Lp(t.target,r,n,o),a=Lp(e.target,r,n,o);return bp(t.content,i)===bp(e.content,a)}s(sU,"hasEquivalentCanonicalContent");function iU(t,e,r,n,o){let i=Lp(t.target,r,n,o),a=Lp(e.target,r,n,o),c=bp(t.content,i).trim(),l=bp(e.content,a).trim();return c.length>l.length&&c.includes(l)}s(iU,"hasCanonicalSupersetContent");function dA(t,e,r){let n=new Map;for(let a of t){if(!a.path.endsWith(qn))continue;let c=n.get(a.path)??new Set;c.add(a.target),n.set(a.path,c);}let o=new Map;for(let a of t)eU(a)&&o.set(a.path,a);let i=new Map;return t.filter(a=>{if(sh(a)){let l=n.get(a.path);if(l&&[...l].some(m=>m!=="cursor"))return false}if(ih(a)){let l=n.get(a.path);if(l&&[...l].some(m=>m!=="cursor"&&m!=="gemini-cli"))return false}if(!mA(a)&&!pA(a)&&!sh(a)&&!ih(a)&&!rU(a)&&!nU(a)&&!uA(a))return true;let c=o.get(a.path);return c?oU(a)||mA(a)||pA(a)||uA(a)?false:!(sU(c,a,e,r,i)||iU(c,a,e,r,i)):true})}s(dA,"preferEquivalentCodexAgents");Vt();zg();Vt();Vt();gt();function gA(t,e,r,n){let o=n.normalize(e),i=n.normalize(r);t.set(o,i),t.set(`${o}/`,`${i}/`);}s(gA,"addPackAbsoluteDirMapping");function aU(t){let e=new Set;for(let{relativePath:r}of t){let n=r.replace(/\\/g,"/"),o=posix.dirname(n);for(;o!=="."&&o.length>0;){e.add(o);let i=posix.dirname(o);if(i===o)break;o=i;}}return [...e]}s(aU,"skillSupportingDirPrefixes");function hA(t,e,r,n,o){let i=Tc(e,o);if(!i)return;let a=J(n),c=a.join(n,".agentsmesh","packs");for(let l of r.skills){let m=a.dirname(l.source);if(!m.startsWith(c))continue;let p=a.normalize(a.join(n,i,l.name));gA(t,m,p,a),t.set(a.normalize(l.source),a.normalize(a.join(p,"SKILL.md")));for(let u of l.supportingFiles){let f=a.normalize(a.join(p,u.relativePath));t.set(a.normalize(u.absolutePath),f);}for(let u of aU(l.supportingFiles))gA(t,a.join(m,u),a.join(p,u),a);}}s(hA,"addPackSkillArtifactMappings");Vt();function cU(t){return `.agentsmesh/rules/${basename(t.source)}`}s(cU,"canonicalRulePath");function lU(t){return `.github/instructions/${basename(t.source,".md")}.instructions.md`}s(lU,"copilotInstructionsPath");function _A(t,e,r,n,o){if(t!=="copilot"||!n?.startsWith(".github/instructions/"))return;let i=J(r);for(let a of o.rules)a.root||a.globs.length===0||e.set(i.normalize(i.join(r,cU(a))),i.normalize(i.join(r,lU(a))));}s(_A,"applyCopilotInstructionArtifactRefs");gt();function Ap(t){return t?(t.outputFamilies??[]).filter(e=>e.kind==="additional").flatMap(e=>[...e.explicitPaths??[]]):[]}s(Ap,"getAdditionalRootDecorationPaths");function IA(t,e){for(let r of t?.outputFamilies??[])if(r.pathPrefix!==void 0&&e.startsWith(r.pathPrefix)||r.explicitPaths?.includes(e))return r.id;return "default"}s(IA,"resolveRewriteFamilyId");function ah(t,e){e!==void 0&&e.length>0&&!t.includes(e)&&t.push(e);}s(ah,"pushUnique");function SA(t,e,r,n){let o=[],i=r.get(`.agentsmesh/rules/${basename(e.source)}`);ah(o,i);let a=vt(t,n);if(e.root)for(let c of Ap(a))ah(o,c);for(let c of a?.extraRuleOutputPaths?.(e,{refs:r,scope:n})??[])ah(o,c);return o}s(SA,"extraRuleOutputPaths");gt();function CA(t,e,r,n,o,i){let a=vt(t,e);if(!a?.mirrorGlobalPath)return;let c=a.mirrorGlobalPath(r,i??[]),l=c===null?[]:Array.isArray(c)?c:[c];for(let m of l)m!==r&&o.set(m,n);}s(CA,"addSkillMirrorSourceEntry");function pU(t){return `.agentsmesh/commands/${t.name}.md`}s(pU,"canonicalCommandPath");function uU(t){return `.agentsmesh/agents/${t.name}.md`}s(uU,"canonicalAgentPath");function dU(t){return `.agentsmesh/skills/${t.name}/SKILL.md`}s(dU,"canonicalSkillPath");function RA(t,e,r,n,o,i){let a=i?.scope??"project",c=J(n),l=new Map([...Uc(t,e,r,a)].map(([m,p])=>[c.normalize(c.join(n,m)),c.normalize(c.join(n,p))]));return _A(t,l,n,o,e),hA(l,t,e,n,a),l}s(RA,"buildArtifactPathMap");function OA(t,e,r,n="project",o){let i=Uc(t,e,r,n),a=new Map;for(let c of e.rules)for(let l of SA(t,c,i,n))a.set(l,c.source);for(let c of e.commands){let l=i.get(pU(c));l&&a.set(l,c.source);}for(let c of e.agents){let l=i.get(uU(c));l&&a.set(l,c.source);}for(let c of e.skills){let l=i.get(dU(c));l&&(a.set(l,c.source),CA(t,n,l,c.source,a,o));for(let m of c.supportingFiles){let p=`.agentsmesh/skills/${c.name}/${m.relativePath.replace(/\\/g,"/")}`,u=i.get(p);u&&(a.set(u,m.absolutePath),CA(t,n,u,m.absolutePath,a,o));}}return a}s(OA,"buildOutputSourceMap");gt();Ce();Tu();function hU(t,e){if(!e)return null;for(let r of e){let n=et(r);if(n?.sharedArtifacts){for(let[o,i]of Object.entries(n.sharedArtifacts))if(i==="owner"&&t.startsWith(o))return r}}return null}s(hU,"findSharedArtifactOwner");function EA(t,e,r){if(e==="global"){let n=hU(t.path,r);if(n)return n;let o=J_(t.path);if(o)return o}return t.target}s(EA,"artifactMapTargetForResult");function yU(t,e){return `${t}\0${(e??[]).join(",")}`}s(yU,"sourceMapCacheKey");function ch(t,e){let r=J(t),n=new Set;for(let o of e){let i=r.join(t,o.path);n.add(i);let a=r.dirname(i);for(;a.startsWith(t)&&!n.has(a)&&(n.add(a),a!==t);)a=r.dirname(a);}return n}s(ch,"collectPlannedPaths");function _U(t,e,r){let n=vt(t.target,e),o=IA(n,t.path);if(o!=="default")return `${t.target}:${o}`;let i=EA(t,e,r);return i===t.target?t.target:`${t.target}~via~${i}`}s(_U,"artifactCacheKey");function kA(t,e,r,n,o="project",i){let a=ch(n,t),c=new Map,l=new Map;return t.map(m=>{let p=yU(m.target,i),f=(l.get(p)??(()=>{let _=OA(m.target,e,r,o,i);return l.set(p,_),_})()).get(m.path);if(!f)return m;let g=EA(m,o,i),h=_U(m,o,i),R=c.get(h)??(()=>{let _=RA(g,e,r,n,m.path,{scope:o});return c.set(h,_),_})(),S=pp({content:m.content,projectRoot:n,sourceFile:f,destinationFile:J(n).join(n,m.path),translatePath:s(_=>R.get(_)??_,"translatePath"),pathExists:s(_=>a.has(_)||existsSync(_),"pathExists"),explicitCurrentDirLinks:true,rewriteBarePathTokens:true,scope:o,pathIsDirectory:s(_=>{try{return statSync(_).isDirectory()}catch{return false}},"pathIsDirectory")});return S.content===m.content?m:{...m,content:S.content}})}s(kA,"rewriteGeneratedReferences");Vt();jo();var SU=/!?\[[^\]]*\]\(([^)]+)\)/g,CU=/^\s*\[[^\]\n]+\]:\s*(?:<([^>\n]*)>|(\S+))/gm;function RU(t){return t.endsWith(".md")||t.endsWith(".mdc")}s(RU,"isMarkdownLikeOutput");function OU(t,e){return e.some(([r,n])=>t>=r&&t<n)}s(OU,"isOffsetInRanges");function EU(t){let e=t.trim(),r=/^(.*?)\s+(["'])([\s\S]*?)\2\s*$/.exec(e);return r?.[1]!==void 0&&(e=r[1].trim()),e.startsWith("<")&&e.endsWith(">")&&(e=e.slice(1,-1).trim()),e}s(EU,"parseMarkdownLinkDestination");function kU(t){let e=t.trim();return !e||e.startsWith("#")||/^https?:\/\//i.test(e)||/^mailto:/i.test(e)||/^data:/i.test(e)||/^javascript:/i.test(e)||/^ftp:/i.test(e)?true:/^[a-zA-Z]:[\\/]/.test(e)?false:!!/^[a-zA-Z][a-zA-Z0-9+.-]*:/.test(e)}s(kU,"shouldSkipLocalValidation");function wU(t,e){if(e.has(t))return true;try{let r=statSync(t);return r.isFile()||r.isDirectory()}catch{return false}}s(wU,"pathExistsForGenerate");function LU(t,e,r){let o=EU(t).split("#")[0]??"",{candidate:i}=mi(o),a=i,c=ca.exec(a);c&&(a=a.slice(0,c.index));let l;try{l=decodeURIComponent(a);}catch{l=a;}if(kU(l))return [];let m=Dc(l,e,r);if(m.length===0){let u=J(e),f=U(e,r);m=[U(e,u.join(u.dirname(f),l)),U(e,u.join(e,l))];}let p=[];for(let u of m)for(let f of Nc(e,u)){let g=U(e,f);p.includes(g)||p.push(g);}return p}s(LU,"resolveMarkdownLinkTargets");function bU(t,e){let r=ch(e,t),n=[];for(let o of t){if(!RU(o.path))continue;let i=U(e,J(e).join(e,o.path)),a=mp(o.content),c=s((l,m)=>{if(OU(m,a))return;let p=LU(l,e,i);p.length!==0&&(p.some(u=>wU(u,r))||n.push({generatePath:o.path,target:o.target,rawLink:l.trim(),checkedPaths:p}));},"visitDestination");for(let l of o.content.matchAll(SU)){let m=l[1];m!==void 0&&c(m,l.index??0);}for(let l of o.content.matchAll(CU)){let m=(l[1]??l[2]??"").trim();m&&c(m,l.index??0);}}return n}s(bU,"findBrokenMarkdownLinks");function wA(t,e){let r=bU(t,e);if(r.length===0)return;let n=r.map(o=>` ${o.generatePath} (${o.target}): "${o.rawLink}" \u2192 not found (tried: ${o.checkedPaths.join(", ")})`);throw new Error(`Generated markdown contains broken local links:
|
|
162
164
|
${n.join(`
|
|
163
165
|
`)}
|
|
164
|
-
Fix canonical sources or generators so every local link targets an existing file or folder.`)}s(qb,"validateGeneratedMarkdownLinks");ze();var tA="AGENTS.md";function Qb(t){switch(t){case "created":return 3;case "updated":return 2;case "unchanged":return 1;case "skipped":return 0}}s(Qb,"statusRank");function Uj(t,e){return Qb(e.status)<=Qb(t.status)?t:{...t,status:e.status,currentContent:e.currentContent??t.currentContent}}s(Uj,"mergeDuplicateMetadata");function Rp(t){return t.trim()}s(Rp,"trimmedContent");function Kj(t,e){if(!t.path.endsWith(tA)||t.path!==e.path)return null;let r=Rp(t.content),n=Rp(e.content);if(!r||!n)return null;let o=r.includes(n),i=n.includes(r);return o===i?null:o?t:e}s(Kj,"richerAgentsResult");function Wj(t,e){if(!t.path.endsWith(tA)||t.path!==e.path)return null;let r=t.target===Ra?t:e.target===Ra?e:null,n=r===t?e:t;if(!r)return null;let o=Rp(r.content).length,i=Rp(n.content).length;return o===i?null:o>i?r:n}s(Wj,"richerCodexAgentsResult");function kp(t){let e=[];for(let r of t){let n=e.findIndex(i=>i.path===r.path);if(n===-1){e.push(r);continue}let o=e[n];if(o.content!==r.content){let i=Kj(o,r);if(i){e[n]=i;continue}let a=Wj(o,r);if(a){e[n]=a;continue}throw new Error(`Conflicting generated outputs for ${r.path}: ${o.target} and ${r.target} produce different content.`)}e[n]=Uj(o,r);}return e}s(kp,"resolveOutputCollisions");function eA(t){let e=t.currentContent===void 0?"created":t.currentContent!==t.content?"updated":"unchanged";return t.status===e?t:{...t,status:e}}s(eA,"refreshResultStatus");A();ut();ye();function nA(t,e){return t===null?"created":t!==e?"updated":"unchanged"}s(nA,"computeStatus");function Bj(t,e,r){let n=Rg(t,e,r);if(n!==null)return n;let o=tt(t);if(!o)return null;let i=r==="global"?o.globalSupport?.layout:o.project;return i?(n=i.rewriteGeneratedPath?i.rewriteGeneratedPath(e):e,n):null}s(Bj,"resolveGeneratedOutputPath");async function Mc(t,e,r,n,o,i){let a=Bj(e,r.path,o);if(a===null)return null;let c=await y(join(n,a)),l=t.findIndex(u=>u.path===a&&u.target===e),m=l>=0?t[l]:void 0,p=i?.mergeContent?.(c,m,r.content,a)??r.content;return l>=0&&t.splice(l,1),t.push({target:e,path:a,content:p,currentContent:c??void 0,status:nA(c,p)}),a}s(Mc,"emitGeneratedOutput");function Yg(t,e,r){return {capability:Po(t,r)?.[e]??{level:"none"},scope:r}}s(Yg,"featureContext");async function Gs(t,e,r,n,o,i,a,c){if(o)for(let l of e){let m=c(l);if(!m)continue;let p=Yg(l,a,i);for(let u of m(r,p)){let f=await Mc(t,l,u,n,i);if(f===null)continue;let g=Tt(l,i);if(g?.mirrorGlobalPath){let h=g.mirrorGlobalPath(f,e),R=h===null?[]:Array.isArray(h)?h:[h];for(let C of R){let _=await y(join(n,C));t.push({target:l,path:C,content:u.content,currentContent:_??void 0,status:nA(_,u.content)});}}}}}s(Gs,"generateFeature");Ou();ut();function Hj(t){return t?.rootInstructionPath?[t.rootInstructionPath,...Sp(t)]:[]}s(Hj,"rootDecorationPaths");function oA(t,e,r="project"){return t.map(n=>{let o=Tt(n.target,r);if(!o)return n;let i=Hj(o);if(i.length===0||!i.includes(n.path))return n;let c=n.path===o.rootInstructionPath&&o.renderPrimaryRootInstruction?o.renderPrimaryRootInstruction(e):n.content,l=x_(c);return l===n.content?n:{...n,content:l}})}s(oA,"decoratePrimaryRootInstructions");ut();ye();vf();function Xg(t,e,r,n,o){let a=($e(t)??tt(t))?.mergeGeneratedOutputContent?.(e,r,n,o);if(a!=null)return a;let c=r?.content??e;return c!==null&&BO.includes(o)?zO(c,n):n}s(Xg,"mergeOutputContent");async function sA(t,e,r,n,o){for(let i of e){let a=ta(i,"permissions",void 0,o)??tt(i)?.generators.generatePermissions;if(a)for(let c of a(r))await Mc(t,i,c,n,o,{mergeContent:s((l,m,p,u)=>Xg(i,l,m,p,u),"mergeContent")});}}s(sA,"generatePermissionsFeature");async function iA(t,e,r,n,o,i){for(let a of e){let c=ta(a,"hooks",i,o)??tt(a)?.generators.generateHooks;if(!c)continue;let l=Yg(a,"hooks",o),m=[...c(r,l)],u=($e(a)??tt(a))?.postProcessHookOutputs;u&&(m=[...await u(n,r,m)]);for(let f of m)await Mc(t,a,f,n,o,{mergeContent:s((g,h,R,C)=>Xg(a,g,h,R,C),"mergeContent")});}}s(iA,"generateHooksFeature");async function aA(t,e,r,n,o){for(let i of e){let c=($e(i)??tt(i))?.emitScopedSettings;if(!c)continue;let l=c(r,o);if(l.length!==0)for(let m of l)await Mc(t,i,m,n,o,{mergeContent:s((p,u,f,g)=>Xg(i,p,u,f,g),"mergeContent")});}}s(aA,"generateScopedSettingsFeature");async function je(t){let{config:e,canonical:r,projectRoot:n,scope:o="project",targetFilter:i}=t,a=[...e.targets,...e.pluginTargets??[]],c=i?a.filter(x=>i.includes(x)):a;function l(x,Z){return ta(x,Z,e,o)}s(l,"resolveGen");let m=e.features.includes("rules"),p=e.features.includes("commands"),u=e.features.includes("agents"),f=e.features.includes("skills"),g=e.features.includes("mcp"),h=e.features.includes("permissions"),R=e.features.includes("hooks"),C=e.features.includes("ignore"),_=[];await Gs(_,c,r,n,m,o,"rules",x=>l(x,"rules")),await Gs(_,c,r,n,p,o,"commands",x=>l(x,"commands")),await Gs(_,c,r,n,u,o,"agents",x=>l(x,"agents")),await Gs(_,c,r,n,f,o,"skills",x=>l(x,"skills")),await Gs(_,c,r,n,g,o,"mcp",x=>l(x,"mcp")),h&&await sA(_,c,r,n,o),R&&await iA(_,c,r,n,o,e),await Gs(_,c,r,n,C,o,"ignore",x=>l(x,"ignore"));let E=new Set(e.features);for(let x of c){let B=($e(x)??tt(x))?.globalSupport?.scopeExtras;if(B){let J=await B(r,n,o,E);_.push(...J);}}(g||C||R||u||h)&&await aA(_,c,r,n,o);let T=oA(_,r,o),D=Zb(T,r,e,n,o,c);return qb(D,n),kp(Gb(D.map(eA),r,e))}s(je,"generate");Vn();nt();A();qn();var oU=6e4,sU=30,iU=200,aU=2e3;async function gA(t,e={}){let r=e.retries??sU,n=e.retryDelayMs??iU,o=e.staleMs??oU;await mkdir(dirname(t),{recursive:true});let i=0;for(;;){let a=await cU(t);if(a)return a;let c=await lU(t);if(c!=="young"&&mU(c,o)){await rm$1(t,{recursive:true,force:true}).catch(()=>{});continue}if(i>=r){let l=c==="young"?null:c;throw new Xs(t,uU(l))}i++,await fU(n);}}s(gA,"acquireProcessLock");async function cU(t){try{await mkdir(t,{recursive:!1});}catch(i){if(i.code==="EEXIST")return null;throw i}let e=join(t,"holder.json"),r={pid:process.pid,started:Date.now(),hostname:hA()};await writeFile(e,JSON.stringify(r),"utf-8");let n=false,o=s(()=>{if(!n){n=true;try{rmSync(t,{recursive:!0,force:!0});}catch{}}},"signalHandler");return process.once("SIGINT",o),process.once("SIGTERM",o),process.once("exit",o),async()=>{n||(n=true,process.off("SIGINT",o),process.off("SIGTERM",o),process.off("exit",o),await rm$1(t,{recursive:true,force:true}).catch(()=>{}));}}s(cU,"tryAcquire");async function lU(t){try{let e=await readFile(join(t,"holder.json"),"utf-8"),r=JSON.parse(e);return dU(r)?r:null}catch{try{let e=await stat(t);if(Date.now()-e.mtimeMs<aU)return "young"}catch{}return null}}s(lU,"inspectLock");function mU(t,e){return !t||Date.now()-t.started>e?true:t.hostname&&t.hostname!==hA()?false:!pU(t.pid)}s(mU,"isStale");function pU(t){if(!Number.isInteger(t)||t<=0)return false;try{return process.kill(t,0),!0}catch(e){return e.code==="EPERM"}}s(pU,"isProcessAlive");function uU(t){return t?`${t.hostname?`${t.hostname}:`:""}pid ${t.pid} (running ${Date.now()-t.started}ms)`:"unknown (unreadable lock metadata)"}s(uU,"describeHolder");function dU(t){if(typeof t!="object"||t===null)return false;let e=t;return typeof e.pid=="number"&&typeof e.started=="number"}s(dU,"isLockMetadata");function hA(){return hostname()}s(hA,"getHostname");function fU(t){return new Promise(e=>setTimeout(e,t))}s(fU,"sleep");A();ut();async function yA(t,e=t){let r=await readdir(t,{withFileTypes:true}),n=[];for(let o of r){let i=join(t,o.name);if(o.isDirectory()){n.push(...await yA(i,e));continue}n.push(relative(e,i).replace(/\\/g,"/"));}return n}s(yA,"listFiles");async function _U(t,e,r){if(r.has(e))return;let n=join(t,e);await v(n)&&await rm$1(n,{recursive:true,force:true});}s(_U,"removeIfStale");async function _A(t){let e=new Set(t.expectedPaths),r=new Set,n=t.scope??"project";for(let o of t.targets){let i=Sg(o,n);if(i){for(let a of i.files)r.add(a);for(let a of i.dirs){let c=join(t.projectRoot,a);if(await v(c))for(let l of await yA(c))r.add(`${a}/${l}`.replace(/\/+/g,"/"));}}}for(let o of r)await _U(t.projectRoot,o,e);}s(_A,"cleanupStaleGeneratedOutputs");function sa(t,e,r){let n=resolve(t),o=resolve(t,e);if(o===n||o.startsWith(`${n}${sep}`))return o;throw new Error(`Unsafe generated output path for ${r}: ${e}`)}s(sa,"ensurePathInsideRoot");ba();A();nt();async function th(t,e){let r=await Hn(t.canonicalDir),n=e.length>0?await oa(e):{},o=await yp(join(t.canonicalDir,"packs")),i=process.env.USER??process.env.USERNAME??"unknown";await gp(t.canonicalDir,{generatedAt:new Date().toISOString(),generatedBy:i,libVersion:Sa(),checksums:r,extends:n,packs:o});try{await Py(me(),join(t.configDir,".agentsmeshcache"));}catch(a){I.warn(`Could not create .agentsmeshcache symlink: ${a instanceof Error?a.message:String(a)}`);}}s(th,"writeLockFile");async function AA(t){let{mode:e,scope:r,dryRun:n,context:o,resolvedExtends:i,flags:a,root:c,options:l}=t;if(e==="check")return {exitCode:0,data:{scope:r,mode:e,files:[],summary:wp([])}};if(n||await th(o,i),l.printMatrix!==false){let{runMatrix:m}=await Promise.resolve().then(()=>(jc(),ch)),{renderMatrix:p}=await Promise.resolve().then(()=>(Kc(),lh)),u=await m(a,c);p(u,{verbose:a.verbose===true});}return {exitCode:0,data:{scope:r,mode:e,files:[],summary:wp([])}}}s(AA,"handleEmptyResults");function xA(t,e){let r=t.filter(a=>a.status!=="skipped"),n=r.filter(a=>a.status!=="unchanged"),o=r.map(a=>({path:a.path,target:a.target,status:a.status}));return {exitCode:n.length===0?0:1,data:{scope:e,mode:"check",files:o,summary:wp(r)}}}s(xA,"buildCheckResult");async function PA(t){let{results:e,dryRun:r,scope:n,mode:o,context:i,activeTargets:a,resolvedExtends:c,flags:l,root:m,options:p}=t,u=r?null:await gA(join(i.canonicalDir,".generate.lock"));try{if(!r){for(let h of e)if(h.status==="created"||h.status==="updated"){let R=sa(i.rootBase,h.path,h.target);await S(R,h.content);}await _A({projectRoot:i.rootBase,targets:a,expectedPaths:e.map(h=>h.path),scope:n}),await th(i,c);}}finally{u&&await u();}if(p.printMatrix!==false){let{runMatrix:h}=await Promise.resolve().then(()=>(jc(),ch)),{renderMatrix:R}=await Promise.resolve().then(()=>(Kc(),lh)),C=await h(l,m);R(C,{verbose:l.verbose===true});}let f=e.filter(h=>h.status!=="skipped"),g=f.map(h=>({path:h.path,target:h.target,status:h.status}));return {exitCode:0,data:{scope:n,mode:o,files:g,summary:wp(f)}}}s(PA,"handleGenerateOrDryRun");function wp(t){return {created:t.filter(e=>e.status==="created").length,updated:t.filter(e=>e.status==="updated").length,unchanged:t.filter(e=>e.status==="unchanged").length}}s(wp,"buildSummary");async function ia(t,e,r={}){if(t.features!==void 0)throw new Error("--features is no longer supported. Configure features in agentsmesh.yaml.");let n=e??process.cwd(),o=t.check===true,i=t["dry-run"]===true,a=t.force===true,c=t.global===true?"global":"project",l=t["refresh-cache"]===true||t["no-cache"]===true,m=t.targets,p=typeof m=="string"&&m?m.split(",").map(D=>D.trim()).filter(Boolean):void 0,u=o?"check":i?"dry-run":"generate",{config:f,context:g}=await lt(n,c);await Jt(f,n);let h=f.collaboration?.lock_features??[];if(f.collaboration?.strategy==="lock"&&!a&&h.length>0){let D=await fp(g.canonicalDir);if(D!==null){let x=await Hn(g.canonicalDir),Z=hp(D.checksums,x,h);if(Z.length>0){I.error("Locked feature violation (strategy: lock). Modified files:");for(let B of Z)I.error(` ${B}`);throw I.error("Run 'agentsmesh generate --force' to accept these changes."),new Error("Locked feature violation. Use --force to override.")}}}let{canonical:R,resolvedExtends:C}=await ee(f,g.configDir,{refreshRemoteCache:l},g.canonicalDir),_=[...f.targets,...f.pluginTargets??[]];if(p){let D=p.filter(x=>!_.includes(x));if(D.length>0)throw new Error(`Unknown target(s) in --targets: ${D.join(", ")}. Available: ${_.join(", ")}`)}let E=p?_.filter(D=>p.includes(D)):_,T=await je({config:f,canonical:R,projectRoot:g.rootBase,scope:c,targetFilter:p});return T.length===0?AA({mode:u,scope:c,dryRun:i,context:g,resolvedExtends:C,flags:t,root:n,options:r}):o?xA(T,c):PA({results:T,dryRun:i,scope:c,mode:u,context:g,activeTargets:E,resolvedExtends:C,flags:t,root:n,options:r})}s(ia,"runGenerate");nt();function mh(t,e){return t==="global"?`~/${e}`:e}s(mh,"formatDisplayPath");function aa(t){let{data:e}=t,{scope:r,mode:n,files:o}=e;if(o.length===0){I.info("No files to generate (no root rule or rules feature disabled)."),n==="check"&&I.success("Generated files are in sync.");return}if(n==="check"){let l=o.filter(m=>m.status!=="unchanged");if(l.length===0){I.success("Generated files are in sync.");return}for(let m of l)I.error(`[check] ${m.status} ${mh(r,m.path)} (${m.target})`);I.error("Generated files are out of sync. Run 'agentsmesh generate' to update them.");return}if(n==="dry-run"){for(let l of o)I.info(`[dry-run] ${l.status} ${mh(r,l.path)} (${l.target})`);return}for(let l of o)(l.status==="created"||l.status==="updated")&&I.success(`${l.status} ${mh(r,l.path)}`);let{created:i,updated:a,unchanged:c}=e.summary;i>0||a>0?I.info(`Generated: ${i} created, ${a} updated, ${c} unchanged`):I.info(`Nothing changed. (${c} unchanged)`);}s(aa,"renderGenerate");A();ut();ze();var LU=["codex-cli"];function TA(){return it.filter(t=>!LU.includes(t))}s(TA,"starterInitTargetIds");var bU=["rules","commands","agents","skills","mcp","hooks","ignore","permissions"],AU=TA();function Ep(t,e=AU){let r=(t.length>0?t:e).map(o=>` - ${o}`).join(`
|
|
165
|
-
`),n=
|
|
166
|
+
Fix canonical sources or generators so every local link targets an existing file or folder.`)}s(wA,"validateGeneratedMarkdownLinks");Xe();var bA="AGENTS.md";function LA(t){switch(t){case "created":return 3;case "updated":return 2;case "unchanged":return 1;case "skipped":return 0}}s(LA,"statusRank");function AU(t,e){return LA(e.status)<=LA(t.status)?t:{...t,status:e.status,currentContent:e.currentContent??t.currentContent}}s(AU,"mergeDuplicateMetadata");function xp(t){return t.trim()}s(xp,"trimmedContent");function xU(t,e){if(!t.path.endsWith(bA)||t.path!==e.path)return null;let r=xp(t.content),n=xp(e.content);if(!r||!n)return null;let o=r.includes(n),i=n.includes(r);return o===i?null:o?t:e}s(xU,"richerAgentsResult");function PU(t,e){if(!t.path.endsWith(bA)||t.path!==e.path)return null;let r=t.target===wa?t:e.target===wa?e:null,n=r===t?e:t;if(!r)return null;let o=xp(r.content).length,i=xp(n.content).length;return o===i?null:o>i?r:n}s(PU,"richerCodexAgentsResult");function Pp(t){let e=[];for(let r of t){let n=e.findIndex(i=>i.path===r.path);if(n===-1){e.push(r);continue}let o=e[n];if(o.content!==r.content){let i=xU(o,r);if(i){e[n]=i;continue}let a=PU(o,r);if(a){e[n]=a;continue}throw new Error(`Conflicting generated outputs for ${r.path}: ${o.target} and ${r.target} produce different content.`)}e[n]=AU(o,r);}return e}s(Pp,"resolveOutputCollisions");function AA(t){let e=t.currentContent===void 0?"created":t.currentContent!==t.content?"updated":"unchanged";return t.status===e?t:{...t,status:e}}s(AA,"refreshResultStatus");b();gt();Ce();function PA(t,e){return t===null?"created":t!==e?"updated":"unchanged"}s(PA,"computeStatus");function TU(t,e,r){let n=vg(t,e,r);if(n!==null)return n;let o=et(t);if(!o)return null;let i=r==="global"?o.globalSupport?.layout:o.project;return i?(n=i.rewriteGeneratedPath?i.rewriteGeneratedPath(e):e,n):null}s(TU,"resolveGeneratedOutputPath");async function Wc(t,e,r,n,o,i){let a=TU(e,r.path,o);if(a===null)return null;let c=await y(join(n,a)),l=t.findIndex(u=>u.path===a&&u.target===e),m=l>=0?t[l]:void 0,p=i?.mergeContent?.(c,m,r.content,a)??r.content;return l>=0&&t.splice(l,1),t.push({target:e,path:a,content:p,currentContent:c??void 0,status:PA(c,p)}),a}s(Wc,"emitGeneratedOutput");function lh(t,e,r){return {capability:vo(t,r)?.[e]??{level:"none"},scope:r}}s(lh,"featureContext");async function zs(t,e,r,n,o,i,a,c){if(o)for(let l of e){let m=c(l);if(!m)continue;let p=lh(l,a,i);for(let u of m(r,p)){let f=await Wc(t,l,u,n,i);if(f===null)continue;let g=vt(l,i);if(g?.mirrorGlobalPath){let h=g.mirrorGlobalPath(f,e),R=h===null?[]:Array.isArray(h)?h:[h];for(let S of R){let _=await y(join(n,S));t.push({target:l,path:S,content:u.content,currentContent:_??void 0,status:PA(_,u.content)});}}}}}s(zs,"generateFeature");Mu();gt();function DU(t){return t?.rootInstructionPath?[t.rootInstructionPath,...Ap(t)]:[]}s(DU,"rootDecorationPaths");function TA(t,e,r="project"){return t.map(n=>{let o=vt(n.target,r);if(!o)return n;let i=DU(o);if(i.length===0||!i.includes(n.path))return n;let c=n.path===o.rootInstructionPath&&o.renderPrimaryRootInstruction?o.renderPrimaryRootInstruction(e):n.content,l=nI(c);return l===n.content?n:{...n,content:l}})}s(TA,"decoratePrimaryRootInstructions");gt();Ce();Xf();function mh(t,e,r,n,o){let a=(Ke(t)??et(t))?.mergeGeneratedOutputContent?.(e,r,n,o);if(a!=null)return a;let c=r?.content??e;return c!==null&&_k.includes(o)?Sk(c,n):n}s(mh,"mergeOutputContent");async function DA(t,e,r,n,o){for(let i of e){let a=aa(i,"permissions",void 0,o)??et(i)?.generators.generatePermissions;if(a)for(let c of a(r))await Wc(t,i,c,n,o,{mergeContent:s((l,m,p,u)=>mh(i,l,m,p,u),"mergeContent")});}}s(DA,"generatePermissionsFeature");async function NA(t,e,r,n,o,i){for(let a of e){let c=aa(a,"hooks",i,o)??et(a)?.generators.generateHooks;if(!c)continue;let l=lh(a,"hooks",o),m=[...c(r,l)],u=(Ke(a)??et(a))?.postProcessHookOutputs;u&&(m=[...await u(n,r,m)]);for(let f of m)await Wc(t,a,f,n,o,{mergeContent:s((g,h,R,S)=>mh(a,g,h,R,S),"mergeContent")});}}s(NA,"generateHooksFeature");async function FA(t,e,r,n,o){for(let i of e){let c=(Ke(i)??et(i))?.emitScopedSettings;if(!c)continue;let l=c(r,o);if(l.length!==0)for(let m of l)await Wc(t,i,m,n,o,{mergeContent:s((p,u,f,g)=>mh(i,p,u,f,g),"mergeContent")});}}s(FA,"generateScopedSettingsFeature");async function He(t){let{config:e,canonical:r,projectRoot:n,scope:o="project",targetFilter:i}=t,a=[...e.targets,...e.pluginTargets??[]],c=i?a.filter(A=>i.includes(A)):a;function l(A,Z){return aa(A,Z,e,o)}s(l,"resolveGen");let m=e.features.includes("rules"),p=e.features.includes("commands"),u=e.features.includes("agents"),f=e.features.includes("skills"),g=e.features.includes("mcp"),h=e.features.includes("permissions"),R=e.features.includes("hooks"),S=e.features.includes("ignore"),_=[];await zs(_,c,r,n,m,o,"rules",A=>l(A,"rules")),await zs(_,c,r,n,p,o,"commands",A=>l(A,"commands")),await zs(_,c,r,n,u,o,"agents",A=>l(A,"agents")),await zs(_,c,r,n,f,o,"skills",A=>l(A,"skills")),await zs(_,c,r,n,g,o,"mcp",A=>l(A,"mcp")),h&&await DA(_,c,r,n,o),R&&await NA(_,c,r,n,o,e),await zs(_,c,r,n,S,o,"ignore",A=>l(A,"ignore"));let k=new Set(e.features);for(let A of c){let B=(Ke(A)??et(A))?.globalSupport?.scopeExtras;if(B){let V=await B(r,n,o,k);_.push(...V);}}(g||S||R||u||h)&&await FA(_,c,r,n,o);let T=TA(_,r,o),P=kA(T,r,e,n,o,c);return wA(P,n),Pp(dA(P.map(AA),r,e))}s(He,"generate");Qn();st();b();dn();var zU=6e4,VU=30,JU=200,YU=2e3;async function KA(t,e={}){let r=e.retries??VU,n=e.retryDelayMs??JU,o=e.staleMs??zU;await mkdir(dirname(t),{recursive:true});let i=0;for(;;){let a=await XU(t);if(a)return a;let c=await ZU(t);if(c!=="young"&&qU(c,o)){await rm$1(t,{recursive:true,force:true}).catch(()=>{});continue}if(i>=r){let l=c==="young"?null:c;throw new ni(t,t0(l))}i++,await r0(n);}}s(KA,"acquireProcessLock");async function XU(t){try{await mkdir(t,{recursive:!1});}catch(i){if(i.code==="EEXIST")return null;throw i}let e=join(t,"holder.json"),r={pid:process.pid,started:Date.now(),hostname:BA()};await writeFile(e,JSON.stringify(r),"utf-8");let n=false,o=s(()=>{if(!n){n=true;try{rmSync(t,{recursive:!0,force:!0});}catch{}}},"signalHandler");return process.once("SIGINT",o),process.once("SIGTERM",o),process.once("exit",o),async()=>{n||(n=true,process.off("SIGINT",o),process.off("SIGTERM",o),process.off("exit",o),await rm$1(t,{recursive:true,force:true}).catch(()=>{}));}}s(XU,"tryAcquire");async function ZU(t){try{let e=await readFile(join(t,"holder.json"),"utf-8"),r=JSON.parse(e);return e0(r)?r:null}catch{try{let e=await stat(t);if(Date.now()-e.mtimeMs<YU)return "young"}catch{}return null}}s(ZU,"inspectLock");function qU(t,e){return !t||Date.now()-t.started>e?true:t.hostname&&t.hostname!==BA()?false:!QU(t.pid)}s(qU,"isStale");function QU(t){if(!Number.isInteger(t)||t<=0)return false;try{return process.kill(t,0),!0}catch(e){return e.code==="EPERM"}}s(QU,"isProcessAlive");function t0(t){return t?`${t.hostname?`${t.hostname}:`:""}pid ${t.pid} (running ${Date.now()-t.started}ms)`:"unknown (unreadable lock metadata)"}s(t0,"describeHolder");function e0(t){if(typeof t!="object"||t===null)return false;let e=t;return typeof e.pid=="number"&&typeof e.started=="number"}s(e0,"isLockMetadata");function BA(){return hostname()}s(BA,"getHostname");function r0(t){return new Promise(e=>setTimeout(e,t))}s(r0,"sleep");b();gt();async function HA(t,e=t){let r=await readdir(t,{withFileTypes:true}),n=[];for(let o of r){let i=join(t,o.name);if(o.isDirectory()){n.push(...await HA(i,e));continue}n.push(relative(e,i).replace(/\\/g,"/"));}return n}s(HA,"listFiles");async function i0(t,e,r){if(r.has(e))return;let n=join(t,e);await F(n)&&await rm$1(n,{recursive:true,force:true});}s(i0,"removeIfStale");async function zA(t){let e=new Set(t.expectedPaths),r=new Set,n=t.scope??"project";for(let o of t.targets){let i=Fg(o,n);if(i){for(let a of i.files)r.add(a);for(let a of i.dirs){let c=join(t.projectRoot,a);if(await F(c))for(let l of await HA(c))r.add(`${a}/${l}`.replace(/\/+/g,"/"));}}}for(let o of r)await i0(t.projectRoot,o,e);}s(zA,"cleanupStaleGeneratedOutputs");function ua(t,e,r){let n=resolve(t),o=resolve(t,e);if(o===n||o.startsWith(`${n}${sep}`))return o;throw new Error(`Unsafe generated output path for ${r}: ${e}`)}s(ua,"ensurePathInsideRoot");Ta();b();st();async function fh(t,e){let r=await Zn(t.canonicalDir),n=e.length>0?await pa(e):{},o=await kp(join(t.canonicalDir,"packs")),i=process.env.USER??process.env.USERNAME??"unknown";await Op(t.canonicalDir,{generatedAt:new Date().toISOString(),generatedBy:i,libVersion:ka(),checksums:r,extends:n,packs:o});try{await mu(fe(),join(t.configDir,".agentsmeshcache"));}catch(a){I.warn(`Could not create .agentsmeshcache symlink: ${a instanceof Error?a.message:String(a)}`);}}s(fh,"writeLockFile");async function nx(t){let{mode:e,scope:r,dryRun:n,context:o,resolvedExtends:i,flags:a,root:c,options:l}=t;if(e==="check")return {exitCode:0,data:{scope:r,mode:e,files:[],summary:Dp([])}};if(n||await fh(o,i),l.printMatrix!==false){let{runMatrix:m}=await Promise.resolve().then(()=>(Hc(),Rh)),{renderMatrix:p}=await Promise.resolve().then(()=>(Vc(),Oh)),u=await m(a,c);p(u,{verbose:a.verbose===true});}return {exitCode:0,data:{scope:r,mode:e,files:[],summary:Dp([])}}}s(nx,"handleEmptyResults");function ox(t,e){let r=t.filter(a=>a.status!=="skipped"),n=r.filter(a=>a.status!=="unchanged"),o=r.map(a=>({path:a.path,target:a.target,status:a.status}));return {exitCode:n.length===0?0:1,data:{scope:e,mode:"check",files:o,summary:Dp(r)}}}s(ox,"buildCheckResult");async function sx(t){let{results:e,dryRun:r,scope:n,mode:o,context:i,activeTargets:a,resolvedExtends:c,flags:l,root:m,options:p}=t,u=r?null:await KA(join(i.canonicalDir,".generate.lock"));try{if(!r){for(let h of e)if(h.status==="created"||h.status==="updated"){let R=ua(i.rootBase,h.path,h.target);await C(R,h.content);}await zA({projectRoot:i.rootBase,targets:a,expectedPaths:e.map(h=>h.path),scope:n}),await fh(i,c);}}finally{u&&await u();}if(p.printMatrix!==false){let{runMatrix:h}=await Promise.resolve().then(()=>(Hc(),Rh)),{renderMatrix:R}=await Promise.resolve().then(()=>(Vc(),Oh)),S=await h(l,m);R(S,{verbose:l.verbose===true});}let f=e.filter(h=>h.status!=="skipped"),g=f.map(h=>({path:h.path,target:h.target,status:h.status}));return {exitCode:0,data:{scope:n,mode:o,files:g,summary:Dp(f)}}}s(sx,"handleGenerateOrDryRun");function Dp(t){return {created:t.filter(e=>e.status==="created").length,updated:t.filter(e=>e.status==="updated").length,unchanged:t.filter(e=>e.status==="unchanged").length}}s(Dp,"buildSummary");async function da(t,e,r={}){if(t.features!==void 0)throw new Error("--features is no longer supported. Configure features in agentsmesh.yaml.");let n=e??process.cwd(),o=t.check===true,i=t["dry-run"]===true,a=t.force===true,c=t.global===true?"global":"project",l=t["refresh-cache"]===true||t["no-cache"]===true,m=t.targets,p=typeof m=="string"&&m?m.split(",").map(P=>P.trim()).filter(Boolean):void 0,u=o?"check":i?"dry-run":"generate",{config:f,context:g}=await ut(n,c);await qt(f,n);let h=f.collaboration?.lock_features??[];if(f.collaboration?.strategy==="lock"&&!a&&h.length>0){let P=await Rp(g.canonicalDir);if(P!==null){let A=await Zn(g.canonicalDir),Z=Ep(P.checksums,A,h);if(Z.length>0){I.error("Locked feature violation (strategy: lock). Modified files:");for(let B of Z)I.error(` ${B}`);throw I.error("Run 'agentsmesh generate --force' to accept these changes."),new Error("Locked feature violation. Use --force to override.")}}}let{canonical:R,resolvedExtends:S}=await se(f,g.configDir,{refreshRemoteCache:l},g.canonicalDir),_=[...f.targets,...f.pluginTargets??[]];if(p){let P=p.filter(A=>!_.includes(A));if(P.length>0)throw new Error(`Unknown target(s) in --targets: ${P.join(", ")}. Available: ${_.join(", ")}`)}let k=p?_.filter(P=>p.includes(P)):_,T=await He({config:f,canonical:R,projectRoot:g.rootBase,scope:c,targetFilter:p});return T.length===0?nx({mode:u,scope:c,dryRun:i,context:g,resolvedExtends:S,flags:t,root:n,options:r}):o?ox(T,c):sx({results:T,dryRun:i,scope:c,mode:u,context:g,activeTargets:k,resolvedExtends:S,flags:t,root:n,options:r})}s(da,"runGenerate");st();function Eh(t,e){return t==="global"?`~/${e}`:e}s(Eh,"formatDisplayPath");function fa(t){let{data:e}=t,{scope:r,mode:n,files:o}=e;if(o.length===0){I.info("No files to generate (no root rule or rules feature disabled)."),n==="check"&&I.success("Generated files are in sync.");return}if(n==="check"){let l=o.filter(m=>m.status!=="unchanged");if(l.length===0){I.success("Generated files are in sync.");return}for(let m of l)I.error(`[check] ${m.status} ${Eh(r,m.path)} (${m.target})`);I.error("Generated files are out of sync. Run 'agentsmesh generate' to update them.");return}if(n==="dry-run"){for(let l of o)I.info(`[dry-run] ${l.status} ${Eh(r,l.path)} (${l.target})`);return}for(let l of o)(l.status==="created"||l.status==="updated")&&I.success(`${l.status} ${Eh(r,l.path)}`);let{created:i,updated:a,unchanged:c}=e.summary;i>0||a>0?I.info(`Generated: ${i} created, ${a} updated, ${c} unchanged`):I.info(`Nothing changed. (${c} unchanged)`);}s(fa,"renderGenerate");b();gt();Xe();var g0=["codex-cli"];function ix(){return lt.filter(t=>!g0.includes(t))}s(ix,"starterInitTargetIds");var h0=["rules","commands","agents","skills","mcp","hooks","ignore","permissions"],y0=ix();function Np(t,e=y0){let r=(t.length>0?t:e).map(o=>` - ${o}`).join(`
|
|
167
|
+
`),n=h0.map(o=>` - ${o}`).join(`
|
|
166
168
|
`);return `# yaml-language-server: $schema=https://unpkg.com/agentsmesh/schemas/agentsmesh.json
|
|
167
169
|
version: 1
|
|
168
170
|
targets:
|
|
169
171
|
${r}
|
|
170
172
|
features:
|
|
171
173
|
${n}
|
|
172
|
-
`}s(
|
|
174
|
+
`}s(Np,"buildConfig");var Fp=`---
|
|
173
175
|
root: true
|
|
174
176
|
description: "Project rules"
|
|
175
177
|
---
|
|
@@ -178,7 +180,7 @@ description: "Project rules"
|
|
|
178
180
|
|
|
179
181
|
Add your project-wide instructions here.
|
|
180
182
|
This file is always included in AI tool context and synced to all configured tools.
|
|
181
|
-
`,
|
|
183
|
+
`,kh=`---
|
|
182
184
|
description: "Example contextual rule \u2014 rename and customize"
|
|
183
185
|
# targets: [claude-code, cursor] # limit to specific tools (optional)
|
|
184
186
|
# globs: ["src/**/*.ts"] # activate only for matching files (optional)
|
|
@@ -187,14 +189,14 @@ description: "Example contextual rule \u2014 rename and customize"
|
|
|
187
189
|
# Example Rule
|
|
188
190
|
|
|
189
191
|
Replace this with your coding standards, conventions, or domain-specific guidelines.
|
|
190
|
-
`,
|
|
192
|
+
`,wh=`---
|
|
191
193
|
description: "Example command \u2014 rename and customize"
|
|
192
194
|
# allowed-tools: [Read, Grep, Glob, Bash]
|
|
193
195
|
---
|
|
194
196
|
|
|
195
197
|
Describe the task for this command here.
|
|
196
198
|
Commands are invoked on-demand (e.g. /example) with a focused tool set.
|
|
197
|
-
`,
|
|
199
|
+
`,Lh=`---
|
|
198
200
|
name: example-agent
|
|
199
201
|
description: "Example subagent \u2014 rename and customize"
|
|
200
202
|
# tools: [Read, Grep, Glob]
|
|
@@ -205,7 +207,7 @@ description: "Example subagent \u2014 rename and customize"
|
|
|
205
207
|
|
|
206
208
|
Describe this agent's role and instructions here.
|
|
207
209
|
Agents are specialized subagents with restricted tools and a specific purpose.
|
|
208
|
-
`,
|
|
210
|
+
`,bh=`---
|
|
209
211
|
name: example-skill
|
|
210
212
|
description: "Example skill \u2014 rename and customize"
|
|
211
213
|
---
|
|
@@ -214,7 +216,7 @@ description: "Example skill \u2014 rename and customize"
|
|
|
214
216
|
|
|
215
217
|
Describe the skill procedure here.
|
|
216
218
|
Skills are reusable multi-step procedures that commands and agents can reference.
|
|
217
|
-
`,
|
|
219
|
+
`,Ah=`{
|
|
218
220
|
"mcpServers": {
|
|
219
221
|
// agentsmesh self-serve MCP server \u2014 exposes your canonical config to AI agents.
|
|
220
222
|
// Lets agents introspect rules/commands/agents/skills and trigger generate.
|
|
@@ -241,7 +243,7 @@ Skills are reusable multi-step procedures that commands and agents can reference
|
|
|
241
243
|
// }
|
|
242
244
|
}
|
|
243
245
|
}
|
|
244
|
-
`,
|
|
246
|
+
`,xh=`# Lifecycle hooks \u2014 run shell commands before/after AI tool use
|
|
245
247
|
# Events: PreToolUse, PostToolUse, SubagentStart, SubagentStop
|
|
246
248
|
# Matcher: tool name pattern (e.g. "Edit|Write", "Bash", "*")
|
|
247
249
|
#
|
|
@@ -254,7 +256,7 @@ Skills are reusable multi-step procedures that commands and agents can reference
|
|
|
254
256
|
# - matcher: Edit|Write
|
|
255
257
|
# type: command
|
|
256
258
|
# command: npm test --passWithNoTests
|
|
257
|
-
`,
|
|
259
|
+
`,Ph=`# Tool permission allow/deny lists
|
|
258
260
|
#
|
|
259
261
|
# allow:
|
|
260
262
|
# - Bash(npm run:*)
|
|
@@ -270,14 +272,14 @@ Skills are reusable multi-step procedures that commands and agents can reference
|
|
|
270
272
|
allow: []
|
|
271
273
|
deny: []
|
|
272
274
|
ask: []
|
|
273
|
-
`,
|
|
275
|
+
`,Th=`# Patterns ignored by all configured AI tools (gitignore syntax)
|
|
274
276
|
#
|
|
275
277
|
# node_modules/
|
|
276
278
|
# dist/
|
|
277
279
|
# .env*
|
|
278
280
|
# *.log
|
|
279
281
|
# coverage/
|
|
280
|
-
`,
|
|
282
|
+
`,ax=`# yaml-language-server: $schema=https://unpkg.com/agentsmesh/schemas/agentsmesh.json
|
|
281
283
|
# Personal overrides \u2014 NOT committed to git
|
|
282
284
|
# Uncomment and customize for your local setup:
|
|
283
285
|
|
|
@@ -296,40 +298,27 @@ ask: []
|
|
|
296
298
|
# overrides:
|
|
297
299
|
# claude-code:
|
|
298
300
|
# model: opus
|
|
299
|
-
`;
|
|
300
|
-
`).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("#"))),o=
|
|
301
|
+
`;b();gt();function cx(t){let e=[];for(let r of Gt)for(let n of Ng(r.id,t))e.push({target:r.id,path:n});return e}s(cx,"collectDetectionPaths");function lx(t){let e=new Map;for(let{target:r,path:n}of cx(t)){let o=e.get(r)??[];o.push(n),e.set(r,o);}return [...e.entries()].map(([r,n])=>({id:r,paths:n}))}s(lx,"toolIndicators");lx("project");async function mx(t,e="project"){let r=[];for(let{id:n,paths:o}of lx(e))for(let i of o){let a=join(t,i);if(await F(a)){r.push(n);break}}return [...new Set(r)]}s(mx,"detectExistingConfigs");b();st();function Ht(t,e){return join(t,e)}s(Ht,"ab");async function Dh(t){return await F(t)?(await readdir(t,{withFileTypes:true})).filter(r=>r.isFile()&&r.name.endsWith(".md")).length:0}s(Dh,"countMdFiles");async function I0(t){let e=Ht(t,"skills");if(!await F(e))return false;let r=await readdir(e,{withFileTypes:true});for(let n of r)if(n.isDirectory()&&!n.name.startsWith("_")&&await F(join(e,n.name,"SKILL.md")))return true;return false}s(I0,"hasAnyImportedSkill");async function Nh(t){let e=Ht(t,"rules");await O(e),await C(join(e,"_root.md"),Fp),I.success("Created .agentsmesh/rules/_root.md"),await C(join(e,"_example.md"),kh),I.success("Created .agentsmesh/rules/_example.md");let r=Ht(t,"commands");await O(r),await C(join(r,"_example.md"),wh),I.success("Created .agentsmesh/commands/_example.md");let n=Ht(t,"agents");await O(n),await C(join(n,"_example.md"),Lh),I.success("Created .agentsmesh/agents/_example.md");let o=Ht(t,join("skills","_example"));await O(o),await C(join(o,"SKILL.md"),bh),I.success("Created .agentsmesh/skills/_example/SKILL.md"),await C(Ht(t,"mcp.json"),Ah),I.success("Created .agentsmesh/mcp.json"),await C(Ht(t,"hooks.yaml"),xh),I.success("Created .agentsmesh/hooks.yaml"),await C(Ht(t,"permissions.yaml"),Ph),I.success("Created .agentsmesh/permissions.yaml"),await C(Ht(t,"ignore"),Th),I.success("Created .agentsmesh/ignore");}s(Nh,"writeScaffoldFull");async function ux(t){let e=Ht(t,"rules"),r=await Dh(e),n=join(e,"_root.md"),o=await F(n);await O(e),r===0?(await C(n,Fp),I.success("Created .agentsmesh/rules/_root.md"),await C(join(e,"_example.md"),kh),I.success("Created .agentsmesh/rules/_example.md")):o||(await C(n,Fp),I.success("Created .agentsmesh/rules/_root.md"));let i=Ht(t,"commands");await Dh(i)===0&&(await O(i),await C(join(i,"_example.md"),wh),I.success("Created .agentsmesh/commands/_example.md"));let a=Ht(t,"agents");if(await Dh(a)===0&&(await O(a),await C(join(a,"_example.md"),Lh),I.success("Created .agentsmesh/agents/_example.md")),!await I0(t)){let u=Ht(t,join("skills","_example"));await O(u),await C(join(u,"SKILL.md"),bh),I.success("Created .agentsmesh/skills/_example/SKILL.md");}let c=Ht(t,"mcp.json");await F(c)||(await C(c,Ah),I.success("Created .agentsmesh/mcp.json"));let l=Ht(t,"hooks.yaml");await F(l)||(await C(l,xh),I.success("Created .agentsmesh/hooks.yaml"));let m=Ht(t,"permissions.yaml");await F(m)||(await C(m,Ph),I.success("Created .agentsmesh/permissions.yaml"));let p=Ht(t,"ignore");await F(p)||(await C(p,Th),I.success("Created .agentsmesh/ignore"));}s(ux,"writeScaffoldGapFill");de();var Fh="agentsmesh.yaml",dx="agentsmesh.local.yaml",C0=["agentsmesh.local.yaml",".agentsmeshcache",".agentsmesh/.lock.tmp",".agentsmesh/packs/"],R0=Object.fromEntries(Gt.map(t=>[t.id,(e,r)=>t.generators.importFrom(e,{scope:r})])),fx=Gt.filter(t=>t.globalSupport!==void 0).map(t=>t.id);function O0(t,e){if(e.has(t))return true;let r=t.replace(/\/$/,"");for(;r.includes("/")&&(r=r.slice(0,r.lastIndexOf("/")),r!=="");)if(e.has(r)||e.has(`${r}/`)||e.has(`${r}/**`))return true;return false}s(O0,"isCoveredByExisting");async function E0(t){let e=join(t,".gitignore"),r=await y(e)??"",n=new Set(r.split(`
|
|
302
|
+
`).map(a=>a.trim()).filter(a=>a.length>0&&!a.startsWith("#"))),o=C0.filter(a=>!O0(a,n));if(o.length===0)return false;let i=r.endsWith(`
|
|
301
303
|
`)||r===""?"":`
|
|
302
|
-
`;return await
|
|
304
|
+
`;return await C(e,r+i+o.join(`
|
|
303
305
|
`)+`
|
|
304
|
-
`),true}s(
|
|
306
|
+
`),true}s(E0,"appendToGitignore");async function gx(t,e={}){let r=e.global===true?"global":"project",n=Aa(t,r),o=join(n.configDir,Fh);if(await F(o))throw new Error(`Already initialized. ${Fh} exists. Remove it first to re-init.`);let i=await mx(n.rootBase,r),a=r==="global"?i.filter(g=>fx.includes(g)):i,c=r==="global"?fx:void 0,l=[],m,p=0;if(a.length>0)if(e.yes){for(let g of a){let h=R0[g];if(!h)continue;let R=await h(n.rootBase,r);for(let S of R)l.push({from:relative(n.rootBase,S.fromPath).replaceAll("\\","/"),to:S.toPath.replaceAll("\\","/")});}p=a.length,await ux(n.canonicalDir),m="gap-fill",await C(o,Np(a,c));}else await Nh(n.canonicalDir),m="full",await C(o,Np([],c));else await Nh(n.canonicalDir),m="full",await C(o,Np([],c));let u=join(n.configDir,dx);await C(u,ax);let f=false;return r==="project"&&(f=await E0(t)),{exitCode:0,data:{scope:r,configFile:Fh,localConfigFile:dx,detectedConfigs:a,imported:l,importedToolCount:p,scaffoldType:m,gitignoreUpdated:f}}}s(gx,"runInit");st();function hx(t){let{data:e}=t;if(e.detectedConfigs.length>0&&I.info(`Found existing configurations: ${e.detectedConfigs.join(", ")}`),e.detectedConfigs.length>0&&e.imported.length===0&&I.info("Run 'agentsmesh init --yes' to auto-import, or 'agentsmesh import --from <tool>' manually."),e.imported.length>0){I.info("Auto-importing existing configurations (--yes)...");for(let n of e.imported)I.success(` ${n.from} \u2192 ${n.to}`);I.info(`Imported ${e.imported.length} file(s) from ${e.importedToolCount} tool(s).`);}let r=e.imported.length>0&&e.detectedConfigs.length>0?` (targets: ${e.detectedConfigs.join(", ")})`:"";I.success(`Created ${e.configFile}${r}`),I.success(`Created ${e.localConfigFile}`),e.gitignoreUpdated&&I.success("Updated .gitignore");}s(hx,"renderInit");de();gt();var k0=Object.fromEntries(Gt.map(t=>[t.id,{importFrom:t.generators.importFrom,emptyImportMessage:t.emptyImportMessage,lintRules:t.lintRules,lint:t.lint,capabilities:t.capabilities}]));function vp(t){let e=k0[t];if(!e)throw new Error(`Unknown target: ${t}`);return e}s(vp,"getTargetCatalogEntry");Ce();Qn();Na();var P0={type:"stdio",command:"npx",args:["-y","agentsmesh","mcp"]};function T0(t){return t.mcpServers.agentsmesh!==void 0?false:(t.mcpServers.agentsmesh=P0,true)}s(T0,"injectAgentsmeshEntry");async function Mh(t){let e=resolve(t,".agentsmesh/mcp.json");try{let r;try{r=await Ze(e)??{mcpServers:{}};}catch{r={mcpServers:{}};}if(!T0(r))return !1;let n=JSON.stringify(r,null,2)+`
|
|
305
307
|
`;await mkdir(dirname(e),{recursive:!0});let o=`${e}.tmp.${process.pid}.${Date.now()}`;return await writeFile(o,n,"utf8"),await rename(o,e),!0}catch(r){return process.stderr.write(`[agentsmesh] warning: could not seed agentsmesh MCP server entry into mcp.json: ${r instanceof Error?r.message:String(r)}
|
|
306
|
-
`),false}}s(kh,"seedAgentsmeshMcpEntry");function WA(t,e){return t.map(r=>({from:relative(e,r.fromPath).replaceAll("\\","/"),to:r.toPath}))}s(WA,"mapResults");async function BA(t,e){let r=e??process.cwd(),n=t.from;if(typeof n!="string"||!n)throw new Error("--from is required. Example: agentsmesh import --from claude-code");let o=n.toLowerCase().trim(),i=t.global===true?"global":"project";if(He(o)){let p=wa(r,i),f=await bp(o).importFrom(p.rootBase,{scope:i});return f.length>0&&await kh(p.rootBase),{exitCode:0,data:{scope:i,target:o,files:WA(f,p.rootBase)}}}let a,c;try{({config:a,context:c}=await lt(r,i));}catch{throw new Error(`Unknown --from "${n}" and no agentsmesh.yaml found. Run 'agentsmesh init' to enable plugin targets, or use a builtin: ${it.join(", ")}.`)}await Jt(a,r);let l=tt(o);if(!l)throw new Error(`Unknown --from "${n}". Supported: ${[...it,...a.pluginTargets??[]].join(", ")}.`);let m=await l.generators.importFrom(c.rootBase,{scope:i});return m.length>0&&await kh(c.rootBase),{exitCode:0,data:{scope:i,target:o,files:WA(m,c.rootBase)}}}s(BA,"runImport");le();nn();function Ap(t){let e=[],r={new:0,updated:0,unchanged:0,deleted:0};for(let n of t){if(n.status==="unchanged"){r.unchanged++;continue}if(n.status==="created"){r.new++;let o=createTwoFilesPatch(`${n.path} (current)`,`${n.path} (generated)`,"",n.content,void 0,void 0,{context:3});e.push({path:n.path,patch:o});continue}if(n.status==="updated"&&n.currentContent!==void 0){r.updated++;let o=createTwoFilesPatch(`${n.path} (current)`,`${n.path} (generated)`,n.currentContent,n.content,void 0,void 0,{context:3});e.push({path:n.path,patch:o});continue}}return {diffs:e,summary:r}}s(Ap,"computeDiff");function xp(t){return `${t.new} files would be created, ${t.updated} updated, ${t.unchanged} unchanged, ${t.deleted} deleted`}s(xp,"formatDiffSummary");Vn();async function zA(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=t.targets,i=typeof o=="string"&&o?o.split(",").map(g=>g.trim()).filter(Boolean):void 0,{config:a,context:c}=await lt(r,n);await Jt(a,r);let{canonical:l}=await ee(a,c.configDir,{},c.canonicalDir),m=await je({config:a,canonical:l,projectRoot:c.rootBase,scope:n,targetFilter:i});if(m.length===0)return {exitCode:0,data:{files:[],patches:[],summary:{created:0,updated:0,unchanged:0,deleted:0}}};let{diffs:p,summary:u}=Ap(m);return {exitCode:0,data:{files:m.filter(g=>g.status!=="unchanged"&&g.status!=="skipped").map(g=>({path:g.path,target:g.target,status:g.status})),patches:p.map(g=>({path:g.path,patch:g.patch})),summary:{created:u.new,updated:u.updated,unchanged:u.unchanged,deleted:u.deleted}}}}s(zA,"runDiff");le();nn();A();ye();Vo();bt();var zU=[{canonicalKey:"permissions",capabilityKey:"permissions",featureFlag:"permissions",file:".agentsmesh/permissions.yaml",label:"permissions",hasContent:s(t=>{let e=t.permissions;if(!e)return false;let r=e.ask?.length??0;return e.allow.length+e.deny.length+r>0},"hasContent")},{canonicalKey:"hooks",capabilityKey:"hooks",featureFlag:"hooks",file:".agentsmesh/hooks.yaml",label:"hooks",hasContent:s(t=>{let e=t.hooks;return e?Object.values(e).some(r=>Array.isArray(r)&&r.length>0):false},"hasContent")},{canonicalKey:"mcp",capabilityKey:"mcp",featureFlag:"mcp",file:".agentsmesh/mcp.json",label:"MCP servers",hasContent:s(t=>{let e=t.mcp;return e?Object.keys(e.mcpServers).length>0:false},"hasContent")},{canonicalKey:"commands",capabilityKey:"commands",featureFlag:"commands",file:".agentsmesh/commands",label:"commands",hasContent:s(t=>t.commands.length>0,"hasContent")},{canonicalKey:"agents",capabilityKey:"agents",featureFlag:"agents",file:".agentsmesh/agents",label:"agents",hasContent:s(t=>t.agents.length>0,"hasContent")},{canonicalKey:"skills",capabilityKey:"skills",featureFlag:"skills",file:".agentsmesh/skills",label:"skills",hasContent:s(t=>t.skills.length>0,"hasContent")},{canonicalKey:"ignore",capabilityKey:"ignore",featureFlag:"ignore",file:".agentsmesh/ignore",label:"ignore patterns",hasContent:s(t=>t.ignore.length>0,"hasContent")}];function VA(t){let e=new Set(t.enabledFeatures),r=[];for(let n of zU)!e.has(n.featureFlag)||!n.hasContent(t.canonical)||Xe(t.capabilities[n.capabilityKey]).level!=="none"||r.push(U(n.file,t.target,`${t.target} does not support ${n.label}; canonical entries are silently dropped during generation. Disable the feature for this target or remove the canonical content.`));return r}s(VA,"lintSilentFeatureDrops");bt();var VU=/^(?:\s*(?:bash|sh|zsh|pwsh|powershell)\s+)?["']?(?<path>(?:\.{1,2}\/|[^/\s"'`]+\/)[^\s"'`]+)["']?(?:\s|$)/;function JU(t){let r=t.match(VU)?.groups?.path;return typeof r=="string"?r:null}s(JU,"extractScriptToken");function JA(t){if(t.hasScriptProjection)return [];let e=t.canonical.hooks;if(!e)return [];let r=[];for(let n of Object.values(e))if(Array.isArray(n))for(let o of n){if(typeof o?.command!="string")continue;let i=JU(o.command);i&&r.push(U(".agentsmesh/hooks.yaml",t.target,`${t.target} hook command references script "${i}"; agentsmesh does not copy hook scripts into ${t.target} output, so the script must already exist relative to the hook execution directory or the generated config will fail.`));}return r}s(JA,"lintHookScriptReferences");bt();function YA(t){if(t.preservesManualActivation)return [];let e=[];for(let r of t.canonical.rules)r.root||r.trigger==="manual"&&(r.targets.length>0&&!r.targets.includes(t.target)||e.push(U(r.source,t.target,`Rule has trigger: 'manual' (Cursor-style "@-mention only" activation), but ${t.target} loads every rule unconditionally. The rule will become always-on for ${t.target} \u2014 restrict it with \`targets: [cursor]\`, convert it to a skill with manual invocation, or remove it.`)));return e}s(YA,"lintRuleScopeInversion");var YU=["node_modules",".git","dist","coverage",".agentsmesh"];async function XU(t){return (await N(t)).filter(n=>{let o=relative(t,n);return !YU.some(i=>o.includes(`/${i}/`)||o.startsWith(`${i}/`))}).map(n=>relative(t,n))}s(XU,"getProjectFiles");async function Pp(t,e,r,n,o={}){let i=o.scope??"project",a=[...t.targets,...t.pluginTargets??[]],c=n?a.filter(C=>n.includes(C)):a,l=t.features.includes("rules"),m=t.features.includes("commands"),p=t.features.includes("mcp"),u=t.features.includes("permissions"),f=t.features.includes("hooks"),g=[],h=i==="global"?[]:await XU(r);for(let C of c){let _=tt(C),E=He(C)?bp(C):_;E?.capabilities&&g.push(...VA({target:C,capabilities:E.capabilities,canonical:e,enabledFeatures:t.features})),f&&g.push(...JA({target:C,canonical:e,hasScriptProjection:_?.postProcessHookOutputs!==void 0})),l&&g.push(...YA({target:C,canonical:e,preservesManualActivation:_?.preservesManualActivation===true})),l&&E?.lintRules&&g.push(...E.lintRules(e,r,h,{scope:i})),_?.generators.lint&&g.push(..._.generators.lint(e));let T={scope:i};m&&E?.lint?.commands&&g.push(...E.lint.commands(e,T)),p&&E?.lint?.mcp&&g.push(...E.lint.mcp(e,T)),u&&E?.lint?.permissions&&g.push(...E.lint.permissions(e,T)),f&&E?.lint?.hooks&&g.push(...E.lint.hooks(e,T));}let R=g.some(C=>C.level==="error");return {diagnostics:g,hasErrors:R}}s(Pp,"runLint");Vn();async function ZA(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=t.targets,i=typeof o=="string"&&o?o.split(",").map(u=>u.trim()).filter(Boolean):void 0,{config:a,context:c}=await lt(r,n);await Jt(a,r);let{canonical:l}=await ee(a,c.configDir,{},c.canonicalDir),{diagnostics:m,hasErrors:p}=await Pp(a,l,c.configDir,i,{scope:n});return {exitCode:p?1:0,data:{diagnostics:m.map(u=>({level:u.level,file:u.file,target:u.target,message:u.message})),summary:{errors:m.filter(u=>u.level==="error").length,warnings:m.filter(u=>u.level==="warning").length}}}}s(ZA,"runLintCmd");nt();function qA(t){let{data:e}=t;if(e.diagnostics.length===0){I.success("All checks passed.");return}let r=e.diagnostics.filter(a=>a.level==="error"),n=e.diagnostics.filter(a=>a.level==="warning");for(let a of r)I.error(`${a.file} (${a.target}): ${a.message}`);for(let a of n)I.warn(`${a.file} (${a.target}): ${a.message}`);let o=e.summary.errors,i=e.summary.warnings;I.info(`${o} error${o!==1?"s":""}, ${i} warning${i!==1?"s":""}`);}s(qA,"renderLint");nt();function QA(t){let{data:e}=t;if(!e.hasLock){I.error("Not initialized for collaboration. Run 'agentsmesh generate' first.");return}if(e.inSync){I.success("Lock file is in sync.");return}let r=new Set(e.lockedViolations);I.error("Conflict detected:");for(let n of e.extendsModified)I.error(` extend "${n}" was modified`);for(let n of e.modified){let o=r.has(n)?" [LOCKED]":"";I.error(` ${n} was modified${o}`);}for(let n of e.added){let o=r.has(n)?" [LOCKED]":"";I.error(` ${n} was added${o}`);}for(let n of e.removed){let o=r.has(n)?" [LOCKED]":"";I.error(` ${n} was removed${o}`);}I.info("Run 'agentsmesh merge' to resolve, or 'agentsmesh generate --force' to accept current state.");}s(QA,"renderCheck");nt();function tx(t){let{data:e}=t;if(e.files.length===0){I.info(`Nothing to import from ${e.target}.`);return}for(let n of e.files)I.success(`${n.from} \u2192 ${n.to}`);let r=e.scope==="global"?" --global":"";I.info(`Imported ${e.files.length} file(s). Run 'agentsmesh generate${r}' to sync to other tools.`);}s(tx,"renderImport");nt();function ex(t){let{summary:e}=t.data;if(e.created+e.updated+e.unchanged+e.deleted===0){I.info("No files to generate (no root rule or rules feature disabled).");return}for(let n of t.data.patches)process.stdout.write(n.patch);I.info(xp({new:e.created,updated:e.updated,unchanged:e.unchanged,deleted:e.deleted}));}s(ex,"renderDiff");nt();function rx(t){if(!t.data.hadConflict){I.info("No conflicts to resolve.");return}I.success("Lock file conflict resolved.");}s(rx,"renderMerge");jc();Kc();le();nn();jc();Kc();nt();var QU=300;function t0(t){return t.replace(/\\/g,"/").replace(/\/+$/,"")}s(t0,"normalizeWatchPath");function e0(t,e,r){let n=t0(relative(t,e));return n===".lock"||n===".lock.tmp"||n===".generate.lock"||n.endsWith("/.lock")||n.endsWith("/.lock.tmp")||n.endsWith("/.generate.lock")||n.includes("/.generate.lock/")||n.startsWith(".generate.lock/")}s(e0,"shouldIgnoreWatchPath");function r0(t,e,r,n,o,i,a,c,l){return JSON.stringify({features:t,rulesCount:e,commandsCount:r,agentsCount:n,skillsCount:o,mcpServerCount:i,permissionsCount:a,hooksCount:c,ignoreCount:l})}s(r0,"featureFingerprint");async function ox(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",{context:o}=await lt(r,n),i=[o.canonicalDir,join(o.configDir,"agentsmesh.yaml"),join(o.configDir,"agentsmesh.local.yaml")],a=null,c=null,l=false,m=null,u=s(async()=>{if(l)return;a=null;let{config:R,context:C}=await lt(r,n),{canonical:_}=await ee(R,C.configDir,{},C.canonicalDir),E=_.mcp?Object.keys(_.mcp.mcpServers).length:0,T=_.permissions?_.permissions.allow.length+_.permissions.deny.length:0,D=_.hooks?Object.values(_.hooks).reduce((kt,Ct)=>kt+(Array.isArray(Ct)?Ct.length:0),0):0,x=_.ignore.length,Z=r0(R.features,_.rules.length,_.commands.length,_.agents.length,_.skills.length,E,T,D,x),B=c!==null&&c!==Z;if(c=Z,l)return;let J=await ia(t,r,{printMatrix:false});if(aa(J),!l)if(B){let kt=await Gc(t,r);Uc(kt,{verbose:t.verbose===true});}else I.info("Regenerated.");},"run"),f=s(()=>{let R=u().catch(C=>{if(!l){let _=C instanceof Error?C.message:String(C);I.error(_);}}).finally(()=>{m===R&&(m=null);});m=R;},"scheduleRun"),g=s(()=>{l||(a&&clearTimeout(a),a=setTimeout(f,QU));},"schedule"),h=qU.watch(i,{ignoreInitial:true,usePolling:process.platform==="win32"});return h.on("all",(R,C)=>{e0(o.canonicalDir,C)||g();}),await new Promise((R,C)=>{h.once("ready",R),h.once("error",C);}),I.info(n==="global"?"Watching ~/.agentsmesh/ and agentsmesh.yaml...":"Watching .agentsmesh/ and agentsmesh.yaml..."),m=u(),await m,m=null,{stop:s(async()=>{l=true,a&&(clearTimeout(a),a=null),await h.close(),m&&await m;},"stop")}}s(ox,"runWatch");le();al();async function Tp(t){let{config:e,configDir:r,canonicalDir:n}=t,o=await fp(n);if(o===null)return {inSync:false,hasLock:false,modified:[],added:[],removed:[],extendsModified:[],lockedViolations:[]};let i=await Hn(n),a=await ti(e,r),c=a.length>0?await oa(a):{},l=new Set(Object.keys(o.checksums)),m=new Set(Object.keys(i)),p=[],u=[],f=[];for(let _ of l){let E=i[_];E===void 0?f.push(_):E!==o.checksums[_]&&p.push(_);}for(let _ of m)l.has(_)||u.push(_);let g=new Set([...Object.keys(o.extends),...Object.keys(c)]),h=[];for(let _ of g)c[_]!==o.extends[_]&&h.push(_);let R=hp(o.checksums,i,e.collaboration?.lock_features??[]);return {inSync:p.length===0&&u.length===0&&f.length===0&&h.length===0,hasLock:true,modified:p,added:u,removed:f,extendsModified:h,lockedViolations:R}}s(Tp,"checkLockSync");Vn();async function sx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",{config:o,context:i}=await lt(r,n);await Jt(o,r);let a=await Tp({config:o,configDir:i.configDir,canonicalDir:i.canonicalDir});return a.hasLock?{exitCode:a.inSync?0:1,data:{hasLock:true,inSync:a.inSync,modified:[...a.modified],added:[...a.added],removed:[...a.removed],extendsModified:[...a.extendsModified],lockedViolations:[...a.lockedViolations]}}:{exitCode:1,data:{hasLock:false,inSync:false,modified:[],added:[],removed:[],extendsModified:[],lockedViolations:[]}}}s(sx,"runCheck");le();A();al();var o0=".lock",s0="<<<<<<<";async function Oh(t){let e=join(t,o0),r=await y(e);return r===null?false:r.includes(s0)}s(Oh,"hasLockConflict");async function ax(t,e,r){if(!await Oh(t))throw new Error("No conflict to resolve.");let o=await Hn(t),i=dirname(t),a=r?await ti(r,i):[],c=a.length>0?await oa(a):{},l=await yp(join(t,"packs")),m=process.env.USER??process.env.USERNAME??"unknown";await gp(t,{generatedAt:new Date().toISOString(),generatedBy:m,libVersion:e,checksums:o,extends:c,packs:l});}s(ax,"resolveLockConflict");async function cx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",{config:o,context:i}=await lt(r,n),a=i.canonicalDir;return await Oh(a)?(await ax(a,Sa(),o),{exitCode:0,data:{hadConflict:true,resolved:true}}):{exitCode:0,data:{hadConflict:false,resolved:false}}}s(cx,"runMerge");le();A();ba();var c0=promisify(execFile);async function wh(t){let{stdout:e}=await c0("git",t,{env:{...process.env,GIT_TERMINAL_PROMPT:"0"}});return e.trim()}s(wh,"runGit");async function lx(){try{return await wh(["--version"]),!0}catch{return false}}s(lx,"isGitAvailable");async function l0(t,e){let r=[e,`refs/heads/${e}`,`refs/tags/${e}`],n;for(let o of r)try{let a=(await wh(["ls-remote",t,o])).split(`
|
|
307
|
-
`).map(l=>l.trim()).find(l=>l.length>0);if(!a)continue;let c=a.split(/\s+/)[0];if(c&&/^[0-9a-f]{40}$/i.test(c))return c}catch(i){n=i;}throw new Error(`Could not resolve ref "${e}" for ${t}: ${n instanceof Error?n.message:String(n)}`)}s(
|
|
308
|
-
`).find(a=>a.trim().length>0);if(!o)throw new Error(`Could not resolve HEAD for ${e}`);let i=o.split(/\s+/)[0];if(!i||!/^[0-9a-f]{40}$/i.test(i))throw new Error(`Invalid ls-remote HEAD line for ${e}`);return i.toLowerCase()}return l0(e,r)}s(mx,"resolveRemoteRefForInstall");async function px(t){if(t.kind==="local")return {resolvedPath:t.localRoot,sourceForYaml:t.localSourceForYaml};let e=t.gitRemoteUrl;if(!e)throw new Error("Internal error: missing git remote URL");let r=await mx(t.rawRef||"HEAD",e);if(t.kind==="github"){let c=`github:${t.org}/${t.repo}@${r}`;return {resolvedPath:(await Qs(c,"install",{cacheDir:me(),refresh:false,allowOfflineFallback:false})).resolvedPath,sourceForYaml:c,version:r}}if(t.kind==="gitlab"){let c=`gitlab:${t.org}/${t.repo}@${r}`;return {resolvedPath:(await Qs(c,"install",{cacheDir:me(),refresh:false,allowOfflineFallback:false})).resolvedPath,sourceForYaml:c,version:r}}let n=r,i=`git+${(t.gitPlusBase??e).split("#")[0]}#${n}`;return {resolvedPath:(await Qs(i,"install",{cacheDir:me(),refresh:false,allowOfflineFallback:false})).resolvedPath,sourceForYaml:i,version:r}}s(px,"fetchInstallSource");async function ux(t,e){if(t.kind==="local")return {resolvedPath:t.localRoot,sourceForYaml:t.localSourceForYaml};try{let r=await px(t);return {resolvedPath:r.resolvedPath,sourceForYaml:r.sourceForYaml,version:r.version}}catch(r){let n=r instanceof Error?r.message:String(r),o=new Error(`Failed to fetch from ${e}: ${n}. Check your network connection and try again.`);throw r instanceof Error&&(o.cause=r),o}}s(ux,"resolveInstallResolvedPath");function Eh(t){try{let e=new URL(t);if(e.hostname!=="github.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("tree");if(n<2||n+1>=r.length)return null;let o=r[0],i=r[1],a=r[n+1],c=r.slice(n+2).join("/");return !o||!i||!a?null:{org:o,repo:i,ref:a,path:c||""}}catch{return null}}s(Eh,"parseGithubTreeUrl");function Lh(t){try{let e=new URL(t);if(e.hostname!=="github.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("blob");if(n<2||n+1>=r.length)return null;let o=r[0],i=r[1],a=r[n+1],c=r.slice(n+2).join("/");return !o||!i||!a||!c?null:{org:o,repo:i,ref:a,path:c}}catch{return null}}s(Lh,"parseGithubBlobUrl");function bh(t){try{let e=new URL(t);if(e.hostname!=="gitlab.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("-");if(n<0||r[n+1]!=="tree")return null;let o=n+1;if(o+1>=r.length)return null;let i=r[o+1],a=r.slice(o+2).join("/"),c=r.slice(0,n);if(c.length<2)return null;let l=c[c.length-1],m=c.slice(0,-1).join("/");return !m||!l||!i?null:{namespace:m,project:l,ref:i,path:a||""}}catch{return null}}s(bh,"parseGitlabTreeUrl");function Ah(t){try{let e=new URL(t);if(e.hostname!=="gitlab.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("-");if(n<0||r[n+1]!=="blob")return null;let o=n+1;if(o+1>=r.length)return null;let i=r[o+1],a=r.slice(o+2).join("/"),c=r.slice(0,n);if(c.length<2)return null;let l=c[c.length-1],m=c.slice(0,-1).join("/");return !m||!l||!i||!a?null:{namespace:m,project:l,ref:i,path:a}}catch{return null}}s(Ah,"parseGitlabBlobUrl");var m0=new Set(["tree","blob","commit","releases","actions","issues","pulls","settings","wiki","discussions","security","projects","packages"]);function xh(t){try{let e=new URL(t);if(e.hostname!=="github.com")return null;let r=e.pathname.split("/").filter(Boolean).map(i=>i.replace(/\.git$/i,""));if(r.length<2||r.length>2||m0.has(r[1]))return null;let n=r[0],o=r[1];return {org:n,repo:o}}catch{return null}}s(xh,"parseGithubRepoUrl");function Ph(t){try{let e=new URL(t);if(e.hostname!=="gitlab.com")return null;let r=e.pathname.split("/").filter(Boolean).map(i=>i.replace(/\.git$/i,""));if(r.length<2||r.includes("-"))return null;let n=r[r.length-1],o=r.slice(0,-1).join("/");return !o||!n?null:{namespace:o,project:n}}catch{return null}}s(Ph,"parseGitlabRepoUrl");function Th(t){let e=t.match(/^git@github\.com:([^/]+)\/(.+?)(?:\.git)?$/i);return e?{org:e[1],repo:e[2].replace(/\.git$/i,"")}:null}s(Th,"parseGitSshGithub");function Dh(t){let e=t.match(/^git@gitlab\.com:(.+?)(?:\.git)?$/i);if(!e)return null;let n=e[1].replace(/\.git$/i,"").split("/").filter(Boolean);if(n.length<2)return null;let o=n[n.length-1];return {namespace:n.slice(0,-1).join("/"),project:o}}s(Dh,"parseGitSshGitlab");A();var d0=/^[A-Za-z]:[\\/]/,f0=/^[A-Za-z]:\//;function dx(...t){return t.some(e=>e.includes("\\")||d0.test(e))?win32:posix}s(dx,"pathApiFor");function Bc(t){return t.replace(/\\/g,"/")}s(Bc,"toPosixPath");function Wc(t){return Bc(t).replace(/^\/+|\/+$/g,"")}s(Wc,"normalizeInstallPathField");function Dp(t){let e=Bc(t);return e===""||e==="."||e==="./."?".":e.startsWith("./")||e.startsWith("../")||e.startsWith("/")||f0.test(e)?e:`./${e}`}s(Dp,"normalizeLocalSourceForYaml");function vo(t){return {...t,source:t.source_kind==="local"?Dp(t.source):t.source,...t.path!==void 0?{path:Wc(t.path)}:{},...t.paths!==void 0?{paths:t.paths.map(e=>Wc(e))}:{}}}s(vo,"normalizePersistedInstallPaths");function fx(t,e,r){let n=dx(t,e),o=n.normalize(t),i=n.normalize(e),a=Wc(r),c=`${n.sep}.agentsmesh${n.sep}`,l=o.indexOf(c);if(l>=0){let p=o.slice(0,l),u=o.slice(l+c.length),f=Wc(u),g=Bc(n.relative(i,p))||".";return {kind:"local",rawRef:"",pathInRepo:a||f.replace(/\.md$/i,"").replace(/\/$/,""),localRoot:p,localSourceForYaml:Dp(g)}}let m=Bc(n.relative(i,o))||".";return {kind:"local",rawRef:"",pathInRepo:a,localRoot:o,localSourceForYaml:Dp(m)}}s(fx,"localParsedFromAbsPath");async function Nh(t,e,r){let n=t.trim(),o=r?.trim().replace(/\\/g,"/")??"";if(n.startsWith("git+")){let l=n.lastIndexOf("#"),m=l<0?n:n.slice(0,l),p=l<0?"HEAD":n.slice(l+1),u=m.slice(4);return {kind:"git",rawRef:p,gitPlusBase:u,gitRemoteUrl:u,pathInRepo:o}}if(n.startsWith("https://")||n.startsWith("http://")){let l=Eh(n)??Lh(n);if(l)return {kind:"github",rawRef:l.ref,org:l.org,repo:l.repo,gitRemoteUrl:`https://github.com/${l.org}/${l.repo}.git`,pathInRepo:o||l.path};let m=xh(n);if(m)return {kind:"github",rawRef:"HEAD",org:m.org,repo:m.repo,gitRemoteUrl:`https://github.com/${m.org}/${m.repo}.git`,pathInRepo:o};let p=bh(n)??Ah(n);if(p)return {kind:"gitlab",rawRef:p.ref,org:p.namespace,repo:p.project,gitRemoteUrl:`https://gitlab.com/${p.namespace}/${p.project}.git`,pathInRepo:o||p.path};let u=Ph(n);if(u)return {kind:"gitlab",rawRef:"HEAD",org:u.namespace,repo:u.project,gitRemoteUrl:`https://gitlab.com/${u.namespace}/${u.project}.git`,pathInRepo:o}}if(n.startsWith("git@github.com:")){let l=Th(n);if(!l)throw new Error(`Invalid GitHub SSH URL: ${n}`);return {kind:"github",rawRef:"HEAD",org:l.org,repo:l.repo,gitRemoteUrl:`https://github.com/${l.org}/${l.repo}.git`,pathInRepo:o}}if(n.startsWith("git@gitlab.com:")){let l=Dh(n);if(!l)throw new Error(`Invalid GitLab SSH URL: ${n}`);return {kind:"gitlab",rawRef:"HEAD",gitRemoteUrl:`https://gitlab.com/${l.namespace}/${l.project}.git`,pathInRepo:o}}if(n.startsWith("git@")){let l=n.match(/^git@([^:]+):(.+?)(?:\.git)?$/);if(!l)throw new Error(`Invalid SSH git URL: ${n}`);let m=l[1],p=l[2].replace(/\.git$/i,"");return {kind:"git",rawRef:"HEAD",gitRemoteUrl:`ssh://git@${m}/${p}.git`,pathInRepo:o}}let i=n.match(/^github:([^/]+)\/(.+?)@([^/@]+)$/);if(i){let l=i[1],m=i[2];return {kind:"github",rawRef:i[3],org:l,repo:m,gitRemoteUrl:`https://github.com/${l}/${m}.git`,pathInRepo:o}}let a=n.match(/^gitlab:(.+)\/([^/@]+)@([^/@]+)$/);if(a){let l=a[1],m=a[2];return {kind:"gitlab",rawRef:a[3],org:l,repo:m,gitRemoteUrl:`https://gitlab.com/${l}/${m}.git`,pathInRepo:o}}let c=resolve(e,n);if(!await v(c))throw new Error(`Path does not exist: ${c}`);return fx(c,e,o)}s(Nh,"parseInstallSource");A();nt();ln();A();lp();var gx=z$1.object({name:z$1.string().min(1),source:z$1.string().min(1),version:z$1.string().optional(),source_kind:z$1.enum(["github","gitlab","git","local"]),features:z$1.array(Zs).min(1),pick:Oa.optional(),target:Re.optional(),path:z$1.string().optional(),paths:z$1.array(z$1.string().min(1)).min(1).optional(),as:na.optional()}),I0=z$1.object({version:z$1.literal(1),installs:z$1.array(gx).default([])});function C0(t,e){return t.length===e.length&&[...t].sort().every((r,n)=>r===[...e].sort()[n])}s(C0,"sameFeatures");function S0(t,e){return t.source===e.source&&t.target===e.target&&t.as===e.as&&C0(t.features,e.features)}s(S0,"sameInstallIdentity");function hx(t){return join(t,"installs.yaml")}s(hx,"manifestPath");async function Fh(t){let e=await y(hx(t));if(e===null)return [];try{return I0.parse(parse(e)).installs.map(r=>vo(r))}catch{return []}}s(Fh,"readInstallManifest");async function yx(t,e){let r=vo(e),o=(await Fh(t)).filter(i=>i.name!==r.name&&!S0(i,r));o.push(r),await S(hx(t),stringify({version:1,installs:o.sort((i,a)=>i.name.localeCompare(a.name))}));}s(yx,"upsertInstallManifestEntry");function _x(t){return vo(gx.parse({name:t.name,source:t.source,version:t.version,source_kind:t.sourceKind,features:t.features,pick:t.pick,target:t.target,path:t.path,paths:t.paths,as:t.as}))}s(_x,"buildInstallManifestEntry");async function k0(t){let e=await Fh(t.canonicalDir);if(e.length===0){I.info("No recorded installs found in .agentsmesh/installs.yaml.");return}let r=[];for(let n of e){let o=join(t.canonicalDir,"packs",n.name);await v(o)||r.push(n);}if(r.length===0){I.info("All recorded packs are already installed.");return}for(let n of r)await t.reinstall(n);I.success(`Reinstalled ${r.length} pack(s) from .agentsmesh/installs.yaml.`);}s(k0,"syncInstalledPacks");async function Ix(t){return t.sync?(await k0({canonicalDir:t.canonicalDir,reinstall:t.reinstall}),true):false}s(Ix,"maybeRunInstallSync");lp();function Cx(t){return {sync:t.sync===true,dryRun:t["dry-run"]===true,force:t.force===true,useExtends:t.extends===true,explicitPath:typeof t.path=="string"?t.path:void 0,explicitTarget:typeof t.target=="string"?t.target.trim():void 0,explicitAs:typeof t.as=="string"?na.parse(t.as.trim()):void 0,nameOverride:typeof t.name=="string"?t.name.trim():""}}s(Cx,"readInstallFlags");$g();function js(t){let e=[];return t.skills.length&&e.push("skills"),t.rules.length&&e.push("rules"),t.commands.length&&e.push("commands"),t.agents.length&&e.push("agents"),t.mcp!==null&&e.push("mcp"),t.permissions!==null&&e.push("permissions"),t.hooks!==null&&e.push("hooks"),t.ignore.length&&e.push("ignore"),e}s(js,"featuresFromCanonical");async function Np(t){let{sliceRoot:e,implicitPick:r}=await ip(t),n=await ap(e);return {canonical:n,features:js(n),implicitPick:r}}s(Np,"discoverFromContentRoot");function Sx(t){return t.description.trim()?{skill:t,ok:true}:{skill:t,ok:false,reason:"missing description in frontmatter"}}s(Sx,"validateSkill");function Rx(t){return t.description.trim()?{rule:t,ok:true}:{rule:t,ok:false,reason:"missing description in frontmatter"}}s(Rx,"validateRule");function kx(t){return t.description.trim()?{command:t,ok:true}:{command:t,ok:false,reason:"missing description in frontmatter"}}s(kx,"validateCommand");function Ox(t){return t.description.trim()?{agent:t,ok:true}:{agent:t,ok:false,reason:"missing description in frontmatter"}}s(Ox,"validateAgent");function ae(t){return basename(t.source).replace(/\.md$/i,"")}s(ae,"ruleSlug");function w0(t){if(!t)return;let e=[];return t.skills!==void 0&&e.push("skills"),t.rules!==void 0&&e.push("rules"),t.commands!==void 0&&e.push("commands"),t.agents!==void 0&&e.push("agents"),e.length>0?e:void 0}s(w0,"featuresFromImplicitPick");function la(t,e){let{implicitPick:r}=e,n=e.scopedFeatures??w0(r);if(!r&&!n)return t;let o=new Set(n??[]),i={...t,mcp:!n||o.has("mcp")?t.mcp:null,permissions:!n||o.has("permissions")?t.permissions:null,hooks:!n||o.has("hooks")?t.hooks:null,ignore:!n||o.has("ignore")?t.ignore:[]};if(r?.skills!==void 0){let a=new Set(r.skills);i={...i,skills:r.skills.length===0?[]:i.skills.filter(c=>a.has(c.name))};}else n&&!o.has("skills")&&(i={...i,skills:[]});if(r?.rules!==void 0){let a=new Set(r.rules);i={...i,rules:r.rules.length===0?[]:i.rules.filter(c=>a.has(ae(c)))};}else n&&!o.has("rules")&&(i={...i,rules:[]});if(r?.commands!==void 0){let a=new Set(r.commands);i={...i,commands:r.commands.length===0?[]:i.commands.filter(c=>a.has(c.name))};}else n&&!o.has("commands")&&(i={...i,commands:[]});if(r?.agents!==void 0){let a=new Set(r.agents);i={...i,agents:r.agents.length===0?[]:i.agents.filter(c=>a.has(c.name))};}else n&&!o.has("agents")&&(i={...i,agents:[]});return i}s(la,"narrowDiscoveredForInstallScope");A();sp();A();M();var b0=new Set(["README.md","README.rst","README.txt","README","LICENSE","LICENSE.md","LICENSE.txt","LICENSE-MIT","LICENSE-APACHE","CONTRIBUTING.md","CHANGELOG.md","CODE_OF_CONDUCT.md","package.json","package-lock.json","pnpm-lock.yaml","yarn.lock",".gitignore",".gitattributes",".editorconfig",".DS_Store"]),A0=new Set([".git",".github",".gitlab","node_modules",".vscode",".idea"]);async function Fp(t){let e=await y(t);if(!e)return "";let{frontmatter:r}=w(e);return typeof r.name!="string"?"":r.name.toLowerCase().replace(/[^a-z0-9-]+/g,"-").replace(/-+/g,"-").replace(/^-|-$/g,"")}s(Fp,"readSkillFrontmatterName");async function wx(t,e){await cp$1(t,e,{recursive:true,filter:s(r=>{let n=relative(t,r).replace(/\\/g,"/");if(n==="")return true;let o=n.split("/")[0];return !(A0.has(o)||!n.includes("/")&&b0.has(n))},"filter")});}s(wx,"cpFilteredSkill");async function N0(){let t=await mkdtemp(join(tmpdir(),"am-install-manual-")),e=join(t,"repo");return await O(join(e,".agentsmesh")),{discoveryRoot:e,cleanup:s(async()=>{await rm$1(t,{recursive:true,force:true});},"cleanup")}}s(N0,"createStageRoot");async function F0(t,e){if((await stat(t)).isFile()){if(!t.toLowerCase().endsWith(".md"))throw new Error(`Manual install only supports .md files for this collection: ${t}`);await O(e),await cp$1(t,join(e,basename(t)));return}let n=(await N(t)).filter(i=>i.toLowerCase().endsWith(".md"));if(n.length===0)throw new Error(`No .md files found under ${t} for manual install.`);let o=new Map;await O(e);for(let i of n){let a=basename(i),c=o.get(a);if(c)throw new Error(`Manual install found duplicate file name "${a}" under ${t} (${c} and ${i}).`);o.set(a,i),await cp$1(i,join(e,a));}}s(F0,"stageMarkdownCollection");async function Ex(t,e,r){if(r.length===0)return false;let n=new Set(r),o=new Map;for(let i of await N(t)){if(!i.endsWith("/SKILL.md")&&!i.endsWith("\\SKILL.md"))continue;let a=dirname(i),c=basename(a);if(!n.has(c))continue;let l=o.get(c);if(l&&l!==a)throw new Error(`Manual skill replay found duplicate skill "${c}" under ${t} (${l} and ${a}).`);o.set(c,a);}if(o.size!==r.length)return false;await O(e);for(let i of r)await cp$1(o.get(i),join(e,i),{recursive:true});return true}s(Ex,"stagePreferredSkills");async function v0(t,e,r={}){if((await stat(t)).isFile()){if(basename(t)!=="SKILL.md")throw new Error(`Manual skill install expects SKILL.md or a skill directory: ${t}`);let o=basename(dirname(t)),i=join(e,o);await O(i),await cp$1(dirname(t),i,{recursive:true});return}if(await $s(t)){if((await stat(join(t,"SKILL.md")).catch(()=>null))?.isFile()){if(await Ex(t,e,r.preferredSkillNames??[]))return;let c=await Fp(join(t,"SKILL.md"))||basename(t),l=join(e,c);await O(e),await wx(t,l);return}if(await Ex(t,e,r.preferredSkillNames??[]))return;await O(e);let o=await N(t),i=new Set;for(let a of o.filter(c=>c.endsWith("/SKILL.md")||c.endsWith("\\SKILL.md")))i.add(relative(t,dirname(a)).split(/[\\/]/)[0]);for(let a of i)await cp$1(join(t,a),join(e,a),{recursive:true});return}throw new Error(`Manual skill install expects a skill directory or skills collection at ${t}.`)}s(v0,"stageSkills");async function Lx(t,e,r={}){let n=await N0();try{let o=join(n.discoveryRoot,".agentsmesh",e);return e==="skills"?await v0(t,o,r):await F0(t,o),n}catch(o){throw await n.cleanup(),o}}s(Lx,"stageManualInstallScope");async function bx(t,e,r,n){let o=await Lx(t,e,{preferredSkillNames:e==="skills"?n?.skills:void 0}),{canonical:i}=await Np(o.discoveryRoot),a=la(i,{scopedFeatures:[e]});return {prep:{yamlTarget:r,scopedFeatures:[e],cleanup:o.cleanup},narrowed:a,discoveredFeatures:js(a)}}s(bx,"resolveManualDiscoveredForInstall");ln();_u();A();var M0=[{prefix:".gemini/commands",target:"gemini-cli"},{prefix:".github/instructions",target:"copilot"},{prefix:".github/copilot-instructions.md",target:"copilot"},{prefix:".github/copilot",target:"copilot"},{prefix:".github/prompts",target:"copilot"},{prefix:".github/skills",target:"copilot"},{prefix:".github/agents",target:"copilot"},{prefix:".github/hooks",target:"copilot"},{prefix:".claude/commands",target:"claude-code"},{prefix:".claude/rules",target:"claude-code"},{prefix:".claude/skills",target:"claude-code"},{prefix:".claude/agents",target:"claude-code"},{prefix:".cursor/commands",target:"cursor"},{prefix:".cursor/rules",target:"cursor"},{prefix:".cursor/agents",target:"cursor"},{prefix:".cursor/skills",target:"cursor"},{prefix:".continue/prompts",target:"continue"},{prefix:".continue/rules",target:"continue"},{prefix:".continue/skills",target:"continue"},{prefix:".junie/commands",target:"junie"},{prefix:".junie/rules",target:"junie"},{prefix:".junie/agents",target:"junie"},{prefix:".junie/skills",target:"junie"},{prefix:".kiro/steering",target:"kiro"},{prefix:".kiro/skills",target:"kiro"},{prefix:".kilo/commands",target:"kilo-code"},{prefix:".kilo/rules",target:"kilo-code"},{prefix:".kilo/skills",target:"kilo-code"},{prefix:".kilo/agents",target:"kilo-code"},{prefix:".kilocode/workflows",target:"kilo-code"},{prefix:".kilocode/rules",target:"kilo-code"},{prefix:".kilocode/skills",target:"kilo-code"},{prefix:".kilocodemodes",target:"kilo-code"},{prefix:".kilocodeignore",target:"kilo-code"},{prefix:".cline/skills",target:"cline"},{prefix:".clinerules/workflows",target:"cline"},{prefix:".windsurf/rules",target:"windsurf"},{prefix:".codex",target:"codex-cli"}];function $0(t){return t.replace(/\\/g,"/").replace(/^\/+|\/+$/g,"")}s($0,"norm");function Mp(t){let e=$0(t),r=[...M0].sort((n,o)=>o.prefix.length-n.prefix.length);for(let{prefix:n,target:o}of r)if(e===n||e.startsWith(`${n}/`))return o}s(Mp,"targetHintFromNativePath");function Mh(t,e){return Mp(t)===e}s(Mh,"pathSupportsNativePick");function Ax(t,e){if(!t||!e)return;let r=Mp(e);if(r&&r!==t)throw new Error(`--target "${t}" does not match the install path (native path suggests "${r}"). Omit --target to auto-detect, or point at a subtree for that target.`)}s(Ax,"validateTargetMatchesPath");function xx(t){return (t.commands?.length??0)+(t.rules?.length??0)+(t.skills?.length??0)+(t.agents?.length??0)>0}s(xx,"extendPickHasArrays");A();A();Pt();async function Tx(t,e){let r=join(t,...ge.split("/")),n=join(t,...e.split("/")),o=await N(n),i=[];for(let a of o){if(!/\.(toml|md)$/i.test(a))continue;let c=relative(r,a).replace(/\\/g,"/");if(c.startsWith("..")||c==="")continue;let m=c.replace(/\.(toml|md)$/i,"").split("/").filter(Boolean).join(":");m&&i.push(m);}return [...new Set(i)].sort()}s(Tx,"inferGeminiCommandNamesFromFiles");Pt();Pe();A();async function Us(t){let e=await N(t),r=new Set;for(let n of e){if(basename(n)==="SKILL.md"){r.add(basename(dirname(n)));continue}!relative(t,n).replace(/\\/g,"/").includes("/")&&n.toLowerCase().endsWith(".md")&&r.add(basename(n,".md"));}return [...r].filter(Boolean).sort()}s(Us,"skillNamesFromNativeSkillDir");A();ve();async function Dx(t,e){let r=join(t,...e.split("/"));if(e.startsWith(Eo)){let n=await N(r),o=[...new Set(n.filter(i=>i.toLowerCase().endsWith(".prompt.md")).map(i=>basename(i,".prompt.md")))].sort();return o.length?{commands:o}:{}}if(e.startsWith(".github/copilot")&&!e.includes("copilot-instructions.md")){let n=await N(r),o=[...new Set(n.filter(i=>i.includes(".instructions.md")).map(i=>basename(i).replace(/\.instructions\.md$/i,"")))].sort();return o.length?{rules:o}:{}}if(e.startsWith(".github/instructions")){let n=await N(r),o=new Set;for(let a of n){let c=basename(a);c.toLowerCase().endsWith(".instructions.md")?o.add(c.replace(/\.instructions\.md$/i,"")):c.toLowerCase().endsWith(".md")&&o.add(basename(a,".md"));}let i=[...o].sort();return i.length?{rules:i}:{}}if(e.startsWith(".github/skills")){let n=await Us(r);return n.length?{skills:n}:{}}if(e.startsWith(".github/agents")){let n=await N(r),o=[...new Set(n.filter(i=>i.toLowerCase().endsWith(".agent.md")).map(i=>basename(i,".agent.md")))].sort();return o.length?{agents:o}:{}}return {}}s(Dx,"inferCopilotPickFromPath");async function Ie(t,e){let r=await N(t),n=e.toLowerCase();return [...new Set(r.filter(o=>o.toLowerCase().endsWith(n)).map(o=>basename(o,e)))].sort()}s(Ie,"mdNames");async function Fx(t,e,r){let n=e.replace(/\\/g,"/").replace(/^\/+|\/+$/g,""),o=join(t,...n.split("/"));if(r==="gemini-cli"){if(n===ge||n.startsWith(`${ge}/`)){let i=await Tx(t,n);return i.length?{commands:i}:{}}return {}}if(r==="claude-code"){if(n.startsWith(".claude/commands")){let i=await Ie(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".claude/rules")){let i=await Ie(o,".md");return i.length?{rules:i}:{}}if(n.startsWith(".claude/agents")){let i=await Ie(o,".md");return i.length?{agents:i}:{}}if(n.startsWith(".claude/skills/")){let a=n.replace(/^\.claude\/skills\/?/,"").split("/").filter(Boolean)[0];return a?{skills:[a]}:{}}return {}}if(r==="cursor"){if(n.startsWith(".cursor/rules")){let i=await Ie(o,".mdc");return i.length?{rules:i}:{}}if(n.startsWith(".cursor/commands")){let i=await Ie(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".cursor/agents")){let i=await Ie(o,".md");return i.length?{agents:i}:{}}if(n.startsWith(".cursor/skills")){let i=await Us(o);return i.length?{skills:i}:{}}return {}}if(r==="copilot")return Dx(t,n);if(r==="windsurf"&&n.startsWith(".windsurf/rules")){let i=await Ie(o,".md");return i.length?{rules:i}:{}}if(r==="cline"){if(n.startsWith(Gt)){let i=await Us(o);return i.length?{skills:i}:{}}if(n.startsWith(Pr)){let i=await Ie(o,".md");return i.length?{commands:i}:{}}return {}}if(r==="continue"){if(n.startsWith(".continue/rules")){let i=await Ie(o,".md");return i.length?{rules:i}:{}}if(n.startsWith(".continue/prompts")){let i=await Ie(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".continue/skills")){let i=await Us(o);return i.length?{skills:i}:{}}return {}}if(r==="junie"){if(n.startsWith(".junie/commands")){let i=await Ie(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".junie/rules")){let i=await Ie(o,".md");return i.length?{rules:i}:{}}if(n.startsWith(".junie/agents")){let i=await Ie(o,".md");return i.length?{agents:i}:{}}if(n.startsWith(".junie/skills")){let i=await Us(o);return i.length?{skills:i}:{}}return {}}if(r==="codex-cli"&&n.startsWith(".codex")){let i=await N(o),a=[...new Set(i.filter(c=>c.toLowerCase().endsWith(".md")).map(c=>basename(c,".md")))].sort();return a.length?{rules:a}:{}}return {}}s(Fx,"inferImplicitPickFromNativePath");function vx(t){return (t.commands?.length??0)+(t.rules?.length??0)+(t.skills?.length??0)+(t.agents?.length??0)===0}s(vx,"isImplicitPickEmpty");Fg();function Vc(t){return t.replace(/\\/g,"/").replace(/\/+$/,"")}s(Vc,"normalizePath");function J0(t,e){let r=Vc(t),n=Vc(e);return r===n||r.startsWith(`${n}/`)||n.startsWith(`${r}/`)}s(J0,"overlapsPath");function $p(t,e){let r=t??[];return r.includes(e)||r.push(e),r}s($p,"addUnique");async function Y0(t){let e=await mkdtemp(join(tmpdir(),"am-install-native-")),r=join(e,"repo"),n=s(async()=>{await rm$1(e,{recursive:true,force:true});},"cleanup");try{return await cp$1(t,r,{recursive:!0}),{stageRoot:r,cleanup:n}}catch(o){throw await n(),o}}s(Y0,"makeStageRoot");function X0(t,e){let r;for(let o of t){if(o.feature==="rules"&&o.toPath.startsWith(".agentsmesh/rules/")){r={...r,rules:$p(r?.rules,basename(o.toPath,".md"))};continue}if(o.feature==="commands"&&o.toPath.startsWith(".agentsmesh/commands/")){let i=Vc(relative(join(e,".agentsmesh","commands"),join(e,o.toPath)));r={...r,commands:$p(r?.commands,i.replace(/\.md$/i,"").split("/").filter(Boolean).join(":"))};continue}if(o.feature==="agents"&&o.toPath.startsWith(".agentsmesh/agents/")){r={...r,agents:$p(r?.agents,basename(o.toPath,".md"))};continue}if(o.feature==="skills"&&o.toPath.startsWith(".agentsmesh/skills/")){let a=Vc(relative(join(e,".agentsmesh","skills"),join(e,o.toPath))).split("/")[0];a&&(r={...r,skills:$p(r?.skills,a)});}}return r&&(r.rules?.length??0)+(r.commands?.length??0)+(r.agents?.length??0)+(r.skills?.length??0)>0?r:void 0}s(X0,"buildPickFromResults");function Z0(t,e,r,n){let o=join(e,...Vc(t).split("/")),i=r.filter(a=>J0(o,a.fromPath));if(i.length===0)throw new Error(`No installable native resources found under "${t}" for target "${n}".`);return {features:[...new Set(i.map(a=>a.feature))],pick:X0(i,e)}}s(Z0,"scopeImportedResults");async function Gh(t,e){let{stageRoot:r,cleanup:n}=await Y0(t);try{let o=await Pc(r,e);return {stageRoot:r,results:o,cleanup:n}}catch(o){throw await n(),o}}s(Gh,"stageImportedNativeRepo");async function jh(t,e,r){let n=await Gh(t,r);try{return {stageRoot:n.stageRoot,cleanup:n.cleanup,...Z0(e,n.stageRoot,n.results,r)}}catch(o){throw await n.cleanup(),o}}s(jh,"stageNativeInstallScope");async function jx(t,e,r,n){let o=n.explicitTarget?.trim();o&&Re.parse(o);let i=r.replace(/\\/g,"/").replace(/^\/+|\/+$/g,"");Ax(o,i);let a=join(t,".agentsmesh"),c=await v(a),l=i?Mp(i):void 0,m=!c&&!o?await hl(t)??void 0:void 0;if(!o&&l&&m&&l!==m)throw new Error(`Install path suggests native layout "${l}" but auto-detect imported "${m}". Use --target ${l} for this path, or install from the repo root without a conflicting subtree path.`);let p=o??l??m,u=!!i&&!!p&&!i.startsWith(".agentsmesh");if(!c&&p){if(u){let E=await jh(t,i,p);return {discoveryRoot:E.stageRoot,implicitPick:E.pick,scopedFeatures:E.features,yamlTarget:p,importHappened:true,cleanup:E.cleanup}}let _=await Gh(t,p);return {discoveryRoot:i?join(_.stageRoot,i):_.stageRoot,yamlTarget:p,importHappened:true,cleanup:_.cleanup}}let f;c?i?p&&Mh(i,p)?f=t:f=e:f=t:f=e;let g,h,R;if(u&&p){let _=await jh(t,i,p);f=_.stageRoot,g=_.pick,h=_.features,R=_.cleanup;}else if(f===t&&i&&p&&Mh(i,p)&&(g=await Fx(t,i,p),vx(g)))throw new Error(`No installable native resources found under "${i}" for target "${p}".`);let C;return o?C=o:p&&(g&&xx(g)||(h?.length??0)>0)&&(C=p),{discoveryRoot:f,implicitPick:g,scopedFeatures:h,yamlTarget:C,importHappened:R!==void 0,cleanup:R}}s(jx,"prepareInstallDiscovery");async function Ux(t,e,r,n){let o=await jx(t,e,r,{explicitTarget:n}),{canonical:i,implicitPick:a}=await Np(o.discoveryRoot),c=a??o.implicitPick,l=la(i,{implicitPick:c,scopedFeatures:o.scopedFeatures}),m=js(l);return {prep:o,discovered:i,implicitPick:c,narrowed:l,discoveredFeatures:m}}s(Ux,"resolveDiscoveredForInstall");async function Kx(t){return t.explicitAs?{implicitPick:void 0,...await bx(t.contentRoot,t.explicitAs,t.explicitTarget,t.replayPick)}:Ux(t.resolvedPath,t.contentRoot,t.pathInRepo,t.explicitTarget)}s(Kx,"resolveInstallDiscovery");function pa(t){return t==="."||t===""?void 0:t}s(pa,"trimDot");function Q0(t,e){let r=basename(e).replace(/\.md$/i,"");return t==="agents"?{agents:[r]}:t==="commands"?{commands:[r]}:{rules:[r]}}s(Q0,"markdownPick");async function Bx(t){if(!t.as)return {pathInRepo:pa(t.pathInRepo)};let e=t.pathInRepo.replace(/^\/+|\/+$/g,""),r=await stat(t.contentRoot);if(t.as!=="skills"&&r.isFile()&&t.contentRoot.toLowerCase().endsWith(".md"))return {pathInRepo:pa(dirname(e)),pick:Q0(t.as,e||t.contentRoot)};if(t.as==="skills"){if(r.isFile()&&basename(t.contentRoot)==="SKILL.md"){let n=e?dirname(e):dirname(t.contentRoot);return {pathInRepo:pa(dirname(n)),pick:{skills:[basename(n)]}}}if(r.isDirectory()){let n=e||basename(t.contentRoot),o=join(t.contentRoot.replace(/\/+$/g,""),"SKILL.md");try{if((await stat(o)).isFile()){let a=await Fp(o);return {pathInRepo:pa(dirname(n)),pick:{skills:[a||basename(n)]}}}}catch{return {pathInRepo:pa(e)}}}}return {pathInRepo:pa(e)}}s(Bx,"resolveManualInstallPersistence");nn();nt();async function on(t){return process.stdin.isTTY?new Promise(e=>{let r=Hx.createInterface({input:process.stdin,output:process.stdout});r.question(`${t} (y/n) `,n=>{r.close();let o=n.trim().toLowerCase();e(o==="y"||o==="yes");});}):false}s(on,"confirm");function tK(t){return !!(t.skills.length||t.rules.length||t.commands.length||t.agents.length)}s(tK,"hasArrayResources");function zx(t){return tK(t)||t.mcp!==null||t.permissions!==null||t.hooks!==null||t.ignore.length>0}s(zx,"hasInstallableResources");async function Vx(t,e,r,n){let o=t.skills.map(c=>Sx(c)),i=o.filter(c=>c.ok).map(c=>c.skill),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await on(`Include invalid skill "${c.skill.name}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.skill);else e&&(i=o.map(c=>c.skill));return r&&(i=o.filter(c=>c.ok).map(c=>c.skill)),i}s(Vx,"resolveSkillPool");async function Jx(t,e,r,n){let o=t.rules.map(c=>Rx(c)),i=o.filter(c=>c.ok).map(c=>c.rule),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await on(`Include invalid rule "${ae(c.rule)}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.rule);else e&&(i=o.map(c=>c.rule));return r&&(i=o.filter(c=>c.ok).map(c=>c.rule)),i}s(Jx,"resolveRulePool");async function Yx(t,e,r,n){let o=t.commands.map(c=>kx(c)),i=o.filter(c=>c.ok).map(c=>c.command),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await on(`Include invalid command "${c.command.name}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.command);else e&&(i=o.map(c=>c.command));return r&&(i=o.filter(c=>c.ok).map(c=>c.command)),i}s(Yx,"resolveCommandPool");async function Xx(t,e,r,n){let o=t.agents.map(c=>Ox(c)),i=o.filter(c=>c.ok).map(c=>c.agent),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await on(`Include invalid agent "${c.agent.name}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.agent);else e&&(i=o.map(c=>c.agent));return r&&(i=o.filter(c=>c.ok).map(c=>c.agent)),i}s(Xx,"resolveAgentPool");async function Zx(t,e){let r=e.skills.map(a=>a.name),n=e.rules.map(a=>ae(a)),o=e.commands.map(a=>a.name),i=e.agents.map(a=>a.name);for(let a of e.skills)t.skills.some(c=>c.name===a.name)&&(await on(`Skill "${a.name}" already exists in merged config. Add extend anyway?`)||(r=r.filter(l=>l!==a.name)));for(let a of e.rules){let c=ae(a);t.rules.some(l=>ae(l)===c)&&(await on(`Rule "${c}" already exists in merged config. Add extend anyway?`)||(n=n.filter(m=>m!==c)));}for(let a of e.commands)t.commands.some(c=>c.name===a.name)&&(await on(`Command "${a.name}" already exists in merged config. Add extend anyway?`)||(o=o.filter(l=>l!==a.name)));for(let a of e.agents)t.agents.some(c=>c.name===a.name)&&(await on(`Agent "${a.name}" already exists in merged config. Add extend anyway?`)||(i=i.filter(l=>l!==a.name)));return {skillNames:r,ruleSlugs:n,commandNames:o,agentNames:i}}s(Zx,"resolveInstallConflicts");function qx(t,e){if(!t)return;let r={},n=t.skills?.filter(c=>e.skillNames.includes(c)),o=t.rules?.filter(c=>e.ruleSlugs.includes(c)),i=t.commands?.filter(c=>e.commandNames.includes(c)),a=t.agents?.filter(c=>e.agentNames.includes(c));return n&&n.length>0&&(r.skills=n),o&&o.length>0&&(r.rules=o),i&&i.length>0&&(r.commands=i),a&&a.length>0&&(r.agents=a),Object.keys(r).length>0?r:void 0}s(qx,"pickForSelectedResources");function eK(t,e){let r=t.split("/").filter(Boolean);return r.length>0&&r[r.length-1]===e}s(eK,"pathEndsWithName");function Gp(t,e,r){return r!==1||e.length!==1?false:eK(t,e[0])}s(Gp,"inferSingleNamePick");function Qx(t){let{pathInRepo:e,implicitPick:r,preConflictCounts:n,selected:o}=t,i={},a=o.skillNames.length>0&&(!!r?.skills?.length||o.skillNames.length<n.skills||Gp(e,o.skillNames,n.skills)),c=o.ruleSlugs.length>0&&(!!r?.rules?.length||o.ruleSlugs.length<n.rules||Gp(e,o.ruleSlugs,n.rules)),l=o.commandNames.length>0&&(!!r?.commands?.length||o.commandNames.length<n.commands||Gp(e,o.commandNames,n.commands)),m=o.agentNames.length>0&&(!!r?.agents?.length||o.agentNames.length<n.agents||Gp(e,o.agentNames,n.agents));return a&&(i.skills=[...o.skillNames]),c&&(i.rules=[...o.ruleSlugs]),l&&(i.commands=[...o.commandNames]),m&&(i.agents=[...o.agentNames]),Object.keys(i).length?i:void 0}s(Qx,"buildInstallPick");function tP(t,e){let r=new Set(t);return e.skillNames.length===0&&r.delete("skills"),e.ruleSlugs.length===0&&r.delete("rules"),e.commandNames.length===0&&r.delete("commands"),e.agentNames.length===0&&r.delete("agents"),[...r]}s(tP,"deriveInstallFeatures");function rK(t){return t.skillNames.length===0&&t.ruleSlugs.length===0&&t.commandNames.length===0&&t.agentNames.length===0}s(rK,"isEmptyInstallSelection");function eP(t){let{selected:e,discoveredFeatures:r,preConflict:n}=t,o=s(c=>r.includes(c),"had"),i=o("skills")&&e.skillNames.length===0&&n.skills>0&&"skills"||o("rules")&&e.ruleSlugs.length===0&&n.rules>0&&"rules"||o("commands")&&e.commandNames.length===0&&n.commands>0&&"commands"||o("agents")&&e.agentNames.length===0&&n.agents>0&&"agents";if(i)throw new Error(`No ${i} selected to install.`);let a=r.some(c=>["mcp","permissions","hooks","ignore"].includes(c));if(rK(e)&&!a)throw new Error("No resources selected to install.")}s(eP,"ensureInstallSelection");ln();function rP(t,e){if(t.find(n=>n.name===e.name&&n.source!==e.source))throw new Error(`Extends entry "${e.name}" already exists with a different source. Use --name to provide a different name.`)}s(rP,"assertExtendNameAvailable");function nK(t,e,r){if(r===void 0){if(!t)return;let o={...t};for(let i of ["skills","commands","rules","agents"])e.includes(i)&&delete o[i];return Object.keys(o).length?o:void 0}let n={...t};for(let o of ["skills","commands","rules","agents"]){if(!(o in r))continue;let i=r[o];if(i===void 0||i.length===0){delete n[o];continue}n[o]=[...new Set([...t?.[o]??[],...i])];}return Object.keys(n).length?n:void 0}s(nK,"mergePick");function nP(t,e){let r=t.findIndex(a=>a.source===e.source);if(r<0)return [...t,{name:e.name,source:e.source,version:e.version,features:e.features,path:e.path,pick:e.pick,target:e.target}];let n=t[r],o=[...new Set([...n.features,...e.features])],i=nK(n.pick,e.features,e.pick);return t.map((a,c)=>c===r?{name:e.name,source:e.source,version:e.version??n.version,features:o,path:e.path!==void 0?e.path:n.path,pick:i,target:e.target??n.target}:a)}s(nP,"mergeExtendList");A();async function oP(t,e,r){let n=await y(t);if(n===null)throw new Error(`Missing config: ${t}`);let o=parse(n),i=nP(e.extends,r);o.extends=i;let a=stringify(o,{indent:2,lineWidth:0});await S(t,a.endsWith(`
|
|
308
|
+
`),false}}s(Mh,"seedAgentsmeshMcpEntry");function yx(t,e){return t.map(r=>({from:relative(e,r.fromPath).replaceAll("\\","/"),to:r.toPath}))}s(yx,"mapResults");async function _x(t,e){let r=e??process.cwd(),n=t.from;if(typeof n!="string"||!n)throw new Error("--from is required. Example: agentsmesh import --from claude-code");let o=n.toLowerCase().trim(),i=t.global===true?"global":"project";if(Ye(o)){let p=Aa(r,i),f=await vp(o).importFrom(p.rootBase,{scope:i});return f.length>0&&await Mh(p.rootBase),{exitCode:0,data:{scope:i,target:o,files:yx(f,p.rootBase)}}}let a,c;try{({config:a,context:c}=await ut(r,i));}catch{throw new Error(`Unknown --from "${n}" and no agentsmesh.yaml found. Run 'agentsmesh init' to enable plugin targets, or use a builtin: ${lt.join(", ")}.`)}await qt(a,r);let l=et(o);if(!l)throw new Error(`Unknown --from "${n}". Supported: ${[...lt,...a.pluginTargets??[]].join(", ")}.`);let m=await l.generators.importFrom(c.rootBase,{scope:i});return m.length>0&&await Mh(c.rootBase),{exitCode:0,data:{scope:i,target:o,files:yx(m,c.rootBase)}}}s(_x,"runImport");de();ln();function Mp(t){let e=[],r={new:0,updated:0,unchanged:0,deleted:0};for(let n of t){if(n.status==="unchanged"){r.unchanged++;continue}if(n.status==="created"){r.new++;let o=createTwoFilesPatch(`${n.path} (current)`,`${n.path} (generated)`,"",n.content,void 0,void 0,{context:3});e.push({path:n.path,patch:o});continue}if(n.status==="updated"&&n.currentContent!==void 0){r.updated++;let o=createTwoFilesPatch(`${n.path} (current)`,`${n.path} (generated)`,n.currentContent,n.content,void 0,void 0,{context:3});e.push({path:n.path,patch:o});continue}}return {diffs:e,summary:r}}s(Mp,"computeDiff");function $p(t){return `${t.new} files would be created, ${t.updated} updated, ${t.unchanged} unchanged, ${t.deleted} deleted`}s($p,"formatDiffSummary");Qn();async function Sx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=t.targets,i=typeof o=="string"&&o?o.split(",").map(g=>g.trim()).filter(Boolean):void 0,{config:a,context:c}=await ut(r,n);await qt(a,r);let{canonical:l}=await se(a,c.configDir,{},c.canonicalDir),m=await He({config:a,canonical:l,projectRoot:c.rootBase,scope:n,targetFilter:i});if(m.length===0)return {exitCode:0,data:{files:[],patches:[],summary:{created:0,updated:0,unchanged:0,deleted:0}}};let{diffs:p,summary:u}=Mp(m);return {exitCode:0,data:{files:m.filter(g=>g.status!=="unchanged"&&g.status!=="skipped").map(g=>({path:g.path,target:g.target,status:g.status})),patches:p.map(g=>({path:g.path,patch:g.patch})),summary:{created:u.new,updated:u.updated,unchanged:u.unchanged,deleted:u.deleted}}}}s(Sx,"runDiff");de();ln();b();Ce();ts();Tt();var N0=[{canonicalKey:"permissions",capabilityKey:"permissions",featureFlag:"permissions",file:".agentsmesh/permissions.yaml",label:"permissions",hasContent:s(t=>{let e=t.permissions;if(!e)return false;let r=e.ask?.length??0;return e.allow.length+e.deny.length+r>0},"hasContent")},{canonicalKey:"hooks",capabilityKey:"hooks",featureFlag:"hooks",file:".agentsmesh/hooks.yaml",label:"hooks",hasContent:s(t=>{let e=t.hooks;return e?Object.values(e).some(r=>Array.isArray(r)&&r.length>0):false},"hasContent")},{canonicalKey:"mcp",capabilityKey:"mcp",featureFlag:"mcp",file:".agentsmesh/mcp.json",label:"MCP servers",hasContent:s(t=>{let e=t.mcp;return e?Object.keys(e.mcpServers).length>0:false},"hasContent")},{canonicalKey:"commands",capabilityKey:"commands",featureFlag:"commands",file:".agentsmesh/commands",label:"commands",hasContent:s(t=>t.commands.length>0,"hasContent")},{canonicalKey:"agents",capabilityKey:"agents",featureFlag:"agents",file:".agentsmesh/agents",label:"agents",hasContent:s(t=>t.agents.length>0,"hasContent")},{canonicalKey:"skills",capabilityKey:"skills",featureFlag:"skills",file:".agentsmesh/skills",label:"skills",hasContent:s(t=>t.skills.length>0,"hasContent")},{canonicalKey:"ignore",capabilityKey:"ignore",featureFlag:"ignore",file:".agentsmesh/ignore",label:"ignore patterns",hasContent:s(t=>t.ignore.length>0,"hasContent")}];function Cx(t){let e=new Set(t.enabledFeatures),r=[];for(let n of N0)!e.has(n.featureFlag)||!n.hasContent(t.canonical)||tr(t.capabilities[n.capabilityKey]).level!=="none"||r.push(j(n.file,t.target,`${t.target} does not support ${n.label}; canonical entries are silently dropped during generation. Disable the feature for this target or remove the canonical content.`));return r}s(Cx,"lintSilentFeatureDrops");Tt();var F0=/^(?:\s*(?:bash|sh|zsh|pwsh|powershell)\s+)?["']?(?<path>(?:\.{1,2}\/|[^/\s"'`]+\/)[^\s"'`]+)["']?(?:\s|$)/;function v0(t){let r=t.match(F0)?.groups?.path;return typeof r=="string"?r:null}s(v0,"extractScriptToken");function Rx(t){if(t.hasScriptProjection)return [];let e=t.canonical.hooks;if(!e)return [];let r=[];for(let n of Object.values(e))if(Array.isArray(n))for(let o of n){if(typeof o?.command!="string")continue;let i=v0(o.command);i&&r.push(j(".agentsmesh/hooks.yaml",t.target,`${t.target} hook command references script "${i}"; agentsmesh does not copy hook scripts into ${t.target} output, so the script must already exist relative to the hook execution directory or the generated config will fail.`));}return r}s(Rx,"lintHookScriptReferences");Tt();function Ox(t){if(t.preservesManualActivation)return [];let e=[];for(let r of t.canonical.rules)r.root||r.trigger==="manual"&&(r.targets.length>0&&!r.targets.includes(t.target)||e.push(j(r.source,t.target,`Rule has trigger: 'manual' (Cursor-style "@-mention only" activation), but ${t.target} loads every rule unconditionally. The rule will become always-on for ${t.target} \u2014 restrict it with \`targets: [cursor]\`, convert it to a skill with manual invocation, or remove it.`)));return e}s(Ox,"lintRuleScopeInversion");var M0=["node_modules",".git","dist","coverage",".agentsmesh"];async function $0(t){return (await D(t)).filter(n=>{let o=relative(t,n);return !M0.some(i=>o.includes(`/${i}/`)||o.startsWith(`${i}/`))}).map(n=>relative(t,n))}s($0,"getProjectFiles");async function Gp(t,e,r,n,o={}){let i=o.scope??"project",a=[...t.targets,...t.pluginTargets??[]],c=n?a.filter(S=>n.includes(S)):a,l=t.features.includes("rules"),m=t.features.includes("commands"),p=t.features.includes("mcp"),u=t.features.includes("permissions"),f=t.features.includes("hooks"),g=[],h=i==="global"?[]:await $0(r);for(let S of c){let _=et(S),k=Ye(S)?vp(S):_;k?.capabilities&&g.push(...Cx({target:S,capabilities:k.capabilities,canonical:e,enabledFeatures:t.features})),f&&g.push(...Rx({target:S,canonical:e,hasScriptProjection:_?.postProcessHookOutputs!==void 0})),l&&g.push(...Ox({target:S,canonical:e,preservesManualActivation:_?.preservesManualActivation===true})),l&&k?.lintRules&&g.push(...k.lintRules(e,r,h,{scope:i})),_?.generators.lint&&g.push(..._.generators.lint(e));let T={scope:i};m&&k?.lint?.commands&&g.push(...k.lint.commands(e,T)),p&&k?.lint?.mcp&&g.push(...k.lint.mcp(e,T)),u&&k?.lint?.permissions&&g.push(...k.lint.permissions(e,T)),f&&k?.lint?.hooks&&g.push(...k.lint.hooks(e,T));}let R=g.some(S=>S.level==="error");return {diagnostics:g,hasErrors:R}}s(Gp,"runLint");Qn();async function kx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=t.targets,i=typeof o=="string"&&o?o.split(",").map(u=>u.trim()).filter(Boolean):void 0,{config:a,context:c}=await ut(r,n);await qt(a,r);let{canonical:l}=await se(a,c.configDir,{},c.canonicalDir),{diagnostics:m,hasErrors:p}=await Gp(a,l,c.configDir,i,{scope:n});return {exitCode:p?1:0,data:{diagnostics:m.map(u=>({level:u.level,file:u.file,target:u.target,message:u.message})),summary:{errors:m.filter(u=>u.level==="error").length,warnings:m.filter(u=>u.level==="warning").length}}}}s(kx,"runLintCmd");st();function wx(t){let{data:e}=t;if(e.diagnostics.length===0){I.success("All checks passed.");return}let r=e.diagnostics.filter(a=>a.level==="error"),n=e.diagnostics.filter(a=>a.level==="warning");for(let a of r)I.error(`${a.file} (${a.target}): ${a.message}`);for(let a of n)I.warn(`${a.file} (${a.target}): ${a.message}`);let o=e.summary.errors,i=e.summary.warnings;I.info(`${o} error${o!==1?"s":""}, ${i} warning${i!==1?"s":""}`);}s(wx,"renderLint");st();function Lx(t){let{data:e}=t;if(!e.hasLock){I.error("Not initialized for collaboration. Run 'agentsmesh generate' first.");return}if(e.inSync){I.success("Lock file is in sync.");return}let r=new Set(e.lockedViolations);I.error("Conflict detected:");for(let n of e.extendsModified)I.error(` extend "${n}" was modified`);for(let n of e.modified){let o=r.has(n)?" [LOCKED]":"";I.error(` ${n} was modified${o}`);}for(let n of e.added){let o=r.has(n)?" [LOCKED]":"";I.error(` ${n} was added${o}`);}for(let n of e.removed){let o=r.has(n)?" [LOCKED]":"";I.error(` ${n} was removed${o}`);}I.info("Run 'agentsmesh merge' to resolve, or 'agentsmesh generate --force' to accept current state.");}s(Lx,"renderCheck");st();function bx(t){let{data:e}=t;if(e.files.length===0){I.info(`Nothing to import from ${e.target}.`);return}for(let n of e.files)I.success(`${n.from} \u2192 ${n.to}`);let r=e.scope==="global"?" --global":"";I.info(`Imported ${e.files.length} file(s). Run 'agentsmesh generate${r}' to sync to other tools.`);}s(bx,"renderImport");st();function Ax(t){let{summary:e}=t.data;if(e.created+e.updated+e.unchanged+e.deleted===0){I.info("No files to generate (no root rule or rules feature disabled).");return}for(let n of t.data.patches)process.stdout.write(n.patch);I.info($p({new:e.created,updated:e.updated,unchanged:e.unchanged,deleted:e.deleted}));}s(Ax,"renderDiff");st();function xx(t){if(!t.data.hadConflict){I.info("No conflicts to resolve.");return}I.success("Lock file conflict resolved.");}s(xx,"renderMerge");Hc();Vc();de();ln();Hc();Vc();st();var U0=300;function W0(t){return t.replace(/\\/g,"/").replace(/\/+$/,"")}s(W0,"normalizeWatchPath");function K0(t,e,r){let n=W0(relative(t,e));return n===""?true:n===".lock"||n===".lock.tmp"||n===".generate.lock"||n.endsWith("/.lock")||n.endsWith("/.lock.tmp")||n.endsWith("/.generate.lock")||n.includes("/.generate.lock/")||n.startsWith(".generate.lock/")}s(K0,"shouldIgnoreWatchPath");function B0(t,e,r,n,o,i,a,c,l){return JSON.stringify({features:t,rulesCount:e,commandsCount:r,agentsCount:n,skillsCount:o,mcpServerCount:i,permissionsCount:a,hooksCount:c,ignoreCount:l})}s(B0,"featureFingerprint");async function Tx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",{context:o}=await ut(r,n),i=[o.canonicalDir,join(o.configDir,"agentsmesh.yaml"),join(o.configDir,"agentsmesh.local.yaml")],a=null,c=null,l=false,m=null,u=s(async()=>{if(l)return;a=null;let{config:R,context:S}=await ut(r,n),{canonical:_}=await se(R,S.configDir,{},S.canonicalDir),k=_.mcp?Object.keys(_.mcp.mcpServers).length:0,T=_.permissions?_.permissions.allow.length+_.permissions.deny.length:0,P=_.hooks?Object.values(_.hooks).reduce((Lt,Et)=>Lt+(Array.isArray(Et)?Et.length:0),0):0,A=_.ignore.length,Z=B0(R.features,_.rules.length,_.commands.length,_.agents.length,_.skills.length,k,T,P,A),B=c!==null&&c!==Z;if(c=Z,l)return;let V=await da(t,r,{printMatrix:false});if(fa(V),!l)if(B){let Lt=await Bc(t,r);zc(Lt,{verbose:t.verbose===true});}else I.info("Regenerated.");},"run"),f=s(()=>{let R=u().catch(S=>{if(!l){let _=S instanceof Error?S.message:String(S);I.error(_);}}).finally(()=>{m===R&&(m=null);});m=R;},"scheduleRun"),g=s(()=>{l||(a&&clearTimeout(a),a=setTimeout(f,U0));},"schedule"),h=j0.watch(i,{ignoreInitial:true,usePolling:process.platform==="win32"});return h.on("all",(R,S)=>{K0(o.canonicalDir,S)||g();}),await new Promise((R,S)=>{h.once("ready",R),h.once("error",S);}),I.info(n==="global"?"Watching ~/.agentsmesh/ and agentsmesh.yaml...":"Watching .agentsmesh/ and agentsmesh.yaml..."),m=u(),await m,m=null,{stop:s(async()=>{l=true,a&&(clearTimeout(a),a=null),await h.close(),m&&await m;},"stop")}}s(Tx,"runWatch");de();dl();async function jp(t){let{config:e,configDir:r,canonicalDir:n}=t,o=await Rp(n);if(o===null)return {inSync:false,hasLock:false,modified:[],added:[],removed:[],extendsModified:[],lockedViolations:[]};let i=await Zn(n),a=await ai(e,r),c=a.length>0?await pa(a):{},l=new Set(Object.keys(o.checksums)),m=new Set(Object.keys(i)),p=[],u=[],f=[];for(let _ of l){let k=i[_];k===void 0?f.push(_):k!==o.checksums[_]&&p.push(_);}for(let _ of m)l.has(_)||u.push(_);let g=new Set([...Object.keys(o.extends),...Object.keys(c)]),h=[];for(let _ of g)c[_]!==o.extends[_]&&h.push(_);let R=Ep(o.checksums,i,e.collaboration?.lock_features??[]);return {inSync:p.length===0&&u.length===0&&f.length===0&&h.length===0,hasLock:true,modified:p,added:u,removed:f,extendsModified:h,lockedViolations:R}}s(jp,"checkLockSync");Qn();async function Dx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",{config:o,context:i}=await ut(r,n);await qt(o,r);let a=await jp({config:o,configDir:i.configDir,canonicalDir:i.canonicalDir});return a.hasLock?{exitCode:a.inSync?0:1,data:{hasLock:true,inSync:a.inSync,modified:[...a.modified],added:[...a.added],removed:[...a.removed],extendsModified:[...a.extendsModified],lockedViolations:[...a.lockedViolations]}}:{exitCode:1,data:{hasLock:false,inSync:false,modified:[],added:[],removed:[],extendsModified:[],lockedViolations:[]}}}s(Dx,"runCheck");de();b();dl();var z0=".lock",V0="<<<<<<<";async function $h(t){let e=join(t,z0),r=await y(e);return r===null?false:r.includes(V0)}s($h,"hasLockConflict");async function Fx(t,e,r){if(!await $h(t))throw new Error("No conflict to resolve.");let o=await Zn(t),i=dirname(t),a=r?await ai(r,i):[],c=a.length>0?await pa(a):{},l=await kp(join(t,"packs")),m=process.env.USER??process.env.USERNAME??"unknown";await Op(t,{generatedAt:new Date().toISOString(),generatedBy:m,libVersion:e,checksums:o,extends:c,packs:l});}s(Fx,"resolveLockConflict");async function vx(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",{config:o,context:i}=await ut(r,n),a=i.canonicalDir;return await $h(a)?(await Fx(a,ka(),o),{exitCode:0,data:{hadConflict:true,resolved:true}}):{exitCode:0,data:{hadConflict:false,resolved:false}}}s(vx,"runMerge");de();b();Ta();var X0=promisify(execFile);function Up(t,e){if(t.startsWith("-"))throw new Error(`agentsmesh refuses ${e} starting with "-" (option-injection guard): ${t}`)}s(Up,"ensureNotFlag");async function Gh(t){let{stdout:e}=await X0("git",t,{env:{...process.env,GIT_TERMINAL_PROMPT:"0"}});return e.trim()}s(Gh,"runGit");async function Mx(){try{return await Gh(["--version"]),!0}catch{return false}}s(Mx,"isGitAvailable");async function Z0(t,e){Up(t,"remote-url"),Up(e,"ref");let r=[e,`refs/heads/${e}`,`refs/tags/${e}`],n;for(let o of r)try{let a=(await Gh(["ls-remote",t,o])).split(`
|
|
309
|
+
`).map(l=>l.trim()).find(l=>l.length>0);if(!a)continue;let c=a.split(/\s+/)[0];if(c&&/^[0-9a-f]{40}$/i.test(c))return c}catch(i){n=i;}throw new Error(`Could not resolve ref "${e}" for ${t}: ${n instanceof Error?n.message:String(n)}`)}s(Z0,"gitLsRemoteResolve");async function $x(t,e){Up(e,"remote-url");let r=t===""?"HEAD":t;if(Up(r,"ref"),/^[0-9a-f]{40}$/i.test(r))return r.toLowerCase();if(r==="HEAD"){let o=(await Gh(["ls-remote",e,"HEAD"])).split(`
|
|
310
|
+
`).find(a=>a.trim().length>0);if(!o)throw new Error(`Could not resolve HEAD for ${e}`);let i=o.split(/\s+/)[0];if(!i||!/^[0-9a-f]{40}$/i.test(i))throw new Error(`Invalid ls-remote HEAD line for ${e}`);return i.toLowerCase()}return Z0(e,r)}s($x,"resolveRemoteRefForInstall");async function Gx(t){if(t.kind==="local")return {resolvedPath:t.localRoot,sourceForYaml:t.localSourceForYaml};let e=t.gitRemoteUrl;if(!e)throw new Error("Internal error: missing git remote URL");let r=await $x(t.rawRef||"HEAD",e);if(t.kind==="github"){let c=`github:${t.org}/${t.repo}@${r}`;return {resolvedPath:(await ii(c,"install",{cacheDir:fe(),refresh:false,allowOfflineFallback:false})).resolvedPath,sourceForYaml:c,version:r}}if(t.kind==="gitlab"){let c=`gitlab:${t.org}/${t.repo}@${r}`;return {resolvedPath:(await ii(c,"install",{cacheDir:fe(),refresh:false,allowOfflineFallback:false})).resolvedPath,sourceForYaml:c,version:r}}let n=r,i=`git+${(t.gitPlusBase??e).split("#")[0]}#${n}`;return {resolvedPath:(await ii(i,"install",{cacheDir:fe(),refresh:false,allowOfflineFallback:false})).resolvedPath,sourceForYaml:i,version:r}}s(Gx,"fetchInstallSource");async function jx(t,e){if(t.kind==="local")return {resolvedPath:t.localRoot,sourceForYaml:t.localSourceForYaml};try{let r=await Gx(t);return {resolvedPath:r.resolvedPath,sourceForYaml:r.sourceForYaml,version:r.version}}catch(r){let n=r instanceof Error?r.message:String(r),o=new Error(`Failed to fetch from ${e}: ${n}. Check your network connection and try again.`);throw r instanceof Error&&(o.cause=r),o}}s(jx,"resolveInstallResolvedPath");function jh(t){try{let e=new URL(t);if(e.hostname!=="github.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("tree");if(n<2||n+1>=r.length)return null;let o=r[0],i=r[1],a=r[n+1],c=r.slice(n+2).join("/");return !o||!i||!a?null:{org:o,repo:i,ref:a,path:c||""}}catch{return null}}s(jh,"parseGithubTreeUrl");function Uh(t){try{let e=new URL(t);if(e.hostname!=="github.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("blob");if(n<2||n+1>=r.length)return null;let o=r[0],i=r[1],a=r[n+1],c=r.slice(n+2).join("/");return !o||!i||!a||!c?null:{org:o,repo:i,ref:a,path:c}}catch{return null}}s(Uh,"parseGithubBlobUrl");function Wh(t){try{let e=new URL(t);if(e.hostname!=="gitlab.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("-");if(n<0||r[n+1]!=="tree")return null;let o=n+1;if(o+1>=r.length)return null;let i=r[o+1],a=r.slice(o+2).join("/"),c=r.slice(0,n);if(c.length<2)return null;let l=c[c.length-1],m=c.slice(0,-1).join("/");return !m||!l||!i?null:{namespace:m,project:l,ref:i,path:a||""}}catch{return null}}s(Wh,"parseGitlabTreeUrl");function Kh(t){try{let e=new URL(t);if(e.hostname!=="gitlab.com")return null;let r=e.pathname.split("/").filter(Boolean),n=r.indexOf("-");if(n<0||r[n+1]!=="blob")return null;let o=n+1;if(o+1>=r.length)return null;let i=r[o+1],a=r.slice(o+2).join("/"),c=r.slice(0,n);if(c.length<2)return null;let l=c[c.length-1],m=c.slice(0,-1).join("/");return !m||!l||!i||!a?null:{namespace:m,project:l,ref:i,path:a}}catch{return null}}s(Kh,"parseGitlabBlobUrl");var q0=new Set(["tree","blob","commit","releases","actions","issues","pulls","settings","wiki","discussions","security","projects","packages"]);function Bh(t){try{let e=new URL(t);if(e.hostname!=="github.com")return null;let r=e.pathname.split("/").filter(Boolean).map(i=>i.replace(/\.git$/i,""));if(r.length<2||r.length>2||q0.has(r[1]))return null;let n=r[0],o=r[1];return {org:n,repo:o}}catch{return null}}s(Bh,"parseGithubRepoUrl");function Hh(t){try{let e=new URL(t);if(e.hostname!=="gitlab.com")return null;let r=e.pathname.split("/").filter(Boolean).map(i=>i.replace(/\.git$/i,""));if(r.length<2||r.includes("-"))return null;let n=r[r.length-1],o=r.slice(0,-1).join("/");return !o||!n?null:{namespace:o,project:n}}catch{return null}}s(Hh,"parseGitlabRepoUrl");function zh(t){let e=t.match(/^git@github\.com:([^/]+)\/(.+?)(?:\.git)?$/i);return e?{org:e[1],repo:e[2].replace(/\.git$/i,"")}:null}s(zh,"parseGitSshGithub");function Vh(t){let e=t.match(/^git@gitlab\.com:(.+?)(?:\.git)?$/i);if(!e)return null;let n=e[1].replace(/\.git$/i,"").split("/").filter(Boolean);if(n.length<2)return null;let o=n[n.length-1];return {namespace:n.slice(0,-1).join("/"),project:o}}s(Vh,"parseGitSshGitlab");b();var eW=/^[A-Za-z]:[\\/]/,rW=/^[A-Za-z]:\//;function Ux(...t){return t.some(e=>e.includes("\\")||eW.test(e))?win32:posix}s(Ux,"pathApiFor");function Yc(t){return t.replace(/\\/g,"/")}s(Yc,"toPosixPath");function Jc(t){return Yc(t).replace(/^\/+|\/+$/g,"")}s(Jc,"normalizeInstallPathField");function Wp(t){let e=Yc(t);return e===""||e==="."||e==="./."?".":e.startsWith("./")||e.startsWith("../")||e.startsWith("/")||rW.test(e)?e:`./${e}`}s(Wp,"normalizeLocalSourceForYaml");function Uo(t){return {...t,source:t.source_kind==="local"?Wp(t.source):t.source,...t.path!==void 0?{path:Jc(t.path)}:{},...t.paths!==void 0?{paths:t.paths.map(e=>Jc(e))}:{}}}s(Uo,"normalizePersistedInstallPaths");function Wx(t,e,r){let n=Ux(t,e),o=n.normalize(t),i=n.normalize(e),a=Jc(r),c=`${n.sep}.agentsmesh${n.sep}`,l=o.indexOf(c);if(l>=0){let p=o.slice(0,l),u=o.slice(l+c.length),f=Jc(u),g=Yc(n.relative(i,p))||".";return {kind:"local",rawRef:"",pathInRepo:a||f.replace(/\.md$/i,"").replace(/\/$/,""),localRoot:p,localSourceForYaml:Wp(g)}}let m=Yc(n.relative(i,o))||".";return {kind:"local",rawRef:"",pathInRepo:a,localRoot:o,localSourceForYaml:Wp(m)}}s(Wx,"localParsedFromAbsPath");async function Jh(t,e,r){let n=t.trim(),o=r?.trim().replace(/\\/g,"/")??"";if(n.startsWith("git+")){let l=n.lastIndexOf("#"),m=l<0?n:n.slice(0,l),p=l<0?"HEAD":n.slice(l+1),u=m.slice(4);return {kind:"git",rawRef:p,gitPlusBase:u,gitRemoteUrl:u,pathInRepo:o}}if(n.startsWith("https://")||n.startsWith("http://")){let l=jh(n)??Uh(n);if(l)return {kind:"github",rawRef:l.ref,org:l.org,repo:l.repo,gitRemoteUrl:`https://github.com/${l.org}/${l.repo}.git`,pathInRepo:o||l.path};let m=Bh(n);if(m)return {kind:"github",rawRef:"HEAD",org:m.org,repo:m.repo,gitRemoteUrl:`https://github.com/${m.org}/${m.repo}.git`,pathInRepo:o};let p=Wh(n)??Kh(n);if(p)return {kind:"gitlab",rawRef:p.ref,org:p.namespace,repo:p.project,gitRemoteUrl:`https://gitlab.com/${p.namespace}/${p.project}.git`,pathInRepo:o||p.path};let u=Hh(n);if(u)return {kind:"gitlab",rawRef:"HEAD",org:u.namespace,repo:u.project,gitRemoteUrl:`https://gitlab.com/${u.namespace}/${u.project}.git`,pathInRepo:o}}if(n.startsWith("git@github.com:")){let l=zh(n);if(!l)throw new Error(`Invalid GitHub SSH URL: ${n}`);return {kind:"github",rawRef:"HEAD",org:l.org,repo:l.repo,gitRemoteUrl:`https://github.com/${l.org}/${l.repo}.git`,pathInRepo:o}}if(n.startsWith("git@gitlab.com:")){let l=Vh(n);if(!l)throw new Error(`Invalid GitLab SSH URL: ${n}`);return {kind:"gitlab",rawRef:"HEAD",gitRemoteUrl:`https://gitlab.com/${l.namespace}/${l.project}.git`,pathInRepo:o}}if(n.startsWith("git@")){let l=n.match(/^git@([^:]+):(.+?)(?:\.git)?$/);if(!l)throw new Error(`Invalid SSH git URL: ${n}`);let m=l[1],p=l[2].replace(/\.git$/i,"");return {kind:"git",rawRef:"HEAD",gitRemoteUrl:`ssh://git@${m}/${p}.git`,pathInRepo:o}}let i=n.match(/^github:([^/]+)\/(.+?)@([^/@]+)$/);if(i){let l=i[1],m=i[2];return {kind:"github",rawRef:i[3],org:l,repo:m,gitRemoteUrl:`https://github.com/${l}/${m}.git`,pathInRepo:o}}let a=n.match(/^gitlab:(.+)\/([^/@]+)@([^/@]+)$/);if(a){let l=a[1],m=a[2];return {kind:"gitlab",rawRef:a[3],org:l,repo:m,gitRemoteUrl:`https://gitlab.com/${l}/${m}.git`,pathInRepo:o}}let c=resolve(e,n);if(!await F(c))throw new Error(`Path does not exist: ${c}`);return Wx(c,e,o)}s(Jh,"parseInstallSource");b();st();fn();b();yp();var Kx=z$1.object({name:z$1.string().min(1),source:z$1.string().min(1),version:z$1.string().optional(),source_kind:z$1.enum(["github","gitlab","git","local"]),features:z$1.array(oi).min(1),pick:ba.optional(),target:Le.optional(),path:z$1.string().optional(),paths:z$1.array(z$1.string().min(1)).min(1).optional(),as:ma.optional()}),aW=z$1.object({version:z$1.literal(1),installs:z$1.array(Kx).default([])});function cW(t,e){return t.length===e.length&&[...t].sort().every((r,n)=>r===[...e].sort()[n])}s(cW,"sameFeatures");function lW(t,e){return t.source===e.source&&t.target===e.target&&t.as===e.as&&cW(t.features,e.features)}s(lW,"sameInstallIdentity");function Bx(t){return join(t,"installs.yaml")}s(Bx,"manifestPath");async function Yh(t){let e=await y(Bx(t));if(e===null)return [];try{return aW.parse(parse(e)).installs.map(r=>Uo(r))}catch{return []}}s(Yh,"readInstallManifest");async function Hx(t,e){let r=Uo(e),o=(await Yh(t)).filter(i=>i.name!==r.name&&!lW(i,r));o.push(r),await C(Bx(t),stringify({version:1,installs:o.sort((i,a)=>i.name.localeCompare(a.name))}));}s(Hx,"upsertInstallManifestEntry");function zx(t){return Uo(Kx.parse({name:t.name,source:t.source,version:t.version,source_kind:t.sourceKind,features:t.features,pick:t.pick,target:t.target,path:t.path,paths:t.paths,as:t.as}))}s(zx,"buildInstallManifestEntry");async function pW(t){let e=await Yh(t.canonicalDir);if(e.length===0){I.info("No recorded installs found in .agentsmesh/installs.yaml.");return}let r=[];for(let n of e){let o=join(t.canonicalDir,"packs",n.name);await F(o)||r.push(n);}if(r.length===0){I.info("All recorded packs are already installed.");return}for(let n of r)await t.reinstall(n);I.success(`Reinstalled ${r.length} pack(s) from .agentsmesh/installs.yaml.`);}s(pW,"syncInstalledPacks");async function Vx(t){return t.sync?(await pW({canonicalDir:t.canonicalDir,reinstall:t.reinstall}),true):false}s(Vx,"maybeRunInstallSync");yp();function Jx(t){return {sync:t.sync===true,dryRun:t["dry-run"]===true,force:t.force===true,useExtends:t.extends===true,explicitPath:typeof t.path=="string"?t.path:void 0,explicitTarget:typeof t.target=="string"?t.target.trim():void 0,explicitAs:typeof t.as=="string"?ma.parse(t.as.trim()):void 0,nameOverride:typeof t.name=="string"?t.name.trim():""}}s(Jx,"readInstallFlags");qg();function Vs(t){let e=[];return t.skills.length&&e.push("skills"),t.rules.length&&e.push("rules"),t.commands.length&&e.push("commands"),t.agents.length&&e.push("agents"),t.mcp!==null&&e.push("mcp"),t.permissions!==null&&e.push("permissions"),t.hooks!==null&&e.push("hooks"),t.ignore.length&&e.push("ignore"),e}s(Vs,"featuresFromCanonical");async function Kp(t){let{sliceRoot:e,implicitPick:r}=await fp(t),n=await gp(e);return {canonical:n,features:Vs(n),implicitPick:r}}s(Kp,"discoverFromContentRoot");function Yx(t){return t.description.trim()?{skill:t,ok:true}:{skill:t,ok:false,reason:"missing description in frontmatter"}}s(Yx,"validateSkill");function Xx(t){return t.description.trim()?{rule:t,ok:true}:{rule:t,ok:false,reason:"missing description in frontmatter"}}s(Xx,"validateRule");function Zx(t){return t.description.trim()?{command:t,ok:true}:{command:t,ok:false,reason:"missing description in frontmatter"}}s(Zx,"validateCommand");function qx(t){return t.description.trim()?{agent:t,ok:true}:{agent:t,ok:false,reason:"missing description in frontmatter"}}s(qx,"validateAgent");function pe(t){return basename(t.source).replace(/\.md$/i,"")}s(pe,"ruleSlug");function dW(t){if(!t)return;let e=[];return t.skills!==void 0&&e.push("skills"),t.rules!==void 0&&e.push("rules"),t.commands!==void 0&&e.push("commands"),t.agents!==void 0&&e.push("agents"),e.length>0?e:void 0}s(dW,"featuresFromImplicitPick");function ha(t,e){let{implicitPick:r}=e,n=e.scopedFeatures??dW(r);if(!r&&!n)return t;let o=new Set(n??[]),i={...t,mcp:!n||o.has("mcp")?t.mcp:null,permissions:!n||o.has("permissions")?t.permissions:null,hooks:!n||o.has("hooks")?t.hooks:null,ignore:!n||o.has("ignore")?t.ignore:[]};if(r?.skills!==void 0){let a=new Set(r.skills);i={...i,skills:r.skills.length===0?[]:i.skills.filter(c=>a.has(c.name))};}else n&&!o.has("skills")&&(i={...i,skills:[]});if(r?.rules!==void 0){let a=new Set(r.rules);i={...i,rules:r.rules.length===0?[]:i.rules.filter(c=>a.has(pe(c)))};}else n&&!o.has("rules")&&(i={...i,rules:[]});if(r?.commands!==void 0){let a=new Set(r.commands);i={...i,commands:r.commands.length===0?[]:i.commands.filter(c=>a.has(c.name))};}else n&&!o.has("commands")&&(i={...i,commands:[]});if(r?.agents!==void 0){let a=new Set(r.agents);i={...i,agents:r.agents.length===0?[]:i.agents.filter(c=>a.has(c.name))};}else n&&!o.has("agents")&&(i={...i,agents:[]});return i}s(ha,"narrowDiscoveredForInstallScope");b();dp();b();v();var hW=new Set(["README.md","README.rst","README.txt","README","LICENSE","LICENSE.md","LICENSE.txt","LICENSE-MIT","LICENSE-APACHE","CONTRIBUTING.md","CHANGELOG.md","CODE_OF_CONDUCT.md","package.json","package-lock.json","pnpm-lock.yaml","yarn.lock",".gitignore",".gitattributes",".editorconfig",".DS_Store"]),yW=new Set([".git",".github",".gitlab","node_modules",".vscode",".idea"]);async function Bp(t){let e=await y(t);if(!e)return "";let{frontmatter:r}=E(e);return typeof r.name!="string"?"":r.name.toLowerCase().replace(/[^a-z0-9-]+/g,"-").replace(/-+/g,"-").replace(/^-|-$/g,"")}s(Bp,"readSkillFrontmatterName");async function Qx(t,e){await cp$1(t,e,{recursive:true,filter:s(r=>{let n=relative(t,r).replace(/\\/g,"/");if(n==="")return true;let o=n.split("/")[0];return !(yW.has(o)||!n.includes("/")&&hW.has(n))},"filter")});}s(Qx,"cpFilteredSkill");async function RW(){let t=await mkdtemp(join(tmpdir(),"am-install-manual-")),e=join(t,"repo");return await O(join(e,".agentsmesh")),{discoveryRoot:e,cleanup:s(async()=>{await rm$1(t,{recursive:true,force:true});},"cleanup")}}s(RW,"createStageRoot");async function OW(t,e){if((await stat(t)).isFile()){if(!t.toLowerCase().endsWith(".md"))throw new Error(`Manual install only supports .md files for this collection: ${t}`);await O(e),await cp$1(t,join(e,basename(t)));return}let n=(await D(t)).filter(i=>i.toLowerCase().endsWith(".md"));if(n.length===0)throw new Error(`No .md files found under ${t} for manual install.`);let o=new Map;await O(e);for(let i of n){let a=basename(i),c=o.get(a);if(c)throw new Error(`Manual install found duplicate file name "${a}" under ${t} (${c} and ${i}).`);o.set(a,i),await cp$1(i,join(e,a));}}s(OW,"stageMarkdownCollection");async function tP(t,e,r){if(r.length===0)return false;let n=new Set(r),o=new Map;for(let i of await D(t)){if(!i.endsWith("/SKILL.md")&&!i.endsWith("\\SKILL.md"))continue;let a=dirname(i),c=basename(a);if(!n.has(c))continue;let l=o.get(c);if(l&&l!==a)throw new Error(`Manual skill replay found duplicate skill "${c}" under ${t} (${l} and ${a}).`);o.set(c,a);}if(o.size!==r.length)return false;await O(e);for(let i of r)await cp$1(o.get(i),join(e,i),{recursive:true});return true}s(tP,"stagePreferredSkills");async function EW(t,e,r={}){if((await stat(t)).isFile()){if(basename(t)!=="SKILL.md")throw new Error(`Manual skill install expects SKILL.md or a skill directory: ${t}`);let o=basename(dirname(t)),i=join(e,o);await O(i),await cp$1(dirname(t),i,{recursive:true});return}if(await Hs(t)){if((await stat(join(t,"SKILL.md")).catch(()=>null))?.isFile()){if(await tP(t,e,r.preferredSkillNames??[]))return;let c=await Bp(join(t,"SKILL.md"))||basename(t),l=join(e,c);await O(e),await Qx(t,l);return}if(await tP(t,e,r.preferredSkillNames??[]))return;await O(e);let o=await D(t),i=new Set;for(let a of o.filter(c=>c.endsWith("/SKILL.md")||c.endsWith("\\SKILL.md")))i.add(relative(t,dirname(a)).split(/[\\/]/)[0]);for(let a of i)await cp$1(join(t,a),join(e,a),{recursive:true});return}throw new Error(`Manual skill install expects a skill directory or skills collection at ${t}.`)}s(EW,"stageSkills");async function eP(t,e,r={}){let n=await RW();try{let o=join(n.discoveryRoot,".agentsmesh",e);return e==="skills"?await EW(t,o,r):await OW(t,o),n}catch(o){throw await n.cleanup(),o}}s(eP,"stageManualInstallScope");async function rP(t,e,r,n){let o=await eP(t,e,{preferredSkillNames:e==="skills"?n?.skills:void 0}),{canonical:i}=await Kp(o.discoveryRoot),a=ha(i,{scopedFeatures:[e]});return {prep:{yamlTarget:r,scopedFeatures:[e],cleanup:o.cleanup},narrowed:a,discoveredFeatures:Vs(a)}}s(rP,"resolveManualDiscoveredForInstall");fn();Pu();b();var kW=[{prefix:".gemini/commands",target:"gemini-cli"},{prefix:".github/instructions",target:"copilot"},{prefix:".github/copilot-instructions.md",target:"copilot"},{prefix:".github/copilot",target:"copilot"},{prefix:".github/prompts",target:"copilot"},{prefix:".github/skills",target:"copilot"},{prefix:".github/agents",target:"copilot"},{prefix:".github/hooks",target:"copilot"},{prefix:".claude/commands",target:"claude-code"},{prefix:".claude/rules",target:"claude-code"},{prefix:".claude/skills",target:"claude-code"},{prefix:".claude/agents",target:"claude-code"},{prefix:".cursor/commands",target:"cursor"},{prefix:".cursor/rules",target:"cursor"},{prefix:".cursor/agents",target:"cursor"},{prefix:".cursor/skills",target:"cursor"},{prefix:".continue/prompts",target:"continue"},{prefix:".continue/rules",target:"continue"},{prefix:".continue/skills",target:"continue"},{prefix:".junie/commands",target:"junie"},{prefix:".junie/rules",target:"junie"},{prefix:".junie/agents",target:"junie"},{prefix:".junie/skills",target:"junie"},{prefix:".kiro/steering",target:"kiro"},{prefix:".kiro/skills",target:"kiro"},{prefix:".kilo/commands",target:"kilo-code"},{prefix:".kilo/rules",target:"kilo-code"},{prefix:".kilo/skills",target:"kilo-code"},{prefix:".kilo/agents",target:"kilo-code"},{prefix:".kilocode/workflows",target:"kilo-code"},{prefix:".kilocode/rules",target:"kilo-code"},{prefix:".kilocode/skills",target:"kilo-code"},{prefix:".kilocodemodes",target:"kilo-code"},{prefix:".kilocodeignore",target:"kilo-code"},{prefix:".cline/skills",target:"cline"},{prefix:".clinerules/workflows",target:"cline"},{prefix:".windsurf/rules",target:"windsurf"},{prefix:".codex",target:"codex-cli"}];function wW(t){return t.replace(/\\/g,"/").replace(/^\/+|\/+$/g,"")}s(wW,"norm");function zp(t){let e=wW(t),r=[...kW].sort((n,o)=>o.prefix.length-n.prefix.length);for(let{prefix:n,target:o}of r)if(e===n||e.startsWith(`${n}/`))return o}s(zp,"targetHintFromNativePath");function Zh(t,e){return zp(t)===e}s(Zh,"pathSupportsNativePick");function nP(t,e){if(!t||!e)return;let r=zp(e);if(r&&r!==t)throw new Error(`--target "${t}" does not match the install path (native path suggests "${r}"). Omit --target to auto-detect, or point at a subtree for that target.`)}s(nP,"validateTargetMatchesPath");function oP(t){return (t.commands?.length??0)+(t.rules?.length??0)+(t.skills?.length??0)+(t.agents?.length??0)>0}s(oP,"extendPickHasArrays");b();b();Ft();async function iP(t,e){let r=join(t,...Ie.split("/")),n=join(t,...e.split("/")),o=await D(n),i=[];for(let a of o){if(!/\.(toml|md)$/i.test(a))continue;let c=relative(r,a).replace(/\\/g,"/");if(c.startsWith("..")||c==="")continue;let m=c.replace(/\.(toml|md)$/i,"").split("/").filter(Boolean).join(":");m&&i.push(m);}return [...new Set(i)].sort()}s(iP,"inferGeminiCommandNamesFromFiles");Ft();ve();b();async function Js(t){let e=await D(t),r=new Set;for(let n of e){if(basename(n)==="SKILL.md"){r.add(basename(dirname(n)));continue}!relative(t,n).replace(/\\/g,"/").includes("/")&&n.toLowerCase().endsWith(".md")&&r.add(basename(n,".md"));}return [...r].filter(Boolean).sort()}s(Js,"skillNamesFromNativeSkillDir");b();Ue();async function aP(t,e){let r=join(t,...e.split("/"));if(e.startsWith(Po)){let n=await D(r),o=[...new Set(n.filter(i=>i.toLowerCase().endsWith(".prompt.md")).map(i=>basename(i,".prompt.md")))].sort();return o.length?{commands:o}:{}}if(e.startsWith(".github/copilot")&&!e.includes("copilot-instructions.md")){let n=await D(r),o=[...new Set(n.filter(i=>i.includes(".instructions.md")).map(i=>basename(i).replace(/\.instructions\.md$/i,"")))].sort();return o.length?{rules:o}:{}}if(e.startsWith(".github/instructions")){let n=await D(r),o=new Set;for(let a of n){let c=basename(a);c.toLowerCase().endsWith(".instructions.md")?o.add(c.replace(/\.instructions\.md$/i,"")):c.toLowerCase().endsWith(".md")&&o.add(basename(a,".md"));}let i=[...o].sort();return i.length?{rules:i}:{}}if(e.startsWith(".github/skills")){let n=await Js(r);return n.length?{skills:n}:{}}if(e.startsWith(".github/agents")){let n=await D(r),o=[...new Set(n.filter(i=>i.toLowerCase().endsWith(".agent.md")).map(i=>basename(i,".agent.md")))].sort();return o.length?{agents:o}:{}}return {}}s(aP,"inferCopilotPickFromPath");async function Oe(t,e){let r=await D(t),n=e.toLowerCase();return [...new Set(r.filter(o=>o.toLowerCase().endsWith(n)).map(o=>basename(o,e)))].sort()}s(Oe,"mdNames");async function lP(t,e,r){let n=e.replace(/\\/g,"/").replace(/^\/+|\/+$/g,""),o=join(t,...n.split("/"));if(r==="gemini-cli"){if(n===Ie||n.startsWith(`${Ie}/`)){let i=await iP(t,n);return i.length?{commands:i}:{}}return {}}if(r==="claude-code"){if(n.startsWith(".claude/commands")){let i=await Oe(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".claude/rules")){let i=await Oe(o,".md");return i.length?{rules:i}:{}}if(n.startsWith(".claude/agents")){let i=await Oe(o,".md");return i.length?{agents:i}:{}}if(n.startsWith(".claude/skills/")){let a=n.replace(/^\.claude\/skills\/?/,"").split("/").filter(Boolean)[0];return a?{skills:[a]}:{}}return {}}if(r==="cursor"){if(n.startsWith(".cursor/rules")){let i=await Oe(o,".mdc");return i.length?{rules:i}:{}}if(n.startsWith(".cursor/commands")){let i=await Oe(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".cursor/agents")){let i=await Oe(o,".md");return i.length?{agents:i}:{}}if(n.startsWith(".cursor/skills")){let i=await Js(o);return i.length?{skills:i}:{}}return {}}if(r==="copilot")return aP(t,n);if(r==="windsurf"&&n.startsWith(".windsurf/rules")){let i=await Oe(o,".md");return i.length?{rules:i}:{}}if(r==="cline"){if(n.startsWith(Kt)){let i=await Js(o);return i.length?{skills:i}:{}}if(n.startsWith(vr)){let i=await Oe(o,".md");return i.length?{commands:i}:{}}return {}}if(r==="continue"){if(n.startsWith(".continue/rules")){let i=await Oe(o,".md");return i.length?{rules:i}:{}}if(n.startsWith(".continue/prompts")){let i=await Oe(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".continue/skills")){let i=await Js(o);return i.length?{skills:i}:{}}return {}}if(r==="junie"){if(n.startsWith(".junie/commands")){let i=await Oe(o,".md");return i.length?{commands:i}:{}}if(n.startsWith(".junie/rules")){let i=await Oe(o,".md");return i.length?{rules:i}:{}}if(n.startsWith(".junie/agents")){let i=await Oe(o,".md");return i.length?{agents:i}:{}}if(n.startsWith(".junie/skills")){let i=await Js(o);return i.length?{skills:i}:{}}return {}}if(r==="codex-cli"&&n.startsWith(".codex")){let i=await D(o),a=[...new Set(i.filter(c=>c.toLowerCase().endsWith(".md")).map(c=>basename(c,".md")))].sort();return a.length?{rules:a}:{}}return {}}s(lP,"inferImplicitPickFromNativePath");function mP(t){return (t.commands?.length??0)+(t.rules?.length??0)+(t.skills?.length??0)+(t.agents?.length??0)===0}s(mP,"isImplicitPickEmpty");Yg();function qc(t){return t.replace(/\\/g,"/").replace(/\/+$/,"")}s(qc,"normalizePath");function vW(t,e){let r=qc(t),n=qc(e);return r===n||r.startsWith(`${n}/`)||n.startsWith(`${r}/`)}s(vW,"overlapsPath");function Vp(t,e){let r=t??[];return r.includes(e)||r.push(e),r}s(Vp,"addUnique");async function MW(t){let e=await mkdtemp(join(tmpdir(),"am-install-native-")),r=join(e,"repo"),n=s(async()=>{await rm$1(e,{recursive:true,force:true});},"cleanup");try{return await cp$1(t,r,{recursive:!0}),{stageRoot:r,cleanup:n}}catch(o){throw await n(),o}}s(MW,"makeStageRoot");function $W(t,e){let r;for(let o of t){if(o.feature==="rules"&&o.toPath.startsWith(".agentsmesh/rules/")){r={...r,rules:Vp(r?.rules,basename(o.toPath,".md"))};continue}if(o.feature==="commands"&&o.toPath.startsWith(".agentsmesh/commands/")){let i=qc(relative(join(e,".agentsmesh","commands"),join(e,o.toPath)));r={...r,commands:Vp(r?.commands,i.replace(/\.md$/i,"").split("/").filter(Boolean).join(":"))};continue}if(o.feature==="agents"&&o.toPath.startsWith(".agentsmesh/agents/")){r={...r,agents:Vp(r?.agents,basename(o.toPath,".md"))};continue}if(o.feature==="skills"&&o.toPath.startsWith(".agentsmesh/skills/")){let a=qc(relative(join(e,".agentsmesh","skills"),join(e,o.toPath))).split("/")[0];a&&(r={...r,skills:Vp(r?.skills,a)});}}return r&&(r.rules?.length??0)+(r.commands?.length??0)+(r.agents?.length??0)+(r.skills?.length??0)>0?r:void 0}s($W,"buildPickFromResults");function GW(t,e,r,n){let o=join(e,...qc(t).split("/")),i=r.filter(a=>vW(o,a.fromPath));if(i.length===0)throw new Error(`No installable native resources found under "${t}" for target "${n}".`);return {features:[...new Set(i.map(a=>a.feature))],pick:$W(i,e)}}s(GW,"scopeImportedResults");async function Qh(t,e){let{stageRoot:r,cleanup:n}=await MW(t);try{let o=await vc(r,e);return {stageRoot:r,results:o,cleanup:n}}catch(o){throw await n(),o}}s(Qh,"stageImportedNativeRepo");async function ty(t,e,r){let n=await Qh(t,r);try{return {stageRoot:n.stageRoot,cleanup:n.cleanup,...GW(e,n.stageRoot,n.results,r)}}catch(o){throw await n.cleanup(),o}}s(ty,"stageNativeInstallScope");async function fP(t,e,r,n){let o=n.explicitTarget?.trim();o&&Le.parse(o);let i=r.replace(/\\/g,"/").replace(/^\/+|\/+$/g,"");nP(o,i);let a=join(t,".agentsmesh"),c=await F(a),l=i?zp(i):void 0,m=!c&&!o?await El(t)??void 0:void 0;if(!o&&l&&m&&l!==m)throw new Error(`Install path suggests native layout "${l}" but auto-detect imported "${m}". Use --target ${l} for this path, or install from the repo root without a conflicting subtree path.`);let p=o??l??m,u=!!i&&!!p&&!i.startsWith(".agentsmesh");if(!c&&p){if(u){let k=await ty(t,i,p);return {discoveryRoot:k.stageRoot,implicitPick:k.pick,scopedFeatures:k.features,yamlTarget:p,importHappened:true,cleanup:k.cleanup}}let _=await Qh(t,p);return {discoveryRoot:i?join(_.stageRoot,i):_.stageRoot,yamlTarget:p,importHappened:true,cleanup:_.cleanup}}let f;c?i?p&&Zh(i,p)?f=t:f=e:f=t:f=e;let g,h,R;if(u&&p){let _=await ty(t,i,p);f=_.stageRoot,g=_.pick,h=_.features,R=_.cleanup;}else if(f===t&&i&&p&&Zh(i,p)&&(g=await lP(t,i,p),mP(g)))throw new Error(`No installable native resources found under "${i}" for target "${p}".`);let S;return o?S=o:p&&(g&&oP(g)||(h?.length??0)>0)&&(S=p),{discoveryRoot:f,implicitPick:g,scopedFeatures:h,yamlTarget:S,importHappened:R!==void 0,cleanup:R}}s(fP,"prepareInstallDiscovery");async function gP(t,e,r,n){let o=await fP(t,e,r,{explicitTarget:n}),{canonical:i,implicitPick:a}=await Kp(o.discoveryRoot),c=a??o.implicitPick,l=ha(i,{implicitPick:c,scopedFeatures:o.scopedFeatures}),m=Vs(l);return {prep:o,discovered:i,implicitPick:c,narrowed:l,discoveredFeatures:m}}s(gP,"resolveDiscoveredForInstall");async function hP(t){return t.explicitAs?{implicitPick:void 0,...await rP(t.contentRoot,t.explicitAs,t.explicitTarget,t.replayPick)}:gP(t.resolvedPath,t.contentRoot,t.pathInRepo,t.explicitTarget)}s(hP,"resolveInstallDiscovery");function _a(t){return t==="."||t===""?void 0:t}s(_a,"trimDot");function UW(t,e){let r=basename(e).replace(/\.md$/i,"");return t==="agents"?{agents:[r]}:t==="commands"?{commands:[r]}:{rules:[r]}}s(UW,"markdownPick");async function _P(t){if(!t.as)return {pathInRepo:_a(t.pathInRepo)};let e=t.pathInRepo.replace(/^\/+|\/+$/g,""),r=await stat(t.contentRoot);if(t.as!=="skills"&&r.isFile()&&t.contentRoot.toLowerCase().endsWith(".md"))return {pathInRepo:_a(dirname(e)),pick:UW(t.as,e||t.contentRoot)};if(t.as==="skills"){if(r.isFile()&&basename(t.contentRoot)==="SKILL.md"){let n=e?dirname(e):dirname(t.contentRoot);return {pathInRepo:_a(dirname(n)),pick:{skills:[basename(n)]}}}if(r.isDirectory()){let n=e||basename(t.contentRoot),o=join(t.contentRoot.replace(/\/+$/g,""),"SKILL.md");try{if((await stat(o)).isFile()){let a=await Bp(o);return {pathInRepo:_a(dirname(n)),pick:{skills:[a||basename(n)]}}}}catch{return {pathInRepo:_a(e)}}}}return {pathInRepo:_a(e)}}s(_P,"resolveManualInstallPersistence");ln();st();async function mn(t){return process.stdin.isTTY?new Promise(e=>{let r=IP.createInterface({input:process.stdin,output:process.stdout});r.question(`${t} (y/n) `,n=>{r.close();let o=n.trim().toLowerCase();e(o==="y"||o==="yes");});}):false}s(mn,"confirm");function WW(t){return !!(t.skills.length||t.rules.length||t.commands.length||t.agents.length)}s(WW,"hasArrayResources");function SP(t){return WW(t)||t.mcp!==null||t.permissions!==null||t.hooks!==null||t.ignore.length>0}s(SP,"hasInstallableResources");async function CP(t,e,r,n){let o=t.skills.map(c=>Yx(c)),i=o.filter(c=>c.ok).map(c=>c.skill),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await mn(`Include invalid skill "${c.skill.name}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.skill);else e&&(i=o.map(c=>c.skill));return r&&(i=o.filter(c=>c.ok).map(c=>c.skill)),i}s(CP,"resolveSkillPool");async function RP(t,e,r,n){let o=t.rules.map(c=>Xx(c)),i=o.filter(c=>c.ok).map(c=>c.rule),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await mn(`Include invalid rule "${pe(c.rule)}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.rule);else e&&(i=o.map(c=>c.rule));return r&&(i=o.filter(c=>c.ok).map(c=>c.rule)),i}s(RP,"resolveRulePool");async function OP(t,e,r,n){let o=t.commands.map(c=>Zx(c)),i=o.filter(c=>c.ok).map(c=>c.command),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await mn(`Include invalid command "${c.command.name}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.command);else e&&(i=o.map(c=>c.command));return r&&(i=o.filter(c=>c.ok).map(c=>c.command)),i}s(OP,"resolveCommandPool");async function EP(t,e,r,n){let o=t.agents.map(c=>qx(c)),i=o.filter(c=>c.ok).map(c=>c.agent),a=o.filter(c=>!c.ok);if(!e&&!r&&n)for(let c of a)await mn(`Include invalid agent "${c.agent.name}" anyway? (${c.reason}). You can fix it later.`)&&i.push(c.agent);else e&&(i=o.map(c=>c.agent));return r&&(i=o.filter(c=>c.ok).map(c=>c.agent)),i}s(EP,"resolveAgentPool");async function kP(t,e){let r=e.skills.map(a=>a.name),n=e.rules.map(a=>pe(a)),o=e.commands.map(a=>a.name),i=e.agents.map(a=>a.name);for(let a of e.skills)t.skills.some(c=>c.name===a.name)&&(await mn(`Skill "${a.name}" already exists in merged config. Add extend anyway?`)||(r=r.filter(l=>l!==a.name)));for(let a of e.rules){let c=pe(a);t.rules.some(l=>pe(l)===c)&&(await mn(`Rule "${c}" already exists in merged config. Add extend anyway?`)||(n=n.filter(m=>m!==c)));}for(let a of e.commands)t.commands.some(c=>c.name===a.name)&&(await mn(`Command "${a.name}" already exists in merged config. Add extend anyway?`)||(o=o.filter(l=>l!==a.name)));for(let a of e.agents)t.agents.some(c=>c.name===a.name)&&(await mn(`Agent "${a.name}" already exists in merged config. Add extend anyway?`)||(i=i.filter(l=>l!==a.name)));return {skillNames:r,ruleSlugs:n,commandNames:o,agentNames:i}}s(kP,"resolveInstallConflicts");function wP(t,e){if(!t)return;let r={},n=t.skills?.filter(c=>e.skillNames.includes(c)),o=t.rules?.filter(c=>e.ruleSlugs.includes(c)),i=t.commands?.filter(c=>e.commandNames.includes(c)),a=t.agents?.filter(c=>e.agentNames.includes(c));return n&&n.length>0&&(r.skills=n),o&&o.length>0&&(r.rules=o),i&&i.length>0&&(r.commands=i),a&&a.length>0&&(r.agents=a),Object.keys(r).length>0?r:void 0}s(wP,"pickForSelectedResources");function KW(t,e){let r=t.split("/").filter(Boolean);return r.length>0&&r[r.length-1]===e}s(KW,"pathEndsWithName");function Jp(t,e,r){return r!==1||e.length!==1?false:KW(t,e[0])}s(Jp,"inferSingleNamePick");function LP(t){let{pathInRepo:e,implicitPick:r,preConflictCounts:n,selected:o}=t,i={},a=o.skillNames.length>0&&(!!r?.skills?.length||o.skillNames.length<n.skills||Jp(e,o.skillNames,n.skills)),c=o.ruleSlugs.length>0&&(!!r?.rules?.length||o.ruleSlugs.length<n.rules||Jp(e,o.ruleSlugs,n.rules)),l=o.commandNames.length>0&&(!!r?.commands?.length||o.commandNames.length<n.commands||Jp(e,o.commandNames,n.commands)),m=o.agentNames.length>0&&(!!r?.agents?.length||o.agentNames.length<n.agents||Jp(e,o.agentNames,n.agents));return a&&(i.skills=[...o.skillNames]),c&&(i.rules=[...o.ruleSlugs]),l&&(i.commands=[...o.commandNames]),m&&(i.agents=[...o.agentNames]),Object.keys(i).length?i:void 0}s(LP,"buildInstallPick");function bP(t,e){let r=new Set(t);return e.skillNames.length===0&&r.delete("skills"),e.ruleSlugs.length===0&&r.delete("rules"),e.commandNames.length===0&&r.delete("commands"),e.agentNames.length===0&&r.delete("agents"),[...r]}s(bP,"deriveInstallFeatures");function BW(t){return t.skillNames.length===0&&t.ruleSlugs.length===0&&t.commandNames.length===0&&t.agentNames.length===0}s(BW,"isEmptyInstallSelection");function AP(t){let{selected:e,discoveredFeatures:r,preConflict:n}=t,o=s(c=>r.includes(c),"had"),i=o("skills")&&e.skillNames.length===0&&n.skills>0&&"skills"||o("rules")&&e.ruleSlugs.length===0&&n.rules>0&&"rules"||o("commands")&&e.commandNames.length===0&&n.commands>0&&"commands"||o("agents")&&e.agentNames.length===0&&n.agents>0&&"agents";if(i)throw new Error(`No ${i} selected to install.`);let a=r.some(c=>["mcp","permissions","hooks","ignore"].includes(c));if(BW(e)&&!a)throw new Error("No resources selected to install.")}s(AP,"ensureInstallSelection");fn();function xP(t,e){if(t.find(n=>n.name===e.name&&n.source!==e.source))throw new Error(`Extends entry "${e.name}" already exists with a different source. Use --name to provide a different name.`)}s(xP,"assertExtendNameAvailable");function HW(t,e,r){if(r===void 0){if(!t)return;let o={...t};for(let i of ["skills","commands","rules","agents"])e.includes(i)&&delete o[i];return Object.keys(o).length?o:void 0}let n={...t};for(let o of ["skills","commands","rules","agents"]){if(!(o in r))continue;let i=r[o];if(i===void 0||i.length===0){delete n[o];continue}n[o]=[...new Set([...t?.[o]??[],...i])];}return Object.keys(n).length?n:void 0}s(HW,"mergePick");function PP(t,e){let r=t.findIndex(a=>a.source===e.source);if(r<0)return [...t,{name:e.name,source:e.source,version:e.version,features:e.features,path:e.path,pick:e.pick,target:e.target}];let n=t[r],o=[...new Set([...n.features,...e.features])],i=HW(n.pick,e.features,e.pick);return t.map((a,c)=>c===r?{name:e.name,source:e.source,version:e.version??n.version,features:o,path:e.path!==void 0?e.path:n.path,pick:i,target:e.target??n.target}:a)}s(PP,"mergeExtendList");b();async function TP(t,e,r){let n=await y(t);if(n===null)throw new Error(`Missing config: ${t}`);let o=parse(n),i=PP(e.extends,r);o.extends=i;let a=stringify(o,{indent:2,lineWidth:0});await C(t,a.endsWith(`
|
|
309
311
|
`)?a:`${a}
|
|
310
|
-
`);}s(
|
|
311
|
-
${JSON.stringify(i,null,2)}`);return}let a=join(e,"agentsmesh.yaml");await
|
|
312
|
-
`);return `sha256:${
|
|
313
|
-
`),t.permissions!==null&&await
|
|
312
|
+
`);}s(TP,"writeAgentsmeshWithNewExtend");st();async function DP(t){let{configDir:e,config:r,entryArgs:n,dryRun:o}=t,i=YW(n);if(xP(r.extends,i),o){I.info(`[dry-run] Would add extend:
|
|
313
|
+
${JSON.stringify(i,null,2)}`);return}let a=join(e,"agentsmesh.yaml");await TP(a,r,i),I.success(`Wrote extends entry "${i.name}" to agentsmesh.yaml.`);}s(DP,"writeInstallAsExtend");function YW(t){return {name:t.name,source:t.source,version:t.version,features:t.features,path:t.path,pick:t.pick,target:t.yamlTarget!==void 0?Le.parse(t.yamlTarget):void 0}}s(YW,"toNewExtendEntry");b();b();var ZW="pack.yaml";async function Yp(t){let e=await D(t),r=[];for(let i of e.sort()){let a=relative(t,i).replace(/\\/g,"/");if(a===ZW)continue;let c=await Cp(i);c!==null&&r.push(`${a}:${c}`);}let n=r.join(`
|
|
314
|
+
`);return `sha256:${jc(n)}`}s(Yp,"hashPackContent");async function eK(t,e){if(t.rules.length===0)return;let r=join(e,"rules");await O(r);for(let n of t.rules){let o=join(r,basename(n.source));await copyFile(n.source,o);}}s(eK,"writeRules");async function rK(t,e){if(t.commands.length===0)return;let r=join(e,"commands");await O(r);for(let n of t.commands){let o=join(r,basename(n.source));await copyFile(n.source,o);}}s(rK,"writeCommands");async function nK(t,e){if(t.agents.length===0)return;let r=join(e,"agents");await O(r);for(let n of t.agents){let o=join(r,basename(n.source));await copyFile(n.source,o);}}s(nK,"writeAgents");async function oK(t,e){if(t.skills.length===0)return;let r=join(e,"skills");await O(r);for(let n of t.skills){let o=join(r,n.name);await O(o),await copyFile(n.source,join(o,"SKILL.md"));for(let i of n.supportingFiles){let a=join(o,i.relativePath);await O(dirname(a)),await copyFile(i.absolutePath,a);}}}s(oK,"writeSkills");async function sK(t,e){t.mcp!==null&&await C(join(e,"mcp.json"),`${JSON.stringify(t.mcp,null,2)}
|
|
315
|
+
`),t.permissions!==null&&await C(join(e,"permissions.yaml"),stringify(t.permissions)),t.hooks!==null&&await C(join(e,"hooks.yaml"),stringify(t.hooks)),t.ignore.length>0&&await C(join(e,"ignore"),`${t.ignore.join(`
|
|
314
316
|
`)}
|
|
315
|
-
`);}s(
|
|
316
|
-
`),t.permissions!==null&&await
|
|
317
|
+
`);}s(sK,"writeSettings");function iK(t){if(t.includes("/")||t.includes("\\")||t===".."||t==="."||t.includes("\0"))throw new Error(`Invalid pack name "${t}". Pack names must be a single directory segment without path separators.`)}s(iK,"validatePackName");async function FP(t,e,r,n){iK(e);let o=join(t,`${e}.tmp`),i=join(t,e);await F(o)&&await rm$1(o,{recursive:true,force:true}),await O(o),await eK(r,o),await rK(r,o),await nK(r,o),await oK(r,o),await sK(r,o);let a=await Yp(o),c=Uo({...n,content_hash:a});return await C(join(o,"pack.yaml"),stringify(c)),await F(i)&&await rm$1(i,{recursive:true,force:true}),await mkdir(t,{recursive:true}),await rename(o,i),c}s(FP,"materializePack");Sp();b();function sy(t,e){return [...new Set([...t,...e])]}s(sy,"union");function cK(t,e){if(t.path===void 0&&t.paths===void 0||e===void 0)return {path:void 0,paths:void 0};let n=sy(t.paths??(t.path?[t.path]:[]),[e]);return n.length===1?{path:n[0],paths:void 0}:{path:void 0,paths:n}}s(cK,"mergePathScope");function lK(t,e,r){let n={...t};for(let i of e)r&&r[i]!==void 0?n[i]=sy(n[i]??[],r[i]):delete n[i];return (n.skills?.length??0)>0||(n.rules?.length??0)>0||(n.commands?.length??0)>0||(n.agents?.length??0)>0?n:void 0}s(lK,"mergePick");async function mK(t,e){if(t.rules.length===0)return;let r=join(e,"rules");await O(r);for(let n of t.rules)await copyFile(n.source,join(r,basename(n.source)));}s(mK,"mergeRules");async function pK(t,e){if(t.commands.length===0)return;let r=join(e,"commands");await O(r);for(let n of t.commands)await copyFile(n.source,join(r,basename(n.source)));}s(pK,"mergeCommands");async function uK(t,e){if(t.agents.length===0)return;let r=join(e,"agents");await O(r);for(let n of t.agents)await copyFile(n.source,join(r,basename(n.source)));}s(uK,"mergeAgents");async function dK(t,e){if(t.skills.length===0)return;let r=join(e,"skills");await O(r);for(let n of t.skills){let o=join(r,n.name);await O(o),await copyFile(n.source,join(o,"SKILL.md"));for(let i of n.supportingFiles){let a=join(o,i.relativePath);await O(dirname(a)),await copyFile(i.absolutePath,a);}}}s(dK,"mergeSkills");async function fK(t,e){t.mcp!==null&&await C(join(e,"mcp.json"),`${JSON.stringify(t.mcp,null,2)}
|
|
318
|
+
`),t.permissions!==null&&await C(join(e,"permissions.yaml"),stringify(t.permissions)),t.hooks!==null&&await C(join(e,"hooks.yaml"),stringify(t.hooks)),t.ignore.length>0&&await C(join(e,"ignore"),`${t.ignore.join(`
|
|
317
319
|
`)}
|
|
318
|
-
`);}s(
|
|
319
|
-
`,o=parse(n)??{};if(o.plugins||(o.plugins=[]),o.plugins.some(a=>a.id===e.id))return;let i={id:e.id,source:e.source};e.version!==void 0&&(i.version=e.version),o.plugins.push(i),await
|
|
320
|
-
|
|
321
|
-
// Project-level paths
|
|
322
|
-
export const ${e}_DIR = '.${t.id}';
|
|
323
|
-
export const ${e}_RULES_DIR = '.${t.id}/rules';
|
|
324
|
-
|
|
325
|
-
// Global-level paths
|
|
326
|
-
export const ${e}_GLOBAL_DIR = '~/.${t.id}';
|
|
327
|
-
export const ${e}_GLOBAL_RULES_DIR = '~/.${t.id}/rules';
|
|
328
|
-
|
|
329
|
-
// Canonical paths
|
|
330
|
-
export const ${e}_CANONICAL_ROOT_RULE = '.agentsmesh/rules/_root.md';
|
|
331
|
-
export const ${e}_CANONICAL_RULES_DIR = '.agentsmesh/rules';
|
|
332
|
-
`}s(kP,"TEMPLATE_CONSTANTS");function OP(t){let e=da(t.id),r=ua(t.id);return `import type { TargetGenerators } from '../catalog/target.interface.js';
|
|
320
|
+
`);}s(fK,"mergeSettings");async function vP(t,e,r,n,o,i){await mK(r,t),await pK(r,t),await uK(r,t),await dK(r,t),await fK(r,t);let a=sy(e.features,n),c=lK(e.pick,n,o),l=cK(e,i?.path),m=await Yp(t),p=new Date().toISOString(),u=Uo({...e,source:i?.source??e.source,...i?.version!==void 0?{version:i.version}:e.version!==void 0?{version:e.version}:{},features:a,pick:c,...i?.target!==void 0?{target:i.target}:e.target!==void 0?{target:e.target}:{},...l,...i?.as!==void 0?{as:i.as}:e.as!==void 0?{as:e.as}:{},updated_at:p,content_hash:m});return await C(join(t,"pack.yaml"),stringify(u)),u}s(vP,"mergeIntoPack");Ru();fn();st();b();function hK(t){return t?{path:t,paths:void 0}:{path:void 0,paths:void 0}}s(hK,"pathScope");function yK(t,e){let r=new Set(e.skillNames),n=new Set(e.ruleSlugs),o=new Set(e.commandNames),i=new Set(e.agentNames);return {...t,skills:t.skills.filter(a=>r.has(a.name)),rules:t.rules.filter(a=>n.has(pe(a))),commands:t.commands.filter(a=>o.has(a.name)),agents:t.agents.filter(a=>i.has(a.name))}}s(yK,"applySelection");async function MP(t){let{canonicalDir:e,packName:r,narrowed:n,selected:o,sourceForYaml:i,version:a,sourceKind:c,entryFeatures:l,pick:m,yamlTarget:p,pathInRepo:u,manualAs:f,renameExistingPack:g}=t,h=join(e,"packs"),R=yK(n,o),S=new Date().toISOString(),_=p!==void 0?Le.parse(p):void 0,k=await eA(h,i,{target:_,as:f,features:l}),T=r,P=l,A=m,Z=u,B;if(k){let V=k.packDir,Lt=k.meta;if(g&&k.name!==r){let kr=join(h,r);if(await F(kr))throw new Error(`Auto-generated pack name "${r}" collides with an existing incompatible pack. Use --name to choose a different pack name.`);await rename(k.packDir,kr),V=kr,Lt={...k.meta,name:r};}let Et=await vP(V,Lt,R,l,m,{source:i,...a!==void 0?{version:a}:{},..._!==void 0?{target:_}:{},...u?{path:u}:{},...f!==void 0?{as:f}:{}});T=Et.name,P=Et.features,A=Et.pick,Z=Et.path,B=Et.paths,I.success(`Updated pack "${Et.name}" in .agentsmesh/packs/.`);}else {if(await _p(join(h,r)))throw new Error(`Auto-generated pack name "${r}" collides with an existing incompatible pack. Use --name to choose a different pack name.`);await FP(h,r,R,{name:r,source:i,...a!==void 0&&{version:a},source_kind:c,installed_at:S,updated_at:S,features:l,...m!==void 0&&{pick:m},..._!==void 0&&{target:_},...hK(u),...f!==void 0&&{as:f}}),I.success(`Installed pack "${r}" to .agentsmesh/packs/.`);}await Hx(e,zx({name:T,source:i,version:a,sourceKind:c,features:P,pick:A,target:_,path:Z,paths:B,as:f})),c!=="local"&&await I_(i);}s(MP,"installAsPack");function IK(t){return t.toLowerCase().replace(/[^a-z0-9-]+/g,"-").replace(/-+/g,"-").replace(/^-|-$/g,"")}s(IK,"sanitize");function SK(t){try{let r=new URL(t.replace(/^git\+/,"https://").replace(/^ssh:\/\/git@/,"https://")).pathname.split("/").filter(Boolean);if(r.length===0)return "repo";let n=r[r.length-1].replace(/\.git$/i,"");return r.length>=2?`${r[r.length-2].replace(/\.git$/i,"")}-${n}`:n}catch{return "repo"}}s(SK,"gitUrlLastSegments");function $P(t,e,r){let n;if(t.kind==="local"){let c=(t.localRoot??"local").split(/[/\\]/).filter(Boolean);n=c[c.length-1]??"local";}else t.kind==="github"&&t.org&&t.repo?n=`${t.org}-${t.repo}`:t.kind==="gitlab"&&t.org&&t.repo?n=`${t.org.replace(/\//g,"-")}-${t.repo}`:t.gitRemoteUrl?n=SK(t.gitRemoteUrl):n="extend";e.featureHint?n=`${n}-${e.featureHint}`:n=`${n}-pack`;let o=IK(n)||"extend";if(!r.has(o))return o;let i=2;for(;r.has(`${o}-${i}`);)i++;return `${o}-${i}`}s($P,"suggestExtendName");function GP(t){let{config:e,parsed:r,entryFeatures:n,nameOverride:o}=t,i=new Set(e.extends.map(a=>a.name));return o||$P(r,{featureHint:n.length===1?n[0]:void 0},i)}s(GP,"selectInstallEntryName");function jP(t,e,r){if(!r?.features&&!r?.pick)return {narrowed:t,discoveredFeatures:e};let n=ha(t,{scopedFeatures:r.features,implicitPick:r.pick});return {narrowed:n,discoveredFeatures:Vs(n)}}s(jP,"applyReplayInstallScope");function UP(t,e){let r=[];for(let n of t.skillNames)r.push({kind:"skill",name:n,path:e});for(let n of t.ruleSlugs)r.push({kind:"rule",name:n,path:e});for(let n of t.commandNames)r.push({kind:"command",name:n,path:e});for(let n of t.agentNames)r.push({kind:"agent",name:n,path:e});return r}s(UP,"buildInstalledList");function WP(t,e,r,n,o){let i=[];for(let a of t)o.skillNames.includes(a.name)||i.push({kind:"skill",name:a.name,reason:"conflict"});for(let a of e){let c=pe(a);o.ruleSlugs.includes(c)||i.push({kind:"rule",name:c,reason:"conflict"});}for(let a of r)o.commandNames.includes(a.name)||i.push({kind:"command",name:a.name,reason:"conflict"});for(let a of n)o.agentNames.includes(a.name)||i.push({kind:"agent",name:a.name,reason:"conflict"});return i}s(WP,"buildSkippedList");async function KP(t){let{scope:e,force:r,dryRun:n,tty:o,useExtends:i,nameOverride:a,explicitAs:c,config:l,context:m,parsed:p,sourceForYaml:u,version:f,pathInRepo:g,persisted:h,replay:R,prep:S,implicitPick:_,narrowed:k,discoveredFeatures:T}=t,{narrowed:P,discoveredFeatures:A}=jP(k,T,R);if(!SP(P))throw new Error(_||S.scopedFeatures?"No resources match the install path or implicit selection (check pick names exist at that path).":"No supported resources found to install (skills, rules, commands, agents).");let Z=await CP(P,r,n,o),B=await RP(P,r,n,o),V=await OP(P,r,n,o),Lt=await EP(P,r,n,o),Et={skills:Z.length,rules:B.length,commands:V.length,agents:Lt.length},{canonical:kr}=await se(l,m.configDir,{},m.canonicalDir),Mt=!r&&!n&&o?await kP(kr,{skills:Z,rules:B,commands:V,agents:Lt}):{skillNames:Z.map(no=>no.name),ruleSlugs:B.map(no=>pe(no)),commandNames:V.map(no=>no.name),agentNames:Lt.map(no=>no.name)};AP({selected:Mt,discoveredFeatures:A,preConflict:Et});let wr=R?.features??bP(A,Mt);if(wr.length===0)throw new Error("No features left to install after selection.");let bt=wP(R?.pick,Mt)??h.pick??LP({pathInRepo:h.pathInRepo??g,implicitPick:_,preConflictCounts:Et,selected:Mt}),pt=GP({config:l,parsed:p,entryFeatures:wr,nameOverride:a}),pn=UP(Mt,pt),Ve=WP(Z,B,V,Lt,Mt);if(i){if(await DP({configDir:m.configDir,config:l,entryArgs:{name:pt,source:u,version:f,features:wr,path:h.pathInRepo,pick:bt,yamlTarget:S.yamlTarget},dryRun:n}),n)return {installed:pn,skipped:Ve}}else {if(n)return I.info(`[dry-run] Would install pack "${pt}" to ${e==="global"?"~/.agentsmesh/packs/.":".agentsmesh/packs/."}`),{installed:pn,skipped:Ve};await MP({canonicalDir:m.canonicalDir,packName:pt,narrowed:P,selected:Mt,sourceForYaml:u,version:f,sourceKind:p.kind,entryFeatures:wr,pick:bt,yamlTarget:S.yamlTarget,pathInRepo:h.pathInRepo,manualAs:c,renameExistingPack:a===""});}let ro=await da(e==="global"?{global:true}:{},m.rootBase);return fa(ro),ro.exitCode!==0&&I.warn(`Generate failed after install. Fix the issue and run agentsmesh generate${e==="global"?" --global":""}.`),{installed:pn,skipped:Ve}}s(KP,"executeRunInstallPoolsAndWrite");async function ay(t,e,r,n){let{sync:o,dryRun:i,force:a,useExtends:c,explicitPath:l,explicitTarget:m,explicitAs:p,nameOverride:u}=Jx(t),f=t.global===true?"global":"project",g=e[0]?.trim();if(o){let{context:Mt}=await ut(r,f),wr=[],bt=[];if(await Vx({sync:o,canonicalDir:Mt.canonicalDir,reinstall:s(async pt=>{let pn=pt.paths&&pt.paths.length>0?pt.paths:[pt.path];for(let Ve of pn){let ro=await ay({...a?{force:true}:{},...i?{"dry-run":true}:{},...f==="global"?{global:true}:{},name:pt.name,...pt.target?{target:pt.target}:{},...Ve?{path:Ve}:{},...pt.as?{as:pt.as}:{}},[pt.source],r,{features:pt.features,pick:pt.pick});wr.push(...ro.data.installed),bt.push(...ro.data.skipped);}},"reinstall")}))return {exitCode:0,data:{source:"",mode:"sync",installed:wr,skipped:bt,dryRun:i}}}if(!g)throw new Error("Missing source. Usage: agentsmesh install <source> [--path ...] [--target ...]");let h=process.stdin.isTTY;if(!h&&!a&&!i)throw new Error("Non-interactive terminal: use --force or --dry-run for agentsmesh install.");let{config:R,context:S}=await ut(r,f),_=await Jh(g,S.configDir,l);if(_.kind!=="local"&&!await Mx())throw new Error("git is required for remote installs. Please install git and try again.");let{resolvedPath:k,sourceForYaml:T,version:P}=await jx(_,g),A=_.pathInRepo.replace(/^\/+|\/+$/g,"");if(A){let Mt=normalize(A).replace(/\\/g,"/");if(Mt===".."||Mt.startsWith("../"))throw new Error(`Install --path "${_.pathInRepo}" escapes the source root. Path must stay within the source.`)}let Z=A?join(k,A):k;if(!await F(Z))throw new Error(`Install path does not exist: ${Z}`);let B=await _P({as:p,contentRoot:Z,pathInRepo:A}),{prep:V,implicitPick:Lt,narrowed:Et,discoveredFeatures:kr}=await hP({resolvedPath:k,contentRoot:Z,pathInRepo:A,explicitTarget:m,explicitAs:p,replayPick:n?.pick});try{let Mt=await KP({scope:f,force:a,dryRun:i,tty:h,useExtends:c,nameOverride:u,explicitAs:p,config:R,context:S,parsed:_,sourceForYaml:T,version:P,pathInRepo:A,persisted:B,replay:n,prep:V,implicitPick:Lt,narrowed:Et,discoveredFeatures:kr});return {exitCode:0,data:{source:g,mode:"install",installed:Mt.installed,skipped:Mt.skipped,dryRun:i}}}finally{V.cleanup&&await V.cleanup();}}s(ay,"runInstall");async function BP(t,e,r){return ay(t,e,r)}s(BP,"runInstall");st();function HP(t){let{data:e}=t;if(!(e.mode==="sync"&&e.installed.length===0&&e.skipped.length===0)){if(e.installed.length>0&&!e.dryRun){let n=[...new Set(e.installed.map(o=>o.kind))].map(o=>{let i=e.installed.filter(a=>a.kind===o).length;return `${i} ${o}${i>1?"s":""}`}).join(", ");I.success(`Installed ${n}.`);}if(e.skipped.length>0)for(let r of e.skipped)I.warn(`Skipped ${r.kind} "${r.name}": ${r.reason}`);}}s(HP,"renderInstall");uh();b();var my="agentsmesh.yaml";async function py(t){let e=join(t,my),r=await y(e);return r===null?{}:parse(r)??{}}s(py,"readScopedConfigRaw");async function VP(t,e){let r=join(t,my),n=await y(r)??`version: 1
|
|
321
|
+
`,o=parse(n)??{};if(o.plugins||(o.plugins=[]),o.plugins.some(a=>a.id===e.id))return;let i={id:e.id,source:e.source};e.version!==void 0&&(i.version=e.version),o.plugins.push(i),await C(r,stringify(o));}s(VP,"writePluginEntry");async function JP(t,e){let r=join(t,my),n=await y(r);if(n===null)return false;let o=parse(n)??{},i=(o.plugins??[]).length;o.plugins=(o.plugins??[]).filter(c=>c.id!==e),o.pluginTargets&&(o.pluginTargets=o.pluginTargets.filter(c=>c!==e));let a=o.plugins.length<i;return a&&await C(r,stringify(o)),a}s(JP,"removePluginEntry");async function YP(t,e,r){let n=e[0];if(n===void 0||n==="")return {exitCode:0,data:{subcommand:"list",plugins:[]},showHelp:true};switch(n){case "add":return OK(t,e.slice(1),r);case "list":return EK(r);case "remove":return kK(e.slice(1),r);case "info":return wK(e.slice(1),r);default:return {exitCode:2,data:{subcommand:"list",plugins:[]},showHelp:true,error:`Unknown plugin subcommand: ${n}`}}}s(YP,"runPlugin");async function OK(t,e,r){let n=e[0];if(!n)throw new Lr("Usage: agentsmesh plugin add <source> [--version <v>] [--id <id>]");let o=typeof t.version=="string"?t.version:"latest",a=(typeof t.id=="string"?t.id:void 0)??LK(n);return await VP(r,{id:a,source:n,version:o==="latest"?void 0:o}),{exitCode:0,data:{subcommand:"add",id:a,package:n,version:o}}}s(OK,"runPluginAdd");async function EK(t){let r=(await py(t)).plugins??[],n=[];for(let o of r){let i="\u2717",a="";try{let c=await Tp(o,t);i=c.descriptors.length>0?"\u2713":"\u2713 (0 descriptors)",a=c.descriptors.map(l=>l.id).join(", ");}catch{}n.push({id:o.id,package:o.source,version:o.version,status:i,targets:a});}return {exitCode:0,data:{subcommand:"list",plugins:n}}}s(EK,"runPluginList");async function kK(t,e){let r=t[0];if(!r)throw new Lr("Usage: agentsmesh plugin remove <id>");let n=await JP(e,r);return {exitCode:0,data:{subcommand:"remove",id:r,found:n}}}s(kK,"runPluginRemove");async function wK(t,e){let r=t[0];if(!r)throw new Lr("Usage: agentsmesh plugin info <id>");let o=((await py(e)).plugins??[]).find(c=>c.id===r);if(!o)return {exitCode:1,data:{subcommand:"info",id:r,package:"",descriptors:[]}};let i;try{i=await Tp(o,e);}catch{return {exitCode:1,data:{subcommand:"info",id:r,package:o.source,version:o.version,descriptors:[]}}}let a=i.descriptors.map(c=>({id:c.id,description:c.emptyImportMessage}));return {exitCode:0,data:{subcommand:"info",id:r,package:o.source,version:o.version,descriptors:a}}}s(wK,"runPluginInfo");function LK(t){let e=t;if(e.startsWith("@")){let n=e.indexOf("/");n!==-1&&(e=e.slice(n+1));}e.startsWith("agentsmesh-target-")&&(e=e.slice(18)),e.startsWith("file:")&&(e=e.slice(5));let r=e.replace(/\\/g,"/").split("/");return e=r[r.length-1]??e,e=e.replace(/\.(js|ts)$/,""),e=e.toLowerCase().replace(/[^a-z0-9-]/g,"-").replace(/-+/g,"-").replace(/^-|-$/g,""),e||"plugin"}s(LK,"derivePluginId");st();function XP(t){if(t.error&&I.error(t.error),t.showHelp){TK();return}let{data:e}=t;switch(e.subcommand){case "add":bK(e.id,e.package,e.version);break;case "list":AK(e.plugins);break;case "remove":xK(e.id,e.found);break;case "info":PK(e,t.exitCode);break}}s(XP,"renderPlugin");function bK(t,e,r){I.success(`Plugin '${t}' added to agentsmesh.yaml`),I.warn("Plugins load as trusted Node.js modules and run with full process privileges. Only install plugins from sources you trust.");let n=r!=="latest"?`@${r}`:"@latest";I.info(`Next: npm install ${e}${n}`),I.info(`Then add '${t}' to pluginTargets in agentsmesh.yaml to enable it.`);}s(bK,"renderAdd");function AK(t){if(t.length===0){I.info("No plugins configured. Use: agentsmesh plugin add <source>");return}I.info("Configured plugins:");for(let e of t){let r=e.version!==void 0?`@${e.version}`:"",n=e.status??"",o=e.targets??"";I.info(` ${e.id} | ${e.package}${r} | ${n} | ${o}`);}}s(AK,"renderList");function xK(t,e){e?I.success(`Plugin '${t}' removed from agentsmesh.yaml`):I.warn(`Plugin '${t}' was not found in agentsmesh.yaml`);}s(xK,"renderRemove");function PK(t,e){if(e!==0&&t.package===""){I.error(`Plugin '${t.id}' not found in agentsmesh.yaml. Use: agentsmesh plugin add`);return}if(e!==0){I.error(`Failed to load plugin '${t.id}'`);return}I.info(`Plugin: ${t.id}`),I.info(`Source: ${t.package}${t.version!==void 0?`@${t.version}`:""}`),I.info(`Descriptors: ${t.descriptors.length}`);for(let r of t.descriptors)I.info(` - ${r.id}: ${r.description}`);}s(PK,"renderInfo");function TK(){I.info("Usage: agentsmesh plugin <subcommand> [args] [flags]"),I.info(""),I.info("Subcommands:"),I.info(" add <source> Register a plugin package in agentsmesh.yaml"),I.info(" list Show all configured plugins and load status"),I.info(" remove <id> Remove a plugin from agentsmesh.yaml"),I.info(" info <id> Show descriptor details for a configured plugin"),I.info(""),I.info("Flags (add):"),I.info(" --version <v> Pin plugin version"),I.info(" --id <id> Override derived plugin id"),I.info(""),I.info("Note: plugins load as trusted Node.js modules and run with full process privileges."),I.info(" Only install plugins from sources you trust.");}s(TK,"printPluginHelp");b();Xe();function Wo(t){return t.toUpperCase().replace(/-/g,"_")}s(Wo,"toPrefix");function to(t){return t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join("")}s(to,"toPascal");function uy(t){let e=Wo(t.id),r=to(t.id);return `import type { TargetGenerators } from '../catalog/target.interface.js';
|
|
333
322
|
import type { TargetDescriptor, TargetLayout } from '../catalog/target-descriptor.js';
|
|
334
323
|
import { generateRules } from './generator.js';
|
|
335
324
|
import { importFrom${r} } from './importer.js';
|
|
@@ -426,21 +415,80 @@ export const descriptor = {
|
|
|
426
415
|
buildImportPaths: build${r}ImportPaths,
|
|
427
416
|
detectionPaths: [${e}_DIR],
|
|
428
417
|
} satisfies TargetDescriptor;
|
|
429
|
-
`}s(
|
|
418
|
+
`}s(uy,"TEMPLATE_INDEX");function dy(t){return `import { describe, it, expect } from 'vitest';
|
|
419
|
+
import type { CanonicalFiles } from '../../../../src/core/types.js';
|
|
420
|
+
import { generateRules } from '../../../../src/targets/${t.id}/generator.js';
|
|
421
|
+
|
|
422
|
+
function makeCanonical(overrides: Partial<CanonicalFiles> = {}): CanonicalFiles {
|
|
423
|
+
return {
|
|
424
|
+
rules: [],
|
|
425
|
+
commands: [],
|
|
426
|
+
agents: [],
|
|
427
|
+
skills: [],
|
|
428
|
+
mcp: null,
|
|
429
|
+
permissions: null,
|
|
430
|
+
hooks: null,
|
|
431
|
+
ignore: [],
|
|
432
|
+
...overrides,
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
|
|
436
|
+
describe('generateRules (${t.id})', () => {
|
|
437
|
+
it('returns an array', () => {
|
|
438
|
+
const result = generateRules(makeCanonical());
|
|
439
|
+
expect(Array.isArray(result)).toBe(true);
|
|
440
|
+
});
|
|
441
|
+
|
|
442
|
+
it('returns empty array when no rules', () => {
|
|
443
|
+
const result = generateRules(makeCanonical({ rules: [] }));
|
|
444
|
+
expect(result).toHaveLength(0);
|
|
445
|
+
});
|
|
446
|
+
});
|
|
447
|
+
`}s(dy,"TEMPLATE_GENERATOR_TEST");function fy(t){let e=to(t.id);return `import { describe, it, expect } from 'vitest';
|
|
448
|
+
import { importFrom${e} } from '../../../../src/targets/${t.id}/importer.js';
|
|
449
|
+
|
|
450
|
+
describe('importFrom${e} (${t.id})', () => {
|
|
451
|
+
it('returns an array', async () => {
|
|
452
|
+
const result = await importFrom${e}('/tmp/stub-project');
|
|
453
|
+
expect(Array.isArray(result)).toBe(true);
|
|
454
|
+
});
|
|
455
|
+
|
|
456
|
+
it('returns empty array by default', async () => {
|
|
457
|
+
const result = await importFrom${e}('/tmp/stub-project', { scope: 'project' });
|
|
458
|
+
expect(result).toHaveLength(0);
|
|
459
|
+
});
|
|
460
|
+
});
|
|
461
|
+
`}s(fy,"TEMPLATE_IMPORTER_TEST");function gy(t){return `# ${t.displayName} Workspace
|
|
462
|
+
|
|
463
|
+
Follow the ${t.displayName} configuration files and keep changes small.
|
|
464
|
+
`}s(gy,"TEMPLATE_FIXTURE_ROOT_MD");function ZP(t){let e=Wo(t.id);return `export const ${e}_TARGET = '${t.id}';
|
|
465
|
+
|
|
466
|
+
// Project-level paths
|
|
467
|
+
export const ${e}_DIR = '.${t.id}';
|
|
468
|
+
export const ${e}_RULES_DIR = '.${t.id}/rules';
|
|
469
|
+
|
|
470
|
+
// Global-level paths
|
|
471
|
+
export const ${e}_GLOBAL_DIR = '~/.${t.id}';
|
|
472
|
+
export const ${e}_GLOBAL_RULES_DIR = '~/.${t.id}/rules';
|
|
473
|
+
|
|
474
|
+
// Canonical paths
|
|
475
|
+
export const ${e}_CANONICAL_ROOT_RULE = '.agentsmesh/rules/_root.md';
|
|
476
|
+
export const ${e}_CANONICAL_RULES_DIR = '.agentsmesh/rules';
|
|
477
|
+
`}s(ZP,"TEMPLATE_CONSTANTS");function qP(t){let e=Wo(t.id);return `import type { CanonicalFiles } from '../../core/types.js';
|
|
430
478
|
import { ${e}_TARGET, ${e}_DIR } from './constants.js';
|
|
431
479
|
|
|
432
|
-
export interface ${
|
|
480
|
+
export interface ${to(t.id)}Output {
|
|
433
481
|
path: string;
|
|
434
482
|
content: string;
|
|
435
483
|
}
|
|
436
484
|
|
|
437
|
-
export function generateRules(_canonical: CanonicalFiles): ${
|
|
485
|
+
export function generateRules(_canonical: CanonicalFiles): ${to(t.id)}Output[] {
|
|
438
486
|
// TODO(agentsmesh-scaffold): implement generateRules for ${t.displayName}
|
|
439
487
|
void ${e}_TARGET;
|
|
440
488
|
void ${e}_DIR;
|
|
441
489
|
return [];
|
|
442
490
|
}
|
|
443
|
-
`}s(
|
|
491
|
+
`}s(qP,"TEMPLATE_GENERATOR");function QP(t){let e=to(t.id),r=Wo(t.id);return `import type { ImportResult } from '../../core/types.js';
|
|
444
492
|
import type { TargetLayoutScope } from '../catalog/target-descriptor.js';
|
|
445
493
|
import { ${r}_TARGET } from './constants.js';
|
|
446
494
|
|
|
@@ -452,7 +500,7 @@ export async function importFrom${e}(
|
|
|
452
500
|
void ${r}_TARGET;
|
|
453
501
|
return [];
|
|
454
502
|
}
|
|
455
|
-
`}s(
|
|
503
|
+
`}s(QP,"TEMPLATE_IMPORTER");function tT(t){let e=Wo(t.id);return `/** Lint rules for the ${t.id} target. */
|
|
456
504
|
import type { CanonicalFiles, LintDiagnostic } from '../../core/types.js';
|
|
457
505
|
import { validateRules } from '../../core/lint/validate-rules.js';
|
|
458
506
|
import { ${e}_TARGET } from './constants.js';
|
|
@@ -470,7 +518,7 @@ export function lintRules(
|
|
|
470
518
|
target: ${e}_TARGET,
|
|
471
519
|
}));
|
|
472
520
|
}
|
|
473
|
-
`}s(
|
|
521
|
+
`}s(tT,"TEMPLATE_LINTER");function eT(t){return `/**
|
|
474
522
|
* ${t.displayName}-specific lint hooks.
|
|
475
523
|
*/
|
|
476
524
|
|
|
@@ -480,7 +528,7 @@ export function lintHooks(_canonical: CanonicalFiles): LintDiagnostic[] {
|
|
|
480
528
|
// TODO(agentsmesh-scaffold): implement target-specific hook validation for ${t.displayName}
|
|
481
529
|
return [];
|
|
482
530
|
}
|
|
483
|
-
`}s(
|
|
531
|
+
`}s(eT,"TEMPLATE_LINT_HOOKS");function rT(t){let e=to(t.id),r=Wo(t.id);return `import type { TargetLayoutScope } from '../../../targets/catalog/target-descriptor.js';
|
|
484
532
|
import { ${r}_DIR } from '../../../targets/${t.id}/constants.js';
|
|
485
533
|
|
|
486
534
|
export async function build${e}ImportPaths(
|
|
@@ -492,60 +540,14 @@ export async function build${e}ImportPaths(
|
|
|
492
540
|
// Reference: src/core/reference/import-maps/kiro.ts for a full example
|
|
493
541
|
void ${r}_DIR;
|
|
494
542
|
}
|
|
495
|
-
`}s(
|
|
496
|
-
import type { CanonicalFiles } from '../../../../src/core/types.js';
|
|
497
|
-
import { generateRules } from '../../../../src/targets/${t.id}/generator.js';
|
|
498
|
-
|
|
499
|
-
function makeCanonical(overrides: Partial<CanonicalFiles> = {}): CanonicalFiles {
|
|
500
|
-
return {
|
|
501
|
-
rules: [],
|
|
502
|
-
commands: [],
|
|
503
|
-
agents: [],
|
|
504
|
-
skills: [],
|
|
505
|
-
mcp: null,
|
|
506
|
-
permissions: null,
|
|
507
|
-
hooks: null,
|
|
508
|
-
ignore: [],
|
|
509
|
-
...overrides,
|
|
510
|
-
};
|
|
511
|
-
}
|
|
512
|
-
|
|
513
|
-
describe('generateRules (${t.id})', () => {
|
|
514
|
-
it('returns an array', () => {
|
|
515
|
-
const result = generateRules(makeCanonical());
|
|
516
|
-
expect(Array.isArray(result)).toBe(true);
|
|
517
|
-
});
|
|
518
|
-
|
|
519
|
-
it('returns empty array when no rules', () => {
|
|
520
|
-
const result = generateRules(makeCanonical({ rules: [] }));
|
|
521
|
-
expect(result).toHaveLength(0);
|
|
522
|
-
});
|
|
523
|
-
});
|
|
524
|
-
`}s(xP,"TEMPLATE_GENERATOR_TEST");function PP(t){let e=ua(t.id);return `import { describe, it, expect } from 'vitest';
|
|
525
|
-
import { importFrom${e} } from '../../../../src/targets/${t.id}/importer.js';
|
|
526
|
-
|
|
527
|
-
describe('importFrom${e} (${t.id})', () => {
|
|
528
|
-
it('returns an array', async () => {
|
|
529
|
-
const result = await importFrom${e}('/tmp/stub-project');
|
|
530
|
-
expect(Array.isArray(result)).toBe(true);
|
|
531
|
-
});
|
|
532
|
-
|
|
533
|
-
it('returns empty array by default', async () => {
|
|
534
|
-
const result = await importFrom${e}('/tmp/stub-project', { scope: 'project' });
|
|
535
|
-
expect(result).toHaveLength(0);
|
|
536
|
-
});
|
|
537
|
-
});
|
|
538
|
-
`}s(PP,"TEMPLATE_IMPORTER_TEST");function TP(t){return `# ${t.displayName} Workspace
|
|
539
|
-
|
|
540
|
-
Follow the ${t.displayName} configuration files and keep changes small.
|
|
541
|
-
`}s(TP,"TEMPLATE_FIXTURE_ROOT_MD");var zK=/^[a-z][a-z0-9-]*$/;async function DP(t){let{id:e,projectRoot:r,force:n=false}=t,o=t.displayName??e,i={id:e,displayName:o};if(!zK.test(e))throw new Error(`Invalid target id "${e}". Must match /^[a-z][a-z0-9-]*$/ (lowercase letters, digits, hyphens; start with a letter).`);if(it.includes(e))throw new Error(`Target "${e}" already exists as a built-in target. Choose a different id.`);let a=[{rel:`src/targets/${e}/constants.ts`,content:kP(i)},{rel:`src/targets/${e}/index.ts`,content:OP(i)},{rel:`src/targets/${e}/generator.ts`,content:wP(i)},{rel:`src/targets/${e}/importer.ts`,content:EP(i)},{rel:`src/targets/${e}/linter.ts`,content:LP(i)},{rel:`src/targets/${e}/lint.ts`,content:bP(i)},{rel:`src/core/reference/import-maps/${e}.ts`,content:AP(i)},{rel:`tests/unit/targets/${e}/generator.test.ts`,content:xP(i)},{rel:`tests/unit/targets/${e}/importer.test.ts`,content:PP(i)},{rel:`tests/e2e/fixtures/${e}-project/AGENTS.md`,content:TP(i)}],c=[],l=[];for(let p of a){let u=join(r,p.rel);if(!n&&await v(u)){l.push(u);continue}await S(u,p.content),c.push(u);}let m=["1. Run: pnpm catalog:generate (auto-discovers the new target \u2014 updates IDs, descriptors, and import-map barrel)",`2. Fill in TODO(agentsmesh-scaffold) markers in src/targets/${e}/`,`3. Run: pnpm typecheck && pnpm test -- tests/unit/targets/${e}`,"4. Run: pnpm schemas:generate && pnpm matrix:generate"];return {written:c,skipped:l,postSteps:m}}s(DP,"writeTargetScaffold");async function FP(t,e,r){let n=e[0];return n===void 0||n===""?{exitCode:0,data:{id:"",written:[],skipped:[],postSteps:[]},showHelp:true}:n==="scaffold"?VK(t,e.slice(1),r):{exitCode:2,data:{id:"",written:[],skipped:[],postSteps:[]},showHelp:true,error:`Unknown target subcommand: ${n}`}}s(FP,"runTarget");async function VK(t,e,r){let n=e[0];if(!n)throw new kr("Usage: agentsmesh target scaffold <id> [--name <displayName>] [--force]");let o=typeof t.name=="string"?t.name:void 0,i=t.force===true,a;try{a=await DP({id:n,displayName:o,projectRoot:r,force:i});}catch(c){return {exitCode:1,data:{id:n,written:[],skipped:[],postSteps:[]},error:c instanceof Error?c.message:String(c)}}return {exitCode:0,data:{id:n,written:a.written.map(c=>NP(c,r)),skipped:a.skipped.map(c=>NP(c,r)),postSteps:a.postSteps}}}s(VK,"runScaffold");function NP(t,e){return (t.startsWith(e)?t.slice(e.length+1):t).replaceAll("\\","/")}s(NP,"relativize");nt();function vP(t){if(t.error&&I.error(t.error),t.showHelp){JK();return}let{data:e}=t;for(let r of e.written)I.success(`created ${r}`);for(let r of e.skipped)I.warn(`skipped ${r} (already exists \u2014 use --force to overwrite)`);if(e.written.length>0){I.info(""),I.info("Next steps:");for(let r of e.postSteps)I.info(` ${r}`);}}s(vP,"renderTarget");function JK(){I.info("Usage: agentsmesh target <subcommand> [args] [flags]"),I.info(""),I.info("Subcommands:"),I.info(" scaffold <id> Generate a new target skeleton (files, tests, fixture)"),I.info(""),I.info("Flags (scaffold):"),I.info(" --name <displayName> Human-readable name (defaults to id)"),I.info(" --force Overwrite existing files");}s(JK,"printTargetHelp");ye();zo();A();le();Vn();ln();function rW(t,e){return t===".agentsmesh"?false:!!(t.startsWith(".")||!e)}s(rW,"shouldSymlink");function nW(t){let e=mkdtempSync(join(tmpdir(),"am-convert-")),r=readdirSync(t,{withFileTypes:true});for(let n of r){if(!rW(n.name,n.isDirectory()))continue;let o=join(t,n.name),i=join(e,n.name);symlinkSync(o,i,n.isDirectory()?"dir":"file");}return mkdirSync(join(e,".agentsmesh"),{recursive:true}),e}s(nW,"createTempProjectRoot");async function Kp(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=n==="global"?homedir():r,i=t.from,a=t.to;if(typeof i!="string"||!i)throw new Error("--from is required. Example: agentsmesh convert --from cursor --to claude-code");if(typeof a!="string"||!a)throw new Error("--to is required. Example: agentsmesh convert --from cursor --to claude-code");let c=i.toLowerCase().trim(),l=a.toLowerCase().trim();if(c===l)throw new Error("--from and --to must be different targets.");let m=He(c),p=He(l);if(!m||!p)try{let{config:C}=await lt(r,"project");await Jt(C,r);}catch{let C=[];throw m||C.push(`--from "${i}"`),p||C.push(`--to "${a}"`),new Error(`Unknown ${C.join(" and ")}. Supported: ${it.join(", ")}.`)}let u=tt(c);if(!u)throw new Error(`Unknown --from "${i}". Supported: ${it.join(", ")}.`);if(!tt(l))throw new Error(`Unknown --to "${a}". Supported: ${it.join(", ")}.`);let g=t["dry-run"]===true,h=g?"dry-run":"convert",R=nW(o);try{await u.generators.importFrom(R,{scope:n});let C=await pe(R),_=jo.parse({version:1,targets:p?[l]:[],pluginTargets:p?[]:[l]}),E=await je({config:_,canonical:C,projectRoot:o,scope:n,targetFilter:[l]});if(!g){for(let x of E)if(x.status==="created"||x.status==="updated"){let Z=sa(o,x.path,x.target);await S(Z,x.content);}}let T=E.filter(x=>x.status!=="skipped"),D=T.map(x=>({path:x.path,target:x.target,status:x.status}));return {exitCode:0,data:{from:c,to:l,mode:h,files:D,summary:{created:T.filter(x=>x.status==="created").length,updated:T.filter(x=>x.status==="updated").length,unchanged:T.filter(x=>x.status==="unchanged").length}}}}finally{rmSync(R,{recursive:true,force:true});}}s(Kp,"runConvert");nt();function MP(t){let{data:e}=t;if(e.files.length===0){I.info(`No files found to convert from ${e.from}.`);return}if(e.mode==="dry-run"){for(let i of e.files)I.info(`[dry-run] ${i.status} ${i.path} (${i.target})`);return}for(let i of e.files)(i.status==="created"||i.status==="updated")&&I.success(`${i.status} ${i.path}`);let{created:r,updated:n,unchanged:o}=e.summary;r>0||n>0?I.info(`Converted from ${e.from} \u2192 ${e.to}: ${r} created, ${n} updated, ${o} unchanged`):I.info(`Nothing changed. (${o} unchanged)`);}s(MP,"renderConvert");var oW=/(^|\s)\/[A-Za-z]|^[A-Z]:[\\/]/,G=class extends Error{static{s(this,"McpError");}code;details;constructor(e,r,n){if(oW.test(r))throw new Error(`McpError refuses absolute fs path in message: ${r}`);super(r),this.code=e,this.details=n;}toEnvelope(){return this.details===void 0?{code:this.code,message:this.message}:{code:this.code,message:this.message,details:this.details}}};async function qh(t){let e=resolve(t.projectRoot,".agentsmesh",t.feature),r=resolve(e,t.relativePath);if(!r.startsWith(e+sep)&&r!==e)throw new G("PATH_TRAVERSAL",`path escapes ${t.feature} directory`);if(Buffer.byteLength(t.content,"utf8")>1048576)throw new G("LIMIT_EXCEEDED","file body exceeds 1 MiB cap",{limit:1048576,actual:Buffer.byteLength(t.content,"utf8")});await mkdir(dirname(r),{recursive:true});let n=`${r}.tmp.${process.pid}.${Date.now()}`;return await writeFile(n,t.content,"utf8"),await rename(n,r),r}s(qh,"safeWrite");var uW=/^---\r?\n([\s\S]*?)\r?\n---\r?\n\r?\n?([\s\S]*)$/;function $o(t){let e=uW.exec(t);return e?{frontmatter:parse(e[1]??"")??{},body:e[2]??""}:{frontmatter:{},body:t}}s($o,"parseMd");function fa(t,e){return Object.keys(t).length===0?e:`---
|
|
543
|
+
`}s(rT,"TEMPLATE_IMPORT_MAP");var NK=/^[a-z][a-z0-9-]*$/;async function nT(t){let{id:e,projectRoot:r,force:n=false}=t,o=t.displayName??e,i={id:e,displayName:o};if(!NK.test(e))throw new Error(`Invalid target id "${e}". Must match /^[a-z][a-z0-9-]*$/ (lowercase letters, digits, hyphens; start with a letter).`);if(lt.includes(e))throw new Error(`Target "${e}" already exists as a built-in target. Choose a different id.`);let a=[{rel:`src/targets/${e}/constants.ts`,content:ZP(i)},{rel:`src/targets/${e}/index.ts`,content:uy(i)},{rel:`src/targets/${e}/generator.ts`,content:qP(i)},{rel:`src/targets/${e}/importer.ts`,content:QP(i)},{rel:`src/targets/${e}/linter.ts`,content:tT(i)},{rel:`src/targets/${e}/lint.ts`,content:eT(i)},{rel:`src/core/reference/import-maps/${e}.ts`,content:rT(i)},{rel:`tests/unit/targets/${e}/generator.test.ts`,content:dy(i)},{rel:`tests/unit/targets/${e}/importer.test.ts`,content:fy(i)},{rel:`tests/e2e/fixtures/${e}-project/AGENTS.md`,content:gy(i)}],c=[],l=[];for(let p of a){let u=join(r,p.rel);if(!n&&await F(u)){l.push(u);continue}await C(u,p.content),c.push(u);}let m=["1. Run: pnpm catalog:generate (auto-discovers the new target \u2014 updates IDs, descriptors, and import-map barrel)",`2. Fill in TODO(agentsmesh-scaffold) markers in src/targets/${e}/`,`3. Run: pnpm typecheck && pnpm test -- tests/unit/targets/${e}`,"4. Run: pnpm schemas:generate && pnpm matrix:generate"];return {written:c,skipped:l,postSteps:m}}s(nT,"writeTargetScaffold");async function sT(t,e,r){let n=e[0];return n===void 0||n===""?{exitCode:0,data:{id:"",written:[],skipped:[],postSteps:[]},showHelp:true}:n==="scaffold"?FK(t,e.slice(1),r):{exitCode:2,data:{id:"",written:[],skipped:[],postSteps:[]},showHelp:true,error:`Unknown target subcommand: ${n}`}}s(sT,"runTarget");async function FK(t,e,r){let n=e[0];if(!n)throw new Lr("Usage: agentsmesh target scaffold <id> [--name <displayName>] [--force]");let o=typeof t.name=="string"?t.name:void 0,i=t.force===true,a;try{a=await nT({id:n,displayName:o,projectRoot:r,force:i});}catch(c){return {exitCode:1,data:{id:n,written:[],skipped:[],postSteps:[]},error:c instanceof Error?c.message:String(c)}}return {exitCode:0,data:{id:n,written:a.written.map(c=>oT(c,r)),skipped:a.skipped.map(c=>oT(c,r)),postSteps:a.postSteps}}}s(FK,"runScaffold");function oT(t,e){return (t.startsWith(e)?t.slice(e.length+1):t).replaceAll("\\","/")}s(oT,"relativize");st();function iT(t){if(t.error&&I.error(t.error),t.showHelp){vK();return}let{data:e}=t;for(let r of e.written)I.success(`created ${r}`);for(let r of e.skipped)I.warn(`skipped ${r} (already exists \u2014 use --force to overwrite)`);if(e.written.length>0){I.info(""),I.info("Next steps:");for(let r of e.postSteps)I.info(` ${r}`);}}s(iT,"renderTarget");function vK(){I.info("Usage: agentsmesh target <subcommand> [args] [flags]"),I.info(""),I.info("Subcommands:"),I.info(" scaffold <id> Generate a new target skeleton (files, tests, fixture)"),I.info(""),I.info("Flags (scaffold):"),I.info(" --name <displayName> Human-readable name (defaults to id)"),I.info(" --force Overwrite existing files");}s(vK,"printTargetHelp");Ce();Qo();b();de();Qn();fn();function BK(t,e){return t===".agentsmesh"?false:!!(t.startsWith(".")||!e)}s(BK,"shouldSymlink");function HK(t){let e=mkdtempSync(join(tmpdir(),"am-convert-")),r=readdirSync(t,{withFileTypes:true});for(let n of r){if(!BK(n.name,n.isDirectory()))continue;let o=join(t,n.name),i=join(e,n.name);symlinkSync(o,i,n.isDirectory()?"dir":"file");}return mkdirSync(join(e,".agentsmesh"),{recursive:true}),e}s(HK,"createTempProjectRoot");async function Zp(t,e){let r=e??process.cwd(),n=t.global===true?"global":"project",o=n==="global"?homedir():r,i=t.from,a=t.to;if(typeof i!="string"||!i)throw new Error("--from is required. Example: agentsmesh convert --from cursor --to claude-code");if(typeof a!="string"||!a)throw new Error("--to is required. Example: agentsmesh convert --from cursor --to claude-code");let c=i.toLowerCase().trim(),l=a.toLowerCase().trim();if(c===l)throw new Error("--from and --to must be different targets.");let m=Ye(c),p=Ye(l);if(!m||!p)try{let{config:S}=await ut(r,"project");await qt(S,r);}catch{let S=[];throw m||S.push(`--from "${i}"`),p||S.push(`--to "${a}"`),new Error(`Unknown ${S.join(" and ")}. Supported: ${lt.join(", ")}.`)}let u=et(c);if(!u)throw new Error(`Unknown --from "${i}". Supported: ${lt.join(", ")}.`);if(!et(l))throw new Error(`Unknown --to "${a}". Supported: ${lt.join(", ")}.`);let g=t["dry-run"]===true,h=g?"dry-run":"convert",R=HK(o);try{await u.generators.importFrom(R,{scope:n});let S=await ge(R),_=Vo.parse({version:1,targets:p?[l]:[],pluginTargets:p?[]:[l]}),k=await He({config:_,canonical:S,projectRoot:o,scope:n,targetFilter:[l]});if(!g){for(let A of k)if(A.status==="created"||A.status==="updated"){let Z=ua(o,A.path,A.target);await C(Z,A.content);}}let T=k.filter(A=>A.status!=="skipped"),P=T.map(A=>({path:A.path,target:A.target,status:A.status}));return {exitCode:0,data:{from:c,to:l,mode:h,files:P,summary:{created:T.filter(A=>A.status==="created").length,updated:T.filter(A=>A.status==="updated").length,unchanged:T.filter(A=>A.status==="unchanged").length}}}}finally{rmSync(R,{recursive:true,force:true});}}s(Zp,"runConvert");st();function aT(t){let{data:e}=t;if(e.files.length===0){I.info(`No files found to convert from ${e.from}.`);return}if(e.mode==="dry-run"){for(let i of e.files)I.info(`[dry-run] ${i.status} ${i.path} (${i.target})`);return}for(let i of e.files)(i.status==="created"||i.status==="updated")&&I.success(`${i.status} ${i.path}`);let{created:r,updated:n,unchanged:o}=e.summary;r>0||n>0?I.info(`Converted from ${e.from} \u2192 ${e.to}: ${r} created, ${n} updated, ${o} unchanged`):I.info(`Nothing changed. (${o} unchanged)`);}s(aT,"renderConvert");var zK=/(^|\s)\/[A-Za-z]|^[A-Z]:[\\/]/,$=class extends Error{static{s(this,"McpError");}code;details;constructor(e,r,n){if(zK.test(r))throw new Error(`McpError refuses absolute fs path in message: ${r}`);super(r),this.code=e,this.details=n;}toEnvelope(){return this.details===void 0?{code:this.code,message:this.message}:{code:this.code,message:this.message,details:this.details}}};function cT(t){return t.replace(/(['"`])\/[^'"`\s]+\1/gu,"$1<redacted>$1").replace(/(\s|^)\/[A-Za-z][^\s'"`]*/gu,"$1<redacted>").replace(/(\s|^)[A-Z]:[\\/][^\s'"`]*/gu,"$1<redacted>")}s(cT,"redactAbsolutePaths");async function hy(t){let e=resolve(t.projectRoot,".agentsmesh",t.feature),r=resolve(e,t.relativePath);if(!r.startsWith(e+sep)&&r!==e)throw new $("PATH_TRAVERSAL",`path escapes ${t.feature} directory`);if(Buffer.byteLength(t.content,"utf8")>1048576)throw new $("LIMIT_EXCEEDED","file body exceeds 1 MiB cap",{limit:1048576,actual:Buffer.byteLength(t.content,"utf8")});await mkdir(dirname(r),{recursive:true});let n=`${r}.tmp.${process.pid}.${Date.now()}`;return await writeFile(n,t.content,"utf8"),await rename(n,r),r}s(hy,"safeWrite");var tB=/^---\r?\n([\s\S]*?)\r?\n---\r?\n\r?\n?([\s\S]*)$/;function Bo(t){let e=tB.exec(t);return e?{frontmatter:parse(e[1]??"")??{},body:e[2]??""}:{frontmatter:{},body:t}}s(Bo,"parseMd");function Ia(t,e){return Object.keys(t).length===0?e:`---
|
|
542
544
|
${stringify(t).trimEnd()}
|
|
543
545
|
---
|
|
544
546
|
|
|
545
|
-
${e}`}s(fa,"serializeMd");var yW=/^[a-zA-Z0-9_][a-zA-Z0-9_/-]*$/,_W={rules:"_root"};function Wp(t){if(!yW.test(t)||t.includes("..")||t.includes("//")||t.endsWith("/"))throw new G("INVALID_NAME",`invalid name: ${t}`)}s(Wp,"checkName");function Bp(t,e,r){return resolve(t,".agentsmesh",e,`${r}.md`)}s(Bp,"pathFor");function ga(t){let{feature:e,frontmatterSchema:r,toSummary:n}=t,o=s(c=>resolve(c,".agentsmesh",e),"featureDir");async function i(c){try{return (await readdir(o(c),{withFileTypes:!0})).filter(m=>m.isFile()&&m.name.endsWith(".md")).map(m=>m.name)}catch{return []}}s(i,"listFiles");async function a(c){try{return await stat(c),!0}catch{return false}}return s(a,"exists"),{async list(c){let l=await i(c.projectRoot),m=[];for(let p of l){let u=p.replace(/\.md$/,""),f=await readFile(join(o(c.projectRoot),p),"utf8"),{frontmatter:g}=$o(f);m.push(n(u,g));}return m},async get(c,{name:l}){Wp(l);let m=Bp(c.projectRoot,e,l);try{let p=await readFile(m,"utf8"),{frontmatter:u,body:f}=$o(p);return {name:l,frontmatter:u,body:f}}catch(p){throw p.code==="ENOENT"?new G("NOT_FOUND",`${e} "${l}" not found`):new G("IO_ERROR",`failed to read ${e}`)}},async create(c,{name:l,frontmatter:m,body:p,dry_run:u}){Wp(l);let f=r.safeParse(m);if(!f.success)throw new G("VALIDATION_FAILED","invalid frontmatter",f.error.issues);let g=Bp(c.projectRoot,e,l);if(await a(g))throw new G("ALREADY_EXISTS",`${e} "${l}" exists`);if((await i(c.projectRoot)).length>=1e3)throw new G("LIMIT_EXCEEDED",`${e} dir at ${1e3} entries`);let R=fa(m,p);return u===true?{path:g,written:false}:(await qh({projectRoot:c.projectRoot,feature:e,relativePath:`${l}.md`,content:R}),{path:g,written:true})},async update(c,{name:l,frontmatter:m,body:p,merge:u,dry_run:f}){Wp(l);let g=Bp(c.projectRoot,e,l),h;try{let T=await readFile(g,"utf8");h=$o(T);}catch(T){throw T.code==="ENOENT"?new G("NOT_FOUND",`${e} "${l}" not found`):new G("IO_ERROR",`failed to read ${e}`)}let R=m===void 0?h.frontmatter:u===true?{...h.frontmatter,...m}:m,C=r.safeParse(R);if(!C.success)throw new G("VALIDATION_FAILED","invalid frontmatter",C.error.issues);let _=p!==void 0?p:h.body,E=fa(R,_);return f===true?{path:g,written:false}:(await qh({projectRoot:c.projectRoot,feature:e,relativePath:`${l}.md`,content:E}),{path:g,written:true})},async delete(c,{name:l,force:m,dry_run:p}){if(Wp(l),_W[e]===l&&m!==true)throw new G("PROTECTED_FILE",`${e} "${l}" requires force: true`);let u=Bp(c.projectRoot,e,l);if(!await a(u))throw new G("NOT_FOUND",`${e} "${l}" not found`);return p===true?{path:u,deleted:false}:(await rm$1(u),{path:u,deleted:true})}}}s(ga,"createCanonicalHandlers");var IW=z$1.object({description:z$1.string().optional(),root:z$1.boolean().optional(),globs:z$1.array(z$1.string()).nullable().optional(),targets:z$1.array(z$1.string()).nullable().optional()}).passthrough(),jP=ga({feature:"rules",frontmatterSchema:IW,toSummary:s((t,e)=>({name:t,description:e.description??null,root:!!e.root,globs:e.globs??null,targets:e.targets??null}),"toSummary")});var CW=z$1.object({description:z$1.string().optional(),"allowed-tools":z$1.array(z$1.string()).optional()}).passthrough(),UP=ga({feature:"commands",frontmatterSchema:CW,toSummary:s((t,e)=>({name:t,description:e.description??null,allowedTools:e["allowed-tools"]??null}),"toSummary")});var SW=z$1.object({name:z$1.string().optional(),description:z$1.string().optional(),tools:z$1.array(z$1.string()).optional(),model:z$1.string().optional()}).passthrough(),KP=ga({feature:"agents",frontmatterSchema:SW,toSummary:s((t,e)=>({name:t,description:e.description??null,tools:e.tools??null,model:e.model??null}),"toSummary")});async function BP(t){let e=resolve(t.projectRoot,".agentsmesh/skills",t.skillName),r=resolve(e,t.filePath);if(!r.startsWith(e+sep)&&r!==e)throw new G("PATH_TRAVERSAL","file escapes skill directory");try{return await readFile(r,"utf8")}catch(n){throw n.code==="ENOENT"?new G("NOT_FOUND",`skill file not found: ${t.filePath}`):new G("IO_ERROR","failed to read skill file")}}s(BP,"safeRead");var bW=/^[a-zA-Z0-9_][a-zA-Z0-9_-]*$/,AW=/^[a-zA-Z0-9_][a-zA-Z0-9_/-]*\.[a-zA-Z0-9]+$/,JP=z$1.object({name:z$1.string().optional(),description:z$1.string().optional()}).passthrough();function qc(t){if(!bW.test(t))throw new G("INVALID_NAME",`invalid skill name: ${t}`)}s(qc,"checkName");function ry(t){if(!AW.test(t)||t.includes("..")||t.includes("//"))throw new G("PATH_TRAVERSAL",`invalid supporting-file path: ${t}`)}s(ry,"checkSupportPath");async function Vp(t,e){if(Buffer.byteLength(e,"utf8")>1048576)throw new G("LIMIT_EXCEEDED","file body exceeds 1 MiB cap");await mkdir(dirname(t),{recursive:true});let r=`${t}.tmp.${process.pid}.${Date.now()}`;await writeFile(r,e,"utf8"),await rename(r,t);}s(Vp,"atomicWrite");var YP=s(t=>resolve(t,".agentsmesh/skills"),"skillsDir"),Qc=s((t,e)=>resolve(YP(t),e),"skillDir"),Bs={async list(t){let e;try{e=(await readdir(YP(t.projectRoot),{withFileTypes:!0})).filter(n=>n.isDirectory()).map(n=>n.name);}catch{return []}let r=[];for(let n of e)try{let o=await readFile(resolve(Qc(t.projectRoot,n),"SKILL.md"),"utf8"),i=$o(o).frontmatter;r.push({name:n,description:i.description??null});}catch{}return r},async get(t,{name:e}){qc(e);let r=Qc(t.projectRoot,e);try{let n=await readFile(resolve(r,"SKILL.md"),"utf8"),{frontmatter:o,body:i}=$o(n),c=(await readdir(r)).filter(l=>l!=="SKILL.md").sort();return {name:e,frontmatter:o,body:i,supportingFiles:c}}catch(n){throw n.code==="ENOENT"?new G("NOT_FOUND",`skill "${e}" not found`):new G("IO_ERROR","failed to read skill")}},async getFile(t,{name:e,path:r}){return qc(e),ry(r),{content:await BP({projectRoot:t.projectRoot,skillName:e,filePath:r}),encoding:"utf-8"}},async create(t,e){qc(e.name);let r=JP.safeParse(e.frontmatter);if(!r.success)throw new G("VALIDATION_FAILED","invalid frontmatter",r.error.issues);let n=Qc(t.projectRoot,e.name),o=false;try{await stat(n),o=!0;}catch{}if(o)throw new G("ALREADY_EXISTS",`skill "${e.name}" exists`);let i=e.supportingFiles??{},a=Object.keys(i);if(a.forEach(ry),a.length+1>1e3)throw new G("LIMIT_EXCEEDED","supporting files exceed cap");if(e.dry_run===true)return {path:n,written:false,supportingFilesWritten:[]};let c=resolve(n,"SKILL.md");await Vp(c,fa(e.frontmatter,e.body));for(let[l,m]of Object.entries(i))await Vp(resolve(n,l),m);return {path:n,written:true,supportingFilesWritten:a}},async update(t,e){qc(e.name);let r=Qc(t.projectRoot,e.name),n;try{let p=await readFile(resolve(r,"SKILL.md"),"utf8");n=$o(p);}catch(p){throw p.code==="ENOENT"?new G("NOT_FOUND",`skill "${e.name}" not found`):new G("IO_ERROR","failed to read skill")}let o=e.frontmatter===void 0?n.frontmatter:e.merge===true?{...n.frontmatter,...e.frontmatter}:e.frontmatter,i=JP.safeParse(o);if(!i.success)throw new G("VALIDATION_FAILED","invalid frontmatter",i.error.issues);let a=e.body!==void 0?e.body:n.body,c=e.supportingFiles??{};Object.keys(c).forEach(ry);let l=[],m=[];if(e.dry_run===true)return Object.entries(c).forEach(([p,u])=>(u===null?m:l).push(p)),{path:r,written:false,supportingFilesAffected:{written:l,deleted:m}};await Vp(resolve(r,"SKILL.md"),fa(o,a));for(let[p,u]of Object.entries(c)){let f=resolve(r,p);if(u===null)try{await rm$1(f),m.push(p);}catch{}else await Vp(f,u),l.push(p);}return {path:r,written:true,supportingFilesAffected:{written:l,deleted:m}}},async delete(t,{name:e,dry_run:r}){qc(e);let n=Qc(t.projectRoot,e);try{await stat(n);}catch{throw new G("NOT_FOUND",`skill "${e}" not found`)}return r===true?{path:n,deleted:false}:(await rm$1(n,{recursive:true}),{path:n,deleted:true})}};async function XP(t){if(t.filename!==void 0&&t.filename!=="agentsmesh.yaml")throw new G("PATH_TRAVERSAL","only agentsmesh.yaml is writable");if(Buffer.byteLength(t.content,"utf8")>1048576)throw new G("LIMIT_EXCEEDED","config exceeds 1 MiB cap");let e=resolve(t.projectRoot,"agentsmesh.yaml"),r=`${e}.tmp.${process.pid}.${Date.now()}`;return await writeFile(r,t.content,"utf8"),await rename(r,e),e}s(XP,"safeConfigWrite");ln();Aa();async function tl(t){try{return parse(await readFile(t,"utf8"))}catch(e){if(e.code==="ENOENT")return null;throw new G("IO_ERROR","failed to read yaml")}}s(tl,"readYaml");async function ya(t,e){if(Buffer.byteLength(e,"utf8")>1048576)throw new G("LIMIT_EXCEEDED","file exceeds 1 MiB cap");let r=`${t}.tmp.${process.pid}.${Date.now()}`;await writeFile(r,e,"utf8"),await rename(r,t);}s(ya,"atomicWrite");var Se={async getConfig(t){let e=await tl(resolve(t.projectRoot,"agentsmesh.yaml"));if(e===null)throw new G("NO_PROJECT","agentsmesh.yaml missing");return e},async listMcpServers(t){let e=resolve(t.projectRoot,".agentsmesh/mcp.json");try{return {servers:(await Ve(e))?.mcpServers??null}}catch{return {servers:null}}},async getPermissions(t){return await tl(resolve(t.projectRoot,".agentsmesh/permissions.yaml"))??null},async getHooks(t){return await tl(resolve(t.projectRoot,".agentsmesh/hooks.yaml"))??null},async getIgnore(t){try{return {patterns:(await readFile(resolve(t.projectRoot,".agentsmesh/ignore"),"utf8")).split(/\r?\n/).filter(r=>r!==""&&!r.startsWith("#"))}}catch{return {patterns:null}}},async updateConfig(t,e){let r=await tl(resolve(t.projectRoot,"agentsmesh.yaml"))??{},n={...r},o=s((l,m)=>{m!==void 0&&(n[l]=e.merge===true&&Array.isArray(r[l])?Array.from(new Set([...r[l],...m])):m);},"apply");o("targets",e.targets),o("features",e.features),e.conversions!==void 0&&(n.conversions=e.merge===true&&r.conversions!==void 0?{...r.conversions,...e.conversions}:e.conversions);let i=jo.safeParse(n);if(!i.success)throw new G("VALIDATION_FAILED","invalid config",i.error.issues);let a=stringify(n);return e.dry_run===true?{path:resolve(t.projectRoot,"agentsmesh.yaml"),written:false}:{path:await XP({projectRoot:t.projectRoot,content:a,filename:e.filename}),written:true}},async addMcpServer(t,e){let r=resolve(t.projectRoot,".agentsmesh/mcp.json"),n=await Ve(r).catch(()=>null)??{mcpServers:{}};if(n.mcpServers[e.name]!==void 0)throw new G("ALREADY_EXISTS",`server "${e.name}" exists`);return n.mcpServers[e.name]=e.server,e.dry_run===true?{path:r,written:false}:(await ya(r,JSON.stringify(n,null,2)+`
|
|
546
|
-
`),{path:r,written:true})},async updateMcpServer(t,e){let r=resolve(t.projectRoot,".agentsmesh/mcp.json"),n=await
|
|
547
|
-
`),{path:r,written:true})},async removeMcpServer(t,e){let r=resolve(t.projectRoot,".agentsmesh/mcp.json"),n=await
|
|
548
|
-
`),{path:r,removed:true})},async updatePermissions(t,e){let r=resolve(t.projectRoot,".agentsmesh/permissions.yaml"),n=await
|
|
547
|
+
${e}`}s(Ia,"serializeMd");var sB=/^[a-zA-Z0-9_][a-zA-Z0-9_-]*$/,iB={rules:"_root"};function qp(t){if(!sB.test(t)||t.includes(".."))throw new $("INVALID_NAME",`invalid name: ${t}`)}s(qp,"checkName");function Qp(t,e,r){return resolve(t,".agentsmesh",e,`${r}.md`)}s(Qp,"pathFor");function Sa(t){let{feature:e,frontmatterSchema:r,toSummary:n}=t,o=s(c=>resolve(c,".agentsmesh",e),"featureDir");async function i(c){try{return (await readdir(o(c),{withFileTypes:!0})).filter(m=>m.isFile()&&m.name.endsWith(".md")).map(m=>m.name)}catch{return []}}s(i,"listFiles");async function a(c){try{return await stat(c),!0}catch{return false}}return s(a,"exists"),{async list(c){let l=await i(c.projectRoot),m=[];for(let p of l){let u=p.replace(/\.md$/,""),f=await readFile(join(o(c.projectRoot),p),"utf8"),{frontmatter:g}=Bo(f);m.push(n(u,g));}return m},async get(c,{name:l}){qp(l);let m=Qp(c.projectRoot,e,l);try{let p=await readFile(m,"utf8"),{frontmatter:u,body:f}=Bo(p);return {name:l,frontmatter:u,body:f}}catch(p){let u=p.code;throw u==="ENOENT"?new $("NOT_FOUND",`${e} "${l}" not found`):new $("IO_ERROR",`failed to read ${e}`,{errno:u})}},async create(c,{name:l,frontmatter:m,body:p,dry_run:u}){qp(l);let f=r.safeParse(m);if(!f.success)throw new $("VALIDATION_FAILED","invalid frontmatter",f.error.issues);let g=Qp(c.projectRoot,e,l);if(await a(g))throw new $("ALREADY_EXISTS",`${e} "${l}" exists`);if((await i(c.projectRoot)).length>=1e3)throw new $("LIMIT_EXCEEDED",`${e} dir at ${1e3} entries`);let R=Ia(m,p);return u===true?{path:g,written:false}:(await hy({projectRoot:c.projectRoot,feature:e,relativePath:`${l}.md`,content:R}),{path:g,written:true})},async update(c,{name:l,frontmatter:m,body:p,merge:u,dry_run:f}){qp(l);let g=Qp(c.projectRoot,e,l),h;try{let T=await readFile(g,"utf8");h=Bo(T);}catch(T){let P=T.code;throw P==="ENOENT"?new $("NOT_FOUND",`${e} "${l}" not found`):new $("IO_ERROR",`failed to read ${e}`,{errno:P})}let R=m===void 0?h.frontmatter:u===true?{...h.frontmatter,...m}:m,S=r.safeParse(R);if(!S.success)throw new $("VALIDATION_FAILED","invalid frontmatter",S.error.issues);let _=p!==void 0?p:h.body,k=Ia(R,_);return f===true?{path:g,written:false}:(await hy({projectRoot:c.projectRoot,feature:e,relativePath:`${l}.md`,content:k}),{path:g,written:true})},async delete(c,{name:l,force:m,dry_run:p}){if(qp(l),iB[e]===l&&m!==true)throw new $("PROTECTED_FILE",`${e} "${l}" requires force: true`);let u=Qp(c.projectRoot,e,l);if(!await a(u))throw new $("NOT_FOUND",`${e} "${l}" not found`);return p===true?{path:u,deleted:false}:(await rm$1(u),{path:u,deleted:true})}}}s(Sa,"createCanonicalHandlers");var aB=z$1.object({description:z$1.string().optional(),root:z$1.boolean().optional(),globs:z$1.array(z$1.string()).nullable().optional(),targets:z$1.array(z$1.string()).nullable().optional()}).passthrough(),pT=Sa({feature:"rules",frontmatterSchema:aB,toSummary:s((t,e)=>({name:t,description:e.description??null,root:!!e.root,globs:e.globs??null,targets:e.targets??null}),"toSummary")});var cB=z$1.object({description:z$1.string().optional(),"allowed-tools":z$1.array(z$1.string()).optional()}).passthrough(),uT=Sa({feature:"commands",frontmatterSchema:cB,toSummary:s((t,e)=>({name:t,description:e.description??null,allowedTools:e["allowed-tools"]??null}),"toSummary")});var lB=z$1.object({name:z$1.string().optional(),description:z$1.string().optional(),tools:z$1.array(z$1.string()).optional(),model:z$1.string().optional()}).passthrough(),dT=Sa({feature:"agents",frontmatterSchema:lB,toSummary:s((t,e)=>({name:t,description:e.description??null,tools:e.tools??null,model:e.model??null}),"toSummary")});var mB=z$1.object({name:z$1.string().describe('Item name (e.g. "auth", "code-review")')}),pB=z$1.object({name:z$1.string().describe('Item name (e.g. "auth", "code-review")'),frontmatter:z$1.record(z$1.string(),z$1.unknown()).describe("YAML frontmatter fields (e.g. { description, globs, targets })"),body:z$1.string().describe("Markdown body content"),dry_run:z$1.boolean().optional().describe("Preview changes without writing to disk")}),uB=z$1.object({}).strict();function _y(t,e){let r=t==="rule"?"rules":t==="command"?"commands":"agents";return [{name:`list_${r}`,description:`List ${r} with summary metadata`,inputSchema:uB,handler:s(n=>e.list(n),"handler"),resourceUri:`agentsmesh://canonical/${r}`},{name:`get_${t}`,description:`Get a single ${t} by name`,inputSchema:mB,handler:s((n,o)=>e.get(n,o),"handler"),resourceUri:`agentsmesh://canonical/${r}/{name}`},{name:`create_${t}`,description:`Create a new ${t}`,inputSchema:pB,handler:s((n,o)=>e.create(n,o),"handler")},{name:`update_${t}`,description:`Update a ${t}. Default: replace frontmatter entirely. Set merge=true to shallow-merge. Omitting body preserves the existing body.`,inputSchema:z$1.object({name:z$1.string().describe("Name of the item to update"),frontmatter:z$1.record(z$1.string(),z$1.unknown()).optional().describe("New frontmatter fields (replaces by default; set merge=true to shallow-merge)"),body:z$1.string().optional().describe("New markdown body (omit to preserve existing)"),merge:z$1.boolean().optional().describe("If true, shallow-merge frontmatter instead of replacing"),dry_run:z$1.boolean().optional().describe("Preview changes without writing to disk")}),handler:s((n,o)=>e.update(n,o),"handler")},{name:`delete_${t}`,description:`Delete a ${t}. For rules: deleting _root requires force=true.`,inputSchema:z$1.object({name:z$1.string().describe("Name of the item to delete"),force:z$1.boolean().optional().describe("Required to delete protected files like _root"),dry_run:z$1.boolean().optional().describe("Preview without deleting")}),handler:s((n,o)=>e.delete(n,o),"handler")}]}s(_y,"canonicalTools");var fT=[..._y("rule",pT),..._y("command",uT),..._y("agent",dT)];async function hT(t){let e=resolve(t.projectRoot,".agentsmesh/skills",t.skillName),r=resolve(e,t.filePath);if(!r.startsWith(e+sep)&&r!==e)throw new $("PATH_TRAVERSAL","file escapes skill directory");try{return await readFile(r,"utf8")}catch(n){throw n.code==="ENOENT"?new $("NOT_FOUND",`skill file not found: ${t.filePath}`):new $("IO_ERROR","failed to read skill file")}}s(hT,"safeRead");var IB=/^[a-zA-Z0-9_][a-zA-Z0-9_-]*$/,SB=/^[a-zA-Z0-9_][a-zA-Z0-9_/-]*\.[a-zA-Z0-9]+$/,ST=z$1.object({name:z$1.string().optional(),description:z$1.string().optional()}).passthrough();function nl(t){if(!IB.test(t))throw new $("INVALID_NAME",`invalid skill name: ${t}`)}s(nl,"checkName");function Cy(t){if(!SB.test(t)||t.includes("..")||t.includes("//"))throw new $("PATH_TRAVERSAL",`invalid supporting-file path: ${t}`)}s(Cy,"checkSupportPath");async function ru(t,e){if(Buffer.byteLength(e,"utf8")>1048576)throw new $("LIMIT_EXCEEDED","file body exceeds 1 MiB cap");await mkdir(dirname(t),{recursive:true});let r=`${t}.tmp.${process.pid}.${Date.now()}`;await writeFile(r,e,"utf8"),await rename(r,t);}s(ru,"atomicWrite");var CT=s(t=>resolve(t,".agentsmesh/skills"),"skillsDir"),ol=s((t,e)=>resolve(CT(t),e),"skillDir"),Zs={async list(t){let e;try{e=(await readdir(CT(t.projectRoot),{withFileTypes:!0})).filter(n=>n.isDirectory()).map(n=>n.name);}catch{return []}let r=[];for(let n of e)try{let o=await readFile(resolve(ol(t.projectRoot,n),"SKILL.md"),"utf8"),i=Bo(o).frontmatter;r.push({name:n,description:i.description??null});}catch{}return r},async get(t,{name:e}){nl(e);let r=ol(t.projectRoot,e);try{let n=await readFile(resolve(r,"SKILL.md"),"utf8"),{frontmatter:o,body:i}=Bo(n),c=(await readdir(r)).filter(l=>l!=="SKILL.md").sort();return {name:e,frontmatter:o,body:i,supportingFiles:c}}catch(n){throw n.code==="ENOENT"?new $("NOT_FOUND",`skill "${e}" not found`):new $("IO_ERROR","failed to read skill")}},async getFile(t,{name:e,path:r}){return nl(e),Cy(r),{content:await hT({projectRoot:t.projectRoot,skillName:e,filePath:r}),encoding:"utf-8"}},async create(t,e){nl(e.name);let r=ST.safeParse(e.frontmatter);if(!r.success)throw new $("VALIDATION_FAILED","invalid frontmatter",r.error.issues);let n=ol(t.projectRoot,e.name),o=false;try{await stat(n),o=!0;}catch{}if(o)throw new $("ALREADY_EXISTS",`skill "${e.name}" exists`);let i=e.supportingFiles??{},a=Object.keys(i);if(a.forEach(Cy),a.length+1>1e3)throw new $("LIMIT_EXCEEDED","supporting files exceed cap");if(e.dry_run===true)return {path:n,written:false,supportingFilesWritten:[]};let c=resolve(n,"SKILL.md");await ru(c,Ia(e.frontmatter,e.body));for(let[l,m]of Object.entries(i))await ru(resolve(n,l),m);return {path:n,written:true,supportingFilesWritten:a}},async update(t,e){nl(e.name);let r=ol(t.projectRoot,e.name),n;try{let p=await readFile(resolve(r,"SKILL.md"),"utf8");n=Bo(p);}catch(p){throw p.code==="ENOENT"?new $("NOT_FOUND",`skill "${e.name}" not found`):new $("IO_ERROR","failed to read skill")}let o=e.frontmatter===void 0?n.frontmatter:e.merge===true?{...n.frontmatter,...e.frontmatter}:e.frontmatter,i=ST.safeParse(o);if(!i.success)throw new $("VALIDATION_FAILED","invalid frontmatter",i.error.issues);let a=e.body!==void 0?e.body:n.body,c=e.supportingFiles??{};Object.keys(c).forEach(Cy);let l=[],m=[];if(e.dry_run===true)return Object.entries(c).forEach(([p,u])=>(u===null?m:l).push(p)),{path:r,written:false,supportingFilesAffected:{written:l,deleted:m}};await ru(resolve(r,"SKILL.md"),Ia(o,a));for(let[p,u]of Object.entries(c)){let f=resolve(r,p);if(u===null)try{await rm$1(f),m.push(p);}catch{}else await ru(f,u),l.push(p);}return {path:r,written:true,supportingFilesAffected:{written:l,deleted:m}}},async delete(t,{name:e,dry_run:r}){nl(e);let n=ol(t.projectRoot,e);try{await stat(n);}catch{throw new $("NOT_FOUND",`skill "${e}" not found`)}return r===true?{path:n,deleted:false}:(await rm$1(n,{recursive:true}),{path:n,deleted:true})}};var CB=z$1.object({}).strict(),RB=z$1.object({name:z$1.string().describe("Item name")}),RT=[{name:"list_skills",description:"List skills",inputSchema:CB,handler:s(t=>Zs.list(t),"handler"),resourceUri:"agentsmesh://canonical/skills"},{name:"get_skill",description:"Get one skill (frontmatter + body + supporting filenames)",inputSchema:RB,handler:s((t,e)=>Zs.get(t,e),"handler"),resourceUri:"agentsmesh://canonical/skills/{name}"},{name:"get_skill_file",description:"Read a skill supporting file by name and relative path",inputSchema:z$1.object({name:z$1.string().describe("Skill name"),path:z$1.string().describe('Relative path within the skill directory (e.g. "helper.md")')}),handler:s((t,e)=>Zs.getFile(t,e),"handler"),resourceUri:"agentsmesh://canonical/skills/{name}/files/{path}"},{name:"create_skill",description:"Create a skill directory with SKILL.md and optional supporting files",inputSchema:z$1.object({name:z$1.string().describe("Skill name (becomes directory name)"),frontmatter:z$1.record(z$1.string(),z$1.unknown()).describe("YAML frontmatter for SKILL.md"),body:z$1.string().describe("Markdown body for SKILL.md"),supportingFiles:z$1.record(z$1.string(),z$1.string()).optional().describe("Map of relative-path \u2192 content for supporting files"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Zs.create(t,e),"handler")},{name:"update_skill",description:"Update a skill. supportingFiles: string value writes/replaces, null deletes, unlisted files are untouched.",inputSchema:z$1.object({name:z$1.string().describe("Skill name"),frontmatter:z$1.record(z$1.string(),z$1.unknown()).optional().describe("New frontmatter (replaces by default; merge=true to shallow-merge)"),body:z$1.string().optional().describe("New body (omit to preserve existing)"),merge:z$1.boolean().optional().describe("Shallow-merge frontmatter instead of replacing"),supportingFiles:z$1.record(z$1.string(),z$1.union([z$1.string(),z$1.null()])).optional().describe("Map of path \u2192 content (string=write, null=delete, absent=keep)"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Zs.update(t,e),"handler")},{name:"delete_skill",description:"Delete a skill",inputSchema:z$1.object({name:z$1.string(),dry_run:z$1.boolean().optional()}),handler:s((t,e)=>Zs.delete(t,e),"handler")}];async function OT(t){if(t.filename!==void 0&&t.filename!=="agentsmesh.yaml")throw new $("PATH_TRAVERSAL","only agentsmesh.yaml is writable");if(Buffer.byteLength(t.content,"utf8")>1048576)throw new $("LIMIT_EXCEEDED","config exceeds 1 MiB cap");let e=resolve(t.projectRoot,"agentsmesh.yaml"),r=`${e}.tmp.${process.pid}.${Date.now()}`;return await writeFile(r,t.content,"utf8"),await rename(r,e),e}s(OT,"safeConfigWrite");fn();Na();async function sl(t){try{return parse(await readFile(t,"utf8"))}catch(e){if(e.code==="ENOENT")return null;throw new $("IO_ERROR","failed to read yaml")}}s(sl,"readYaml");async function Ra(t,e){if(Buffer.byteLength(e,"utf8")>1048576)throw new $("LIMIT_EXCEEDED","file exceeds 1 MiB cap");let r=`${t}.tmp.${process.pid}.${Date.now()}`;await writeFile(r,e,"utf8"),await rename(r,t);}s(Ra,"atomicWrite");var ke={async getConfig(t){let e=await sl(resolve(t.projectRoot,"agentsmesh.yaml"));if(e===null)throw new $("NO_PROJECT","agentsmesh.yaml missing");return e},async listMcpServers(t){let e=resolve(t.projectRoot,".agentsmesh/mcp.json");try{return {servers:(await Ze(e))?.mcpServers??null}}catch{return {servers:null}}},async getPermissions(t){return await sl(resolve(t.projectRoot,".agentsmesh/permissions.yaml"))??null},async getHooks(t){return await sl(resolve(t.projectRoot,".agentsmesh/hooks.yaml"))??null},async getIgnore(t){try{return {patterns:(await readFile(resolve(t.projectRoot,".agentsmesh/ignore"),"utf8")).split(/\r?\n/).filter(r=>r!==""&&!r.startsWith("#"))}}catch{return {patterns:null}}},async updateConfig(t,e){let r=await sl(resolve(t.projectRoot,"agentsmesh.yaml"))??{},n={...r},o=s((l,m)=>{m!==void 0&&(n[l]=e.merge===true&&Array.isArray(r[l])?Array.from(new Set([...r[l],...m])):m);},"apply");o("targets",e.targets),o("features",e.features),e.conversions!==void 0&&(n.conversions=e.merge===true&&r.conversions!==void 0?{...r.conversions,...e.conversions}:e.conversions);let i=Vo.safeParse(n);if(!i.success)throw new $("VALIDATION_FAILED","invalid config",i.error.issues);let a=stringify(n);return e.dry_run===true?{path:resolve(t.projectRoot,"agentsmesh.yaml"),written:false}:{path:await OT({projectRoot:t.projectRoot,content:a,filename:e.filename}),written:true}},async addMcpServer(t,e){let r=resolve(t.projectRoot,".agentsmesh/mcp.json"),n=await Ze(r).catch(()=>null)??{mcpServers:{}};if(n.mcpServers[e.name]!==void 0)throw new $("ALREADY_EXISTS",`server "${e.name}" exists`);return n.mcpServers[e.name]=e.server,e.dry_run===true?{path:r,written:false}:(await Ra(r,JSON.stringify(n,null,2)+`
|
|
548
|
+
`),{path:r,written:true})},async updateMcpServer(t,e){let r=resolve(t.projectRoot,".agentsmesh/mcp.json"),n=await Ze(r).catch(()=>null);if(n===null||n.mcpServers[e.name]===void 0)throw new $("NOT_FOUND",`server "${e.name}" not found`);return n.mcpServers[e.name]=e.merge===true?{...n.mcpServers[e.name],...e.server}:e.server,e.dry_run===true?{path:r,written:false}:(await Ra(r,JSON.stringify(n,null,2)+`
|
|
549
|
+
`),{path:r,written:true})},async removeMcpServer(t,e){let r=resolve(t.projectRoot,".agentsmesh/mcp.json"),n=await Ze(r).catch(()=>null);if(n===null||n.mcpServers[e.name]===void 0)throw new $("NOT_FOUND",`server "${e.name}" not found`);return delete n.mcpServers[e.name],e.dry_run===true?{path:r,removed:false}:(await Ra(r,JSON.stringify(n,null,2)+`
|
|
550
|
+
`),{path:r,removed:true})},async updatePermissions(t,e){let r=resolve(t.projectRoot,".agentsmesh/permissions.yaml"),n=await sl(r)??{allow:[],deny:[],ask:[]},o={...n},i=s((a,c)=>{c!==void 0&&(o[a]=e.mode==="append"?Array.from(new Set([...n[a]??[],...c])):c);},"apply");return i("allow",e.allow),i("deny",e.deny),i("ask",e.ask),e.dry_run===true?{path:r,written:false}:(await Ra(r,stringify(o)),{path:r,written:true})},async updateHooks(t,e){let r=resolve(t.projectRoot,".agentsmesh/hooks.yaml");return e.dry_run===true?{path:r,written:false}:(await Ra(r,stringify(e.hooks)),{path:r,written:true})},async updateIgnore(t,e){let r=resolve(t.projectRoot,".agentsmesh/ignore"),n;if(e.mode==="append"){let o=(await readFile(r,"utf8").catch(()=>"")).split(/\r?\n/).filter(Boolean);n=Array.from(new Set([...o,...e.patterns]));}else n=e.patterns;return e.dry_run===true?{path:r,written:false}:(await Ra(r,n.join(`
|
|
549
551
|
`)+`
|
|
550
|
-
`),{path:r,written:true})}};nh();ze();function vW(){return Object.fromEntries(it.map(t=>[t,Object.fromEntries(Object.entries(wA).map(([e,r])=>[e,r[t]]))]))}s(vW,"buildTargetIndex");var ZP=vW(),sy={async list(){return ZP},async get(t){let e=ZP[t.targetId];if(e===void 0)throw new G("NOT_FOUND",`unknown target: ${t.targetId}`);return {targetId:t.targetId,capabilities:e}}};qn();qn();sl();le();nn();Vn();ye();ze();async function iy(t,e){let r=tt(t);if(!r)throw new cn(t,{supported:[...it,...tp().map(n=>n.id)]});return r.generators.importFrom(e.root,{scope:e.scope??"project"})}s(iy,"importFrom");async function _a(t,e={}){let r=e.scope??"project",{config:n,context:o}=await lt(t,r);await Jt(n,t);let{canonical:i}=await ee(n,o.configDir,{refreshRemoteCache:e.refreshRemoteCache===true},o.canonicalDir);return {config:n,canonical:i,projectRoot:o.rootBase,scope:r,configDir:o.configDir,canonicalDir:o.canonicalDir}}s(_a,"loadProjectContext");async function ay(t){let e=t.targetFilter?[...t.targetFilter]:void 0;return Pp(t.config,t.canonical,t.projectRoot,e,{scope:t.scope})}s(ay,"lint");async function cy(t){let e=await je(t);return {...Ap(e),results:e}}s(cy,"diff");async function ly(t){return Tp(t)}s(ly,"check");qn();nn();zo();sl();ut();ye();Mt();A();function Ia(t){if(t instanceof G)throw t;if(t instanceof cn)throw new G("VALIDATION_FAILED",t.message);let e=t instanceof Error?t.message:String(t);throw /unknown.*--from|unknown.*--to|unknown target/i.test(e)?new G("VALIDATION_FAILED",e):/lock/i.test(e)?new G("LOCK_HELD","generate lock is held"):new G("IO_ERROR","engine failure",{reason:e})}s(Ia,"wrapEngineError");var Hs={async generate(t,e){try{let r=await _a(t.projectRoot),n=e.targets&&e.targets.length>0?e.targets:void 0,i=(await je({config:r.config,canonical:r.canonical,projectRoot:r.projectRoot,scope:r.scope,targetFilter:n})).filter(m=>m.status!=="skipped"),a=i.filter(m=>m.status==="created"||m.status==="updated");if(!e.dry_run)for(let m of a){let p=sa(r.projectRoot,m.path,m.target);await S(p,m.content);}let c={};for(let m of a){let p=c[m.target]??{filesWritten:0};c[m.target]={filesWritten:p.filesWritten+1};}let l={filesWritten:a.length,byTarget:c,lockfileUpdated:!e.dry_run&&a.length>=0,errors:[],warnings:[]};return e.verbose===!0&&(l.files=i.map(m=>m.path)),l}catch(r){Ia(r);}},async lint(t,e){try{let r=await _a(t.projectRoot),n=await ay({config:r.config,canonical:r.canonical,projectRoot:r.projectRoot,scope:r.scope}),o=e.severity;return {issues:(o?n.diagnostics.filter(a=>a.level===o):n.diagnostics).map(a=>({level:a.level,file:a.file,target:a.target,message:a.message}))}}catch(r){Ia(r);}},async check(t){try{let e=await _a(t.projectRoot),r=await ly({config:e.config,configDir:e.configDir,canonicalDir:e.canonicalDir});return {drift:!r.inSync,missing:[...r.removed],extra:[...r.added],modified:[...r.modified]}}catch(e){Ia(e);}},async diff(t,e){try{let r=await _a(t.projectRoot),n=e.targets&&e.targets.length>0?e.targets:void 0,o=await cy({config:r.config,canonical:r.canonical,projectRoot:r.projectRoot,scope:r.scope,targetFilter:n});return {willCreate:o.summary.new,willModify:o.summary.updated,willDelete:o.summary.deleted}}catch(r){Ia(r);}},async import(t,e){if(e.dry_run===true)throw new G("VALIDATION_FAILED","dry_run is not supported for import \u2014 the engine writes files directly. Use diff to preview changes instead.");try{let r=await iy(e.from,{root:t.projectRoot,scope:"project"});return {imported:r.length,files:r.map(n=>({fromPath:n.fromPath,toPath:n.toPath,feature:n.feature})),warnings:[],errors:[]}}catch(r){if(r instanceof cn)throw new G("VALIDATION_FAILED",`unknown target "${e.from}"`);let n=r instanceof Error?r.message:String(r);if(/unknown target|invalid target|not found/i.test(n))throw new G("VALIDATION_FAILED",n);Ia(r);}},async convert(t,e){try{let r={from:e.from,to:e.to,"dry-run":e.dry_run===!0},n=await Kp(r,t.projectRoot);return {filesAffected:n.data.summary.created+n.data.summary.updated,dryRun:e.dry_run===!0,warnings:[],errors:[]}}catch(r){let n=r instanceof Error?r.message:String(r);if(/unknown.*--from|unknown.*--to|unknown target/i.test(n))throw new G("VALIDATION_FAILED",n);Ia(r);}}};function qP(t){let e=toJSONSchema(t,{target:"draft-07"});return delete e.$schema,e}s(qP,"zodToMcpSchema");var Yn=z$1.object({}).strict(),QP=z$1.object({name:z$1.string().describe('Item name (e.g. "auth", "code-review")')}),UW=z$1.object({name:z$1.string().describe('Item name (e.g. "auth", "code-review")'),frontmatter:z$1.record(z$1.string(),z$1.unknown()).describe("YAML frontmatter fields (e.g. { description, globs, targets })"),body:z$1.string().describe("Markdown body content"),dry_run:z$1.boolean().optional().describe("Preview changes without writing to disk")});function my(t,e){let r=t==="rule"?"rules":t==="command"?"commands":"agents";return [{name:`list_${r}`,description:`List ${r} with summary metadata`,inputSchema:Yn,handler:s(n=>e.list(n),"handler"),resourceUri:`agentsmesh://canonical/${r}`},{name:`get_${t}`,description:`Get a single ${t} by name`,inputSchema:QP,handler:s((n,o)=>e.get(n,o),"handler"),resourceUri:`agentsmesh://canonical/${r}/{name}`},{name:`create_${t}`,description:`Create a new ${t}`,inputSchema:UW,handler:s((n,o)=>e.create(n,o),"handler")},{name:`update_${t}`,description:`Update a ${t}. Default: replace frontmatter entirely. Set merge=true to shallow-merge. Omitting body preserves the existing body.`,inputSchema:z$1.object({name:z$1.string().describe("Name of the item to update"),frontmatter:z$1.record(z$1.string(),z$1.unknown()).optional().describe("New frontmatter fields (replaces by default; set merge=true to shallow-merge)"),body:z$1.string().optional().describe("New markdown body (omit to preserve existing)"),merge:z$1.boolean().optional().describe("If true, shallow-merge frontmatter instead of replacing"),dry_run:z$1.boolean().optional().describe("Preview changes without writing to disk")}),handler:s((n,o)=>e.update(n,o),"handler")},{name:`delete_${t}`,description:`Delete a ${t}. For rules: deleting _root requires force=true.`,inputSchema:z$1.object({name:z$1.string().describe("Name of the item to delete"),force:z$1.boolean().optional().describe("Required to delete protected files like _root"),dry_run:z$1.boolean().optional().describe("Preview without deleting")}),handler:s((n,o)=>e.delete(n,o),"handler")}]}s(my,"canonicalTools");var Jp=[...my("rule",jP),...my("command",UP),...my("agent",KP),{name:"list_skills",description:"List skills",inputSchema:Yn,handler:s(t=>Bs.list(t),"handler"),resourceUri:"agentsmesh://canonical/skills"},{name:"get_skill",description:"Get one skill (frontmatter + body + supporting filenames)",inputSchema:QP,handler:s((t,e)=>Bs.get(t,e),"handler"),resourceUri:"agentsmesh://canonical/skills/{name}"},{name:"get_skill_file",description:"Read a skill supporting file by name and relative path",inputSchema:z$1.object({name:z$1.string().describe("Skill name"),path:z$1.string().describe('Relative path within the skill directory (e.g. "helper.md")')}),handler:s((t,e)=>Bs.getFile(t,e),"handler"),resourceUri:"agentsmesh://canonical/skills/{name}/files/{path}"},{name:"create_skill",description:"Create a skill directory with SKILL.md and optional supporting files",inputSchema:z$1.object({name:z$1.string().describe("Skill name (becomes directory name)"),frontmatter:z$1.record(z$1.string(),z$1.unknown()).describe("YAML frontmatter for SKILL.md"),body:z$1.string().describe("Markdown body for SKILL.md"),supportingFiles:z$1.record(z$1.string(),z$1.string()).optional().describe("Map of relative-path \u2192 content for supporting files"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Bs.create(t,e),"handler")},{name:"update_skill",description:"Update a skill. supportingFiles: string value writes/replaces, null deletes, unlisted files are untouched.",inputSchema:z$1.object({name:z$1.string().describe("Skill name"),frontmatter:z$1.record(z$1.string(),z$1.unknown()).optional().describe("New frontmatter (replaces by default; merge=true to shallow-merge)"),body:z$1.string().optional().describe("New body (omit to preserve existing)"),merge:z$1.boolean().optional().describe("Shallow-merge frontmatter instead of replacing"),supportingFiles:z$1.record(z$1.string(),z$1.union([z$1.string(),z$1.null()])).optional().describe("Map of path \u2192 content (string=write, null=delete, absent=keep)"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Bs.update(t,e),"handler")},{name:"delete_skill",description:"Delete a skill",inputSchema:z$1.object({name:z$1.string(),dry_run:z$1.boolean().optional()}),handler:s((t,e)=>Bs.delete(t,e),"handler")},{name:"get_config",description:"Read agentsmesh.yaml",inputSchema:Yn,handler:s(t=>Se.getConfig(t),"handler"),resourceUri:"agentsmesh://config"},{name:"list_mcp_servers",description:"List MCP servers in canonical mcp.json",inputSchema:Yn,handler:s(t=>Se.listMcpServers(t),"handler"),resourceUri:"agentsmesh://canonical/mcp"},{name:"get_permissions",description:"Read permissions.yaml",inputSchema:Yn,handler:s(t=>Se.getPermissions(t),"handler"),resourceUri:"agentsmesh://canonical/permissions"},{name:"get_hooks",description:"Read hooks.yaml",inputSchema:Yn,handler:s(t=>Se.getHooks(t),"handler"),resourceUri:"agentsmesh://canonical/hooks"},{name:"get_ignore",description:"Read ignore patterns",inputSchema:Yn,handler:s(t=>Se.getIgnore(t),"handler"),resourceUri:"agentsmesh://canonical/ignore"},{name:"update_config",description:"Update agentsmesh.yaml. Default: replace listed fields. Set merge=true to union arrays and shallow-merge objects. Only writes agentsmesh.yaml, never agentsmesh.local.yaml.",inputSchema:z$1.object({targets:z$1.array(z$1.string()).optional().describe('Target tool IDs (e.g. ["claude-code", "cursor"])'),features:z$1.array(z$1.string()).optional().describe('Feature names (e.g. ["rules", "commands", "mcp"])'),conversions:z$1.record(z$1.string(),z$1.unknown()).optional().describe("Conversion overrides"),merge:z$1.boolean().optional().describe("If true, union arrays and shallow-merge objects instead of replacing"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Se.updateConfig(t,e),"handler")},{name:"add_mcp_server",description:"Add an MCP server entry to .agentsmesh/mcp.json. Fails if name already exists.",inputSchema:z$1.object({name:z$1.string().describe('Server name (e.g. "github", "filesystem")'),server:z$1.record(z$1.string(),z$1.unknown()).describe('Server config (e.g. { type: "stdio", command: "npx", args: [...], env: {...} })'),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Se.addMcpServer(t,e),"handler")},{name:"update_mcp_server",description:"Update an MCP server entry (replace or merge)",inputSchema:z$1.object({name:z$1.string(),server:z$1.record(z$1.string(),z$1.unknown()),merge:z$1.boolean().optional(),dry_run:z$1.boolean().optional()}),handler:s((t,e)=>Se.updateMcpServer(t,e),"handler")},{name:"remove_mcp_server",description:"Remove an MCP server entry",inputSchema:z$1.object({name:z$1.string(),dry_run:z$1.boolean().optional()}),handler:s((t,e)=>Se.removeMcpServer(t,e),"handler")},{name:"update_permissions",description:"Update permissions.yaml. mode=replace (default) overwrites listed fields; mode=append unions and dedups.",inputSchema:z$1.object({allow:z$1.array(z$1.string()).optional().describe('Allowed tool patterns (e.g. ["Bash(npm run:*)"])'),deny:z$1.array(z$1.string()).optional().describe("Denied tool patterns"),ask:z$1.array(z$1.string()).optional().describe("Tools requiring confirmation"),mode:z$1.enum(["replace","append"]).optional().describe("replace=overwrite, append=union+dedup (default: replace)"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Se.updatePermissions(t,e),"handler")},{name:"update_hooks",description:"Replace hooks.yaml content entirely. Read current hooks with get_hooks, modify, then write back.",inputSchema:z$1.object({hooks:z$1.record(z$1.string(),z$1.array(z$1.unknown())).describe("Full hooks structure (e.g. { PreToolUse: [...], PostToolUse: [...] })"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Se.updateHooks(t,e),"handler")},{name:"update_ignore",description:"Update .agentsmesh/ignore patterns. mode=replace (default) overwrites; mode=append adds new patterns.",inputSchema:z$1.object({patterns:z$1.array(z$1.string()).describe('Gitignore-syntax patterns (e.g. ["node_modules/", "dist/", ".env*"])'),mode:z$1.enum(["replace","append"]).optional().describe("replace=overwrite, append=add (default: replace)"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>Se.updateIgnore(t,e),"handler")},{name:"list_target_capabilities",description:"List support matrix for all targets",inputSchema:Yn,handler:s(()=>sy.list(),"handler"),resourceUri:"agentsmesh://capabilities"},{name:"get_target_capabilities",description:"Get feature support levels for a specific target (e.g. which features are native, mapped, or unsupported)",inputSchema:z$1.object({targetId:z$1.string().describe('Target tool ID (e.g. "claude-code", "cursor")')}),handler:s((t,e)=>sy.get(e),"handler"),resourceUri:"agentsmesh://capabilities/{targetId}"},{name:"generate",description:"Generate target-native config files from canonical .agentsmesh/ content. Propagates rules, commands, agents, skills, MCP, hooks, ignore, and permissions to all configured targets.",inputSchema:z$1.object({targets:z$1.array(z$1.string()).optional().describe("Filter to specific targets (default: all from agentsmesh.yaml)"),features:z$1.array(z$1.string()).optional().describe("Filter to specific features"),verbose:z$1.boolean().optional().describe("Include full file list in response"),dry_run:z$1.boolean().optional().describe("Preview without writing files")}),handler:s((t,e)=>Hs.generate(t,e),"handler")},{name:"lint",description:"Lint canonical .agentsmesh/ files for schema errors, missing frontmatter, and other issues",inputSchema:z$1.object({severity:z$1.enum(["error","warning","info"]).optional().describe("Filter results by minimum severity")}),handler:s((t,e)=>Hs.lint(t,e),"handler")},{name:"check",description:"Detect drift between canonical and lockfile",inputSchema:Yn,handler:s(t=>Hs.check(t),"handler")},{name:"diff",description:"Preview what generate would create, modify, or delete without writing",inputSchema:z$1.object({targets:z$1.array(z$1.string()).optional().describe("Filter to specific targets"),features:z$1.array(z$1.string()).optional().describe("Filter to specific features")}),handler:s((t,e)=>Hs.diff(t,e),"handler")},{name:"import",description:"Import another tool's native config into canonical .agentsmesh/. Note: dry_run is not supported (the engine writes directly).",inputSchema:z$1.object({from:z$1.string().describe('Source target ID to import from (e.g. "cursor", "claude-code")'),features:z$1.array(z$1.string()).optional().describe("Restrict import to specific features"),dry_run:z$1.boolean().optional().describe("NOT SUPPORTED \u2014 will throw VALIDATION_FAILED. Use diff instead.")}),handler:s((t,e)=>Hs.import(t,e),"handler")},{name:"convert",description:"Convert config directly from one tool to another (e.g. Cursor \u2192 Claude Code) without creating canonical .agentsmesh/ files",inputSchema:z$1.object({from:z$1.string().describe('Source target ID (e.g. "cursor")'),to:z$1.string().describe('Destination target ID (e.g. "claude-code")'),dry_run:z$1.boolean().optional().describe("Preview conversion without writing files")}),handler:s((t,e)=>Hs.convert(t,e),"handler")}],py=Jp.filter(t=>t.resourceUri!==void 0).map(t=>({uri:t.resourceUri,name:t.name,description:t.description,read:s((e,r)=>t.handler(e,r),"read")}));zo();async function BW(t){let e=resolve(t);for(;;){try{return await stat(resolve(e,"agentsmesh.yaml")),e}catch{}let r=dirname(e);if(r===e)throw new G("NO_PROJECT","agentsmesh.yaml not found");e=r;}}s(BW,"findProjectRoot");async function uy(t){let e=await BW(t.cwd);return {projectRoot:e,loadCanonical:s(()=>pe(e),"loadCanonical")}}s(uy,"resolveContext");async function tB(){let t=dirname(fileURLToPath(import.meta.url));for(let e of [resolve(t,"../../package.json"),resolve(t,"../package.json"),resolve(t,"../../../package.json")])try{let r=JSON.parse(await readFile(e,"utf8"));if(r.name==="agentsmesh")return r.version}catch{}return "0.0.0"}s(tB,"pkgVersion");function eB(t,e){return new RegExp("^"+t.replace(/\{[^}]+\}/g,"([^/]+)")+"$").test(e)}s(eB,"matchTemplate");function rB(t,e){let r=[...t.matchAll(/\{([^}]+)\}/g)].map(i=>i[1]),o=new RegExp("^"+t.replace(/\{[^}]+\}/g,"([^/]+)")+"$").exec(e);return o?Object.fromEntries(r.map((i,a)=>[i,o[a+1]])):{}}s(rB,"extractTemplateParams");async function eT(){let t=new Server({name:"agentsmesh-mcp",version:await tB()},{capabilities:{tools:{},resources:{}}});t.setRequestHandler(ListToolsRequestSchema,async()=>({tools:Jp.map(e=>({name:e.name,description:e.description,inputSchema:qP(e.inputSchema)}))})),t.setRequestHandler(CallToolRequestSchema,async e=>{let r=Jp.find(n=>n.name===e.params.name);if(!r)return {isError:true,content:[{type:"text",text:JSON.stringify({code:"NOT_FOUND",message:`unknown tool: ${e.params.name}`})}]};try{let n=r.inputSchema.safeParse(e.params.arguments??{});if(!n.success)throw new G("VALIDATION_FAILED","invalid input",n.error.issues);let o=await uy({cwd:process.cwd()}),i=await r.handler(o,n.data);return {content:[{type:"text",text:JSON.stringify(i)}]}}catch(n){let o=n instanceof G?n.toEnvelope():{code:"IO_ERROR",message:n instanceof Error?n.message:"unknown error"};return {isError:true,content:[{type:"text",text:JSON.stringify(o)}]}}}),t.setRequestHandler(ListResourcesRequestSchema,async()=>({resources:py.map(e=>({uri:e.uri,name:e.name,description:e.description}))})),t.setRequestHandler(ReadResourceRequestSchema,async e=>{let r=py.find(a=>a.uri===e.params.uri||eB(a.uri,e.params.uri));if(!r)throw new G("NOT_FOUND",`resource not found: ${e.params.uri}`);let n=await uy({cwd:process.cwd()}),o=rB(r.uri,e.params.uri),i=await r.read(n,o);return {contents:[{uri:e.params.uri,mimeType:"application/json",text:JSON.stringify(i)}]}}),await t.connect(new StdioServerTransport);}s(eT,"startServer");nt();async function rT(t,e){Iy(),await eT();}s(rT,"runMcp");var nT={generate:s(async(t,e)=>{let r=await ia(t,void 0,{printMatrix:t.json!==true});ce("generate",r,t,()=>aa(r));},"generate"),init:s(async(t,e)=>{let r=await UA(process.cwd(),{yes:t.yes===true,global:t.global===true});ce("init",r,t,()=>KA(r));},"init"),import:s(async(t,e)=>{let r=await BA(t);ce("import",r,t,()=>tx(r));},"import"),diff:s(async(t,e)=>{let r=await zA(t);ce("diff",r,t,()=>ex(r));},"diff"),lint:s(async(t,e)=>{let r=await ZA(t);ce("lint",r,t,()=>qA(r));},"lint"),check:s(async(t,e)=>{let r=await sx(t);ce("check",r,t,()=>QA(r));},"check"),merge:s(async(t,e)=>{let r=await cx(t);ce("merge",r,t,()=>rx(r));},"merge"),matrix:s(async(t,e)=>{let r=await Gc(t);ce("matrix",r,t,()=>Uc(r,{verbose:t.verbose===true}));},"matrix"),watch:s(async(t,e)=>{if(t.json===true){Js("watch",{success:false,error:"--json is not supported with watch"}),process.exit(1);return}let r=await ox(t),n=s(()=>{r.stop().then(()=>process.exit(0));},"stop");process.on("SIGINT",n),process.on("SIGTERM",n);},"watch"),install:s(async(t,e)=>{t.json===true&&(t.force=true);let r=await hP(t,e,process.cwd());ce("install",r,t,()=>yP(r));},"install"),plugin:s(async(t,e)=>{let r=await SP(t,e,process.cwd());ce("plugin",r,t,()=>RP(r));},"plugin"),target:s(async(t,e)=>{let r=await FP(t,e,process.cwd());ce("target",r,t,()=>vP(r));},"target"),convert:s(async(t,e)=>{let r=await Kp(t);ce("convert",r,t,()=>MP(r));},"convert"),mcp:s(async(t,e)=>{await rT();},"mcp")};function sB(t){let e={},r=[],n="help";for(let o=0;o<t.length;o++){let i=t[o];if(n==="help"&&i==="--version")return {command:"version",flags:{},args:[]};if(n==="help"&&i==="--help")return {command:"help",flags:{},args:[]};if(i.startsWith("--")){let a=i.slice(2),c=t[o+1];c===void 0||c.startsWith("--")?e[a]=true:(e[a]=c,o++);continue}n==="help"?n=i:r.push(i);}return {command:n,flags:e,args:r}}s(sB,"parseArgs");var iB=hy(nT);async function aB(t){let{command:e,flags:r,args:n}=t;if(e==="help"){ky();return}if(e==="version"){wy();return}r.json===true&&_y(),await iB.route(e,r,n);}s(aB,"main");function cB(){let t=process.argv[1];if(!t)return false;let e=fileURLToPath(import.meta.url);try{let r=resolve(process.cwd(),t);return r===e||realpathSync(r)===realpathSync(e)}catch{return t.endsWith("cli.js")||t.includes("agentsmesh")}}s(cB,"isMainModule");if(cB()){let t=sB(process.argv.slice(2));aB(t).catch(e=>Ey(e instanceof Error?e:new Error(String(e)),{verbose:t.flags.verbose===true,json:t.flags.json===true,command:t.command}));}
|
|
551
|
-
export{
|
|
552
|
+
`),{path:r,written:true})}};var $B=/[;&|`$<>!\\\r\n]/u,GB=/^[A-Za-z_][A-Za-z0-9_]*$/u,jB=/^[A-Za-z][A-Za-z0-9_-]*$/u,UB=/^[A-Za-z][A-Za-z0-9_-]*(\([^)]*\))?$/u,wT=/[\r\n]/u;function WB(t){return z$1.string().min(1).max(512).refine(e=>!$B.test(e),{message:`${t} must not contain shell metacharacters (;&|\`$<>!\\\\, newlines)`})}s(WB,"noShellMeta");var Ey=z$1.object({type:z$1.enum(["stdio","sse","http","streamable-http","streamable_http"]).optional(),description:z$1.string().max(1024).optional(),command:WB("command").optional(),args:z$1.array(z$1.string().max(2048)).max(100).optional(),env:z$1.record(z$1.string().regex(GB,"env key must be a valid identifier"),z$1.string().max(8192)).optional(),url:z$1.string().url().max(2048).refine(t=>/^https?:\/\//u.test(t),{message:"url must use http(s) protocol"}).optional(),headers:z$1.record(z$1.string().regex(jB,"header name must be a valid identifier"),z$1.string().max(8192)).optional(),cwd:z$1.string().max(2048).optional(),disabled:z$1.boolean().optional(),timeout:z$1.number().int().nonnegative().max(36e5).optional()}).strict(),KB=z$1.object({type:z$1.enum(["command","prompt"]).optional(),command:z$1.string().min(1).max(8192).optional(),prompt:z$1.string().min(1).max(8192).optional(),timeout:z$1.number().int().nonnegative().max(36e5).optional()}).strict().refine(t=>(t.command??"").length>0||(t.prompt??"").length>0,{message:"hook entry must define command or prompt"}),LT=z$1.string().max(256).refine(t=>!wT.test(t),{message:"hook matcher must not contain newlines"}),BB=z$1.object({matcher:LT,type:z$1.enum(["command","prompt"]).optional(),command:z$1.string().min(1).max(8192).optional(),prompt:z$1.string().min(1).max(8192).optional(),timeout:z$1.number().int().nonnegative().max(36e5).optional()}).strict().refine(t=>(t.command??"").length>0||(t.prompt??"").length>0,{message:"hook entry must define command or prompt"}),HB=z$1.object({matcher:LT,hooks:z$1.array(KB).min(1).max(50)}).strict(),zB=z$1.union([BB,HB]),bT=z$1.record(z$1.string().min(1).max(64),z$1.array(zB).max(100)),VB=z$1.string().min(1).max(256).refine(t=>!wT.test(t),{message:"permission pattern must not contain newlines"}).refine(t=>UB.test(t),{message:"permission pattern must match Tool or Tool(matcher) form"}),ou=z$1.array(VB).max(500);var il=z$1.object({}).strict(),JB=[{name:"get_config",description:"Read agentsmesh.yaml",inputSchema:il,handler:s(t=>ke.getConfig(t),"handler"),resourceUri:"agentsmesh://config"},{name:"list_mcp_servers",description:"List MCP servers in canonical mcp.json",inputSchema:il,handler:s(t=>ke.listMcpServers(t),"handler"),resourceUri:"agentsmesh://canonical/mcp"},{name:"get_permissions",description:"Read permissions.yaml",inputSchema:il,handler:s(t=>ke.getPermissions(t),"handler"),resourceUri:"agentsmesh://canonical/permissions"},{name:"get_hooks",description:"Read hooks.yaml",inputSchema:il,handler:s(t=>ke.getHooks(t),"handler"),resourceUri:"agentsmesh://canonical/hooks"},{name:"get_ignore",description:"Read ignore patterns",inputSchema:il,handler:s(t=>ke.getIgnore(t),"handler"),resourceUri:"agentsmesh://canonical/ignore"}],YB=[{name:"update_config",description:"Update agentsmesh.yaml. Default: replace listed fields. Set merge=true to union arrays and shallow-merge objects. Only writes agentsmesh.yaml, never agentsmesh.local.yaml.",inputSchema:z$1.object({targets:z$1.array(z$1.string()).optional().describe('Target tool IDs (e.g. ["claude-code", "cursor"])'),features:z$1.array(z$1.string()).optional().describe('Feature names (e.g. ["rules", "commands", "mcp"])'),conversions:z$1.record(z$1.string(),z$1.unknown()).optional().describe("Conversion overrides"),merge:z$1.boolean().optional().describe("If true, union arrays and shallow-merge objects instead of replacing"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>ke.updateConfig(t,e),"handler")},{name:"add_mcp_server",description:"Add an MCP server entry to .agentsmesh/mcp.json. Fails if name already exists.",inputSchema:z$1.object({name:z$1.string().describe('Server name (e.g. "github", "filesystem")'),server:Ey.describe('Server config (e.g. { type: "stdio", command: "npx", args: [...], env: {...} })'),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>ke.addMcpServer(t,e),"handler")},{name:"update_mcp_server",description:"Update an MCP server entry (replace or merge)",inputSchema:z$1.object({name:z$1.string(),server:Ey,merge:z$1.boolean().optional(),dry_run:z$1.boolean().optional()}),handler:s((t,e)=>ke.updateMcpServer(t,e),"handler")},{name:"remove_mcp_server",description:"Remove an MCP server entry",inputSchema:z$1.object({name:z$1.string(),dry_run:z$1.boolean().optional()}),handler:s((t,e)=>ke.removeMcpServer(t,e),"handler")},{name:"update_permissions",description:"Update permissions.yaml. mode=replace (default) overwrites listed fields; mode=append unions and dedups.",inputSchema:z$1.object({allow:ou.optional().describe('Allowed tool patterns (e.g. ["Bash(npm run:*)"])'),deny:ou.optional().describe("Denied tool patterns"),ask:ou.optional().describe("Tools requiring confirmation"),mode:z$1.enum(["replace","append"]).optional().describe("replace=overwrite, append=union+dedup (default: replace)"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>ke.updatePermissions(t,e),"handler")},{name:"update_hooks",description:"Replace hooks.yaml content entirely. Read current hooks with get_hooks, modify, then write back.",inputSchema:z$1.object({hooks:bT.describe("Full hooks structure (e.g. { PreToolUse: [...], PostToolUse: [...] })"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>ke.updateHooks(t,e),"handler")},{name:"update_ignore",description:"Update .agentsmesh/ignore patterns. mode=replace (default) overwrites; mode=append adds new patterns.",inputSchema:z$1.object({patterns:z$1.array(z$1.string()).describe('Gitignore-syntax patterns (e.g. ["node_modules/", "dist/", ".env*"])'),mode:z$1.enum(["replace","append"]).optional().describe("replace=overwrite, append=add (default: replace)"),dry_run:z$1.boolean().optional().describe("Preview without writing")}),handler:s((t,e)=>ke.updateIgnore(t,e),"handler")}],AT=[...JB,...YB];yh();Xe();function XB(){return Object.fromEntries(lt.map(t=>[t,Object.fromEntries(Object.entries(QA).map(([e,r])=>[e,r[t]]))]))}s(XB,"buildTargetIndex");var xT=XB(),ky={async list(){return xT},async get(t){let e=xT[t.targetId];if(e===void 0)throw new $("NOT_FOUND",`unknown target: ${t.targetId}`);return {targetId:t.targetId,capabilities:e}}};dn();dn();pl();de();ln();Qn();Ce();Xe();async function wy(t,e){let r=et(t);if(!r)throw new br(t,{supported:[...lt,...cp().map(n=>n.id)]});return r.generators.importFrom(e.root,{scope:e.scope??"project"})}s(wy,"importFrom");async function Oa(t,e={}){let r=e.scope??"project",{config:n,context:o}=await ut(t,r);await qt(n,t);let{canonical:i}=await se(n,o.configDir,{refreshRemoteCache:e.refreshRemoteCache===true},o.canonicalDir);return {config:n,canonical:i,projectRoot:o.rootBase,scope:r,configDir:o.configDir,canonicalDir:o.canonicalDir}}s(Oa,"loadProjectContext");async function Ly(t){let e=t.targetFilter?[...t.targetFilter]:void 0;return Gp(t.config,t.canonical,t.projectRoot,e,{scope:t.scope})}s(Ly,"lint");async function by(t){let e=await He(t);return {...Mp(e),results:e}}s(by,"diff");async function Ay(t){return jp(t)}s(Ay,"check");dn();ln();Qo();pl();gt();Ce();Ut();b();function Ho(t){if(t instanceof $)throw t;if(t instanceof br)throw new $("VALIDATION_FAILED",t.message);let e=t instanceof Error?t.message:String(t);throw /unknown.*--from|unknown.*--to|unknown target/i.test(e)?new $("VALIDATION_FAILED",e):/lock/i.test(e)?new $("LOCK_HELD","generate lock is held"):new $("IO_ERROR","engine failure",{reason:e})}s(Ho,"wrapEngineError");async function PT(t,e){if(e.dry_run===true)throw new $("VALIDATION_FAILED","dry_run is not supported for import \u2014 the engine writes files directly. Use diff to preview changes instead.");try{let r=await wy(e.from,{root:t.projectRoot,scope:"project"});return {imported:r.length,files:r.map(n=>({fromPath:n.fromPath,toPath:n.toPath,feature:n.feature})),warnings:[],errors:[]}}catch(r){if(r instanceof br)throw new $("VALIDATION_FAILED",`unknown target "${e.from}"`);let n=r instanceof Error?r.message:String(r);if(/unknown target|invalid target|not found/i.test(n))throw new $("VALIDATION_FAILED",n);Ho(r);}}s(PT,"importFromTarget");async function TT(t,e){try{let r={from:e.from,to:e.to,"dry-run":e.dry_run===!0},n=await Zp(r,t.projectRoot);return {filesAffected:n.data.summary.created+n.data.summary.updated,dryRun:e.dry_run===!0,warnings:[],errors:[]}}catch(r){let n=r instanceof Error?r.message:String(r);if(/unknown.*--from|unknown.*--to|unknown target/i.test(n))throw new $("VALIDATION_FAILED",n);Ho(r);}}s(TT,"convert");async function tH(t,e){try{let r=await Oa(t.projectRoot),n=e.targets&&e.targets.length>0?e.targets:void 0,i=(await He({config:r.config,canonical:r.canonical,projectRoot:r.projectRoot,scope:r.scope,targetFilter:n})).filter(m=>m.status!=="skipped"),a=i.filter(m=>m.status==="created"||m.status==="updated");if(!e.dry_run)for(let m of a){let p=ua(r.projectRoot,m.path,m.target);await C(p,m.content);}let c={};for(let m of a){let p=c[m.target]??{filesWritten:0};c[m.target]={filesWritten:p.filesWritten+1};}let l={filesWritten:a.length,byTarget:c,lockfileUpdated:!e.dry_run&&a.length>=0,errors:[],warnings:[]};return e.verbose===!0&&(l.files=i.map(m=>m.path)),l}catch(r){Ho(r);}}s(tH,"generate");async function eH(t,e){try{let r=await Oa(t.projectRoot),n=await Ly({config:r.config,canonical:r.canonical,projectRoot:r.projectRoot,scope:r.scope});return {issues:(e.severity?n.diagnostics.filter(i=>i.level===e.severity):n.diagnostics).map(i=>({level:i.level,file:i.file,target:i.target,message:i.message}))}}catch(r){Ho(r);}}s(eH,"lint");async function rH(t){try{let e=await Oa(t.projectRoot),r=await Ay({config:e.config,configDir:e.configDir,canonicalDir:e.canonicalDir});return {drift:!r.inSync,missing:[...r.removed],extra:[...r.added],modified:[...r.modified]}}catch(e){Ho(e);}}s(rH,"check");async function nH(t,e){try{let r=await Oa(t.projectRoot),n=e.targets&&e.targets.length>0?e.targets:void 0,o=await by({config:r.config,canonical:r.canonical,projectRoot:r.projectRoot,scope:r.scope,targetFilter:n});return {willCreate:o.summary.new,willModify:o.summary.updated,willDelete:o.summary.deleted}}catch(r){Ho(r);}}s(nH,"diff");var qs={generate:tH,lint:eH,check:rH,diff:nH,import:PT,convert:TT};var DT=z$1.object({}).strict(),NT=[{name:"list_target_capabilities",description:"List support matrix for all targets",inputSchema:DT,handler:s(()=>ky.list(),"handler"),resourceUri:"agentsmesh://capabilities"},{name:"get_target_capabilities",description:"Get feature support levels for a specific target (e.g. which features are native, mapped, or unsupported)",inputSchema:z$1.object({targetId:z$1.string().describe('Target tool ID (e.g. "claude-code", "cursor")')}),handler:s((t,e)=>ky.get(e),"handler"),resourceUri:"agentsmesh://capabilities/{targetId}"},{name:"generate",description:"Generate target-native config files from canonical .agentsmesh/ content. Propagates rules, commands, agents, skills, MCP, hooks, ignore, and permissions to all configured targets.",inputSchema:z$1.object({targets:z$1.array(z$1.string()).optional().describe("Filter to specific targets (default: all from agentsmesh.yaml)"),features:z$1.array(z$1.string()).optional().describe("Filter to specific features"),verbose:z$1.boolean().optional().describe("Include full file list in response"),dry_run:z$1.boolean().optional().describe("Preview without writing files")}),handler:s((t,e)=>qs.generate(t,e),"handler")},{name:"lint",description:"Lint canonical .agentsmesh/ files for schema errors, missing frontmatter, and other issues",inputSchema:z$1.object({severity:z$1.enum(["error","warning","info"]).optional().describe("Filter results by minimum severity")}),handler:s((t,e)=>qs.lint(t,e),"handler")},{name:"check",description:"Detect drift between canonical and lockfile",inputSchema:DT,handler:s(t=>qs.check(t),"handler")},{name:"diff",description:"Preview what generate would create, modify, or delete without writing",inputSchema:z$1.object({targets:z$1.array(z$1.string()).optional().describe("Filter to specific targets"),features:z$1.array(z$1.string()).optional().describe("Filter to specific features")}),handler:s((t,e)=>qs.diff(t,e),"handler")},{name:"import",description:"Import another tool's native config into canonical .agentsmesh/. Note: dry_run is not supported (the engine writes directly).",inputSchema:z$1.object({from:z$1.string().describe('Source target ID to import from (e.g. "cursor", "claude-code")'),features:z$1.array(z$1.string()).optional().describe("Restrict import to specific features"),dry_run:z$1.boolean().optional().describe("NOT SUPPORTED \u2014 will throw VALIDATION_FAILED. Use diff instead.")}),handler:s((t,e)=>qs.import(t,e),"handler")},{name:"convert",description:"Convert config directly from one tool to another (e.g. Cursor \u2192 Claude Code) without creating canonical .agentsmesh/ files",inputSchema:z$1.object({from:z$1.string().describe('Source target ID (e.g. "cursor")'),to:z$1.string().describe('Destination target ID (e.g. "claude-code")'),dry_run:z$1.boolean().optional().describe("Preview conversion without writing files")}),handler:s((t,e)=>qs.convert(t,e),"handler")}];function FT(t){let e=toJSONSchema(t,{target:"draft-07"});return delete e.$schema,e}s(FT,"zodToMcpSchema");var su=[...fT,...RT,...AT,...NT],xy=su.filter(t=>t.resourceUri!==void 0).map(t=>({uri:t.resourceUri,name:t.name,description:t.description,read:s((e,r)=>t.handler(e,r),"read")}));Qo();async function aH(t){let e=resolve(t);for(;;){try{return await stat(resolve(e,"agentsmesh.yaml")),e}catch{}let r=dirname(e);if(r===e)throw new $("NO_PROJECT","agentsmesh.yaml not found");e=r;}}s(aH,"findProjectRoot");async function Py(t){let e=await aH(t.cwd);return {projectRoot:e,loadCanonical:s(()=>ge(e),"loadCanonical")}}s(Py,"resolveContext");async function yH(){let t=dirname(fileURLToPath(import.meta.url));for(let e of [resolve(t,"../../package.json"),resolve(t,"../package.json"),resolve(t,"../../../package.json")])try{let r=JSON.parse(await readFile(e,"utf8"));if(r.name==="agentsmesh")return r.version}catch{}return "0.0.0"}s(yH,"pkgVersion");function _H(t,e){return new RegExp("^"+t.replace(/\{[^}]+\}/g,"([^/]+)")+"$").test(e)}s(_H,"matchTemplate");function IH(t,e){let r=[...t.matchAll(/\{([^}]+)\}/g)].map(i=>i[1]),o=new RegExp("^"+t.replace(/\{[^}]+\}/g,"([^/]+)")+"$").exec(e);return o?Object.fromEntries(r.map((i,a)=>[i,o[a+1]])):{}}s(IH,"extractTemplateParams");async function MT(){let t=new Server({name:"agentsmesh-mcp",version:await yH()},{capabilities:{tools:{},resources:{}}});t.setRequestHandler(ListToolsRequestSchema,async()=>({tools:su.map(e=>({name:e.name,description:e.description,inputSchema:FT(e.inputSchema)}))})),t.setRequestHandler(CallToolRequestSchema,async e=>{let r=su.find(n=>n.name===e.params.name);if(!r)return {isError:true,content:[{type:"text",text:JSON.stringify({code:"NOT_FOUND",message:`unknown tool: ${e.params.name}`})}]};try{let n=r.inputSchema.safeParse(e.params.arguments??{});if(!n.success)throw new $("VALIDATION_FAILED","invalid input",n.error.issues);let o=await Py({cwd:process.cwd()}),i=await r.handler(o,n.data);return {content:[{type:"text",text:JSON.stringify(i)}]}}catch(n){let o=n instanceof $?n.toEnvelope():{code:"IO_ERROR",message:cT(n instanceof Error?n.message:"unknown error")};return {isError:true,content:[{type:"text",text:JSON.stringify(o)}]}}}),t.setRequestHandler(ListResourcesRequestSchema,async()=>({resources:xy.map(e=>({uri:e.uri,name:e.name,description:e.description}))})),t.setRequestHandler(ReadResourceRequestSchema,async e=>{let r=xy.find(a=>a.uri===e.params.uri||_H(a.uri,e.params.uri));if(!r)throw new $("NOT_FOUND",`resource not found: ${e.params.uri}`);let n=await Py({cwd:process.cwd()}),o=IH(r.uri,e.params.uri),i=await r.read(n,o);return {contents:[{uri:e.params.uri,mimeType:"application/json",text:JSON.stringify(i)}]}}),await t.connect(new StdioServerTransport);}s(MT,"startServer");st();async function $T(t,e){$y(),await MT();}s($T,"runMcp");var GT={generate:s(async(t,e)=>{let r=await da(t,void 0,{printMatrix:t.json!==true});ue("generate",r,t,()=>fa(r));},"generate"),init:s(async(t,e)=>{let r=await gx(process.cwd(),{yes:t.yes===true,global:t.global===true});ue("init",r,t,()=>hx(r));},"init"),import:s(async(t,e)=>{let r=await _x(t);ue("import",r,t,()=>bx(r));},"import"),diff:s(async(t,e)=>{let r=await Sx(t);ue("diff",r,t,()=>Ax(r));},"diff"),lint:s(async(t,e)=>{let r=await kx(t);ue("lint",r,t,()=>wx(r));},"lint"),check:s(async(t,e)=>{let r=await Dx(t);ue("check",r,t,()=>Lx(r));},"check"),merge:s(async(t,e)=>{let r=await vx(t);ue("merge",r,t,()=>xx(r));},"merge"),matrix:s(async(t,e)=>{let r=await Bc(t);ue("matrix",r,t,()=>zc(r,{verbose:t.verbose===true}));},"matrix"),watch:s(async(t,e)=>{if(t.json===true){ei("watch",{success:false,error:"--json is not supported with watch"}),process.exit(1);return}let r=await Tx(t),n=s(()=>{r.stop().then(()=>process.exit(0));},"stop");process.on("SIGINT",n),process.on("SIGTERM",n);},"watch"),install:s(async(t,e)=>{t.json===true&&(t.force=true);let r=await BP(t,e,process.cwd());ue("install",r,t,()=>HP(r));},"install"),plugin:s(async(t,e)=>{let r=await YP(t,e,process.cwd());ue("plugin",r,t,()=>XP(r));},"plugin"),target:s(async(t,e)=>{let r=await sT(t,e,process.cwd());ue("target",r,t,()=>iT(r));},"target"),convert:s(async(t,e)=>{let r=await Zp(t);ue("convert",r,t,()=>aT(r));},"convert"),mcp:s(async(t,e)=>{await $T();},"mcp")};function RH(t){let e={},r=[],n="help";for(let o=0;o<t.length;o++){let i=t[o];if(n==="help"&&i==="--version")return {command:"version",flags:{},args:[]};if(n==="help"&&i==="--help")return {command:"help",flags:{},args:[]};if(i.startsWith("--")){let a=i.slice(2),c=t[o+1];c===void 0||c.startsWith("--")?e[a]=true:(e[a]=c,o++);continue}n==="help"?n=i:r.push(i);}return {command:n,flags:e,args:r}}s(RH,"parseArgs");var OH=Fy(GT);async function EH(t){let{command:e,flags:r,args:n}=t;if(e==="help"){Wy();return}if(e==="version"){By();return}r.json===true&&My(),await OH.route(e,r,n);}s(EH,"main");function kH(){let t=process.argv[1];if(!t)return false;let e=fileURLToPath(import.meta.url);try{let r=resolve(process.cwd(),t);return r===e||realpathSync(r)===realpathSync(e)}catch{return t.endsWith("cli.js")||t.includes("agentsmesh")}}s(kH,"isMainModule");if(kH()){let t=RH(process.argv.slice(2));EH(t).catch(e=>Hy(e instanceof Error?e:new Error(String(e)),{verbose:t.flags.verbose===true,json:t.flags.json===true,command:t.command}));}
|
|
553
|
+
export{RH as parseArgs};
|