agentsmesh 0.14.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 +32 -0
- package/README.md +27 -2
- 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 +343 -111
- package/dist/engine.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.js +343 -111
- 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=ET(t)?LT(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,OT,wT,A=d(()=>{qn();by="\uFEFF",OT=new Set([".md",".mdc",".mdx",".markdown",".txt",".json",".jsonc",".yaml",".yml",".toml",".ini",".sh",".bash",".zsh",".ps1",".js",".mjs",".cjs",".ts",".tsx",".html",".css"]),wT=new Set([".gitignore",".cursorignore",".cursorindexingignore",".aiignore",".agentignore",".clineignore",".geminiignore",".codeiumignore",".continueignore",".copilotignore",".windsurfignore",".junieignore",".kiroignore",".rooignore",".antigravityignore"]);s(ET,"shouldNormalizeLineEndings");s(LT,"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,Sa,ze=d(()=>{Ty();it=qp,Sa="codex-cli";});var Dy,Re,Zs,ka,bT,AT,Ra,xT,PT,jo,ln=d(()=>{ze();Dy=["rules","commands","agents","skills","mcp","hooks","ignore","permissions"],Re=z$1.enum(it),Zs=z$1.enum(Dy),ka=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(),bT=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:ka.optional()}),AT=z$1.object({strategy:z$1.enum(["merge","lock","last-wins"]).default("merge"),lock_features:z$1.array(z$1.string()).default([])}),Ra=z$1.union([z$1.boolean(),z$1.object({project:z$1.boolean().optional(),global:z$1.boolean().optional()}).strict()]),xT=z$1.object({commands_to_skills:z$1.object({"codex-cli":Ra.optional()}).passthrough().optional(),agents_to_skills:z$1.object({"gemini-cli":Ra.optional(),cline:Ra.optional(),"codex-cli":Ra.optional(),windsurf:Ra.optional()}).passthrough().optional()}).strict().optional(),PT=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(bT).default([]),overrides:z$1.record(z$1.string(),z$1.record(z$1.string(),z$1.unknown())).default({}),collaboration:AT.default({strategy:"merge",lock_features:[]}),conversions:xT,plugins:z$1.array(PT).default([]),pluginTargets:z$1.array(z$1.string().regex(/^[a-z][a-z0-9-]*$/)).default([])});});async function NT(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 FT(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 vT(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 rl(t){let e=join(t,tu),r=await FT(e),n=join(t,DT),o=await y(n);if(o!==null){let i=parse(o);if(typeof i=="object"&&i!==null&&!Array.isArray(i)){let a=vT(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 nl(t){let e=await NT(t);if(e===null)throw new We(join(t,tu));return rl(dirname(e))}var tu,DT,ol=d(()=>{A();nt();qn();ln();tu="agentsmesh.yaml",DT="agentsmesh.local.yaml";s(NT,"findConfigPath");s(FT,"loadConfig");s(Qp,"deepMergeObjects");s(vT,"mergeLocalConfig");s(rl,"loadConfigFromExactDir");s(nl,"loadConfigFromDir");});function Oa(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 nl(t);return {config:n,context:{scope:e,rootBase:o,configDir:o,canonicalDir:join(o,".agentsmesh")}}}let r=Oa(t,e);try{let{config:n}=await rl(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(()=>{ol();qn();s(Oa,"resolveScopeContext");s(lt,"loadScopedConfig");});async function sl(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 HT(BT(t),f),t.ref&&await zT(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 VT(t)}}async function My(t){return v(t)}function BT(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 HT(t,e){await su(["clone",t,e]);}async function zT(t,e){await su(["checkout",e],t);}async function VT(t){return su(["rev-parse","HEAD"],t)}async function su(t,e){let{stdout:r}=await WT("git",t,{cwd:e,env:{...process.env,GIT_TERMINAL_PROMPT:"0"}});return r.trim()}var WT,vy,iu=d(()=>{A();WT=promisify(execFile),vy="repo";s(sl,"fetchGitRemoteExtend");s(ou,"readCachedRepo");s(My,"hasCachedRepo");s(BT,"resolveCloneUrl");s(HT,"cloneRepo");s(zT,"checkoutRef");s(VT,"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 qT(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)=>!(ZT(_)||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 ZT(t){let e=t.replace(/\\/g,"/");return e.startsWith("/")||e.split("/").includes("..")}async function qT(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 sl(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(ZT,"isZipSlipPath");s(qT,"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 Ea=d(()=>{s(By,"splitSourceRef");s(Hy,"parseGithubSource");s(zy,"parseGitlabSource");s(Vy,"parseGitSource");s(Uo,"parseRemoteSource");s(cu,"isSupportedRemoteSource");});function rD(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=rD(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(()=>{La();Ea();s(rD,"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("@")):sl(n,e,r,o,qs)}var qy,La=d(()=>{iu();Wy();Ea();lu();qy=80;s(qs,"buildCacheKey");s(me,"getCacheDir");s(Qs,"fetchRemoteExtend");});function lD(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(lD(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 il=d(()=>{A();La();Ea();s(lD,"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
|
-
${Da}`;s(Ru,"normalizeWhitespace");A_=[cN,aN,iN,sN,oN,nN,rN,eN,tN];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 lN(t){return Object.fromEntries(Object.entries(t).filter(([,e])=>e!==void 0))}function mN(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=mN(t,lN({...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(lN,"pruneUndefined");s(mN,"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 Sl(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(Sl,"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,Na,a.name),u=join(p,"SKILL.md"),{frontmatter:f,body:g}=w(o(m,l,u)),h=hl(f,a.name);if(h){await Ee(join(t,Na,a.name));let E=join(t,F_);await O(E);let T=join(E,`${h.name}.md`);await S(T,yl(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,Na,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:`${Na}/${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:`${Na}/${a.name}/${T}`,feature:"skills"});}}}var Na,F_,v_,_t=d(()=>{A();M();et();dt();ne();mi();Na=".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 _N(n),...r};await O(dirname(n)),await S(n,JSON.stringify({mcpServers:i},null,2));}async function _N(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(_N,"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 SN(t,e){return e.some(r=>t.endsWith(r))}async function mt(t){let r=(await N(t.srcDir)).filter(o=>SN(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(SN,"matchesExtension");s(mt,"importFileDirectory");});function W_(t){return typeof t=="string"?t:void 0}function RN(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 kN(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=RN({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 ON(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 wN(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 kN(t);case "command":return ON(t);case "agent":return wN(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(RN,"pruneUndefined");s(Au,"applyRemap");s(kN,"ruleMapper");s(ON,"commandMapper");s(wN,"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 bN(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 AN(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 xN(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 PN(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 TN(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=PN(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 bN(t,e,r,n,o);case "directory":return AN(t,e,r,n,o);case "flatFile":return xN(t,e,r,n);case "mcpJson":return TN(t,e,r,n)}}async function DN(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 NN(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 NN(o,c))a.push(...await DN(l,r,e,t.id,i));return a}var Mt=d(()=>{It();A();fn();M();Qe();et();tr();H_();V_();s(bN,"runSingleFile");s(AN,"runDirectory");s(Y_,"resolveCanonicalFilePath");s(xN,"runFlatFile");s(PN,"parseMcpJson");s(TN,"runMcpJson");s(J_,"dispatchSpec");s(DN,"runSpec");s(NN,"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(Rl,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 vN(t,e){return rI(e).some(n=>MN(t,n))}function eI(t,e){return t.filter(r=>vN(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 MN(t,e){return $N(e).test(t)}function $N(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(vN,"globMatch");s(eI,"globFilter");s(rI,"expandBraces");s(MN,"matchOne");s($N,"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 GN(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=GN(r);return U(".agentsmesh/hooks.yaml",e,`${t} is not supported by ${o}; only ${i} are projected.`)}var bt=d(()=>{s(U,"createWarning");s(GN,"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 HN(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(Aa)?Aa:null;if(c&&a==="SKILL.md"){t.set(e,`${WN}/${o.slice(c.length)}.md`);return}let l=o.startsWith(ai)?ai:o.startsWith(xa)?xa:null;if(l&&a==="SKILL.md"){t.set(e,`${BN}/${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"&&HN(t,e,p,`${r}/${o}`);}function zN(t){return t.split("/").filter(Boolean)[0]??""}async function VN(){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=zN(n);o.startsWith(".")&&e.add(o);}return Tu=e,e}function Nu(t){return t.split("/").some(e=>e.startsWith("."))}async function JN(t){let e=[],r=await VN(),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 kl(t,e){let r=await JN(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,`${KN}/${l}.md`);}}var KN,WN,BN,pI,Tu,Nt=d(()=>{Wt();A();ne();dt();KN=".agentsmesh/rules",WN=".agentsmesh/commands",BN=".agentsmesh/agents",pI=".agentsmesh/skills";s(L,"rel");s(b,"listFiles");s(uI,"addDirectoryMapping");s(HN,"addAncestorMappings");s($,"addSimpleFileMapping");s(W,"addSkillLikeMapping");s(zN,"firstPathSegment");s(VN,"targetRootSegments");s(Nu,"hasHiddenSegment");s(JN,"listScopedAgentsFiles");s(kl,"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,Ol,Ar,er,va,rr,hn,Ma,xr,yn,$a,fi,vu,Xo,wl,gI,Zo=d(()=>{Yo="antigravity",Ol=".agents",Ar=`${Ol}/rules`,er=`${Ar}/general.md`,va=`${Ar}/_root.md`,rr=`${Ol}/skills`,hn=`${Ol}/workflows`,Ma=`${Ol}/antigravity/mcp_config.json`,xr=".gemini/antigravity/GEMINI.md",yn=".gemini/antigravity/skills",$a=".gemini/antigravity/workflows",fi=".gemini/antigravity/mcp_config.json",vu=".agentsmesh/rules/_root.md",Xo=".agentsmesh/rules",wl=".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(va,`${P}/_root.md`);for(let n of await b(e,Ar)){let o=L(e,n);o===er||o===va||$(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,Ga,ja,Ua,Ka,Wa,_n,$u,Ba,gi,Ha,za,El,Ll,Gu,Va,ju,qo,II,In=d(()=>{yI="claude-code",to=".claude/CLAUDE.md",_I="CLAUDE.md",Ga=".claude/rules",ja=".claude/commands",Ua=".claude/agents",Ka=".claude/skills",Wa=".claude/settings.json",_n=".claude/hooks.json",$u=".claude/output-styles",Ba=".claudeignore",gi=".mcp.json",Ha=".claude.json",za=".agentsmesh/rules",El=".agentsmesh/commands",Ll=".agentsmesh/agents",Gu=".agentsmesh/skills",Va=".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,bl,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",bl=".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 kl(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,Al,Rn,Yu,de,yi,Ja,xl,Pl,Xu,Dr=d(()=>{hi="continue",nr=".continue/rules",Tr=".continue/prompts",Ju=".continue/mcpServers",Al=`${Ju}/agentsmesh.json`,Rn=`${nr}/general.md`,Yu=`${nr}/_root.md`,de=".continue/skills",yi=".continue/AGENTS.md",Ja=".continue/config.yaml",xl=".agentsmesh/rules",Pl=".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 ZN(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"))ZN(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(ZN,"addCopilotInstructionMapping");s(qu,"buildCopilotImportPaths");});var LI,oo,bI,Te,kn,De,_i,Nr,Fr,vr,Dl,or,Qu,qN,Ii,sr,Ya,so,io,Mr,ao,co,AI,Ci,td,Xa,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",Dl=".cursor/settings.json",or=".cursorignore",Qu=".cursorindexingignore",qN=".agentsmesh-exports/cursor",Ii=`${qN}/user-rules.md`,sr=".cursor/AGENTS.md",Ya=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",Xa=".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,Nl,vI,Gr,MI,QN,Za,is,qa,Ri,ki,Qa,tc,ec,rc,nc,tF,Fl,as,$I,sd,vl,GI,jI,UI,KI,Oi=d(()=>{ss="junie",lo=".junie",Nl=`${lo}/guidelines.md`,vI=`${lo}/ci-guidelines.md`,Gr=`${lo}/AGENTS.md`,MI="AGENTS.md",QN=`${lo}/mcp`,Za=`${QN}/mcp.json`,is=`${lo}/skills`,qa=`${lo}/rules`,Ri=`${lo}/commands`,ki=`${lo}/agents`,Qa=".aiignore",tc=".junie",ec=`${tc}/skills`,rc=`${tc}/agents`,nc=`${tc}/commands`,tF=`${tc}/mcp`,Fl=`${tF}/mcp.json`,as=`${tc}/AGENTS.md`,$I=".agents/skills",sd=".agentsmesh/rules/_root.md",vl=".agentsmesh/rules",GI=".agentsmesh/commands",jI=".agentsmesh/agents",UI=".agentsmesh/mcp.json",KI=".agentsmesh/ignore";});async function id(t,e){t.set(Nl,`${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,oc,jr,En,Ln,bn,ir,mo,wi,Ml,cs,Ei,ls,sc,$l,Li,po,ms,ps,us,uo,bi,Gl,BI,fo,Ai,ds,HI,zI,fs=d(()=>{qt="kilo-code",oc=".kilo",jr="AGENTS.md",En=`${oc}/rules`,Ln=`${oc}/commands`,bn=`${oc}/agents`,ir=`${oc}/skills`,mo=`${oc}/mcp.json`,wi=".kilocodeignore",Ml=".kilocode",cs=`${Ml}/rules`,Ei=`${Ml}/workflows`,ls=`${Ml}/skills`,sc=`${Ml}/mcp.json`,$l=".kilocodemodes",Li=".kilo",po=`${Li}/AGENTS.md`,ms=`${Li}/rules`,ps=`${Li}/commands`,us=`${Li}/agents`,uo=`${Li}/skills`,bi=`${Li}/mcp.json`,Gl=".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(sc,".agentsmesh/mcp.json");}var VI=d(()=>{Nt();fs();At();s(ad,"buildKiloCodeImportPaths");});var fe,ar,ic,cr,Qt,lr,go,JI,xi,Pi,gs,mr,ho,hs,ac,cc,YI,cd,ld,XI,ZI,md,qI,Ti=d(()=>{fe="kiro",ar="AGENTS.md",ic=".kiro",cr=`${ic}/steering`,Qt=`${ic}/skills`,lr=`${ic}/agents`,go=`${ic}/hooks`,JI=`${ic}/settings`,xi=`${JI}/mcp.json`,Pi=".kiroignore",gs=".kiro/steering",mr=".kiro/steering/AGENTS.md",ho=".kiro/skills",hs=".kiro/agents",ac=".kiro/settings/mcp.json",cc=".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,jl,Ur,An,xn,Pn,ur,Kr,Di,yo,ys,_s,Is,_o,Io,tC,lc,Ul,Kl,ud,Cs=d(()=>{pr="opencode",jl=".opencode",Ur="AGENTS.md",An=`${jl}/rules`,xn=`${jl}/commands`,Pn=`${jl}/agents`,ur=`${jl}/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",lc=".agentsmesh/rules",Ul=".agentsmesh/commands",Kl=".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,mc,Tn,Dn,Wr,pc,uc,Ni,dc,Wl,So,Ro,Nn,Rs,fc,ko,rC,ks,Bl,nC,oC,Os=d(()=>{Co="roo-code",Ss=".roo",dr=`${Ss}/rules/00-root.md`,mc=".roorules",Tn=`${Ss}/rules`,Dn=`${Ss}/commands`,Wr=`${Ss}/skills`,pc=`${Ss}/mcp.json`,uc=".rooignore",Ni=".roomodes",dc="settings/custom_modes.yaml",Wl=".roo",So=`${Wl}/rules`,Ro=`${Wl}/commands`,Nn=`${Wl}/skills`,Rs="mcp_settings.json",fc=".rooignore",ko=`${Wl}/AGENTS.md`,rC=".agents/skills",ks=".agentsmesh/rules",Bl=".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(mc,`${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 kl(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,rF,zr,lC,ws=d(()=>{gr=".rules",Hr=".zed/settings.json",rF=".config/zed",zr=`${rF}/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 iF(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 nF,oF,sF,uC,Rl,Pu=d(()=>{ne();dt();K_();ue();tI();iI();mI();xt();Jo();nF={name:"amp",primaryRootInstructionPath:be,generateRules:$_,generateCommands:j_,generateAgents:U_,generateSkills:G_,importFrom:Q_},oF={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`}}},sF={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(iF,"mergeAmpSettings");Rl={id:"amp",generators:nF,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:oF,globalSupport:{capabilities:uC,detectionPaths:[un,dn],layout:sF},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?iF(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 QF(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(!Sl(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 QF(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();Ql();s(aR,"importCodexRules");s(QF,"importInstructionMirrors");});async function rm(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(rm,"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 yc(t)}var fR=d(()=>{Ql();s(dR,"codexAdvisoryInstructionPath");});var ev,rv,nv,ov,hR,yR=d(()=>{JS();Vt();Bd();mR();uR();xt();si();fR();ne();ev={name:"codex-cli",primaryRootInstructionPath:vn,generateRules:vd,generateCommands:Gd,generateAgents:jd,generateSkills:$d,generateMcp:Ud,importFrom:rm},rv={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`}}},nv={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`}}},ov={rules:"native",additionalRules:"embedded",commands:"embedded",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},hR={id:"codex-cli",generators:ev,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:rv,globalSupport:{capabilities:ov,detectionPaths:[".codex/AGENTS.md",".codex/AGENTS.override.md",".codex/config.toml",".codex/agents",".codex/rules",".agents/skills"],layout:nv},buildImportPaths:Vu,sharedArtifacts:{".agents/skills/":"owner"},detectionPaths:["codex.md","AGENTS.md","AGENTS.override.md",".codex/config.toml",".codex/agents",".codex/rules"]};});function iv(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:iv(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 nm=d(()=>{M();Dr();s(iv,"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:Al,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();nm();Dr();s(RR,"generateRules");s(kR,"generateCommands");s(OR,"generateMcp");s(wR,"generateAgents");s(ER,"generateSkills");});function mv(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 pv(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,mv(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 om(t){let e=[],r=await z(hi,t);return e.push(...await Q(sm,t,"project",{normalize:r})),await yt(t,de,hi,e,r),await pv(t,e),e}var Hd=d(()=>{It();A();_t();Mt();fn();Qe();Dr();zd();s(mv,"readMcpServers");s(pv,"importMcp");s(om,"importFromContinue");});function uv(t){return t==="general.md"||t==="_root.md"}var AR,xR,PR=d(()=>{M();et();nm();Dr();s(uv,"isContinueRootRulePath");AR=s(async({relativePath:t,normalizeTo:e,destDir:r})=>{let n=uv(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:`${xl}/${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:`${Pl}/${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 hv(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var vR,MR=d(()=>{A();Dr();s(hv,"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,Ja));return [{target:"continue",path:Ja,content:m,currentContent:p??void 0,status:hv(p,m)}]},"generateContinueGlobalConfig");});function _v(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var $R,GR=d(()=>{A();Dr();MR();s(_v,"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:_v(c,a)}]},"generateContinueScopeExtras");});var Iv,Cv,Sv,Rv,sm,zd=d(()=>{dt();LR();Dr();Hd();PR();DR();FR();nm();xt();GR();Iv={name:"continue",primaryRootInstructionPath:Rn,generateRules:RR,generateCommands:kR,generateAgents:wR,generateSkills:ER,generateMcp:OR,importFrom:om},Cv={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`}}},Sv={rootInstructionPath:Rn,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[yi]}],skillDir:de,managedOutputs:{dirs:[nr,Tr,de,".agents/skills"],files:[Al,yi,Ja]},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`}}},Rv={rules:"native",additionalRules:"native",commands:"native",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},sm={id:"continue",generators:Iv,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:Cv,globalSupport:{capabilities:Rv,detectionPaths:[nr,Tr,".continue/mcpServers",de],layout:Sv,scopeExtras:$R},importer:{rules:{feature:"rules",mode:"directory",source:{project:[nr],global:[nr]},canonicalDir:xl,extensions:[".md"],map:AR},commands:{feature:"commands",mode:"directory",source:{project:[Tr],global:[Tr]},canonicalDir:Pl,extensions:[".md"],map:xR}},buildImportPaths:Zu,detectionPaths:[".continue/rules",".continue/skills",".continue/mcpServers"]};});var $n,As,jR,xs,Eo,Zr,qr,Ps,Ts,im,am,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",im=".agentsmesh/commands",am=".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 cm(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 lm=d(()=>{M();ve();s(WR,"toStringArray");s(cm,"commandPromptPath");s(BR,"serializeCommandPrompt");s(HR,"parseCommandPromptFrontmatter");});function mm(t){return mn(t)}var Zd=d(()=>{Je();s(mm,"hasHookCommand");});function wv(t){let e=basename(t,".md");return e==="_root"?"root":e}function Ev(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,Rm),toPath:_f,feature:"permissions"}),e}var OO=d(()=>{A();Pt();s(fM,"unescapeRegexLiteral");s(gM,"toolNameToPermissionBase");s(hM,"commandPrefixToBashExpr");s(yM,"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,Cc),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,Sc);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:`${Sc}/${u.name}.md`,feature:"agents"});continue}let f=join(t,Rc,m,"SKILL.md"),g=r(l,c,f),h=join(t,Rc,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:`${Rc}/${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:`${Rc}/${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,Sc);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:`${Sc}/${h}`,feature:"agents"});}}catch{}}var AO=d(()=>{A();M();et();dt();Pt();s(bO,"importGeminiSkillsAndAgents");});async function _M(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 Am(t){let e=[],r=await z(bo,t);return await _M(t,e,r),e.push(...await Q(xm,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(_M,"importRootRule");s(Am,"importFromGemini");});async function PO(t,e,r){let n=t.replace(/\\/g,"/"),o=join(e,n),{frontmatter:i,body:a}=Lm(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")?CM(i):Lm(i),l=xe(a.allowedTools),m=xe(a["allowed-tools"]),p=l.length>0?l:m;return {destPath:o,toPath:`${Om}/${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 CM(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(CM,"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=SM.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=RM.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,SM,RM,vf=d(()=>{BO=[".claude/settings.json",".gemini/settings.json"],SM=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(),RM=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 kM,OM,wM,EM,xm,Ff=d(()=>{yO();Vo();CO();Pt();Nf();vO();$O();xt();si();dt();UO();WO();ue();vf();kM={name:"gemini-cli",primaryRootInstructionPath:Me,generateRules:If,generateCommands:Cf,generateAgents:Sf,generateSkills:Rf,generateIgnore:wf,generatePermissions:IO,importFrom:Am},OM={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`}}},wM={rootInstructionPath:Bi,outputFamilies:[{id:"compat-agents",kind:"additional",explicitPaths:[Hi]}],extraRuleOutputPaths(){return [Hi]},skillDir:Fs,managedOutputs:{dirs:[zi,Fs,kc],files:[Bi,Hi,wm]},rewriteGeneratedPath(t){return t===Me?Bi:t===Qr?Hi:t===Ns?wm:t.startsWith(`${ge}/`)?t.replace(`${ge}/`,`${zi}/`):t.startsWith(".gemini/skills/")?t.replace(".gemini/skills/",`${Fs}/`):t.startsWith(`${Ao}/`)?t.replace(`${Ao}/`,`${kc}/`):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`:`${kc}/${t}.md`}}},EM={rules:"native",additionalRules:"embedded",commands:"native",agents:"native",skills:"native",mcp:"native",hooks:"partial",ignore:"none",permissions:"none"},xm={id:"gemini-cli",generators:kM,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:OM,globalSupport:{capabilities:EM,detectionPaths:[Bi,Hi,wm,zi,Fs,kc],layout:wM},importer:{rules:{feature:"rules",mode:"directory",source:{project:[sO]},canonicalDir:xo,extensions:[".md"],map:NO},commands:{feature:"commands",mode:"directory",source:{project:[ge]},canonicalDir:Om,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(ZM,"steeringFrontmatter");s(Ww,"generateRules");s(Bw,"generateCommands");s(Hw,"generateSkills");s(zw,"generateMcp");s(Vw,"generateHooks");s(Jw,"generateAgents");s(Yw,"generateIgnore");});function QM(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 t$(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 e$(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,QM(c),l)}},"mapEntry")}));}async function r$(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 $m(t,e={}){let r=e.scope??"project",n=[],o=await z(fe,t,r);return await t$(t,n,o,r),await e$(t,n,o),n.push(...await Q(Gm,t,r,{normalize:o})),await yt(t,Qt,fe,n,o),r==="project"&&await r$(t,n),n}var Vf=d(()=>{It();_t();tr();Mt();et();Qe();A();M();zf();Ti();Jf();s(QM,"canonicalRuleMeta");s(t$,"importRoot");s(e$,"importNonRootRules");s(r$,"importHooks");s($m,"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 n$,o$,s$,i$,Gm,Jf=d(()=>{ne();Xw();ue();Vf();qw();tE();xt();Ti();n$={name:fe,primaryRootInstructionPath:ar,generateRules:Ww,generateCommands:Bw,generateAgents:Jw,generateSkills:Hw,generateMcp:zw,generateHooks:Vw,generateIgnore:Yw,importFrom:$m},o$={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`}}},s$={rootInstructionPath:mr,skillDir:ho,managedOutputs:{dirs:[gs,ho,hs,YI],files:[mr,ac,cc]},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?ac:t===Pi?cc: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`}}},i$={rules:"native",additionalRules:"native",commands:"none",agents:"native",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},Gm={id:fe,generators:n$,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:o$,globalSupport:{capabilities:i$,detectionPaths:[gs,mr,ho,hs,ac,cc],layout:s$},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:[ac]},canonicalDir:".agentsmesh",canonicalFilename:ZI},ignore:{feature:"ignore",mode:"flatFile",source:{project:[Pi],global:[cc]},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 a$(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]=a$(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(a$,"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 l$(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 m$(t,e,r){let o=join(t,e==="global"?Io:Kr),i=await y(o);if(i===null)return;let a=l$(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(jm,t,r,{normalize:o})),await yt(t,ur,pr,n,o),await m$(t,r,n),n}var lE=d(()=>{It();_t();Mt();fn();A();Cs();Xf();s(Yf,"toStringRecord");s(l$,"parseOpenCodeMcp");s(m$,"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:`${lc}/${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:`${Ul}/${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:`${Kl}/${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 p$,u$,d$,CE,jm,Xf=d(()=>{aE();Cs();ue();lE();dE();gE();IE();xt();p$={name:pr,primaryRootInstructionPath:Ur,generateRules:rE,generateCommands:nE,generateAgents:oE,generateSkills:iE,generateMcp:sE,importFrom:cE},u$={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`}}},d$={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"},jm={id:pr,generators:p$,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:u$,globalSupport:{capabilities:CE,detectionPaths:[yo,ys,_s,Is,_o,Io],layout:d$},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[Ur],global:[yo]},canonicalDir:lc,canonicalRootFilename:"_root.md",markAsRoot:true},{feature:"rules",mode:"directory",source:{project:[An],global:[ys]},canonicalDir:lc,extensions:[".md"],map:mE}],commands:{feature:"commands",mode:"directory",source:{project:[xn],global:[_s]},canonicalDir:Ul,extensions:[".md"],map:pE},agents:{feature:"agents",mode:"directory",source:{project:[Pn],global:[Is]},canonicalDir:Kl,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:pc,content:JSON.stringify({mcpServers:t.mcp.mcpServers},null,2)}]}function wE(t){return t.ignore.length===0?[]:[{path:uc,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 Um,xE,qf=d(()=>{M();et();Os();Um=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:`${Bl}/${t}`,content:await ot(n,{hasDescription:true,description:typeof o.description=="string"?o.description:void 0,hasAllowedTools:false,allowedTools:[]},i)}},"rooCommandMapper");});async function h$(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 Um({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(Km,t,r,{normalize:o})),await h$(t,n,o),await yt(t,Wr,Co,n,o),n}var TE=d(()=>{It();_t();tr();Mt();qf();Os();tg();s(h$,"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 R$(t,e){return t===null?"created":t!==e?"updated":"unchanged"}var C$,S$,k$,O$,w$,Km,tg=d(()=>{A();bE();Os();ue();TE();qf();NE();xt();C$={name:"roo-code",primaryRootInstructionPath:dr,generateRules:RE,generateCommands:kE,generateSkills:EE,generateMcp:OE,generateIgnore:wE,generateAgents:LE,importFrom:PE},S$={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(R$,"computeStatus");k$=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,dc));return [{target:"roo-code",path:dc,content:i,currentContent:a??void 0,status:R$(a,i)}]},"generateRooGlobalExtras"),O$={rootInstructionPath:ko,skillDir:Nn,managedOutputs:{dirs:[So,Ro,Nn,rC],files:[ko,Rs,fc,dc]},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===pc?Rs:t===uc?fc: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}}},w$={rules:"native",additionalRules:"native",commands:"native",agents:"partial",skills:"native",mcp:"native",hooks:"none",ignore:"native",permissions:"none"},Km={id:"roo-code",generators:C$,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:S$,globalSupport:{capabilities:w$,detectionPaths:[So,Ro,Nn,Rs,fc,ko,dc],layout:O$,scopeExtras:k$},importer:{rules:[{feature:"rules",mode:"singleFile",source:{project:[dr,mc],global:[ko,dr,mc]},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:Um}],commands:{feature:"commands",mode:"directory",source:{project:[Dn],global:[Ro]},canonicalDir:Bl,extensions:[".md"],map:xE},mcp:{feature:"mcp",mode:"mcpJson",source:{project:[pc],global:[Rs]},canonicalDir:".agentsmesh",canonicalFilename:nC},ignore:{feature:"ignore",mode:"flatFile",source:{project:[uc],global:[fc]},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(Wm,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 E$,L$,b$,A$,x$,Wm,eg=d(()=>{ne();dt();jE();ue();KE();BE();JE();xt();Fi();E$={name:Br,primaryRootInstructionPath:fr,generateRules:FE,generateCommands:ME,generateAgents:$E,generateSkills:vE,generateMcp:GE,importFrom:UE},L$={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`}}},b$={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`}}},A$={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"native",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},x$={rules:"none",additionalRules:"none",commands:"none",agents:"none",skills:"native",mcp:"none",hooks:"none",ignore:"none",permissions:"none"},Wm={id:Br,generators:E$,capabilities:A$,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:L$,globalSupport:{capabilities:x$,detectionPaths:[se],layout:b$},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,Oc,Bm,Hm,zm,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",Oc=".codeium/windsurf/global_workflows",Bm=".codeium/windsurf/hooks.json",Hm=".codeium/windsurf/mcp_config.json",zm=".codeium/.codeiumignore",ZE=".agents/skills";});function T$(t){let e=basename(t,".md");return e==="_root"?"root":e}function D$(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=T$(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=D$(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(T$,"ruleSlug");s(D$,"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(Jm,"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 B$(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 H$,z$,V$,J$,SL,RL=d(()=>{iL();Vo();te();ue();yg();yL();CL();xt();si();dt();s(B$,"directoryScopedRuleDir");H$={name:"windsurf",primaryRootInstructionPath:en,generateRules:lg,generateCommands:pg,generateAgents:ug,generateSkills:gg,generateMcp:dg,generateHooks:fg,generateIgnore:mg,importFrom:Jm},z$={rootInstructionPath:en,extraRuleOutputPaths(t){if(t.root)return [en];let e=B$(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}}},V$={rootInstructionPath:qi,skillDir:Qi,managedOutputs:{dirs:[Qi,Oc,ZE],files:[qi,Bm,Hm,zm]},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}/`,`${Oc}/`):t===Yi?Bm:t===Xi?Hm:t===Ji?zm:t},mirrorGlobalPath(t,e){return at(t,".codeium/windsurf/skills",e)},paths:{rulePath(t,e){return qi},commandPath(t,e){return `${Oc}/${t}.md`},agentPath(t,e){return ke(e,"windsurf")?`${Qi}/${V(t)}/SKILL.md`:null}}},J$={rules:"native",additionalRules:"partial",commands:Ze("native","workflows"),agents:"embedded",skills:"native",mcp:"partial",hooks:"native",ignore:"native",permissions:"none"},SL={id:"windsurf",generators:H$,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:z$,globalSupport:{capabilities:J$,detectionPaths:[qi,Qi,Oc,Bm,Hm,zm],layout:V$},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(Ym,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 eG(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 X$,Z$,q$,Q$,tG,Ym,_g=d(()=>{OL();AL();PL();FL();xt();ws();X$={name:"zed",primaryRootInstructionPath:gr,generateRules:kL,importFrom:bL},Z$={rootInstructionPath:gr,managedOutputs:{dirs:[],files:[gr,Hr]},paths:{rulePath(t){return gr},commandPath(){return null},agentPath(){return null}}},q$={rootInstructionPath:void 0,managedOutputs:{dirs:[],files:[zr]},rewriteGeneratedPath(t){return t===Hr?zr:t},paths:{rulePath(){return zr},commandPath(){return null},agentPath(){return null}}},Q$={rules:"native",additionalRules:"embedded",commands:"none",agents:"none",skills:"none",mcp:"native",hooks:"none",ignore:"none",permissions:"none"},tG={rules:"none",additionalRules:"none",commands:"none",agents:"none",skills:"none",mcp:"native",hooks:"none",ignore:"none",permissions:"none"};s(eG,"mergeZedSettings");Ym={id:"zed",generators:X$,capabilities:Q$,emptyImportMessage:"No Zed config found (.rules or .zed/settings.json).",lintRules:xL,lint:{hooks:TL,permissions:DL,ignore:NL},project:Z$,globalSupport:{capabilities:tG,detectionPaths:[zr],layout:q$},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?eG(t,r):null},buildImportPaths:_d,detectionPaths:[gr,Hr]};});var dI={};Jp(dI,{BUILTIN_TARGETS:()=>Ft,TARGET_IDS:()=>it,getBuiltinTargetDefinition:()=>$e,getEffectiveTargetSupportLevel:()=>Xm,getTargetCapabilities:()=>Po,getTargetDetectionPaths:()=>Cg,getTargetLayout:()=>Tt,getTargetManagedOutputs:()=>Sg,getTargetPrimaryRootInstructionPath:()=>nG,getTargetSkillDir:()=>Ec,isBuiltinTargetId:()=>He,resolveTargetFeatureGenerator:()=>ta,rewriteGeneratedOutputPath:()=>Rg});function rG(){return Ig||(R_(Ft),Ig=new Map(Ft.map(t=>[t.id,t]))),Ig}function $e(t){return rG().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 nG(t,e="project"){return Tt(t,e)?.rootInstructionPath}function Ec(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 oG(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 Xm(t,e,r,n="project"){let o=Po(t,n)?.[e]?.level??"none",i=$e(t)??tt(t);return o==="none"&&oG(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=sG[e];return i===null?void 0:i(o.generators)}var Ft,Ig,sG,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=[Rl,Hl,zl,xS,hR,sm,um,Sm,xm,Pm,Dm,Mm,Gm,jm,Km,Wm,SL,Ym];s(rG,"builtinTargetsMap");s($e,"getBuiltinTargetDefinition");s(Po,"getTargetCapabilities");s(Cg,"getTargetDetectionPaths");s(Tt,"getTargetLayout");s(nG,"getTargetPrimaryRootInstructionPath");s(Ec,"getTargetSkillDir");s(Sg,"getTargetManagedOutputs");s(Rg,"rewriteGeneratedOutputPath");s(vL,"isFeatureSuppressedByConversion");s(oG,"isConversionUpgrading");s(Xm,"getEffectiveTargetSupportLevel");sG={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 uG(t){return typeof t=="string"?t:t.level}function ML(t){return pG.includes(t)}function $L(t,e,r,n){for(let o of mG){let i=uG(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 Zm(t){return fG.parse(t)}var Wn,GL,iG,aG,jL,cG,lG,mG,pG,dG,fG,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}),iG=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(),aG=z$1.object({rulePath:z$1.function(),commandPath:z$1.function(),agentPath:z$1.function()}),jL=z$1.object({paths:aG}).passthrough(),cG=z$1.object({capabilities:GL,detectionPaths:z$1.array(z$1.string()),layout:jL,scopeExtras:z$1.function().optional()}).passthrough(),lG=["global","globalCapabilities","globalDetectionPaths","generateScopeExtras"],mG=[{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"}],pG=["mcp","hooks","ignore","permissions"];s(uG,"capabilityLevel");s(ML,"canUseScopedSettings");s($L,"validateCapabilityImplementations");dG=z$1.object({id:z$1.string().regex(/^[a-z][a-z0-9-]*$/,"Target id must be lowercase with hyphens"),generators:iG,capabilities:GL,emptyImportMessage:z$1.string(),lintRules:z$1.union([z$1.function(),z$1.null()]),project:jL,globalSupport:cG.optional(),buildImportPaths:z$1.function(),detectionPaths:z$1.array(z$1.string())}).passthrough(),fG=dG.superRefine((t,e)=>{for(let r of lG)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(Zm,"validateDescriptor");});function gG(){return Og||(Og=new Map(Ft.map(t=>[t.id,t]))),Og}function qm(t){let e=Zm(t);wg.set(e.id,e);}function tt(t){return wg.get(t)??gG().get(t)}function Qm(){return [...wg.values()]}var wg,Og,ye=d(()=>{ut();kg();wg=new Map;s(gG,"builtinDescriptors");s(qm,"registerTargetDescriptor");s(tt,"getDescriptor");s(Qm,"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 _G(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 IG(){let t=new Set([".agentsmesh/"]);for(let e of Ft)for(let r of _G(e))t.add(r);return Array.from(t)}function CG(){let t=new Set([...IG(),...Eg.rootRelativePrefixes]),e=new Set([...yG,...Eg.meshRootSegments]);return {protectedSchemes:[...hG,...Eg.protectedSchemes],rootRelativePrefixes:Array.from(t),meshRootSegments:e}}function tp(){return Lg||(Lg=CG()),Lg}var hG,yG,Eg,Lg,WL=d(()=>{ut();hG=[/\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],yG=new Set(["skills","rules","commands","agents","packs"]),Eg={protectedSchemes:[],rootRelativePrefixes:[],meshRootSegments:[]};s(_G,"topLevelDotfilePrefixes");s(IG,"buildDefaultRootRelativePrefixes");s(CG,"rebuild");s(tp,"getLinkFormatRegistry");});function Ir(t){let e=pt(t);return tp().rootRelativePrefixes.some(r=>e.startsWith(r))}function RG(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&&tp().meshRootSegments.has(r)}function Lc(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=RG(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 kG.has(a)?[]:a.includes(".")?[K(e,n.join(n.dirname(i),a))]:[]}function bc(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 ep(t){let e=[];for(let r of tp().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(OG))e.push([r.index??0,(r.index??0)+r[0].length]);for(let r of t.matchAll(wG))e.push([r.index??0,(r.index??0)+r[0].length]);for(let r of t.matchAll(EG))e.push([r.index??0,(r.index??0)+r[0].length]);return e}var kG,OG,wG,EG,zL,ea,Fo=d(()=>{Wt();WL();s(Ir,"isRootRelativePathToken");s(RG,"isMeshRootRelativePathToken");kG=new Set(["AGENTS.md","CLAUDE.md","GEMINI.md","codex.md",".windsurfrules",".cursorrules"]),OG=/^(?:```|~~~)[^\n]*\n[\s\S]*?^(?:```|~~~)/gm,wG=/<!-- agentsmesh:root-generation-contract:start -->[\s\S]*?<!-- agentsmesh:root-generation-contract:end -->/g,EG=/<!-- 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(Lc,"resolveProjectPath");s(bc,"expandResolvedPaths");s(VL,"isGlobAdjacent");s(ep,"protectedRanges");});function LG(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 LG(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(LG,"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 Lc(t.candidate,t.projectRoot,t.sourceFile)){let m=null,p=null;for(let u of bc(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 bG(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)&&bG(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(bG,"markdownBracketLabelDuplicatesDestination");s(ab,"isMarkdownReferenceDefinitionDestination");s(cb,"getTokenContext");s(lb,"shouldRewritePathToken");});function rp(t){let e=new Set,r=ep(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 dy=pt(T.relative(t.projectRoot,K(t.projectRoot,t.sourceFile))).split("/").filter(Boolean)[0]??"",rT=(C!==null?pt(T.relative(t.projectRoot,C)):"").split("/").filter(Boolean)[0]??"";if(dy.length>0&&dy===rT)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(rp,"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)=>rp({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,Wa),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,Va,m),e.push({fromTool:"claude-code",fromPath:n,toPath:Va,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,Ka),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 Vl(t,e={}){let r=e.scope??"project",n=[],o=await z("claude-code",t,r);return n.push(...await Q(zl,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(Vl,"importFromClaudeCode");});async function xc(t,e){let r=TG[e];if(!r)throw new Error(`No importer registered for native target: ${e}`);return r(t)}var TG,Fg=d(()=>{kd();ff();qd();Nf();Bd();yg();bd();Hd();$f();Vf();Bf();TG={"claude-code":Vl,cursor:Cm,copilot:pm,"gemini-cli":Am,"codex-cli":rm,windsurf:Jm,cline:Zl,continue:om,junie:Tm,kiro:$m,"kilo-code":vm};s(xc,"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 Pc(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,op=d(()=>{A();pl();Mg="SKILL.md";s($s,"isSkillPackLayout");s(Pc,"loadSkillsAtExtendPath");});function vG(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}function MG(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 sp(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 $G(t){if(basename(t)==="rules")return Ko(t);let r=join(t,"rules");return await v(r)?Ko(r):[]}async function GG(t){if(basename(t)==="commands")return Wo(t);let r=join(t,"commands");return await v(r)?Wo(r):[]}async function jG(t){if(basename(t)==="agents")return Ho(t);let r=join(t,"agents");return await v(r)?Ho(r):[]}async function UG(t){if(await $s(t))return Pc(t);let e=join(t,"skills");return await $s(e)?Pc(e):[]}async function ip(t){let e=join(t,".agentsmesh");if(await v(e))return pe(t);let r=vG();if(r.rules=await $G(t),r.commands=await GG(t),r.agents=await jG(t),r.skills=await UG(t),MG(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();ll();zo();cl();al();op();s(vG,"emptyCanonical");s(MG,"isCanonicalSliceEmpty");s(sp,"normalizeSlicePath");s($G,"parseRulesAt");s(GG,"parseCommandsAt");s(jG,"parseAgentsAt");s(UG,"loadSkillsForPartialSlice");s(ip,"loadCanonicalSliceAtPath");});function KG(){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 Pc(e);return {...KG(),skills:a}}let i=t.target??await gl(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 xc(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 xc(e,t.target)),pe(e)}let{sliceRoot:n}=await sp(r);try{return await ip(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();op();$g();s(KG,"emptyCanonical");s(Sb,"loadCanonicalForExtend");});function ap(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(ap,"applyExtendPick");});var HG,na,cp=d(()=>{HG=["rules","commands","agents","skills"],na=z$1.enum(HG);});var zG,kb,Ob=d(()=>{ln();cp();zG=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:zG,installed_at:z$1.string(),updated_at:z$1.string(),features:z$1.array(Zs).min(1),pick:ka.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 JG(t,e){return e?t.length===e.length&&[...t].sort().every((r,n)=>r===[...e].sort()[n]):true}async function lp(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 lp(a);if(c&&wb(c.source)===n&&c.target===r.target&&c.as===r.as&&JG(c.features,r.features))return {meta:c,packDir:a,name:c.name}}return null}async function mp(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 lp(o);i&&r.push({meta:i,packDir:o,name:i.name});}return r}var pp=d(()=>{A();Ob();Ea();s(wb,"sourceIdentity");s(JG,"sameFeatures");s(lp,"readPackMetadata");s(Lb,"findExistingPack");s(mp,"listPacks");});function bb(){return {rules:[],commands:[],agents:[],skills:[],mcp:null,permissions:null,hooks:null,ignore:[]}}async function YG(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")),ul(join(t,"permissions.yaml")),dl(join(t,"hooks.yaml")),fl(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 mp(e),n=bb();for(let{meta:o,packDir:i}of r){let a=await YG(i),c=Kg(a,o.features),l=ap(c,o.features,o.pick,o.name);n=ri(n,l);}return n}var xb=d(()=>{al();cl();ll();pl();ba();uu();fu();gu();yu();nn();jg();pp();s(bb,"emptyCanonical");s(YG,"loadPackCanonical");s(Ab,"loadPacksCanonical");});function Kg(t,e){if(e.length===0)return Pb();let r=new Set(e.flatMap(n=>ZG[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=ap(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 ZG,nn=d(()=>{il();zo();yu();Rb();jg();xb();ZG={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");});async function zj(t,e){let{source:r}=t,n;if(r.startsWith("file:")||r.startsWith("./")||r.startsWith("../")||r.startsWith("/")){let i=r.startsWith("file:")?fileURLToPath(r):r,a=resolve(e,i);n=pathToFileURL(a).href;}else n=r;return await import(n)}function Vj(t){return "descriptor"in t?[t.descriptor]:"descriptors"in t&&Array.isArray(t.descriptors)?t.descriptors:"default"in t?[t.default]:[]}async function kp(t,e){let r;try{r=await zj(t,e);}catch(i){throw new Error(`Plugin '${t.source}' failed to import: ${i instanceof Error?i.message:String(i)}`,{cause:i})}let n=Vj(r),o=[];for(let i of n)try{let a=Zm(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 cA(t,e){let r=[];return await Promise.all(t.map(async n=>{try{let o=await kp(n,e);r.push(o);}catch(o){I.warn(`Plugin '${n.source}' failed to load: ${o instanceof Error?o.message:String(o)}`);}})),r}var Zg=d(()=>{kg();ye();nt();s(zj,"importPluginModule");s(Vj,"extractDescriptors");s(kp,"loadPlugin");s(cA,"loadAllPlugins");});async function Jt(t,e){t.plugins.length!==0&&await cA(t.plugins,e);}var Vn=d(()=>{Zg();s(Jt,"bootstrapPlugins");});function th(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=hU(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]=Xm(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]=Xm(u,"additionalRules",t,r);n.push({feature:`additional rules (${m.length})`,count:m.length,support:p});}}}return n}function hU(t){if(!t)return 0;let e=0;for(let r of Object.values(t))Array.isArray(r)&&(e+=r.length);return e}var _A=d(()=>{ut();s(th,"buildCompatibilityMatrix");s(hU,"countHooks");});function IA(t){return yU[t]??t}var yU,CA=d(()=>{yU={"claude-code":"Claude"};s(IA,"matrixColumnLabel");});function SA(t){return Object.fromEntries(_U.map(e=>[e,Object.fromEntries(it.map(r=>{let o=Po(r,t)?.[e];return [r,o??{level:"none"}]}))]))}function IU(){return process.env.NO_COLOR!==void 0&&process.env.NO_COLOR!==""}function CU(t,e){return IU()?e:`${t}${e}${Mc.reset}`}function kA(t){let e=eh[t];return CU(SU[t],e)}var _U,RA,eh,Mc,SU,rh=d(()=>{ze();ut();_U=["rules","additionalRules","commands","agents","skills","mcp","hooks","ignore","permissions"];s(SA,"buildSupportMatrix");RA=SA("project"),SA("global"),eh={native:"\u2713",embedded:"\u25C6",partial:"\u25D0",none:"\u2013"},Mc={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(IU,"noColor");s(CU,"colorize");SU={native:Mc.green,embedded:Mc.blue,partial:Mc.yellow,none:Mc.dim};s(kA,"coloredSymbol");});function nh(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=>IA(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?eh[Ct]:kA(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=Nc(i),c=a.startsWith("sha256:")?a:`sha256:${a}`;e[r.name]=`local:${c}`;}return e}s(oa,"buildExtendChecksums");ut();ye();function ij(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}s(ij,"addDirectoryMapping");function Tb(t,e,r){let n=posix.dirname(e),o=posix.dirname(r);for(;n!==".agentsmesh/skills"&&n!==".";)ij(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 lj(t,e,r){t.set(e,r),t.set(`${e}/`,`${r}/`);}s(lj,"addDirectoryMapping");function Fc(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=Ec(t,n);if(!i)return o;for(let a of e.skills){lj(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(Fc,"buildReferenceMap");ze();var zn="AGENTS.md";function mj(t){return t.target===Sa&&t.path.endsWith(zn)}s(mj,"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 pj(t){return t.target==="kiro"&&t.path.endsWith(zn)}s(pj,"isKiroAgents");function uj(t){return t.target==="kilo-code"&&t.path.endsWith(zn)}s(uj,"isKiloCodeAgents");function $b(t){return t.target==="warp"&&t.path.endsWith(zn)}s($b,"isWarpAgents");function dj(t){return Hg(t)||zg(t)}s(dj,"isCompatibilityAgents");function _p(t,e,r,n){let o=n.get(t);if(o)return o;let i=new Map;for(let[a,c]of Fc(t,e,r))i.has(c)||i.set(c,a);return n.set(t,i),i}s(_p,"reverseReferenceMap");function Ip(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(Ip,"normalizeContent");function fj(t,e,r,n,o){let i=_p(t.target,r,n,o),a=_p(e.target,r,n,o);return Ip(t.content,i)===Ip(e.content,a)}s(fj,"hasEquivalentCanonicalContent");function gj(t,e,r,n,o){let i=_p(t.target,r,n,o),a=_p(e.target,r,n,o),c=Ip(t.content,i).trim(),l=Ip(e.content,a).trim();return c.length>l.length&&c.includes(l)}s(gj,"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)mj(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)&&!pj(a)&&!uj(a)&&!$b(a))return true;let c=o.get(a.path);return c?dj(a)||vb(a)||Mb(a)||$b(a)?false:!(fj(c,a,e,r,i)||gj(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 hj(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(hj,"skillSupportingDirPrefixes");function Kb(t,e,r,n,o){let i=Ec(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 hj(l.supportingFiles))Ub(t,a.join(m,u),a.join(p,u),a);}}s(Kb,"addPackSkillArtifactMappings");Wt();function yj(t){return `.agentsmesh/rules/${basename(t.source)}`}s(yj,"canonicalRulePath");function _j(t){return `.github/instructions/${basename(t.source,".md")}.instructions.md`}s(_j,"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,yj(a))),i.normalize(i.join(r,_j(a))));}s(Bb,"applyCopilotInstructionArtifactRefs");ut();function Cp(t){return t?(t.outputFamilies??[]).filter(e=>e.kind==="additional").flatMap(e=>[...e.explicitPaths??[]]):[]}s(Cp,"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 Cp(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 Cj(t){return `.agentsmesh/commands/${t.name}.md`}s(Cj,"canonicalCommandPath");function Sj(t){return `.agentsmesh/agents/${t.name}.md`}s(Sj,"canonicalAgentPath");function Rj(t){return `.agentsmesh/skills/${t.name}/SKILL.md`}s(Rj,"canonicalSkillPath");function Jb(t,e,r,n,o,i){let a=i?.scope??"project",c=Y(n),l=new Map([...Fc(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=Fc(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(Cj(c));l&&a.set(l,c.source);}for(let c of e.agents){let l=i.get(Sj(c));l&&a.set(l,c.source);}for(let c of e.skills){let l=i.get(Rj(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 wj(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(wj,"findSharedArtifactOwner");function Xb(t,e,r){if(e==="global"){let n=wj(t.path,r);if(n)return n;let o=S_(t.path);if(o)return o}return t.target}s(Xb,"artifactMapTargetForResult");function Ej(t,e){return `${t}\0${(e??[]).join(",")}`}s(Ej,"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 Lj(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(Lj,"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=Ej(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=Lj(m,o,i),R=c.get(h)??(()=>{let _=Jb(g,e,r,n,m.path,{scope:o});return c.set(h,_),_})(),C=rp({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 Aj=/!?\[[^\]]*\]\(([^)]+)\)/g,xj=/^\s*\[[^\]\n]+\]:\s*(?:<([^>\n]*)>|(\S+))/gm;function Pj(t){return t.endsWith(".md")||t.endsWith(".mdc")}s(Pj,"isMarkdownLikeOutput");function Tj(t,e){return e.some(([r,n])=>t>=r&&t<n)}s(Tj,"isOffsetInRanges");function Dj(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(Dj,"parseMarkdownLinkDestination");function Nj(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(Nj,"shouldSkipLocalValidation");function Fj(t,e){if(e.has(t))return true;try{let r=statSync(t);return r.isFile()||r.isDirectory()}catch{return false}}s(Fj,"pathExistsForGenerate");function vj(t,e,r){let o=Dj(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(Nj(l))return [];let m=Lc(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 bc(e,u)){let g=K(e,f);p.includes(g)||p.push(g);}return p}s(vj,"resolveMarkdownLinkTargets");function Mj(t,e){let r=Jg(e,t),n=[];for(let o of t){if(!Pj(o.path))continue;let i=K(e,Y(e).join(e,o.path)),a=ep(o.content),c=s((l,m)=>{if(Tj(m,a))return;let p=vj(l,e,i);p.length!==0&&(p.some(u=>Fj(u,r))||n.push({generatePath:o.path,target:o.target,rawLink:l.trim(),checkedPaths:p}));},"visitDestination");for(let l of o.content.matchAll(Aj)){let m=l[1];m!==void 0&&c(m,l.index??0);}for(let l of o.content.matchAll(xj)){let m=(l[1]??l[2]??"").trim();m&&c(m,l.index??0);}}return n}s(Mj,"findBrokenMarkdownLinks");function qb(t,e){let r=Mj(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 $j(t,e){return Qb(e.status)<=Qb(t.status)?t:{...t,status:e.status,currentContent:e.currentContent??t.currentContent}}s($j,"mergeDuplicateMetadata");function Sp(t){return t.trim()}s(Sp,"trimmedContent");function Gj(t,e){if(!t.path.endsWith(tA)||t.path!==e.path)return null;let r=Sp(t.content),n=Sp(e.content);if(!r||!n)return null;let o=r.includes(n),i=n.includes(r);return o===i?null:o?t:e}s(Gj,"richerAgentsResult");function jj(t,e){if(!t.path.endsWith(tA)||t.path!==e.path)return null;let r=t.target===Sa?t:e.target===Sa?e:null,n=r===t?e:t;if(!r)return null;let o=Sp(r.content).length,i=Sp(n.content).length;return o===i?null:o>i?r:n}s(jj,"richerCodexAgentsResult");function Rp(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=Gj(o,r);if(i){e[n]=i;continue}let a=jj(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]=$j(o,r);}return e}s(Rp,"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 Uj(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(Uj,"resolveGeneratedOutputPath");async function vc(t,e,r,n,o,i){let a=Uj(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(vc,"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 vc(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 Kj(t){return t?.rootInstructionPath?[t.rootInstructionPath,...Cp(t)]:[]}s(Kj,"rootDecorationPaths");function oA(t,e,r="project"){return t.map(n=>{let o=Tt(n.target,r);if(!o)return n;let i=Kj(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 vc(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 vc(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 vc(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),Rp(Gb(D.map(eA),r,e))}s(je,"generate");Vn();nt();A();qn();var tU=6e4,eU=30,rU=200,nU=2e3;async function uA(t,e={}){let r=e.retries??eU,n=e.retryDelayMs??rU,o=e.staleMs??tU;await mkdir(dirname(t),{recursive:true});let i=0;for(;;){let a=await oU(t);if(a)return a;let c=await sU(t);if(c!=="young"&&iU(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,cU(l))}i++,await mU(n);}}s(uA,"acquireProcessLock");async function oU(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:dA()};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(oU,"tryAcquire");async function sU(t){try{let e=await readFile(join(t,"holder.json"),"utf-8"),r=JSON.parse(e);return lU(r)?r:null}catch{try{let e=await stat(t);if(Date.now()-e.mtimeMs<nU)return "young"}catch{}return null}}s(sU,"inspectLock");function iU(t,e){return !t||Date.now()-t.started>e?true:t.hostname&&t.hostname!==dA()?false:!aU(t.pid)}s(iU,"isStale");function aU(t){if(!Number.isInteger(t)||t<=0)return false;try{return process.kill(t,0),!0}catch(e){return e.code==="EPERM"}}s(aU,"isProcessAlive");function cU(t){return t?`${t.hostname?`${t.hostname}:`:""}pid ${t.pid} (running ${Date.now()-t.started}ms)`:"unknown (unreadable lock metadata)"}s(cU,"describeHolder");function lU(t){if(typeof t!="object"||t===null)return false;let e=t;return typeof e.pid=="number"&&typeof e.started=="number"}s(lU,"isLockMetadata");function dA(){return hostname()}s(dA,"getHostname");function mU(t){return new Promise(e=>setTimeout(e,t))}s(mU,"sleep");A();ut();async function fA(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 fA(i,e));continue}n.push(relative(e,i).replace(/\\/g,"/"));}return n}s(fA,"listFiles");async function fU(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(fU,"removeIfStale");async function gA(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 fA(c))r.add(`${a}/${l}`.replace(/\/+/g,"/"));}}}for(let o of r)await fU(t.projectRoot,o,e);}s(gA,"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");La();A();nt();async function Qg(t,e){let r=await Hn(t.canonicalDir),n=e.length>0?await oa(e):{},o=await hp(join(t.canonicalDir,"packs")),i=process.env.USER??process.env.USERNAME??"unknown";await fp(t.canonicalDir,{generatedAt:new Date().toISOString(),generatedBy:i,libVersion:tl(),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(Qg,"writeLockFile");async function EA(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:Op([])}};if(n||await Qg(o,i),l.printMatrix!==false){let{runMatrix:m}=await Promise.resolve().then(()=>(Gc(),ah)),{renderMatrix:p}=await Promise.resolve().then(()=>(Uc(),ch)),u=await m(a,c);p(u,{verbose:a.verbose===true});}return {exitCode:0,data:{scope:r,mode:e,files:[],summary:Op([])}}}s(EA,"handleEmptyResults");function LA(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:Op(r)}}}s(LA,"buildCheckResult");async function bA(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 uA(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 gA({projectRoot:i.rootBase,targets:a,expectedPaths:e.map(h=>h.path),scope:n}),await Qg(i,c);}}finally{u&&await u();}if(p.printMatrix!==false){let{runMatrix:h}=await Promise.resolve().then(()=>(Gc(),ah)),{renderMatrix:R}=await Promise.resolve().then(()=>(Uc(),ch)),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:Op(f)}}}s(bA,"handleGenerateOrDryRun");function Op(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(Op,"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 dp(g.canonicalDir);if(D!==null){let x=await Hn(g.canonicalDir),Z=gp(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?EA({mode:u,scope:c,dryRun:i,context:g,resolvedExtends:C,flags:t,root:n,options:r}):o?LA(T,c):bA({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 lh(t,e){return t==="global"?`~/${e}`:e}s(lh,"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} ${lh(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} ${lh(r,l.path)} (${l.target})`);return}for(let l of o)(l.status==="created"||l.status==="updated")&&I.success(`${l.status} ${lh(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 kU=["codex-cli"];function AA(){return it.filter(t=>!kU.includes(t))}s(AA,"starterInitTargetIds");var OU=["rules","commands","agents","skills","mcp","hooks","ignore","permissions"],wU=AA();function wp(t,e=wU){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(Rh,"seedAgentsmeshMcpEntry");function jA(t,e){return t.map(r=>({from:relative(e,r.fromPath).replaceAll("\\","/"),to:r.toPath}))}s(jA,"mapResults");async function UA(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=Oa(r,i),f=await Lp(o).importFrom(p.rootBase,{scope:i});return f.length>0&&await Rh(p.rootBase),{exitCode:0,data:{scope:i,target:o,files:jA(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 Rh(c.rootBase),{exitCode:0,data:{scope:i,target:o,files:jA(m,c.rootBase)}}}s(UA,"runImport");le();nn();function bp(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(bp,"computeDiff");function Ap(t){return `${t.new} files would be created, ${t.updated} updated, ${t.unchanged} unchanged, ${t.deleted} deleted`}s(Ap,"formatDiffSummary");Vn();async function WA(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}=bp(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(WA,"runDiff");le();nn();A();ye();Vo();bt();var KU=[{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 BA(t){let e=new Set(t.enabledFeatures),r=[];for(let n of KU)!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(BA,"lintSilentFeatureDrops");bt();var WU=/^(?:\s*(?:bash|sh|zsh|pwsh|powershell)\s+)?["']?(?<path>(?:\.{1,2}\/|[^/\s"'`]+\/)[^\s"'`]+)["']?(?:\s|$)/;function BU(t){let r=t.match(WU)?.groups?.path;return typeof r=="string"?r:null}s(BU,"extractScriptToken");function HA(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=BU(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(HA,"lintHookScriptReferences");bt();function zA(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(zA,"lintRuleScopeInversion");var HU=["node_modules",".git","dist","coverage",".agentsmesh"];async function zU(t){return (await N(t)).filter(n=>{let o=relative(t,n);return !HU.some(i=>o.includes(`/${i}/`)||o.startsWith(`${i}/`))}).map(n=>relative(t,n))}s(zU,"getProjectFiles");async function xp(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 zU(r);for(let C of c){let _=tt(C),E=He(C)?Lp(C):_;E?.capabilities&&g.push(...BA({target:C,capabilities:E.capabilities,canonical:e,enabledFeatures:t.features})),f&&g.push(...HA({target:C,canonical:e,hasScriptProjection:_?.postProcessHookOutputs!==void 0})),l&&g.push(...zA({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(xp,"runLint");Vn();async function JA(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 xp(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(JA,"runLintCmd");nt();function YA(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(YA,"renderLint");nt();function XA(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(XA,"renderCheck");nt();function ZA(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(ZA,"renderImport");nt();function qA(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(Ap({new:e.created,updated:e.updated,unchanged:e.unchanged,deleted:e.deleted}));}s(qA,"renderDiff");nt();function QA(t){if(!t.data.hadConflict){I.info("No conflicts to resolve.");return}I.success("Lock file conflict resolved.");}s(QA,"renderMerge");Gc();Uc();le();nn();Gc();Uc();nt();var YU=300;function XU(t){return t.replace(/\\/g,"/").replace(/\/+$/,"")}s(XU,"normalizeWatchPath");function ZU(t,e,r){let n=XU(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(ZU,"shouldIgnoreWatchPath");function qU(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(qU,"featureFingerprint");async function ex(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=qU(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 $c(t,r);jc(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,YU));},"schedule"),h=JU.watch(i,{ignoreInitial:true,usePolling:process.platform==="win32"});return h.on("all",(R,C)=>{ZU(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(ex,"runWatch");le();il();async function Pp(t){let{config:e,configDir:r,canonicalDir:n}=t,o=await dp(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=gp(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(Pp,"checkLockSync");Vn();async function rx(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 Pp({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(rx,"runCheck");le();A();il();var t0=".lock",e0="<<<<<<<";async function kh(t){let e=join(t,t0),r=await y(e);return r===null?false:r.includes(e0)}s(kh,"hasLockConflict");async function ox(t,e,r){if(!await kh(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 hp(join(t,"packs")),m=process.env.USER??process.env.USERNAME??"unknown";await fp(t,{generatedAt:new Date().toISOString(),generatedBy:m,libVersion:e,checksums:o,extends:c,packs:l});}s(ox,"resolveLockConflict");async function sx(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 kh(a)?(await ox(a,tl(),o),{exitCode:0,data:{hadConflict:true,resolved:true}}):{exitCode:0,data:{hadConflict:false,resolved:false}}}s(sx,"runMerge");le();A();La();var o0=promisify(execFile);async function Oh(t){let{stdout:e}=await o0("git",t,{env:{...process.env,GIT_TERMINAL_PROMPT:"0"}});return e.trim()}s(Oh,"runGit");async function ix(){try{return await Oh(["--version"]),!0}catch{return false}}s(ix,"isGitAvailable");async function s0(t,e){let r=[e,`refs/heads/${e}`,`refs/tags/${e}`],n;for(let o of r)try{let a=(await Oh(["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 s0(e,r)}s(ax,"resolveRemoteRefForInstall");async function cx(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 ax(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(cx,"fetchInstallSource");async function lx(t,e){if(t.kind==="local")return {resolvedPath:t.localRoot,sourceForYaml:t.localSourceForYaml};try{let r=await cx(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(lx,"resolveInstallResolvedPath");function wh(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(wh,"parseGithubTreeUrl");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("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(Eh,"parseGithubBlobUrl");function Lh(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(Lh,"parseGitlabTreeUrl");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]!=="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(bh,"parseGitlabBlobUrl");var i0=new Set(["tree","blob","commit","releases","actions","issues","pulls","settings","wiki","discussions","security","projects","packages"]);function Ah(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||i0.has(r[1]))return null;let n=r[0],o=r[1];return {org:n,repo:o}}catch{return null}}s(Ah,"parseGithubRepoUrl");function xh(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(xh,"parseGitlabRepoUrl");function Ph(t){let e=t.match(/^git@github\.com:([^/]+)\/(.+?)(?:\.git)?$/i);return e?{org:e[1],repo:e[2].replace(/\.git$/i,"")}:null}s(Ph,"parseGitSshGithub");function Th(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(Th,"parseGitSshGitlab");A();var l0=/^[A-Za-z]:[\\/]/,m0=/^[A-Za-z]:\//;function mx(...t){return t.some(e=>e.includes("\\")||l0.test(e))?win32:posix}s(mx,"pathApiFor");function Wc(t){return t.replace(/\\/g,"/")}s(Wc,"toPosixPath");function Kc(t){return Wc(t).replace(/^\/+|\/+$/g,"")}s(Kc,"normalizeInstallPathField");function Tp(t){let e=Wc(t);return e===""||e==="."||e==="./."?".":e.startsWith("./")||e.startsWith("../")||e.startsWith("/")||m0.test(e)?e:`./${e}`}s(Tp,"normalizeLocalSourceForYaml");function vo(t){return {...t,source:t.source_kind==="local"?Tp(t.source):t.source,...t.path!==void 0?{path:Kc(t.path)}:{},...t.paths!==void 0?{paths:t.paths.map(e=>Kc(e))}:{}}}s(vo,"normalizePersistedInstallPaths");function px(t,e,r){let n=mx(t,e),o=n.normalize(t),i=n.normalize(e),a=Kc(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=Kc(u),g=Wc(n.relative(i,p))||".";return {kind:"local",rawRef:"",pathInRepo:a||f.replace(/\.md$/i,"").replace(/\/$/,""),localRoot:p,localSourceForYaml:Tp(g)}}let m=Wc(n.relative(i,o))||".";return {kind:"local",rawRef:"",pathInRepo:a,localRoot:o,localSourceForYaml:Tp(m)}}s(px,"localParsedFromAbsPath");async function Dh(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=wh(n)??Eh(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=Ah(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=Lh(n)??bh(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=xh(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=Ph(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=Th(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 px(c,e,o)}s(Dh,"parseInstallSource");A();nt();ln();A();cp();var ux=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:ka.optional(),target:Re.optional(),path:z$1.string().optional(),paths:z$1.array(z$1.string().min(1)).min(1).optional(),as:na.optional()}),g0=z$1.object({version:z$1.literal(1),installs:z$1.array(ux).default([])});function h0(t,e){return t.length===e.length&&[...t].sort().every((r,n)=>r===[...e].sort()[n])}s(h0,"sameFeatures");function y0(t,e){return t.source===e.source&&t.target===e.target&&t.as===e.as&&h0(t.features,e.features)}s(y0,"sameInstallIdentity");function dx(t){return join(t,"installs.yaml")}s(dx,"manifestPath");async function Nh(t){let e=await y(dx(t));if(e===null)return [];try{return g0.parse(parse(e)).installs.map(r=>vo(r))}catch{return []}}s(Nh,"readInstallManifest");async function fx(t,e){let r=vo(e),o=(await Nh(t)).filter(i=>i.name!==r.name&&!y0(i,r));o.push(r),await S(dx(t),stringify({version:1,installs:o.sort((i,a)=>i.name.localeCompare(a.name))}));}s(fx,"upsertInstallManifestEntry");function gx(t){return vo(ux.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(gx,"buildInstallManifestEntry");async function I0(t){let e=await Nh(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(I0,"syncInstalledPacks");async function hx(t){return t.sync?(await I0({canonicalDir:t.canonicalDir,reinstall:t.reinstall}),true):false}s(hx,"maybeRunInstallSync");cp();function yx(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(yx,"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 Dp(t){let{sliceRoot:e,implicitPick:r}=await sp(t),n=await ip(e);return {canonical:n,features:js(n),implicitPick:r}}s(Dp,"discoverFromContentRoot");function _x(t){return t.description.trim()?{skill:t,ok:true}:{skill:t,ok:false,reason:"missing description in frontmatter"}}s(_x,"validateSkill");function Ix(t){return t.description.trim()?{rule:t,ok:true}:{rule:t,ok:false,reason:"missing description in frontmatter"}}s(Ix,"validateRule");function Cx(t){return t.description.trim()?{command:t,ok:true}:{command:t,ok:false,reason:"missing description in frontmatter"}}s(Cx,"validateCommand");function Sx(t){return t.description.trim()?{agent:t,ok:true}:{agent:t,ok:false,reason:"missing description in frontmatter"}}s(Sx,"validateAgent");function ae(t){return basename(t.source).replace(/\.md$/i,"")}s(ae,"ruleSlug");function S0(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(S0,"featuresFromImplicitPick");function la(t,e){let{implicitPick:r}=e,n=e.scopedFeatures??S0(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();op();A();M();var O0=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"]),w0=new Set([".git",".github",".gitlab","node_modules",".vscode",".idea"]);async function Np(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(Np,"readSkillFrontmatterName");async function Rx(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 !(w0.has(o)||!n.includes("/")&&O0.has(n))},"filter")});}s(Rx,"cpFilteredSkill");async function x0(){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(x0,"createStageRoot");async function P0(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(P0,"stageMarkdownCollection");async function kx(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(kx,"stagePreferredSkills");async function T0(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 kx(t,e,r.preferredSkillNames??[]))return;let c=await Np(join(t,"SKILL.md"))||basename(t),l=join(e,c);await O(e),await Rx(t,l);return}if(await kx(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(T0,"stageSkills");async function Ox(t,e,r={}){let n=await x0();try{let o=join(n.discoveryRoot,".agentsmesh",e);return e==="skills"?await T0(t,o,r):await P0(t,o),n}catch(o){throw await n.cleanup(),o}}s(Ox,"stageManualInstallScope");async function wx(t,e,r,n){let o=await Ox(t,e,{preferredSkillNames:e==="skills"?n?.skills:void 0}),{canonical:i}=await Dp(o.discoveryRoot),a=la(i,{scopedFeatures:[e]});return {prep:{yamlTarget:r,scopedFeatures:[e],cleanup:o.cleanup},narrowed:a,discoveredFeatures:js(a)}}s(wx,"resolveManualDiscoveredForInstall");ln();_u();A();var D0=[{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 N0(t){return t.replace(/\\/g,"/").replace(/^\/+|\/+$/g,"")}s(N0,"norm");function vp(t){let e=N0(t),r=[...D0].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(vp,"targetHintFromNativePath");function vh(t,e){return vp(t)===e}s(vh,"pathSupportsNativePick");function Ex(t,e){if(!t||!e)return;let r=vp(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(Ex,"validateTargetMatchesPath");function Lx(t){return (t.commands?.length??0)+(t.rules?.length??0)+(t.skills?.length??0)+(t.agents?.length??0)>0}s(Lx,"extendPickHasArrays");A();A();Pt();async function Ax(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(Ax,"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 xx(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(xx,"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 Tx(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 Ax(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 xx(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(Tx,"inferImplicitPickFromNativePath");function Dx(t){return (t.commands?.length??0)+(t.rules?.length??0)+(t.skills?.length??0)+(t.agents?.length??0)===0}s(Dx,"isImplicitPickEmpty");Fg();function zc(t){return t.replace(/\\/g,"/").replace(/\/+$/,"")}s(zc,"normalizePath");function B0(t,e){let r=zc(t),n=zc(e);return r===n||r.startsWith(`${n}/`)||n.startsWith(`${r}/`)}s(B0,"overlapsPath");function Mp(t,e){let r=t??[];return r.includes(e)||r.push(e),r}s(Mp,"addUnique");async function H0(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(H0,"makeStageRoot");function z0(t,e){let r;for(let o of t){if(o.feature==="rules"&&o.toPath.startsWith(".agentsmesh/rules/")){r={...r,rules:Mp(r?.rules,basename(o.toPath,".md"))};continue}if(o.feature==="commands"&&o.toPath.startsWith(".agentsmesh/commands/")){let i=zc(relative(join(e,".agentsmesh","commands"),join(e,o.toPath)));r={...r,commands:Mp(r?.commands,i.replace(/\.md$/i,"").split("/").filter(Boolean).join(":"))};continue}if(o.feature==="agents"&&o.toPath.startsWith(".agentsmesh/agents/")){r={...r,agents:Mp(r?.agents,basename(o.toPath,".md"))};continue}if(o.feature==="skills"&&o.toPath.startsWith(".agentsmesh/skills/")){let a=zc(relative(join(e,".agentsmesh","skills"),join(e,o.toPath))).split("/")[0];a&&(r={...r,skills:Mp(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(z0,"buildPickFromResults");function V0(t,e,r,n){let o=join(e,...zc(t).split("/")),i=r.filter(a=>B0(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:z0(i,e)}}s(V0,"scopeImportedResults");async function $h(t,e){let{stageRoot:r,cleanup:n}=await H0(t);try{let o=await xc(r,e);return {stageRoot:r,results:o,cleanup:n}}catch(o){throw await n(),o}}s($h,"stageImportedNativeRepo");async function Gh(t,e,r){let n=await $h(t,r);try{return {stageRoot:n.stageRoot,cleanup:n.cleanup,...V0(e,n.stageRoot,n.results,r)}}catch(o){throw await n.cleanup(),o}}s(Gh,"stageNativeInstallScope");async function Mx(t,e,r,n){let o=n.explicitTarget?.trim();o&&Re.parse(o);let i=r.replace(/\\/g,"/").replace(/^\/+|\/+$/g,"");Ex(o,i);let a=join(t,".agentsmesh"),c=await v(a),l=i?vp(i):void 0,m=!c&&!o?await gl(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 Gh(t,i,p);return {discoveryRoot:E.stageRoot,implicitPick:E.pick,scopedFeatures:E.features,yamlTarget:p,importHappened:true,cleanup:E.cleanup}}let _=await $h(t,p);return {discoveryRoot:i?join(_.stageRoot,i):_.stageRoot,yamlTarget:p,importHappened:true,cleanup:_.cleanup}}let f;c?i?p&&vh(i,p)?f=t:f=e:f=t:f=e;let g,h,R;if(u&&p){let _=await Gh(t,i,p);f=_.stageRoot,g=_.pick,h=_.features,R=_.cleanup;}else if(f===t&&i&&p&&vh(i,p)&&(g=await Tx(t,i,p),Dx(g)))throw new Error(`No installable native resources found under "${i}" for target "${p}".`);let C;return o?C=o:p&&(g&&Lx(g)||(h?.length??0)>0)&&(C=p),{discoveryRoot:f,implicitPick:g,scopedFeatures:h,yamlTarget:C,importHappened:R!==void 0,cleanup:R}}s(Mx,"prepareInstallDiscovery");async function $x(t,e,r,n){let o=await Mx(t,e,r,{explicitTarget:n}),{canonical:i,implicitPick:a}=await Dp(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($x,"resolveDiscoveredForInstall");async function Gx(t){return t.explicitAs?{implicitPick:void 0,...await wx(t.contentRoot,t.explicitAs,t.explicitTarget,t.replayPick)}:$x(t.resolvedPath,t.contentRoot,t.pathInRepo,t.explicitTarget)}s(Gx,"resolveInstallDiscovery");function pa(t){return t==="."||t===""?void 0:t}s(pa,"trimDot");function Y0(t,e){let r=basename(e).replace(/\.md$/i,"");return t==="agents"?{agents:[r]}:t==="commands"?{commands:[r]}:{rules:[r]}}s(Y0,"markdownPick");async function Ux(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:Y0(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 Np(o);return {pathInRepo:pa(dirname(n)),pick:{skills:[a||basename(n)]}}}}catch{return {pathInRepo:pa(e)}}}}return {pathInRepo:pa(e)}}s(Ux,"resolveManualInstallPersistence");nn();nt();async function on(t){return process.stdin.isTTY?new Promise(e=>{let r=Kx.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 X0(t){return !!(t.skills.length||t.rules.length||t.commands.length||t.agents.length)}s(X0,"hasArrayResources");function Wx(t){return X0(t)||t.mcp!==null||t.permissions!==null||t.hooks!==null||t.ignore.length>0}s(Wx,"hasInstallableResources");async function Bx(t,e,r,n){let o=t.skills.map(c=>_x(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(Bx,"resolveSkillPool");async function Hx(t,e,r,n){let o=t.rules.map(c=>Ix(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(Hx,"resolveRulePool");async function zx(t,e,r,n){let o=t.commands.map(c=>Cx(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(zx,"resolveCommandPool");async function Vx(t,e,r,n){let o=t.agents.map(c=>Sx(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(Vx,"resolveAgentPool");async function Jx(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(Jx,"resolveInstallConflicts");function Yx(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(Yx,"pickForSelectedResources");function Z0(t,e){let r=t.split("/").filter(Boolean);return r.length>0&&r[r.length-1]===e}s(Z0,"pathEndsWithName");function $p(t,e,r){return r!==1||e.length!==1?false:Z0(t,e[0])}s($p,"inferSingleNamePick");function Xx(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||$p(e,o.skillNames,n.skills)),c=o.ruleSlugs.length>0&&(!!r?.rules?.length||o.ruleSlugs.length<n.rules||$p(e,o.ruleSlugs,n.rules)),l=o.commandNames.length>0&&(!!r?.commands?.length||o.commandNames.length<n.commands||$p(e,o.commandNames,n.commands)),m=o.agentNames.length>0&&(!!r?.agents?.length||o.agentNames.length<n.agents||$p(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(Xx,"buildInstallPick");function Zx(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(Zx,"deriveInstallFeatures");function q0(t){return t.skillNames.length===0&&t.ruleSlugs.length===0&&t.commandNames.length===0&&t.agentNames.length===0}s(q0,"isEmptyInstallSelection");function qx(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(q0(e)&&!a)throw new Error("No resources selected to install.")}s(qx,"ensureInstallSelection");ln();function Qx(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(Qx,"assertExtendNameAvailable");function Q0(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(Q0,"mergePick");function tP(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=Q0(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(tP,"mergeExtendList");A();async function eP(t,e,r){let n=await y(t);if(n===null)throw new Error(`Missing config: ${t}`);let o=parse(n),i=tP(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(CP,"TEMPLATE_CONSTANTS");function SP(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(LP,"TEMPLATE_GENERATOR_TEST");function bP(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(bP,"TEMPLATE_IMPORTER_TEST");function AP(t){return `# ${t.displayName} Workspace
|
|
539
|
-
|
|
540
|
-
Follow the ${t.displayName} configuration files and keep changes small.
|
|
541
|
-
`}s(AP,"TEMPLATE_FIXTURE_ROOT_MD");var KK=/^[a-z][a-z0-9-]*$/;async function xP(t){let{id:e,projectRoot:r,force:n=false}=t,o=t.displayName??e,i={id:e,displayName:o};if(!KK.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:CP(i)},{rel:`src/targets/${e}/index.ts`,content:SP(i)},{rel:`src/targets/${e}/generator.ts`,content:RP(i)},{rel:`src/targets/${e}/importer.ts`,content:kP(i)},{rel:`src/targets/${e}/linter.ts`,content:OP(i)},{rel:`src/targets/${e}/lint.ts`,content:wP(i)},{rel:`src/core/reference/import-maps/${e}.ts`,content:EP(i)},{rel:`tests/unit/targets/${e}/generator.test.ts`,content:LP(i)},{rel:`tests/unit/targets/${e}/importer.test.ts`,content:bP(i)},{rel:`tests/e2e/fixtures/${e}-project/AGENTS.md`,content:AP(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(xP,"writeTargetScaffold");async function TP(t,e,r){let n=e[0];return n===void 0||n===""?{exitCode:0,data:{id:"",written:[],skipped:[],postSteps:[]},showHelp:true}:n==="scaffold"?WK(t,e.slice(1),r):{exitCode:2,data:{id:"",written:[],skipped:[],postSteps:[]},showHelp:true,error:`Unknown target subcommand: ${n}`}}s(TP,"runTarget");async function WK(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 xP({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=>PP(c,r)),skipped:a.skipped.map(c=>PP(c,r)),postSteps:a.postSteps}}}s(WK,"runScaffold");function PP(t,e){return (t.startsWith(e)?t.slice(e.length+1):t).replaceAll("\\","/")}s(PP,"relativize");nt();function DP(t){if(t.error&&I.error(t.error),t.showHelp){BK();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(DP,"renderTarget");function BK(){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(BK,"printTargetHelp");ye();zo();A();le();Vn();ln();function qK(t,e){return t===".agentsmesh"?false:!!(t.startsWith(".")||!e)}s(qK,"shouldSymlink");function QK(t){let e=mkdtempSync(join(tmpdir(),"am-convert-")),r=readdirSync(t,{withFileTypes:true});for(let n of r){if(!qK(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(QK,"createTempProjectRoot");async function Up(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=QK(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(Up,"runConvert");nt();function NP(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(NP,"renderConvert");var tW=/(^|\s)\/[A-Za-z]|^[A-Z]:[\\/]/,G=class extends Error{static{s(this,"McpError");}code;details;constructor(e,r,n){if(tW.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 Zh(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(Zh,"safeWrite");var cW=/^---\r?\n([\s\S]*?)\r?\n---\r?\n\r?\n?([\s\S]*)$/;function $o(t){let e=cW.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 dW=/^[a-zA-Z0-9_][a-zA-Z0-9_/-]*$/,fW={rules:"_root"};function Kp(t){if(!dW.test(t)||t.includes("..")||t.includes("//")||t.endsWith("/"))throw new G("INVALID_NAME",`invalid name: ${t}`)}s(Kp,"checkName");function Wp(t,e,r){return resolve(t,".agentsmesh",e,`${r}.md`)}s(Wp,"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}){Kp(l);let m=Wp(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}){Kp(l);let f=r.safeParse(m);if(!f.success)throw new G("VALIDATION_FAILED","invalid frontmatter",f.error.issues);let g=Wp(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 Zh({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}){Kp(l);let g=Wp(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 Zh({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(Kp(l),fW[e]===l&&m!==true)throw new G("PROTECTED_FILE",`${e} "${l}" requires force: true`);let u=Wp(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 gW=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(),MP=ga({feature:"rules",frontmatterSchema:gW,toSummary:s((t,e)=>({name:t,description:e.description??null,root:!!e.root,globs:e.globs??null,targets:e.targets??null}),"toSummary")});var hW=z$1.object({description:z$1.string().optional(),"allowed-tools":z$1.array(z$1.string()).optional()}).passthrough(),$P=ga({feature:"commands",frontmatterSchema:hW,toSummary:s((t,e)=>({name:t,description:e.description??null,allowedTools:e["allowed-tools"]??null}),"toSummary")});var yW=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(),GP=ga({feature:"agents",frontmatterSchema:yW,toSummary:s((t,e)=>({name:t,description:e.description??null,tools:e.tools??null,model:e.model??null}),"toSummary")});async function UP(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(UP,"safeRead");var OW=/^[a-zA-Z0-9_][a-zA-Z0-9_-]*$/,wW=/^[a-zA-Z0-9_][a-zA-Z0-9_/-]*\.[a-zA-Z0-9]+$/,HP=z$1.object({name:z$1.string().optional(),description:z$1.string().optional()}).passthrough();function Zc(t){if(!OW.test(t))throw new G("INVALID_NAME",`invalid skill name: ${t}`)}s(Zc,"checkName");function ey(t){if(!wW.test(t)||t.includes("..")||t.includes("//"))throw new G("PATH_TRAVERSAL",`invalid supporting-file path: ${t}`)}s(ey,"checkSupportPath");async function zp(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(zp,"atomicWrite");var zP=s(t=>resolve(t,".agentsmesh/skills"),"skillsDir"),qc=s((t,e)=>resolve(zP(t),e),"skillDir"),Bs={async list(t){let e;try{e=(await readdir(zP(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}){Zc(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 Zc(e),ey(r),{content:await UP({projectRoot:t.projectRoot,skillName:e,filePath:r}),encoding:"utf-8"}},async create(t,e){Zc(e.name);let r=HP.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(ey),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 zp(c,fa(e.frontmatter,e.body));for(let[l,m]of Object.entries(i))await zp(resolve(n,l),m);return {path:n,written:true,supportingFilesWritten:a}},async update(t,e){Zc(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=HP.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(ey);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 zp(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 zp(f,u),l.push(p);}return {path:r,written:true,supportingFilesAffected:{written:l,deleted:m}}},async delete(t,{name:e,dry_run:r}){Zc(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 VP(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(VP,"safeConfigWrite");ln();ba();async function Qc(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(Qc,"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 Qc(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 Qc(resolve(t.projectRoot,".agentsmesh/permissions.yaml"))??null},async getHooks(t){return await Qc(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 Qc(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 VP({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})}};rh();ze();function TW(){return Object.fromEntries(it.map(t=>[t,Object.fromEntries(Object.entries(RA).map(([e,r])=>[e,r[t]]))]))}s(TW,"buildTargetIndex");var JP=TW(),oy={async list(){return JP},async get(t){let e=JP[t.targetId];if(e===void 0)throw new G("NOT_FOUND",`unknown target: ${t.targetId}`);return {targetId:t.targetId,capabilities:e}}};qn();qn();ol();le();nn();Vn();ye();ze();async function sy(t,e){let r=tt(t);if(!r)throw new cn(t,{supported:[...it,...Qm().map(n=>n.id)]});return r.generators.importFrom(e.root,{scope:e.scope??"project"})}s(sy,"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 iy(t){let e=t.targetFilter?[...t.targetFilter]:void 0;return xp(t.config,t.canonical,t.projectRoot,e,{scope:t.scope})}s(iy,"lint");async function ay(t){let e=await je(t);return {...bp(e),results:e}}s(ay,"diff");async function cy(t){return Pp(t)}s(cy,"check");qn();nn();zo();ol();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 iy({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 cy({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 ay({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 sy(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 Up(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 YP(t){let e=toJSONSchema(t,{target:"draft-07"});return delete e.$schema,e}s(YP,"zodToMcpSchema");var Yn=z$1.object({}).strict(),XP=z$1.object({name:z$1.string().describe('Item name (e.g. "auth", "code-review")')}),MW=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 ly(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:XP,handler:s((n,o)=>e.get(n,o),"handler"),resourceUri:`agentsmesh://canonical/${r}/{name}`},{name:`create_${t}`,description:`Create a new ${t}`,inputSchema:MW,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(ly,"canonicalTools");var Vp=[...ly("rule",MP),...ly("command",$P),...ly("agent",GP),{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:XP,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(()=>oy.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)=>oy.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")}],my=Vp.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 jW(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(jW,"findProjectRoot");async function py(t){let e=await jW(t.cwd);return {projectRoot:e,loadCanonical:s(()=>pe(e),"loadCanonical")}}s(py,"resolveContext");async function XW(){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(XW,"pkgVersion");function ZW(t,e){return new RegExp("^"+t.replace(/\{[^}]+\}/g,"([^/]+)")+"$").test(e)}s(ZW,"matchTemplate");function qW(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(qW,"extractTemplateParams");async function qP(){let t=new Server({name:"agentsmesh-mcp",version:await XW()},{capabilities:{tools:{},resources:{}}});t.setRequestHandler(ListToolsRequestSchema,async()=>({tools:Vp.map(e=>({name:e.name,description:e.description,inputSchema:YP(e.inputSchema)}))})),t.setRequestHandler(CallToolRequestSchema,async e=>{let r=Vp.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 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 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:my.map(e=>({uri:e.uri,name:e.name,description:e.description}))})),t.setRequestHandler(ReadResourceRequestSchema,async e=>{let r=my.find(a=>a.uri===e.params.uri||ZW(a.uri,e.params.uri));if(!r)throw new G("NOT_FOUND",`resource not found: ${e.params.uri}`);let n=await py({cwd:process.cwd()}),o=qW(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(qP,"startServer");nt();async function QP(t,e){_y(),await qP();}s(QP,"runMcp");var tT={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 $A(process.cwd(),{yes:t.yes===true,global:t.global===true});ce("init",r,t,()=>GA(r));},"init"),import:s(async(t,e)=>{let r=await UA(t);ce("import",r,t,()=>ZA(r));},"import"),diff:s(async(t,e)=>{let r=await WA(t);ce("diff",r,t,()=>qA(r));},"diff"),lint:s(async(t,e)=>{let r=await JA(t);ce("lint",r,t,()=>YA(r));},"lint"),check:s(async(t,e)=>{let r=await rx(t);ce("check",r,t,()=>XA(r));},"check"),merge:s(async(t,e)=>{let r=await sx(t);ce("merge",r,t,()=>QA(r));},"merge"),matrix:s(async(t,e)=>{let r=await $c(t);ce("matrix",r,t,()=>jc(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 ex(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 dP(t,e,process.cwd());ce("install",r,t,()=>fP(r));},"install"),plugin:s(async(t,e)=>{let r=await _P(t,e,process.cwd());ce("plugin",r,t,()=>IP(r));},"plugin"),target:s(async(t,e)=>{let r=await TP(t,e,process.cwd());ce("target",r,t,()=>DP(r));},"target"),convert:s(async(t,e)=>{let r=await Up(t);ce("convert",r,t,()=>NP(r));},"convert"),mcp:s(async(t,e)=>{await QP();},"mcp")};function eB(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(eB,"parseArgs");var rB=gy(tT);async function nB(t){let{command:e,flags:r,args:n}=t;if(e==="help"){Ry();return}if(e==="version"){wy();return}r.json===true&&yy(),await rB.route(e,r,n);}s(nB,"main");function oB(){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(oB,"isMainModule");if(oB()){let t=eB(process.argv.slice(2));nB(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};
|