oh-my-agent 9.7.0 → 9.8.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.
Files changed (2) hide show
  1. package/bin/cli.js +1 -1
  2. package/package.json +1 -1
package/bin/cli.js CHANGED
@@ -24,7 +24,7 @@ Expecting one of '${G.join("', '")}'`);if(this._lifeCycleHooks[$])this._lifeCycl
24
24
  `),this.outputHelp({error:!0});let G=z||{},J=G.exitCode||1,Q=G.code||"commander.error";this._exit(J,Q,$)}_parseOptionsEnv(){this.options.forEach(($)=>{if($.envVar&&$.envVar in u4.env){let z=$.attributeName();if(this.getOptionValue(z)===void 0||["default","config","env"].includes(this.getOptionValueSource(z)))if($.required||$.optional)this.emit(`optionEnv:${$.name()}`,u4.env[$.envVar]);else this.emit(`optionEnv:${$.name()}`)}})}_parseOptionsImplied(){let $=new yq5(this.options),z=(G)=>{return this.getOptionValue(G)!==void 0&&!["default","implied"].includes(this.getOptionValueSource(G))};this.options.filter((G)=>G.implied!==void 0&&z(G.attributeName())&&$.valueFromOption(this.getOptionValue(G.attributeName()),G)).forEach((G)=>{Object.keys(G.implied).filter((J)=>!z(J)).forEach((J)=>{this.setOptionValueWithSource(J,G.implied[J],"implied")})})}missingArgument($){let z=`error: missing required argument '${$}'`;this.error(z,{code:"commander.missingArgument"})}optionMissingArgument($){let z=`error: option '${$.flags}' argument missing`;this.error(z,{code:"commander.optionMissingArgument"})}missingMandatoryOptionValue($){let z=`error: required option '${$.flags}' not specified`;this.error(z,{code:"commander.missingMandatoryOptionValue"})}_conflictingOption($,z){let G=(K)=>{let Z=K.attributeName(),U=this.getOptionValue(Z),Y=this.options.find((B)=>B.negate&&Z===B.attributeName()),W=this.options.find((B)=>!B.negate&&Z===B.attributeName());if(Y&&(Y.presetArg===void 0&&U===!1||Y.presetArg!==void 0&&U===Y.presetArg))return Y;return W||K},J=(K)=>{let Z=G(K),U=Z.attributeName();if(this.getOptionValueSource(U)==="env")return`environment variable '${Z.envVar}'`;return`option '${Z.flags}'`},Q=`error: ${J($)} cannot be used with ${J(z)}`;this.error(Q,{code:"commander.conflictingOption"})}unknownOption($){if(this._allowUnknownOption)return;let z="";if($.startsWith("--")&&this._showSuggestionAfterError){let J=[],Q=this;do{let K=Q.createHelp().visibleOptions(Q).filter((Z)=>Z.long).map((Z)=>Z.long);J=J.concat(K),Q=Q.parent}while(Q&&!Q._enablePositionalOptions);z=mU2($,J)}let G=`error: unknown option '${$}'${z}`;this.error(G,{code:"commander.unknownOption"})}_excessArguments($){if(this._allowExcessArguments)return;let z=this.registeredArguments.length,G=z===1?"":"s",Q=`error: too many arguments${this.parent?` for '${this.name()}'`:""}. Expected ${z} argument${G} but got ${$.length}.`;this.error(Q,{code:"commander.excessArguments"})}unknownCommand(){let $=this.args[0],z="";if(this._showSuggestionAfterError){let J=[];this.createHelp().visibleCommands(this).forEach((Q)=>{if(J.push(Q.name()),Q.alias())J.push(Q.alias())}),z=mU2($,J)}let G=`error: unknown command '${$}'${z}`;this.error(G,{code:"commander.unknownCommand"})}version($,z,G){if($===void 0)return this._version;this._version=$,z=z||"-V, --version",G=G||"output the version number";let J=this.createOption(z,G);return this._versionOptionName=J.attributeName(),this._registerOption(J),this.on("option:"+J.name(),()=>{this._outputConfiguration.writeOut(`${$}
25
25
  `),this._exit(0,"commander.version",$)}),this}description($,z){if($===void 0&&z===void 0)return this._description;if(this._description=$,z)this._argsDescription=z;return this}summary($){if($===void 0)return this._summary;return this._summary=$,this}alias($){if($===void 0)return this._aliases[0];let z=this;if(this.commands.length!==0&&this.commands[this.commands.length-1]._executableHandler)z=this.commands[this.commands.length-1];if($===z._name)throw Error("Command alias can't be the same as its name");let G=this.parent?._findCommand($);if(G){let J=[G.name()].concat(G.aliases()).join("|");throw Error(`cannot add alias '${$}' to command '${this.name()}' as already have command '${J}'`)}return z._aliases.push($),this}aliases($){if($===void 0)return this._aliases;return $.forEach((z)=>this.alias(z)),this}usage($){if($===void 0){if(this._usage)return this._usage;let z=this.registeredArguments.map((G)=>{return Sq5(G)});return[].concat(this.options.length||this._helpOption!==null?"[options]":[],this.commands.length?"[command]":[],this.registeredArguments.length?z:[]).join(" ")}return this._usage=$,this}name($){if($===void 0)return this._name;return this._name=$,this}helpGroup($){if($===void 0)return this._helpGroupHeading??"";return this._helpGroupHeading=$,this}commandsGroup($){if($===void 0)return this._defaultCommandGroup??"";return this._defaultCommandGroup=$,this}optionsGroup($){if($===void 0)return this._defaultOptionGroup??"";return this._defaultOptionGroup=$,this}_initOptionGroup($){if(this._defaultOptionGroup&&!$.helpGroupHeading)$.helpGroup(this._defaultOptionGroup)}_initCommandGroup($){if(this._defaultCommandGroup&&!$.helpGroup())$.helpGroup(this._defaultCommandGroup)}nameFromFilename($){return this._name=cz.basename($,cz.extname($)),this}executableDir($){if($===void 0)return this._executableDir;return this._executableDir=$,this}helpInformation($){let z=this.createHelp(),G=this._getOutputContext($);z.prepareContext({error:G.error,helpWidth:G.helpWidth,outputHasColors:G.hasColors});let J=z.formatHelp(this,z);if(G.hasColors)return J;return this._outputConfiguration.stripColor(J)}_getOutputContext($){$=$||{};let z=!!$.error,G,J,Q;if(z)G=(Z)=>this._outputConfiguration.writeErr(Z),J=this._outputConfiguration.getErrHasColors(),Q=this._outputConfiguration.getErrHelpWidth();else G=(Z)=>this._outputConfiguration.writeOut(Z),J=this._outputConfiguration.getOutHasColors(),Q=this._outputConfiguration.getOutHelpWidth();return{error:z,write:(Z)=>{if(!J)Z=this._outputConfiguration.stripColor(Z);return G(Z)},hasColors:J,helpWidth:Q}}outputHelp($){let z;if(typeof $==="function")z=$,$=void 0;let G=this._getOutputContext($),J={error:G.error,write:G.write,command:this};this._getCommandAndAncestors().reverse().forEach((K)=>K.emit("beforeAllHelp",J)),this.emit("beforeHelp",J);let Q=this.helpInformation({error:G.error});if(z){if(Q=z(Q),typeof Q!=="string"&&!Buffer.isBuffer(Q))throw Error("outputHelp callback must return a string or a Buffer")}if(G.write(Q),this._getHelpOption()?.long)this.emit(this._getHelpOption().long);this.emit("afterHelp",J),this._getCommandAndAncestors().forEach((K)=>K.emit("afterAllHelp",J))}helpOption($,z){if(typeof $==="boolean"){if($){if(this._helpOption===null)this._helpOption=void 0;if(this._defaultOptionGroup)this._initOptionGroup(this._getHelpOption())}else this._helpOption=null;return this}if(this._helpOption=this.createOption($??"-h, --help",z??"display help for command"),$||z)this._initOptionGroup(this._helpOption);return this}_getHelpOption(){if(this._helpOption===void 0)this.helpOption(void 0,void 0);return this._helpOption}addHelpOption($){return this._helpOption=$,this._initOptionGroup($),this}help($){this.outputHelp($);let z=Number(u4.exitCode??0);if(z===0&&$&&typeof $!=="function"&&$.error)z=1;this._exit(z,"commander.help","(outputHelp)")}addHelpText($,z){let G=["beforeAll","before","after","afterAll"];if(!G.includes($))throw Error(`Unexpected value for position to addHelpText.
26
26
  Expecting one of '${G.join("', '")}'`);let J=`${$}Help`;return this.on(J,(Q)=>{let K;if(typeof z==="function")K=z({error:Q.error,command:Q.command});else K=z;if(K)Q.write(`${K}
27
- `)}),this}_outputHelpIfRequested($){let z=this._getHelpOption();if(z&&$.find((J)=>z.is(J)))this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)")}}function cU2($){return $.map((z)=>{if(!z.startsWith("--inspect"))return z;let G,J="127.0.0.1",Q="9229",K;if((K=z.match(/^(--inspect(-brk)?)$/))!==null)G=K[1];else if((K=z.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null)if(G=K[1],/^\d+$/.test(K[3]))Q=K[3];else J=K[3];else if((K=z.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null)G=K[1],J=K[3],Q=K[4];if(G&&Q!=="0")return`${G}=${J}:${parseInt(Q)+1}`;return z})}function Qf(){if(u4.env.NO_COLOR||u4.env.FORCE_COLOR==="0"||u4.env.FORCE_COLOR==="false")return!1;if(u4.env.FORCE_COLOR||u4.env.CLICOLOR_FORCE!==void 0)return!0;return}gq5.Command=Kf;gq5.useColor=Qf});var nU2=P((iq5)=>{var{Argument:lU2}=zR(),{Command:Zf}=iU2(),{CommanderError:mq5,InvalidArgumentError:pU2}=uq(),{Help:cq5}=$f(),{Option:dU2}=zf();iq5.program=new Zf;iq5.createCommand=($)=>new Zf($);iq5.createOption=($,z)=>new dU2($,z);iq5.createArgument=($,z)=>new lU2($,z);iq5.Command=Zf;iq5.Option=dU2;iq5.Argument=lU2;iq5.Help=cq5;iq5.CommanderError=mq5;iq5.InvalidArgumentError=pU2;iq5.InvalidOptionArgumentError=pU2});var aU2,Mi4,Oi4,Ii4,Ri4,Di4,vi4,Ei4,JR,wi4,Pi4,Ci4;var Uf=N(()=>{aU2=E2(nU2(),1),{program:Mi4,createCommand:Oi4,createArgument:Ii4,createOption:Ri4,CommanderError:Di4,InvalidArgumentError:vi4,InvalidOptionArgumentError:Ei4,Command:JR,Argument:wi4,Option:Pi4,Help:Ci4}=aU2.default});var QR;var Wf=N(()=>{QR={name:"oh-my-agent",version:"9.7.0",description:"Portable multi-agent harness for .agents-based skills and workflows across Antigravity, Claude Code, Codex, OpenCode, and more",type:"module",bin:{"oh-my-agent":"./bin/cli.js",oma:"./bin/cli.js"},files:["bin"],keywords:["oh-my-agent","antigravity",".agents","agent","skills","agent-skills","multi-agent","orchestrator","claude","claude-code","codex","opencode","copilot","cursor","chatgpt","pm","frontend","backend","mobile","qa","debug","terraform","database","workflow","bug-fixing","gemini"],author:"our.first.fluke <our.first.fluke@gmail.com>",contributors:["gracefullight <gracefullight.dev@gmail.com>","gahyun-git <go4it.gh@gmail.com>"],license:"MIT",funding:[{type:"github",url:"https://github.com/sponsors/first-fluke"},{type:"buymeacoffee",url:"https://buymeacoffee.com/firstfluke"}],scripts:{"sync:readme":"node ./scripts/sync-readme.mjs","generate:skill-data":"node ./scripts/generate-skill-data.mjs",build:"bun run generate:skill-data && bun run sync:readme && bun build cli.ts --outfile bin/cli.js --target node --minify --external @napi-rs/keyring",dev:"bun run generate:skill-data && bun run cli.ts",lint:"biome check .","lint:fix":"biome check --write --unsafe .","check:boundaries":"node ./scripts/check-boundaries.mjs",test:"vitest run","test:coverage":"vitest run --coverage",prepublishOnly:"bun run build"},dependencies:{"@clack/prompts":"^1.1.0","@date-fns/tz":"^1.4.1","@napi-rs/keyring":"^1.3.0",axios:"^1.15.0","better-sqlite3":"^12.9.0",chokidar:"^5.0.0",commander:"^14.0.3","date-fns":"^4.2.1",eld:"^2.0.3","fast-xml-parser":"^5",minimatch:"^10.2.5","p-map":"^7.0.4",picocolors:"^1.1.1","puppeteer-core":"^24",remark:"^15.0.1","remark-frontmatter":"^5.0.0","remark-parse":"^11.0.0","smol-toml":"^1.6.1",unified:"^11.0.5",ws:"^8.18.0",yaml:"^2.8.2",zod:"^4.3.6"},optionalDependencies:{pptxgenjs:"^3.12.0"},devDependencies:{"@biomejs/biome":"^2.4.15","@types/better-sqlite3":"^7.6.13","@types/mdast":"^4.0.4","@types/node":"^24","@types/ws":"^8.18.1","@vitest/coverage-v8":"^4.1.4",typescript:"^6",vitest:"^4.0.18"},repository:{type:"git",url:"https://github.com/first-fluke/oh-my-agent"},homepage:"https://firstfluke.com/oh-my-agent",bugs:{url:"https://github.com/first-fluke/oh-my-agent/issues"},antigravity:{skillsPath:".agents/skills",skills:["oma-architecture","oma-brainstorm","oma-coordination","oma-pm","oma-frontend","oma-backend","oma-db","oma-mobile","oma-qa","oma-debug","oma-orchestrator","oma-dev-workflow","oma-tf-infra","oma-scm","oma-pdf","oma-recap"]}}});import*as vY from"node:fs";import{homedir as GF5}from"node:os";import*as yq from"node:path";function rU2($){if(KR)throw Error("install context already set in this process");KR=$}function sU2(){if(KR===null)throw Error("install context not set — entry point must call setInstallContext()");return KR}function EY(){return sU2().installRoot}function I7(){return sU2().mode}function tU2($){let z=process.env.OMA_HOME,G=$.global===!0||process.env.OMA_INSTALL_GLOBAL==="1";if(z!==void 0&&z!=="")return JF5(z),{installRoot:z,mode:G?"global":"project"};if(G)return{installRoot:GF5(),mode:"global"};return{installRoot:process.cwd(),mode:"project"}}function JF5($){if(!yq.isAbsolute($))throw Error("OMA_HOME must be absolute path");for(let G of oU2)if($===G||$.startsWith(G+yq.sep))throw Error(`OMA_HOME=${$} is forbidden (system path ${G})`);let z;try{z=vY.realpathSync($)}catch(G){let J=G instanceof Error?G.message:String(G);throw Error(`OMA_HOME=${$}: ${J}`)}for(let G of oU2)if(z===G||z.startsWith(G+yq.sep))throw Error(`OMA_HOME=${z} is forbidden (system path ${G})`);try{vY.accessSync(z,vY.constants.W_OK)}catch{throw Error(`OMA_HOME=${z} is not writable`)}}var KR=null,oU2;var MJ=N(()=>{oU2=["/etc","/usr","/bin","/boot","/sys","/proc"]});import{join as QF5}from"node:path";function gq($){return $.endsWith("/")?$:`${$}/`}function R7($,z){let G=z.split("/").filter((J)=>J.length>0);return QF5($,...G)}var j0=".agents",ZR,D3,OJ,eU2,$W2,UR,KF5=".antigravitycli",zW2,ZF5=".migration-backup",UF5,WF5,YF5,BF5,VF5,Yf;var v3=N(()=>{ZR=`${j0}/skills`,D3=`${j0}/results`,OJ=`${j0}/state`,eU2=`${OJ}/sessions`,$W2=`${OJ}/retry`,UR=`${OJ}/archive`,zW2=`${j0}/backup`;UF5=gq(D3),WF5=gq(OJ),YF5=gq(KF5),BF5=gq(zW2),VF5=gq(ZF5),Yf=[YF5,UF5,WF5,BF5,VF5]});var y1="first-fluke/oh-my-agent",e4,iz,WR,XF5,lz,r1;var pz=N(()=>{v3();e4=ZR,iz=["antigravity","claude","codex","commandcode","cursor","gemini","grok","kiro","qwen"],WR=["pi","opencode"],XF5=["copilot","hermes"],lz=[...iz,...XF5].sort(),r1={antigravity:{projectPath:".gemini/antigravity-cli/skills",homePath:".gemini/antigravity-cli/skills",requiresHomeConsent:!0},claude:{projectPath:".claude/skills",homePath:".claude/skills"},codex:{projectPath:".codex/skills",homePath:".codex/skills"},commandcode:{projectPath:".commandcode/skills",homePath:".commandcode/skills",optIn:!0},copilot:{projectPath:".github/skills",homePath:".copilot/skills"},cursor:{projectPath:".cursor/skills",homePath:".cursor/skills"},gemini:{projectPath:".gemini/skills",homePath:".gemini/skills"},hermes:{projectPath:".hermes/skills/oma",homePath:".hermes/skills/oma",requiresHomeConsent:!0},kiro:{projectPath:".kiro/skills",homePath:".kiro/skills",optIn:!0},opencode:{projectPath:".opencode/skills",homePath:".opencode/skills"},qwen:{projectPath:".qwen/skills",homePath:".qwen/skills"}}});var WW2={};z5(WW2,{runAction:()=>T2,resolveJsonMode:()=>A5,printDescribe:()=>DF5,addOutputOptions:()=>j5});function j5($,z="Output as JSON"){return $.option("--json",z).option("--output <format>","Output format (text/json)",(G)=>{let J=G.trim().toLowerCase();if(!hq.includes(J))throw Error(`Invalid output format: ${G}. Expected one of ${hq.join(", ")}`);return J})}function LF5($){if($?.json)return"json";let z=$?.output?.trim().toLowerCase();if(z&&hq.includes(z))return z;if(process.env[QW2]?.trim().toLowerCase()==="json")return"json";return"text"}function A5($){return LF5($)==="json"}function KW2($){let z=$.at(-1);return z instanceof JR?z:null}function HF5($){let z=KW2($);if(z)return z.opts();let G=$.at(-1);return G&&typeof G==="object"?G:{}}function qF5($){if($ instanceof Error)return $.message;return String($)}function IJ($){throw Error($)}function Vf($,z){for(let G of $){let J=G.charCodeAt(0);if(J>=0&&J<=31||J===127)IJ(`${z} must not contain control characters`)}}function FF5($,z){if(Vf($,z),/[?#%]/.test($))IJ(`${z} must not contain ?, #, or %`);if($.includes(".."))IJ(`${z} must not contain '..'`)}function kF5($,z){Vf($,z);try{new URL($)}catch{IJ(`${z} must be a valid absolute URL`)}}function Bf($,z,G="text"){if(typeof $==="string"){if(G==="identifier"){FF5($,z);return}if(G==="url"){kF5($,z);return}Vf($,z);return}if(Array.isArray($))for(let[J,Q]of $.entries())Bf(Q,`${z}[${J}]`,G)}function JW2($){let z=$.toLowerCase();if(z==="url"||z.endsWith("url"))return"url";if(z.includes("id")||z.includes("type")||z.includes("vendor")||z.includes("session"))return"identifier";return"text"}function NF5($){let z=$.vendor;if(typeof z==="string"){if(z.split(",").map((K)=>K.trim()).filter(Boolean).filter((K)=>!lz.includes(K)).length>0)IJ(`vendor must be one of ${lz.join(", ")}`)}let G=$.output;if(typeof G==="string"&&!hq.includes(G))IJ(`output must be one of ${hq.join(", ")}`)}function AF5($){let z=$.processedArgs??$.args??[];($.registeredArguments??[]).forEach((Q,K)=>{let Z=Q.name?.()||String(K),U=z[K];if(Bf(U,Z,JW2(Z)),Z==="agent-type"&&typeof U==="string"&&!GW2.includes(U))IJ(`agent-type must be one of ${GW2.join(", ")}`)});let J=$.opts();NF5(J);for(let[Q,K]of Object.entries(J))Bf(K,Q,JW2(Q))}function jF5($){return($.registeredArguments??[]).map((z)=>({name:z.name?.()||"",required:!!z.required,variadic:!!z.variadic}))}function MF5($){return $.options.map((z)=>({flags:z.flags,long:z.long||void 0,short:z.short||void 0,description:z.description||"",required:!!z.required||!!z.mandatory,optional:!!z.optional,defaultValue:z.defaultValue}))}function ZW2($){let z=[],G=$;while(G?.parent)z.unshift(G.name()),G=G.parent;return z.join(" ")}function OF5($){return $.options.some((z)=>z.long==="--json"||z.long==="--output")}function IF5($){return $.options.some((z)=>z.long==="--dry-run")}function UW2($){return{name:$.name(),path:ZW2($),summary:$.summary()||void 0,description:$.description(),arguments:jF5($),options:MF5($),supportsJsonOutput:OF5($),supportsDryRun:IF5($),subcommands:$.commands.map((z)=>UW2(z))}}function RF5($,z){if(!z?.trim())return $;let G=z.trim(),J=[...$.commands];while(J.length>0){let Q=J.shift();if(!Q)continue;if(Q.name()===G||ZW2(Q)===G)return Q;J.push(...Q.commands)}return null}function DF5($,z){let G=RF5($,z);if(!G)IJ(`Unknown command: ${z}`);let J={name:$.name(),version:$.version(),description:$.description(),env:{[QW2]:"Set to json to force machine-readable output on commands that support it."},command:UW2(G)};console.log(JSON.stringify(J,null,2))}function T2($,z={}){return async(...G)=>{let J=KW2(G);if(J&&G.length>=2)G[G.length-2]=J.optsWithGlobals();let Q=HF5(G);try{if(J)AF5(J);await $(...G)}catch(K){let Z=qF5(K);if(z.supportsJsonOutput&&A5(Q))console.log(JSON.stringify({error:Z},null,2));else console.error(Z);process.exitCode=1}}}var QW2="OH_MY_AG_OUTPUT_FORMAT",hq,GW2;var a4=N(()=>{Uf();pz();hq=["text","json"],GW2=["backend","frontend","mobile","qa","debug","pm"]});var YW2,BW2=($)=>{return $===12288||$>=65281&&$<=65376||$>=65504&&$<=65510},VW2=($)=>{return $===8987||$===9001||$>=12272&&$<=12287||$>=12289&&$<=12350||$>=12441&&$<=12543||$>=12549&&$<=12591||$>=12593&&$<=12686||$>=12688&&$<=12771||$>=12783&&$<=12830||$>=12832&&$<=12871||$>=12880&&$<=19903||$>=65040&&$<=65049||$>=65072&&$<=65106||$>=65108&&$<=65126||$>=65128&&$<=65131||$>=127488&&$<=127490||$>=127504&&$<=127547||$>=127552&&$<=127560||$>=131072&&$<=196605||$>=196608&&$<=262141};var XW2=N(()=>{YW2=(()=>{let $=/[\uD800-\uDBFF][\uDC00-\uDFFF]/g;return(z)=>{let G=0;$.lastIndex=0;while($.test(z))G+=1;return z.length-G}})()});var vF5,EF5,LW2,wF5,HW2,PF5,CF5,TF5,qW2=($,z={},G={})=>{let J=z.limit??1/0,Q=z.ellipsis??"",K=z?.ellipsisWidth??(Q?qW2(Q,TF5,G).width:0),Z=0,U=G.controlWidth??0,Y=G.tabWidth??8,W=G.emojiWidth??2,B=2,V=G.regularWidth??1,L=G.wideWidth??2,X=[[PF5,V],[vF5,0],[EF5,U],[wF5,Y],[HW2,W],[LW2,L]],H=0,q=0,F=$.length,k=0,A=!1,j=F,M=Math.max(0,J-K),O=0,I=0,D=0,R=0;$:while(!0){if(I>O||q>=F&&q>H){let E=$.slice(O,I)||$.slice(H,q);k=0;for(let b of E.replaceAll(CF5,"")){let _=b.codePointAt(0)||0;if(BW2(_))R=2;else if(VW2(_))R=L;else R=V;if(D+R>M)j=Math.min(j,Math.max(O,H)+k);if(D+R>J){A=!0;break $}k+=b.length,D+=R}O=I=0}if(q>=F)break $;for(let E=0,b=X.length;E<b;E++){let[_,h]=X[E];if(_.lastIndex=q,_.test($)){if(k=_===LW2?YW2($.slice(q,_.lastIndex)):_===HW2?1:_.lastIndex-q,R=k*h,D+R>M)j=Math.min(j,q+Math.floor((M-D)/h));if(D+R>J){A=!0;break $}D+=R,O=H,I=q,q=H=_.lastIndex;continue $}}q+=1}return{width:A?M:D,index:A?j:F,truncated:A,ellipsed:A&&J>=K}},FW2;var kW2=N(()=>{XW2();vF5=/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]|\u001b\]8;[^;]*;.*?(?:\u0007|\u001b\u005c)/y,EF5=/[\x00-\x08\x0A-\x1F\x7F-\x9F]{1,1000}/y,LW2=/(?:(?![\uFF61-\uFF9F\uFF00-\uFFEF])[\p{Script=Han}\p{Script=Hiragana}\p{Script=Katakana}\p{Script=Hangul}\p{Script=Tangut}]){1,1000}/yu,wF5=/\t{1,1000}/y,HW2=/[\u{1F1E6}-\u{1F1FF}]{2}|\u{1F3F4}[\u{E0061}-\u{E007A}]{2}[\u{E0030}-\u{E0039}\u{E0061}-\u{E007A}]{1,3}\u{E007F}|(?:\p{Emoji}\uFE0F\u20E3?|\p{Emoji_Modifier_Base}\p{Emoji_Modifier}?|\p{Emoji_Presentation})(?:\u200D(?:\p{Emoji_Modifier_Base}\p{Emoji_Modifier}?|\p{Emoji_Presentation}|\p{Emoji}\uFE0F\u20E3?))*/yu,PF5=/(?:[\x20-\x7E\xA0-\xFF](?!\uFE0F)){1,1000}/y,CF5=/\p{M}+/gu,TF5={limit:1/0,ellipsis:""},FW2=qW2});var bF5,_F5=($,z={})=>{return FW2($,bF5,z).width},O6;var Xf=N(()=>{kW2();bF5={limit:1/0,ellipsis:"",ellipsisWidth:0},O6=_F5});function I$($,z,G){return String($).normalize().split(gF5).map((J)=>yF5(J,z,G)).join(`
27
+ `)}),this}_outputHelpIfRequested($){let z=this._getHelpOption();if(z&&$.find((J)=>z.is(J)))this.outputHelp(),this._exit(0,"commander.helpDisplayed","(outputHelp)")}}function cU2($){return $.map((z)=>{if(!z.startsWith("--inspect"))return z;let G,J="127.0.0.1",Q="9229",K;if((K=z.match(/^(--inspect(-brk)?)$/))!==null)G=K[1];else if((K=z.match(/^(--inspect(-brk|-port)?)=([^:]+)$/))!==null)if(G=K[1],/^\d+$/.test(K[3]))Q=K[3];else J=K[3];else if((K=z.match(/^(--inspect(-brk|-port)?)=([^:]+):(\d+)$/))!==null)G=K[1],J=K[3],Q=K[4];if(G&&Q!=="0")return`${G}=${J}:${parseInt(Q)+1}`;return z})}function Qf(){if(u4.env.NO_COLOR||u4.env.FORCE_COLOR==="0"||u4.env.FORCE_COLOR==="false")return!1;if(u4.env.FORCE_COLOR||u4.env.CLICOLOR_FORCE!==void 0)return!0;return}gq5.Command=Kf;gq5.useColor=Qf});var nU2=P((iq5)=>{var{Argument:lU2}=zR(),{Command:Zf}=iU2(),{CommanderError:mq5,InvalidArgumentError:pU2}=uq(),{Help:cq5}=$f(),{Option:dU2}=zf();iq5.program=new Zf;iq5.createCommand=($)=>new Zf($);iq5.createOption=($,z)=>new dU2($,z);iq5.createArgument=($,z)=>new lU2($,z);iq5.Command=Zf;iq5.Option=dU2;iq5.Argument=lU2;iq5.Help=cq5;iq5.CommanderError=mq5;iq5.InvalidArgumentError=pU2;iq5.InvalidOptionArgumentError=pU2});var aU2,Mi4,Oi4,Ii4,Ri4,Di4,vi4,Ei4,JR,wi4,Pi4,Ci4;var Uf=N(()=>{aU2=E2(nU2(),1),{program:Mi4,createCommand:Oi4,createArgument:Ii4,createOption:Ri4,CommanderError:Di4,InvalidArgumentError:vi4,InvalidOptionArgumentError:Ei4,Command:JR,Argument:wi4,Option:Pi4,Help:Ci4}=aU2.default});var QR;var Wf=N(()=>{QR={name:"oh-my-agent",version:"9.8.0",description:"Portable multi-agent harness for .agents-based skills and workflows across Antigravity, Claude Code, Codex, OpenCode, and more",type:"module",bin:{"oh-my-agent":"./bin/cli.js",oma:"./bin/cli.js"},files:["bin"],keywords:["oh-my-agent","antigravity",".agents","agent","skills","agent-skills","multi-agent","orchestrator","claude","claude-code","codex","opencode","copilot","cursor","chatgpt","pm","frontend","backend","mobile","qa","debug","terraform","database","workflow","bug-fixing","gemini"],author:"our.first.fluke <our.first.fluke@gmail.com>",contributors:["gracefullight <gracefullight.dev@gmail.com>","gahyun-git <go4it.gh@gmail.com>"],license:"MIT",funding:[{type:"github",url:"https://github.com/sponsors/first-fluke"},{type:"buymeacoffee",url:"https://buymeacoffee.com/firstfluke"}],scripts:{"sync:readme":"node ./scripts/sync-readme.mjs","generate:skill-data":"node ./scripts/generate-skill-data.mjs",build:"bun run generate:skill-data && bun run sync:readme && bun build cli.ts --outfile bin/cli.js --target node --minify --external @napi-rs/keyring",dev:"bun run generate:skill-data && bun run cli.ts",lint:"biome check .","lint:fix":"biome check --write --unsafe .","check:boundaries":"node ./scripts/check-boundaries.mjs",test:"vitest run","test:coverage":"vitest run --coverage",prepublishOnly:"bun run build"},dependencies:{"@clack/prompts":"^1.1.0","@date-fns/tz":"^1.4.1","@napi-rs/keyring":"^1.3.0",axios:"^1.15.0","better-sqlite3":"^12.9.0",chokidar:"^5.0.0",commander:"^14.0.3","date-fns":"^4.2.1",eld:"^2.0.3","fast-xml-parser":"^5",minimatch:"^10.2.5","p-map":"^7.0.4",picocolors:"^1.1.1","puppeteer-core":"^24",remark:"^15.0.1","remark-frontmatter":"^5.0.0","remark-parse":"^11.0.0","smol-toml":"^1.6.1",unified:"^11.0.5",ws:"^8.18.0",yaml:"^2.8.2",zod:"^4.3.6"},optionalDependencies:{pptxgenjs:"^3.12.0"},devDependencies:{"@biomejs/biome":"^2.4.15","@types/better-sqlite3":"^7.6.13","@types/mdast":"^4.0.4","@types/node":"^24","@types/ws":"^8.18.1","@vitest/coverage-v8":"^4.1.4",typescript:"^6",vitest:"^4.0.18"},repository:{type:"git",url:"https://github.com/first-fluke/oh-my-agent"},homepage:"https://firstfluke.com/oh-my-agent",bugs:{url:"https://github.com/first-fluke/oh-my-agent/issues"},antigravity:{skillsPath:".agents/skills",skills:["oma-architecture","oma-brainstorm","oma-coordination","oma-pm","oma-frontend","oma-backend","oma-db","oma-mobile","oma-qa","oma-debug","oma-orchestrator","oma-dev-workflow","oma-tf-infra","oma-scm","oma-pdf","oma-recap"]}}});import*as vY from"node:fs";import{homedir as GF5}from"node:os";import*as yq from"node:path";function rU2($){if(KR)throw Error("install context already set in this process");KR=$}function sU2(){if(KR===null)throw Error("install context not set — entry point must call setInstallContext()");return KR}function EY(){return sU2().installRoot}function I7(){return sU2().mode}function tU2($){let z=process.env.OMA_HOME,G=$.global===!0||process.env.OMA_INSTALL_GLOBAL==="1";if(z!==void 0&&z!=="")return JF5(z),{installRoot:z,mode:G?"global":"project"};if(G)return{installRoot:GF5(),mode:"global"};return{installRoot:process.cwd(),mode:"project"}}function JF5($){if(!yq.isAbsolute($))throw Error("OMA_HOME must be absolute path");for(let G of oU2)if($===G||$.startsWith(G+yq.sep))throw Error(`OMA_HOME=${$} is forbidden (system path ${G})`);let z;try{z=vY.realpathSync($)}catch(G){let J=G instanceof Error?G.message:String(G);throw Error(`OMA_HOME=${$}: ${J}`)}for(let G of oU2)if(z===G||z.startsWith(G+yq.sep))throw Error(`OMA_HOME=${z} is forbidden (system path ${G})`);try{vY.accessSync(z,vY.constants.W_OK)}catch{throw Error(`OMA_HOME=${z} is not writable`)}}var KR=null,oU2;var MJ=N(()=>{oU2=["/etc","/usr","/bin","/boot","/sys","/proc"]});import{join as QF5}from"node:path";function gq($){return $.endsWith("/")?$:`${$}/`}function R7($,z){let G=z.split("/").filter((J)=>J.length>0);return QF5($,...G)}var j0=".agents",ZR,D3,OJ,eU2,$W2,UR,KF5=".antigravitycli",zW2,ZF5=".migration-backup",UF5,WF5,YF5,BF5,VF5,Yf;var v3=N(()=>{ZR=`${j0}/skills`,D3=`${j0}/results`,OJ=`${j0}/state`,eU2=`${OJ}/sessions`,$W2=`${OJ}/retry`,UR=`${OJ}/archive`,zW2=`${j0}/backup`;UF5=gq(D3),WF5=gq(OJ),YF5=gq(KF5),BF5=gq(zW2),VF5=gq(ZF5),Yf=[YF5,UF5,WF5,BF5,VF5]});var y1="first-fluke/oh-my-agent",e4,iz,WR,XF5,lz,r1;var pz=N(()=>{v3();e4=ZR,iz=["antigravity","claude","codex","commandcode","cursor","gemini","grok","kiro","qwen"],WR=["pi","opencode"],XF5=["copilot","hermes"],lz=[...iz,...XF5].sort(),r1={antigravity:{projectPath:".gemini/antigravity-cli/skills",homePath:".gemini/antigravity-cli/skills",requiresHomeConsent:!0},claude:{projectPath:".claude/skills",homePath:".claude/skills"},codex:{projectPath:".codex/skills",homePath:".codex/skills"},commandcode:{projectPath:".commandcode/skills",homePath:".commandcode/skills",optIn:!0},copilot:{projectPath:".github/skills",homePath:".copilot/skills"},cursor:{projectPath:".cursor/skills",homePath:".cursor/skills"},gemini:{projectPath:".gemini/skills",homePath:".gemini/skills"},hermes:{projectPath:".hermes/skills/oma",homePath:".hermes/skills/oma",requiresHomeConsent:!0},kiro:{projectPath:".kiro/skills",homePath:".kiro/skills",optIn:!0},opencode:{projectPath:".opencode/skills",homePath:".opencode/skills"},qwen:{projectPath:".qwen/skills",homePath:".qwen/skills"}}});var WW2={};z5(WW2,{runAction:()=>T2,resolveJsonMode:()=>A5,printDescribe:()=>DF5,addOutputOptions:()=>j5});function j5($,z="Output as JSON"){return $.option("--json",z).option("--output <format>","Output format (text/json)",(G)=>{let J=G.trim().toLowerCase();if(!hq.includes(J))throw Error(`Invalid output format: ${G}. Expected one of ${hq.join(", ")}`);return J})}function LF5($){if($?.json)return"json";let z=$?.output?.trim().toLowerCase();if(z&&hq.includes(z))return z;if(process.env[QW2]?.trim().toLowerCase()==="json")return"json";return"text"}function A5($){return LF5($)==="json"}function KW2($){let z=$.at(-1);return z instanceof JR?z:null}function HF5($){let z=KW2($);if(z)return z.opts();let G=$.at(-1);return G&&typeof G==="object"?G:{}}function qF5($){if($ instanceof Error)return $.message;return String($)}function IJ($){throw Error($)}function Vf($,z){for(let G of $){let J=G.charCodeAt(0);if(J>=0&&J<=31||J===127)IJ(`${z} must not contain control characters`)}}function FF5($,z){if(Vf($,z),/[?#%]/.test($))IJ(`${z} must not contain ?, #, or %`);if($.includes(".."))IJ(`${z} must not contain '..'`)}function kF5($,z){Vf($,z);try{new URL($)}catch{IJ(`${z} must be a valid absolute URL`)}}function Bf($,z,G="text"){if(typeof $==="string"){if(G==="identifier"){FF5($,z);return}if(G==="url"){kF5($,z);return}Vf($,z);return}if(Array.isArray($))for(let[J,Q]of $.entries())Bf(Q,`${z}[${J}]`,G)}function JW2($){let z=$.toLowerCase();if(z==="url"||z.endsWith("url"))return"url";if(z.includes("id")||z.includes("type")||z.includes("vendor")||z.includes("session"))return"identifier";return"text"}function NF5($){let z=$.vendor;if(typeof z==="string"){if(z.split(",").map((K)=>K.trim()).filter(Boolean).filter((K)=>!lz.includes(K)).length>0)IJ(`vendor must be one of ${lz.join(", ")}`)}let G=$.output;if(typeof G==="string"&&!hq.includes(G))IJ(`output must be one of ${hq.join(", ")}`)}function AF5($){let z=$.processedArgs??$.args??[];($.registeredArguments??[]).forEach((Q,K)=>{let Z=Q.name?.()||String(K),U=z[K];if(Bf(U,Z,JW2(Z)),Z==="agent-type"&&typeof U==="string"&&!GW2.includes(U))IJ(`agent-type must be one of ${GW2.join(", ")}`)});let J=$.opts();NF5(J);for(let[Q,K]of Object.entries(J))Bf(K,Q,JW2(Q))}function jF5($){return($.registeredArguments??[]).map((z)=>({name:z.name?.()||"",required:!!z.required,variadic:!!z.variadic}))}function MF5($){return $.options.map((z)=>({flags:z.flags,long:z.long||void 0,short:z.short||void 0,description:z.description||"",required:!!z.required||!!z.mandatory,optional:!!z.optional,defaultValue:z.defaultValue}))}function ZW2($){let z=[],G=$;while(G?.parent)z.unshift(G.name()),G=G.parent;return z.join(" ")}function OF5($){return $.options.some((z)=>z.long==="--json"||z.long==="--output")}function IF5($){return $.options.some((z)=>z.long==="--dry-run")}function UW2($){return{name:$.name(),path:ZW2($),summary:$.summary()||void 0,description:$.description(),arguments:jF5($),options:MF5($),supportsJsonOutput:OF5($),supportsDryRun:IF5($),subcommands:$.commands.map((z)=>UW2(z))}}function RF5($,z){if(!z?.trim())return $;let G=z.trim(),J=[...$.commands];while(J.length>0){let Q=J.shift();if(!Q)continue;if(Q.name()===G||ZW2(Q)===G)return Q;J.push(...Q.commands)}return null}function DF5($,z){let G=RF5($,z);if(!G)IJ(`Unknown command: ${z}`);let J={name:$.name(),version:$.version(),description:$.description(),env:{[QW2]:"Set to json to force machine-readable output on commands that support it."},command:UW2(G)};console.log(JSON.stringify(J,null,2))}function T2($,z={}){return async(...G)=>{let J=KW2(G);if(J&&G.length>=2)G[G.length-2]=J.optsWithGlobals();let Q=HF5(G);try{if(J)AF5(J);await $(...G)}catch(K){let Z=qF5(K);if(z.supportsJsonOutput&&A5(Q))console.log(JSON.stringify({error:Z},null,2));else console.error(Z);process.exitCode=1}}}var QW2="OH_MY_AG_OUTPUT_FORMAT",hq,GW2;var a4=N(()=>{Uf();pz();hq=["text","json"],GW2=["backend","frontend","mobile","qa","debug","pm"]});var YW2,BW2=($)=>{return $===12288||$>=65281&&$<=65376||$>=65504&&$<=65510},VW2=($)=>{return $===8987||$===9001||$>=12272&&$<=12287||$>=12289&&$<=12350||$>=12441&&$<=12543||$>=12549&&$<=12591||$>=12593&&$<=12686||$>=12688&&$<=12771||$>=12783&&$<=12830||$>=12832&&$<=12871||$>=12880&&$<=19903||$>=65040&&$<=65049||$>=65072&&$<=65106||$>=65108&&$<=65126||$>=65128&&$<=65131||$>=127488&&$<=127490||$>=127504&&$<=127547||$>=127552&&$<=127560||$>=131072&&$<=196605||$>=196608&&$<=262141};var XW2=N(()=>{YW2=(()=>{let $=/[\uD800-\uDBFF][\uDC00-\uDFFF]/g;return(z)=>{let G=0;$.lastIndex=0;while($.test(z))G+=1;return z.length-G}})()});var vF5,EF5,LW2,wF5,HW2,PF5,CF5,TF5,qW2=($,z={},G={})=>{let J=z.limit??1/0,Q=z.ellipsis??"",K=z?.ellipsisWidth??(Q?qW2(Q,TF5,G).width:0),Z=0,U=G.controlWidth??0,Y=G.tabWidth??8,W=G.emojiWidth??2,B=2,V=G.regularWidth??1,L=G.wideWidth??2,X=[[PF5,V],[vF5,0],[EF5,U],[wF5,Y],[HW2,W],[LW2,L]],H=0,q=0,F=$.length,k=0,A=!1,j=F,M=Math.max(0,J-K),O=0,I=0,D=0,R=0;$:while(!0){if(I>O||q>=F&&q>H){let E=$.slice(O,I)||$.slice(H,q);k=0;for(let b of E.replaceAll(CF5,"")){let _=b.codePointAt(0)||0;if(BW2(_))R=2;else if(VW2(_))R=L;else R=V;if(D+R>M)j=Math.min(j,Math.max(O,H)+k);if(D+R>J){A=!0;break $}k+=b.length,D+=R}O=I=0}if(q>=F)break $;for(let E=0,b=X.length;E<b;E++){let[_,h]=X[E];if(_.lastIndex=q,_.test($)){if(k=_===LW2?YW2($.slice(q,_.lastIndex)):_===HW2?1:_.lastIndex-q,R=k*h,D+R>M)j=Math.min(j,q+Math.floor((M-D)/h));if(D+R>J){A=!0;break $}D+=R,O=H,I=q,q=H=_.lastIndex;continue $}}q+=1}return{width:A?M:D,index:A?j:F,truncated:A,ellipsed:A&&J>=K}},FW2;var kW2=N(()=>{XW2();vF5=/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]|\u001b\]8;[^;]*;.*?(?:\u0007|\u001b\u005c)/y,EF5=/[\x00-\x08\x0A-\x1F\x7F-\x9F]{1,1000}/y,LW2=/(?:(?![\uFF61-\uFF9F\uFF00-\uFFEF])[\p{Script=Han}\p{Script=Hiragana}\p{Script=Katakana}\p{Script=Hangul}\p{Script=Tangut}]){1,1000}/yu,wF5=/\t{1,1000}/y,HW2=/[\u{1F1E6}-\u{1F1FF}]{2}|\u{1F3F4}[\u{E0061}-\u{E007A}]{2}[\u{E0030}-\u{E0039}\u{E0061}-\u{E007A}]{1,3}\u{E007F}|(?:\p{Emoji}\uFE0F\u20E3?|\p{Emoji_Modifier_Base}\p{Emoji_Modifier}?|\p{Emoji_Presentation})(?:\u200D(?:\p{Emoji_Modifier_Base}\p{Emoji_Modifier}?|\p{Emoji_Presentation}|\p{Emoji}\uFE0F\u20E3?))*/yu,PF5=/(?:[\x20-\x7E\xA0-\xFF](?!\uFE0F)){1,1000}/y,CF5=/\p{M}+/gu,TF5={limit:1/0,ellipsis:""},FW2=qW2});var bF5,_F5=($,z={})=>{return FW2($,bF5,z).width},O6;var Xf=N(()=>{kW2();bF5={limit:1/0,ellipsis:"",ellipsisWidth:0},O6=_F5});function I$($,z,G){return String($).normalize().split(gF5).map((J)=>yF5(J,z,G)).join(`
28
28
  `)}var YR="\x1B",OW2="›",SF5=39,Hf="\x07",IW2="[",xF5="]",RW2="m",qf,NW2,AW2=($)=>{if($>=30&&$<=37)return 39;if($>=90&&$<=97)return 39;if($>=40&&$<=47)return 49;if($>=100&&$<=107)return 49;if($===1||$===2)return 22;if($===3)return 23;if($===4)return 24;if($===7)return 27;if($===8)return 28;if($===9)return 29;if($===0)return 0;return},jW2=($)=>`${YR}${IW2}${$}${RW2}`,MW2=($)=>`${YR}${qf}${$}${Hf}`,Lf=($,z,G)=>{let J=z[Symbol.iterator](),Q=!1,K=!1,Z=$.at(-1),U=Z===void 0?0:O6(Z),Y=J.next(),W=J.next(),B=0;while(!Y.done){let V=Y.value,L=O6(V);if(U+L<=G)$[$.length-1]+=V;else $.push(V),U=0;if(V===YR||V===OW2)Q=!0,K=z.startsWith(qf,B+1);if(Q){if(K){if(V===Hf)Q=!1,K=!1}else if(V===RW2)Q=!1}else if(U+=L,U===G&&!W.done)$.push(""),U=0;Y=W,W=J.next(),B+=V.length}if(Z=$.at(-1),!U&&Z!==void 0&&Z.length&&$.length>1)$[$.length-2]+=$.pop()},uF5=($)=>{let z=$.split(" "),G=z.length;while(G){if(O6(z[G-1]))break;G--}if(G===z.length)return $;return z.slice(0,G).join(" ")+z.slice(G).join("")},yF5=($,z,G={})=>{if(G.trim!==!1&&$.trim()==="")return"";let J="",Q,K,Z=$.split(" "),U=[""],Y=0;for(let V=0;V<Z.length;V++){let L=Z[V];if(G.trim!==!1){let H=U.at(-1)??"",q=H.trimStart();if(H.length!==q.length)U[U.length-1]=q,Y=O6(q)}if(V!==0){if(Y>=z&&(G.wordWrap===!1||G.trim===!1))U.push(""),Y=0;if(Y||G.trim===!1)U[U.length-1]+=" ",Y++}let X=O6(L);if(G.hard&&X>z){let H=z-Y,q=1+Math.floor((X-H-1)/z);if(Math.floor((X-1)/z)<q)U.push("");Lf(U,L,z),Y=O6(U.at(-1)??"");continue}if(Y+X>z&&Y&&X){if(G.wordWrap===!1&&Y<z){Lf(U,L,z),Y=O6(U.at(-1)??"");continue}U.push(""),Y=0}if(Y+X>z&&G.wordWrap===!1){Lf(U,L,z),Y=O6(U.at(-1)??"");continue}U[U.length-1]+=L,Y+=X}if(G.trim!==!1)U=U.map((V)=>uF5(V));let W=U.join(`
29
29
  `),B=!1;for(let V=0;V<W.length;V++){let L=W[V];if(J+=L,!B){if(B=L>="\uD800"&&L<="\uDBFF",B)continue}else B=!1;if(L===YR||L===OW2){NW2.lastIndex=V+1;let H=NW2.exec(W)?.groups;if(H?.code!==void 0){let q=Number.parseFloat(H.code);Q=q===SF5?void 0:q}else if(H?.uri!==void 0)K=H.uri.length===0?void 0:H.uri}if(W[V+1]===`
30
30
  `){if(K)J+=MW2("");let X=Q?AW2(Q):void 0;if(Q&&X)J+=jW2(X)}else if(L===`
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "oh-my-agent",
3
- "version": "9.7.0",
3
+ "version": "9.8.0",
4
4
  "description": "Portable multi-agent harness for .agents-based skills and workflows across Antigravity, Claude Code, Codex, OpenCode, and more",
5
5
  "type": "module",
6
6
  "bin": {