@initx-plugin/core 0.0.33 → 0.0.35

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/dist/index.d.mts CHANGED
@@ -37,6 +37,7 @@ type MatchedPlugin = HandlerInfo & {
37
37
  declare function fetchPlugins(): Promise<InitxPluginInfo[]>;
38
38
  declare function loadPlugins(): Promise<LoadPluginResult[]>;
39
39
  declare function matchPlugins(plugins: LoadPluginResult[], { key, cliOptions }: InitxBaseContext, ...others: string[]): Promise<MatchedPlugin[]>;
40
+ declare function withPluginPrefix(commands: string[]): string[];
40
41
 
41
42
  type InitxRuleFields<TRule extends object = object> = TRule & {
42
43
  /**
@@ -118,4 +119,4 @@ declare function installManager(): Promise<void>;
118
119
  declare function createStore(name: string, defaultStore?: Record<string, any>): Record<string, any>;
119
120
  declare function writeStore(name: string): void;
120
121
 
121
- export { type HandlerInfo, INITX_DIR, type InitxBaseContext, type InitxContext, type InitxMatcherRules, InitxPlugin, type InitxPluginInfo, type LoadPluginResult, type MatchedPlugin, NODE_MODULES_DIR, PLUGIN_DIR, type PackageInfo, STORE_DIR, STORE_FILE_NAME, createStore, fetchPlugins, installManager, loadPlugins, matchPlugins, writeStore };
122
+ export { type HandlerInfo, INITX_DIR, type InitxBaseContext, type InitxContext, type InitxMatcherRules, InitxPlugin, type InitxPluginInfo, type LoadPluginResult, type MatchedPlugin, NODE_MODULES_DIR, PLUGIN_DIR, type PackageInfo, STORE_DIR, STORE_FILE_NAME, createStore, fetchPlugins, installManager, loadPlugins, matchPlugins, withPluginPrefix, writeStore };
package/dist/index.d.ts CHANGED
@@ -37,6 +37,7 @@ type MatchedPlugin = HandlerInfo & {
37
37
  declare function fetchPlugins(): Promise<InitxPluginInfo[]>;
38
38
  declare function loadPlugins(): Promise<LoadPluginResult[]>;
39
39
  declare function matchPlugins(plugins: LoadPluginResult[], { key, cliOptions }: InitxBaseContext, ...others: string[]): Promise<MatchedPlugin[]>;
40
+ declare function withPluginPrefix(commands: string[]): string[];
40
41
 
41
42
  type InitxRuleFields<TRule extends object = object> = TRule & {
42
43
  /**
@@ -118,4 +119,4 @@ declare function installManager(): Promise<void>;
118
119
  declare function createStore(name: string, defaultStore?: Record<string, any>): Record<string, any>;
119
120
  declare function writeStore(name: string): void;
120
121
 
121
- export { type HandlerInfo, INITX_DIR, type InitxBaseContext, type InitxContext, type InitxMatcherRules, InitxPlugin, type InitxPluginInfo, type LoadPluginResult, type MatchedPlugin, NODE_MODULES_DIR, PLUGIN_DIR, type PackageInfo, STORE_DIR, STORE_FILE_NAME, createStore, fetchPlugins, installManager, loadPlugins, matchPlugins, writeStore };
122
+ export { type HandlerInfo, INITX_DIR, type InitxBaseContext, type InitxContext, type InitxMatcherRules, InitxPlugin, type InitxPluginInfo, type LoadPluginResult, type MatchedPlugin, NODE_MODULES_DIR, PLUGIN_DIR, type PackageInfo, STORE_DIR, STORE_FILE_NAME, createStore, fetchPlugins, installManager, loadPlugins, matchPlugins, withPluginPrefix, writeStore };
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- import{platform as D,homedir as R}from"node:os";import c,{resolve as m}from"pathe";import{useInitxMatcher as b}from"matchinitx";import{defu as E}from"defu";import a,{existsSync as $}from"fs-extra";import h from"node:process";import{c as J}from"@initx-plugin/utils";const L=D()==="win32",y=m(R(),".initx"),g=m(y,"stores"),w="store.json",l=m(y,"plugins"),f=L?"node_modules":"lib/node_modules";let x=!1,S={};const I=o=>c.resolve(g,o,w);function v(o,n={}){a.ensureDirSync(c.resolve(g,o));const t=I(o),r=i=>(O(t,i),M(i));if(!a.existsSync(t))return r(n);let e;try{const i=a.readJsonSync(t);e=E(i,n)}catch{e=n}return r(e)}function k(o){x&&O(I(o),S)}function O(o,n){a.writeJsonSync(o,n,{spaces:2})}function M(o={}){const n=r=>typeof r=="object"&&r!==null&&new Set(["[object Object]","[object Array]"]).has(Object.prototype.toString.call(r)),t=r=>new Proxy(r,{get(e,i){const s=Reflect.get(e,i);return n(s)?t(s):s},set(e,i,s){const u=Reflect.set(e,i,s);return x=!0,u},deleteProperty(e,i){const s=Reflect.deleteProperty(e,i);return x=!0,s}});return S=t(o),S}const d={plugin:/^(?:@initx-plugin\/|initx-plugin-)/,exclude:/@initx-plugin\/(?:core|utils)$/};async function N(){const o=c.resolve(h.cwd(),"package.json");if(!a.existsSync(o))return[];const n=a.readJsonSync(o),{dependencies:t={},devDependencies:r={}}=n;return Object.keys({...t,...r}).filter(e=>d.plugin.test(e)&&!d.exclude.test(e)).map(e=>({name:e,root:c.resolve(h.cwd(),"node_modules",e)}))}async function P(){a.ensureDirSync(l);const o=a.readdirSync(c.resolve(l,f)),n=c.resolve(l,f,"@initx-plugin");return[...a.existsSync(n)?a.readdirSync(n).map(t=>`@initx-plugin/${t}`):[],...o].filter(t=>d.plugin.test(t)&&!d.exclude.test(t)).map(t=>({name:t,root:c.resolve(l,f,t)}))}async function T(){const o=await N(),n=o.map(({name:e})=>e),t=[...(await P()).filter(({name:e})=>!n.includes(e)),...o],r=await import("importx");return Promise.all(t.map(async({root:e})=>{const i=await r.import(e,import.meta.url).then(u=>u.default),s=a.readJsonSync(c.resolve(e,"package.json"));return{packageInfo:{root:e,name:s.name,version:s.version,description:s.description,author:s.author,homepage:s.homepage},instance:new i}}))}async function A(o,{key:n,cliOptions:t},...r){const e=[];for(const i of o){const{instance:s,packageInfo:u}=i,_=await s.run({key:n,cliOptions:t,packageInfo:u,optionsList:Object.keys(t).filter(p=>t[p]===!0).map(p=>`--${p}`)},...r);e.push(..._.map(p=>({handler:p.handler,description:p.description,packageInfo:u})))}return e}function H(o,n){return o.some(t=>typeof t=="string"||typeof t>"u"?t===n:t.test(n))}class U{defaultStore;async run(n,...t){const r=b((e,...i)=>({handler:()=>this.executeHandle(n,e,...i),...e}));return(await Promise.all(r.match(this.rules,n.key,...t).map(async e=>e.verify&&!e.verify(n,...t)||e.optional&&!H(e.optional,t[0])?!1:e))).filter(Boolean)}async executeHandle(n,t,...r){const e=v(n.packageInfo.name,this.defaultStore);await this.handle({...n,rule:t,store:e},...r),k(n.packageInfo.name)}}const j="@initx-plugin/manager";function B(){return $(m(l,f,j))}async function F(){B()||await J("npm",["install","-g",j,"--prefix",l])}export{y as INITX_DIR,U as InitxPlugin,f as NODE_MODULES_DIR,l as PLUGIN_DIR,g as STORE_DIR,w as STORE_FILE_NAME,v as createStore,P as fetchPlugins,F as installManager,T as loadPlugins,A as matchPlugins,k as writeStore};
1
+ import{platform as R,homedir as b}from"node:os";import a,{resolve as m}from"pathe";import{useInitxMatcher as $}from"matchinitx";import{defu as E}from"defu";import c from"fs-extra";import S from"node:process";import{c as J}from"@initx-plugin/utils";const L=R()==="win32",y=m(b(),".initx"),g=m(y,"stores"),w="store.json",l=m(y,"plugins"),f=L?"node_modules":"lib/node_modules";let h=!1,x={};const I=o=>a.resolve(g,o,w);function v(o,t={}){c.ensureDirSync(a.resolve(g,o));const n=I(o),r=i=>(P(n,i),M(i));if(!c.existsSync(n))return r(t);let e;try{const i=c.readJsonSync(n);e=E(i,t)}catch{e=t}return r(e)}function k(o){h&&P(I(o),x)}function P(o,t){c.writeJsonSync(o,t,{spaces:2})}function M(o={}){const t=r=>typeof r=="object"&&r!==null&&new Set(["[object Object]","[object Array]"]).has(Object.prototype.toString.call(r)),n=r=>new Proxy(r,{get(e,i){const s=Reflect.get(e,i);return t(s)?n(s):s},set(e,i,s){const u=Reflect.set(e,i,s);return h=!0,u},deleteProperty(e,i){const s=Reflect.deleteProperty(e,i);return h=!0,s}});return x=n(o),x}const d={plugin:/^(?:@initx-plugin\/|initx-plugin-)/,exclude:/@initx-plugin\/(?:core|utils)$/};async function N(){const o=a.resolve(S.cwd(),"package.json");if(!c.existsSync(o))return[];const t=c.readJsonSync(o),{dependencies:n={},devDependencies:r={}}=t;return Object.keys({...n,...r}).filter(e=>d.plugin.test(e)&&!d.exclude.test(e)).map(e=>({name:e,root:a.resolve(S.cwd(),"node_modules",e)}))}async function O(){c.ensureDirSync(l);const o=c.readdirSync(a.resolve(l,f)),t=a.resolve(l,f,"@initx-plugin");return[...c.existsSync(t)?c.readdirSync(t).map(n=>`@initx-plugin/${n}`):[],...o].filter(n=>d.plugin.test(n)&&!d.exclude.test(n)).map(n=>({name:n,root:a.resolve(l,f,n)}))}async function T(){const o=await N(),t=o.map(({name:e})=>e),n=[...(await O()).filter(({name:e})=>!t.includes(e)),...o],r=await import("importx");return Promise.all(n.map(async({root:e})=>{const i=await r.import(e,import.meta.url).then(u=>u.default),s=c.readJsonSync(a.resolve(e,"package.json"));return{packageInfo:{root:e,name:s.name,version:s.version,description:s.description,author:s.author,homepage:s.homepage},instance:new i}}))}async function A(o,{key:t,cliOptions:n},...r){const e=[];for(const i of o){const{instance:s,packageInfo:u}=i,D=await s.run({key:t,cliOptions:n,packageInfo:u,optionsList:Object.keys(n).filter(p=>n[p]===!0).map(p=>`--${p}`)},...r);e.push(...D.map(p=>({handler:p.handler,description:p.description,packageInfo:u})))}return e}function H(o,t){return o.some(n=>typeof n=="string"||typeof n>"u"?n===t:n.test(t))}function j(o){return o.push("--prefix",l),o}class U{defaultStore;async run(t,...n){const r=$((e,...i)=>({handler:()=>this.executeHandle(t,e,...i),...e}));return(await Promise.all(r.match(this.rules,t.key,...n).map(async e=>e.verify&&!e.verify(t,...n)||e.optional&&!H(e.optional,n[0])?!1:e))).filter(Boolean)}async executeHandle(t,n,...r){const e=v(t.packageInfo.name,this.defaultStore);await this.handle({...t,rule:n,store:e},...r),k(t.packageInfo.name)}}const _="@initx-plugin/manager";function B(){return c.existsSync(m(l,f,_))}async function F(){B()||await J("npm",j(["install",_]))}export{y as INITX_DIR,U as InitxPlugin,f as NODE_MODULES_DIR,l as PLUGIN_DIR,g as STORE_DIR,w as STORE_FILE_NAME,v as createStore,O as fetchPlugins,F as installManager,T as loadPlugins,A as matchPlugins,j as withPluginPrefix,k as writeStore};
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@initx-plugin/core",
3
3
  "type": "module",
4
- "version": "0.0.33",
4
+ "version": "0.0.35",
5
5
  "description": "core module for initx plugins",
6
6
  "license": "MIT",
7
7
  "homepage": "https://github.com/initx-collective/initx#readme",
@@ -27,7 +27,7 @@
27
27
  "importx": "^0.5.2",
28
28
  "matchinitx": "^0.0.4",
29
29
  "pathe": "^2.0.3",
30
- "@initx-plugin/utils": "0.0.33"
30
+ "@initx-plugin/utils": "0.0.35"
31
31
  },
32
32
  "devDependencies": {
33
33
  "@types/fs-extra": "^11.0.4"