@homedev/objector 0.1.21 → 0.1.22
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.js +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import X from"fs/promises";import Z from"path";import u from"yaml";var a=async(w)=>{try{return await X.access(w,X.constants.R_OK),!0}catch{return!1}},J=async(w,r)=>{let O=await(async()=>{let f=[""];if(!Z.isAbsolute(w)&&r?.dirs)f.push(...r.dirs);for(let j of f){let $=Z.join(j,w);if(await a($))return Z.resolve($)}throw new Error(`File not found: "${w}"`)})(),E=await X.readFile(O),T=Z.dirname(O),C={"[.](yml|yaml)$":u.parse,"[.]json$":JSON.parse,...r?.parsers},g=Object.entries(C).find((f)=>O.match(f[0]));if(!g)throw new Error(`Unhandled file type: ${w}`);return{content:g[1](E.toString()),fullPath:O,folderPath:T}};var K=async(w,r)=>{for(let F of w){let O=[];if(r?.root)O.push(r.root);if(r?.loadOptions?.dirs)O.push(...r.loadOptions.dirs);let E=r?.load?await r.load(F):(await J(F,{...r?.loadOptions,dirs:O})).content;if(r?.loaded&&E)await r.loaded(E)}};var D=(w,r,F)=>{for(let O of Object.keys(r)){if(w[O]===void 0)continue;let E=r[O],T=w[O];if(typeof T!==typeof E||Array.isArray(T)!==Array.isArray(E)){let g=F?.mismatch?.(O,T,E,w,r);if(g!==void 0){r[O]=g;continue}throw new Error(`Type mismatch: ${O}`)}let C=F?.mode?.(O,T,E,w,r)??"merge";switch(C){case"source":r[O]=T;continue;case"target":continue;case"skip":delete r[O],delete w[O];continue;case"merge":break;default:throw new Error(`Unknown merge mode: ${C}`)}if(typeof T==="object")if(Array.isArray(T))E.push(...T);else{if(F?.navigate?.(O,T,E,w,r)===!1)continue;D(T,E,F)}else{if(T===E)continue;let g=F?.conflict?.(O,T,E,w,r);r[O]=g===void 0?E:g}}for(let O of Object.keys(w))if(r[O]===void 0)r[O]=w[O]};var d;((C)=>{C[C.Explore=0]="Explore";C[C.SkipSiblings=1]="SkipSiblings";C[C.NoExplore=2]="NoExplore";C[C.ReplaceItem=3]="ReplaceItem";C[C.ReplaceParent=4]="ReplaceParent";C[C.DeleteParent=5]="DeleteParent"})(d||={});class b{action;by;constructor(w,r){this.action=w;this.by=r}static ReplaceParent(w){return new b(4,w)}static ReplaceItem(w){return new b(3,w)}static SkipSiblings(){return new b(1)}static Explore(){return new b(0)}static NoExplore(){return new b(2)}static DeleteParent(){return new b(5)}}var H=async(w,r)=>{let F=async(E)=>{let T=E.key===null,C=T?{action:0}:await r(E);if(E.value&&typeof E.value==="object"&&C.action==0){if(!T)E.path.push(E.key),E.parents.push(E.parent);if(await O(E),!T)E.parents.pop(),E.path.pop()}return C},O=async(E)=>{for(let[T,C]of Object.entries(E.value)){let g=await F({key:T,value:C,path:E.path,parent:E.value,parents:E.parents});switch(g.action){case 4:if(!E.key)throw new Error("Cannot replace root");E.parent[E.key]=g.by;return;case 3:E.value[T]=g.by;break;case 5:delete E.parent[E.key];return;case 1:return}}};await F({key:null,value:w,path:[],parent:null,parents:[]})};var y=(w,r,F="(",O=")")=>{let E=0,T="",C=[];for(let g of w){if(T+=g,g===F)E++;if(g===O)E--;if(E===0&&g===r)C.push(T.slice(0,-1)),T=""}if(T)C.push(T);return C},z=(w)=>{let r=/(?:\s*(?:"([^"]*)"|'([^']*)')\s*|([^"',]+))(?:,)?|(,)/g,F=[],O;while((O=r.exec(w))!==null){let E=O[1]??O[2];F.push({value:E??O[3]?.trim()??"",quoted:E!==void 0})}return F};var I=(w,r,F,O)=>{if(w.startsWith("{")){let E=w.substring(1,w.length-1);return L(r,E,F).toString()}return O?w:void 0},s=(w,r,F,O)=>{let E=I(r,F,O);if(E)return L(w,E,O);let T=/^\[([^=\]]*)([=]*)([^\]]*)\]$/.exec(r);if(T){let[g,M,f,j]=T,$=I(M.trim(),F,O,!0),B=I(j.trim(),F,O,!0);if(Array.isArray(w))switch(f){case"==":case"=":return w.find((W)=>W[$]==B)}}let C=/^([^[\]]*)\[([^\]]*)]/.exec(r);if(C)return w[C[1]][C[2]];return w[r]},L=(w,r,F)=>{let O=void 0,E=void 0;r??="";let T=(j)=>j?.endsWith("?")?[j.substring(0,j.length-1),!0]:[j,!1],C=(j,$)=>{let[B,W]=T($.pop());if(B){let A=s(j,B,w,F);if(A===void 0){if(W||F?.defaultValue!==void 0)return;throw new Error(`Unknown path element: "${B}" in "${r}"`)}return O=j,E=B,C(A,$)}if(F?.set&&E)O[E]=F?.set;return j},g=y(r,F?.separator??".","{","}"),M=g.length>0&&g[g.length-1].startsWith("?=")?g.pop()?.substring(2):void 0;g.reverse();let f=C(w,g);if(f===void 0)return M??F?.defaultValue;return f};var U=(w,r)=>{let F=/^(?<path>[^@>]*)?(?:@(?<from>[^>]*))?$/.exec(w)?.groups;if(!F)throw new Error(`Invalid reference: "${w}"`);let{from:O,path:E}=F;if(!O)return L(r.root,E,{defaultValue:r?.defaultValue});if(r.async===!1){if(!r.load)throw new Error("No load function defined");return L(r.load(O),E,{defaultValue:r?.defaultValue})}else return(r.load??J)(O).then((T)=>L(T,E))};var G=async(w,r,F,O)=>{let E,T=[],C=r;if(!O.sources)return b.Explore();if(C=C.replaceAll(O.sourcesMatcher??/\$\((?<key>[^:()]+)(?::(?<arg>(?:(?:"[^"]*"|[^",()]*),?)*))?\)/g,(g,...M)=>{if(E)return g;let f=(_)=>{if(_ instanceof Promise)return`ð[${T.push(_)}]ñ`;if(typeof _==="object")return E=_,g;return _??""},j=M[M.length-1],$=O.sources[j.key];if(j.arg===void 0)return f(U(j.key,{root:F,load:O?.load}));if($===void 0)throw new Error(`Unhandled source type: ${j.key}`);let[B,W]="fn"in $?[$.fn,$]:[$,{}],A=z(j.arg),l=W.processArgs===!1?[]:A.map((_)=>{if(_.quoted)return _.value;return _.value.startsWith("@")?_.value.substring(1):U(_.value,{root:F})});return f(B({groups:j,args:l,rawArgs:A,path:w,value:C,root:F,key:j.key,options:O,file:O.file}))}),E)C=await E;else if(T.length){let g=await Promise.all(T);C=g.find((M)=>typeof M==="object")??C.replaceAll(/\xf0\[(\d+)]\xf1/g,(M,f)=>g[+f-1])}if(C===null)return b.DeleteParent();if(C===r)return b.Explore();if(C instanceof b)return C;if(typeof C==="string"){let g=await G(w,C,F,O);if(g.action!==0)return g}return b.ReplaceItem(C)};var m=async(w,r,F,O)=>{if(w.key.startsWith("$"))return b.NoExplore();if(!O.keys)return;let E=(O?.keysMatcher??/^\.(?<key>.*)/).exec(w.key)?.groups;if(E){let T=O.keys[E.key];if(T!==void 0){let C=typeof T==="object"?T:{},g=typeof T==="function"?T:T.fn,M={...F,self:w.value,this:w.parent,parent:w.parents[w.parents.length-1],parents:[w.parent,...w.parents.toReversed()]};if(typeof w.value==="string"){let $=await G(r,w.value,M,O);if($.by)w.value=$.by}else await q(w.value,{...O,root:M,filters:[...O.filters??[],...C.filters??[]]});let f={args:[w.value],rawArgs:[],groups:E,path:r,value:w.value,root:F,parent:w.parent,key:w.key,file:O?.file,options:O},j=await g(f);if(j instanceof b)return j;if(j===null)return b.DeleteParent();if(j===void 0)return b.Explore();return b.ReplaceParent(j)}}};var q=async(w,r)=>H(w,async(F)=>{let O=[...F.path,F.key].join(".");if(r.filters?.length&&r.filters.some((T)=>T.test(O)))return b.NoExplore();let E={...w,this:F.parent,parent:F.parents.length>0?F.parents[F.parents.length-1]:{},parents:F.parents.toReversed(),...r.root};try{return await m(F,O,E,r)??(typeof F.value==="string"?await G(O,F.value,E,r):b.Explore())}catch(T){throw new Error(`${T.message}
|
|
2
2
|
in ${r.file??""}(${O}) `)}});var Ir=async(w,r)=>{let F=[];return await H(w,(O)=>{if(r([...O.path,O.key].join("."),O.value))F.push(O.value);return b.Explore()}),F};var P=(w,r="name")=>Object.entries(w).map(([F,O])=>({[r]:F,...O})),Yr=(w,r="name")=>Object.fromEntries(w.map((F)=>[F[r],F])),V=(w,r="name")=>Object.fromEntries(w.map((F)=>{let{[r]:O,...E}=F;return[O,E]}));import Q from"fs/promises";import p from"path";import o from"yaml";import S from"path";var n=(w)=>{return{load:async(r)=>{for(let{file:F,alias:O}of Array.isArray(r.value)?r.value:[r.value]){if(!F)throw new Error("File reference required");await w.load(F,O??F,r.file&&S.dirname(r.file))}delete r.parent[r.key]},include:(r)=>w.load(r.value,void 0,r.file&&S.dirname(r.file)),from:async(r)=>{let F=await U(r.value,{root:r.root,load:(O)=>w.load(O,void 0,r.file&&S.dirname(r.file))});if(r.parent.content){if(Array.isArray(r.parent.content)&&Array.isArray(F))return[...F,...r.parent.content];return w.merge(F,r.parent.content),r.parent.content}return F},concat:async(r)=>{let F=[];for(let O of Array.isArray(r.value)?r.value:[r.value])F.push(...await U(O,{root:r.root,load:(E)=>w.load(E,void 0,r.file&&S.dirname(r.file))}));return F.filter((O)=>O!==void 0)},extends:async(r)=>{for(let F of Array.isArray(r.value)?r.value:[r.value])w.merge(await U(F,{root:r.root,load:(O)=>w.load(O,void 0,r.file&&S.dirname(r.file))}),r.parent);delete r.parent[r.key]},alias:(r)=>{w.alias(r.value,r.parent),delete r.parent[r.key]},if:(r)=>{if(delete r.parent[r.key],r.value===null||r.value===void 0||["0",0,"false",""].includes(r.value)||Array.isArray(r.value)&&r.value.length===0)return null},skip:(r)=>{return delete r.parent[r.key],b.SkipSiblings()},output:(r)=>{delete r.parent[r.key];for(let F of Array.isArray(r.value)?r.value:[r.value])if(typeof F==="string")w.output({name:F,value:r.parent});else w.output({...F,value:F.value??r.parent})},each:{filters:[/select|model/],fn:async(r)=>{delete r.parent[r.key];let F=(f)=>U(f,{root:r.root,load:(j)=>w.load(j,void 0,r.file&&S.dirname(r.file))}),O=()=>{if(typeof r.value==="string"||!r.value.model)return r.parent;if(typeof r.value.model==="string")return F(r.value.model);return r.value.model},E=()=>{if(typeof r.value==="string")return F(r.value);if(Array.isArray(r.value))return r.value;if(typeof r.value.from==="string")return F(r.value.from);return r.value.from},T=async(f)=>{let j=r.value.select;if(j===void 0)return f;if(typeof j!=="string"){let $=JSON.parse(JSON.stringify(j));return await q($,{...r.options,root:{...r.root,result:f}}),$}return await U(j,{root:{...r.root,result:f}})},C=await E(),g=await O();if(!Array.isArray(C))throw new Error('Key "each" requires a source list');if(g===void 0)throw new Error('Key "each" must define a model');if(r.value.extend?.model)g=w.mergeAll([g,...Array.isArray(r.value.extend.model)?r.value.extend.model:[r.value.extend.model]]);let M=[];for(let f=0;f<C.length;f++){let j=JSON.parse(JSON.stringify(g));if(await q(j,{...r.options,root:{...r.root,item:C[f],this:j,index:f}}),r.value.extend?.result)j=w.mergeAll([j,...Array.isArray(r.value.extend?.result)?r.value.extend.result:[Array.isArray(r.value.extend?.result)]]);M.push(await T(j))}return M}}}};import R from"fs/promises";import Y from"path";var N=(w)=>w.replace(/((?:[_ ]+)\w|^\w)/g,(r,F)=>F.toUpperCase()).replace(/_/g,""),i=(w)=>N(w).replace(/((?:[ ]+\w)|^\w)/g,(r,F)=>F.toLowerCase()),h=(w,r)=>w.replace(/([a-z])([A-Z])/g,`$1${r}$2`).replace(/\s+/g,r),k=(w,r)=>{switch(r){case"upper":return w.toUpperCase();case"lower":return w.toLowerCase();default:return w}},v=(w)=>{return{include:async(r)=>await w.load(r.args[0],r.args[1],void 0,{parent:r.root}),file:async(r)=>await R.readFile(r.args[0]).then((F)=>F.toString()),scan:async(r)=>{let F=[],E=(()=>{let T=r.args[2]??["**/node_modules/**"],C=typeof T==="string"?T.split(",").map((g)=>g.trim()):T;if(!Array.isArray(C))throw new Error("Scan exclusion must be a list");return C})();for await(let T of R.glob(r.args[0],{cwd:r.args[1]??Y.dirname(r.file??"."),exclude:(C)=>E.some((g)=>Y.matchesGlob(C,g))}))F.push(T);return F},env:(r)=>process.env[r.args[0]],len:(r)=>r.args[0].length,reverse:(r)=>r.args[0].split("").reverse().join(""),substring:(r)=>r.args[0].substring(+r.args[1],+r.args[2]),concat:(r)=>r.args.join(""),lower:(r)=>r.args[0].toLowerCase(),upper:(r)=>r.args[0].toUpperCase(),pascal:(r)=>N(r.args[0]),camel:(r)=>i(r.args[0]),snake:(r)=>k(h(r.args[0],"_"),r.args[1]),kebab:(r)=>k(h(r.args[0],"-"),r.args[1]),encode:(r)=>Buffer.from(r.args[0]).toString(r.args[1]??"base64"),decode:(r)=>Buffer.from(r.args[0],r.args[1]??"base64").toString(),uuid:(r)=>crypto.randomUUID(),join:(r)=>{let[F,O,E]=r.args,T=F;if(!Array.isArray(T))throw new Error("Object is not a list");if(O?.length)T=T.map((C)=>U(O,{root:{...r.root,...C},load:(g)=>w.load(g)}));return T.join(E?.replace("\\n",`
|
|
3
|
-
`))},list:(r)=>P(r.args[0],r.args[1]),object:(r)=>V(r.args[0],r.args[1]),each:{processArgs:!1,fn:async(r)=>{let F=(M)=>U(M,{root:r.root,load:(f)=>w.load(f,void 0,r.file&&Y.dirname(r.file))}),O=await F(r.rawArgs[0].value),E=await F(r.rawArgs[1].value),T=r.rawArgs[2].value,C=Array.isArray(O)?O:P(O),g=[];for(let M=0;M<C.length;M++){let f=JSON.parse(JSON.stringify(E)),j={instance:f};if(await q(j,{...r.options,root:{...r.root,item:C[M],this:f,index:M,params:r.rawArgs.slice(3).map(($)=>$.value)}}),T&&T!=="@")g.push(j.instance[T]);else g.push(j.instance)}return g}},log:(r)=>{console.log(...r.args)},default:{processArgs:!1,fn:async(r)=>{let F=r.rawArgs[1]?.value?r.rawArgs[1].quoted?r.rawArgs[1].value:await U(r.rawArgs[1].value,{root:r.root,load:(O)=>w.load(O)}):"";return await U(r.rawArgs[0].value,{root:r.root,load:(O)=>w.load(O),defaultValue:F})}}}};class e{options={load:{dirs:[]},merge:{},include:{},fields:{},includeKey:"includes",mergeKey:".merge",includes:[],outputs:[]};cache={};includeDirectory(...w){return this.options.load.dirs??=[],this.options.load.dirs.push(...w),this}include(...w){return this.options.includes??=[],this.options.includes.push(...w),this}keys(w){return this.options.fields.keys={...this.options.fields.keys,...w},this}sources(w){return this.options.fields.sources={...this.options.fields.sources,...w},this}variables(w){return this.options.variables={...this.options.variables,...w},this}output(w){return this.options.outputs??=[],this.options.outputs.push(w),this}defaultProcessors(){return this.sources(v(this)).keys(n(this))}alias(w,r){return this.cache[w]=r,this}getAlias(w){return this.cache[w]}getOutputs(){return this.options.outputs??[]}use(w){return w(this),this}filter(w){return this.options.fields.filters??=[],this.options.fields.filters?.push(w),this}async load(w,r,F,O){if(r&&this.cache[r])return this.cache[r];if(this.cache[w])return this.cache[w];let E=F?[F]:[];this.options.load.dirs&&E.push(...this.options.load.dirs);let T=await J(w,{...this.options.load,dirs:E});if(!T.content)return null;if(r)this.cache[r]=T.content;let C=[];if(this.options.includeKey&&T.content[this.options.includeKey])C.push(...T.content[this.options.includeKey]),delete T.content[this.options.includeKey];if(this.options.includes)C.push(...this.options.includes),this.options.includes.length=0;return await K(C,{root:T.folderPath,loaded:(g)=>{if(this.options.mergeKey)D(g,T.content,{mode:(M,f,j)=>j[this.options.mergeKey],...this.options.merge})},load:(g)=>this.load(g,void 0,
|
|
3
|
+
`))},list:(r)=>P(r.args[0],r.args[1]),object:(r)=>V(r.args[0],r.args[1]),each:{processArgs:!1,fn:async(r)=>{let F=(M)=>U(M,{root:r.root,load:(f)=>w.load(f,void 0,r.file&&Y.dirname(r.file))}),O=await F(r.rawArgs[0].value),E=await F(r.rawArgs[1].value),T=r.rawArgs[2].value,C=Array.isArray(O)?O:P(O),g=[];for(let M=0;M<C.length;M++){let f=JSON.parse(JSON.stringify(E)),j={instance:f};if(await q(j,{...r.options,root:{...r.root,item:C[M],this:f,index:M,params:r.rawArgs.slice(3).map(($)=>$.value)}}),T&&T!=="@")g.push(j.instance[T]);else g.push(j.instance)}return g}},log:(r)=>{console.log(...r.args)},default:{processArgs:!1,fn:async(r)=>{let F=r.rawArgs[1]?.value?r.rawArgs[1].quoted?r.rawArgs[1].value:await U(r.rawArgs[1].value,{root:r.root,load:(O)=>w.load(O)}):"";return await U(r.rawArgs[0].value,{root:r.root,load:(O)=>w.load(O),defaultValue:F})}}}};class e{options={load:{dirs:[]},merge:{},include:{},fields:{},includeKey:"includes",mergeKey:".merge",includes:[],outputs:[]};cache={};includeDirectory(...w){return this.options.load.dirs??=[],this.options.load.dirs.push(...w),this}include(...w){return this.options.includes??=[],this.options.includes.push(...w),this}keys(w){return this.options.fields.keys={...this.options.fields.keys,...w},this}sources(w){return this.options.fields.sources={...this.options.fields.sources,...w},this}variables(w){return this.options.variables={...this.options.variables,...w},this}output(w){return this.options.outputs??=[],this.options.outputs.push(w),this}defaultProcessors(){return this.sources(v(this)).keys(n(this))}alias(w,r){return this.cache[w]=r,this}getAlias(w){return this.cache[w]}getOutputs(){return this.options.outputs??[]}use(w){return w(this),this}filter(w){return this.options.fields.filters??=[],this.options.fields.filters?.push(w),this}async load(w,r,F,O){if(r&&this.cache[r])return this.cache[r];if(this.cache[w])return this.cache[w];let E=F?[F]:[];this.options.load.dirs&&E.push(...this.options.load.dirs);let T=await J(w,{...this.options.load,dirs:E});if(!T.content)return null;if(r)this.cache[r]=T.content;let C=[];if(this.options.includeKey&&T.content[this.options.includeKey])C.push(...T.content[this.options.includeKey]),delete T.content[this.options.includeKey];if(this.options.includes)C.push(...this.options.includes),this.options.includes.length=0;return await K(C,{root:T.folderPath,loaded:(g)=>{if(this.options.mergeKey)D(g,T.content,{mode:(M,f,j)=>j[this.options.mergeKey],...this.options.merge})},load:(g)=>this.load(g,void 0,T.folderPath,{parent:T.content}),...this.options.include}),await q(T.content,{...this.options.fields,file:T.fullPath,root:{...this.options.fields.root,...this.options.variables,$document:{root:T,fileName:w,folder:T.folderPath,fullPath:T.fullPath,...O}},load:(g)=>this.load(g)}),T.content}merge(w,r){D(w,r,{mode:(F,O,E)=>E[this.options.mergeKey],...this.options.merge})}mergeAll(w){let r={};for(let F of w.toReversed())this.merge(F,r);return r}async writeOutputs(w){if(w?.targetDirectory&&w?.removeFirst)try{await Q.rm(w?.targetDirectory,{recursive:!0,force:!0})}catch(r){throw new Error(`Failed to clean the output directory: ${r.message}`)}for(let r of this.getOutputs()){let F=p.join(w?.targetDirectory??".",r.name),O=p.dirname(F);if(w?.writing?.(r)===!1)continue;try{await Q.mkdir(O,{recursive:!0})}catch(E){throw new Error(`Failed to create target directory "${O}" for output "${F}": ${E.message}`)}try{switch(r.type){case"yaml":await Q.writeFile(F,o.stringify(r.value));break;case"json":await Q.writeFile(F,JSON.stringify(r.value));break;default:await Q.writeFile(F,r.value.toString())}}catch(E){throw new Error(`Failed to write output "${F}": ${E.message}`)}}}}export{Yr as toObjectWithKey,V as toObject,P as toList,U as select,K as processIncludes,q as processFields,H as navigate,D as merge,J as load,Ir as find,e as Objector,b as NavigateResult,d as NavigateAction};
|