@jujulego/jill 2.4.0-alpha.2 → 2.4.0-alpha.3

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/README.md CHANGED
@@ -18,12 +18,19 @@ That done it can offer you various utilities:
18
18
 
19
19
  It supports both `npm` and `yarn`.
20
20
 
21
+ ### Hook scripts
22
+ Jill will run hook script like npm do, for both npm and yarn. As npm, when you type `jill run test`, it will first run
23
+ `pretest` if it exists, then `test` and finally `posttest`.
24
+
25
+ This feature can be disabled using the `--no-hooks` option: `jill run --no-hooks test`.
26
+
21
27
  ### Experimental features
22
28
  - `jill group` same as `run` but allows to run multiple scripts in sequence or in parallel using the task syntax
23
29
 
24
30
  #### Task syntax _(only supported by `jill group` command yet)_
25
- Allows to instruct multiple tasks with the given orchestration. The orchetraction is given by the following operators:
31
+ Allows to instruct multiple tasks with the given orchestration. The orchestration is given by the following operators:
26
32
  - `->` in sequence
33
+ - `||` fallbacks
27
34
  - `//` in parallel
28
35
 
29
36
  ##### Examples:
@@ -32,6 +39,11 @@ Allows to instruct multiple tasks with the given orchestration. The orchetractio
32
39
  jill group 'taskA -> taskB -> taskC'
33
40
  ```
34
41
 
42
+ - This will run first **taskA**, if it fails it will run **taskB**, then **taskC** in order, until one succeed.
43
+ ```shell
44
+ jill group 'taskA || taskB || taskC'
45
+ ```
46
+
35
47
  - This will run scripts **taskA**, **taskB** and **taskC** in parallel.
36
48
  ```shell
37
49
  jill group 'taskA // taskB // taskC'
package/dist/71.mjs CHANGED
@@ -1,2 +1,2 @@
1
- export const id=71;export const ids=[71];export const modules={6156:(e,t,n)=>{n.d(t,{O:()=>a});var r=n(8858),o=n(6675),s=n(2761),i=n(9921);let a=class{constructor(e){this._storage=new s.AsyncLocalStorage,this._logger=e.child((0,r.withLabel)("context")),this.reset()}reset(e={}){this._storage.enterWith(e)}_getContext(){return this._storage.getStore()||(this._logger.warning("Trying to access uninitialized context"),{})}_updateContext(e){Object.assign(this._getContext(),e)}get application(){return this._getContext().application}set application(e){this._updateContext({application:e})}get project(){return this._getContext().project}set project(e){this._updateContext({project:e})}get workspace(){return this._getContext().workspace}set workspace(e){this._updateContext({workspace:e})}};var c;a=function(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,i.t)(),(0,c=(0,o.inject)(r.Logger),function(e,t){c(e,t,0)})],a)},9060:(e,t,n)=>{var r=n(8858),o=n(466),s=n(5050);o.nC.bind(r.Logger).toDynamicValue((()=>(0,r.logger$)((0,r.withTimestamp)()))).inSingletonScope().onActivation((({container:e},t)=>(e.get(s.B).connect(t),t)))},5050:(e,t,n)=>{n.d(t,{B:()=>j,h:()=>m});var r=n(8490),o=n(2786),s=n(8858),i=n(8984),a=n(4308),c=n(4086),l=n.n(c),u=n(9921),d=n(6675),p=n(466);const f=Symbol.for("jujulego:jill:log-broadcast-channel");p.nC.bind(f).toConstantValue("jujulego:jill:logger");let g=class{constructor(e){this._source=(0,o.source$)(),this.subscribe=this._source.subscribe,this.unsubscribe=this._source.unsubscribe,this.clear=this._source.clear,this.channel=new c.BroadcastChannel(e),this.channel.unref(),this.channel.onmessage=e=>{this._source.next(e.data)},this.channel.onmessageerror=e=>{this._source.next((0,s.withTimestamp)()({level:s.LogLevel.error,message:s.quick.string`Unable to read message: #!json:${e.data}`}))}}next(e){this.channel.postMessage(e)}};var h;g=function(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,u.t)(),(0,h=(0,d.inject)(f),function(e,t){h(e,t,0)})],g);const m=(0,s.qlevelColor)(s.quick.wrap(a.chalkTemplateStderr).function`#?:${(0,i.qprop)("label")}{grey [#$]} ?#${(0,i.qprop)("message")}`);let j=class{onServiceActivate({container:e}){const t=e.get(g);l().isMainThread?((0,r.flow$)(this._source,(0,s.toStderr)(m)),this.connect(t)):(0,r.flow$)(this._source,t)}connect(e){return(0,r.flow$)(e,(0,r.filter$)((e=>e.level>=this.level)),this._source)}get listeners(){return Array.from(this._source.listeners)}get level(){return this.level$.read()}set level(e){this.level$.mutate(e)}constructor(){this.level$=(0,r.var$)(s.LogLevel.info),this._source=(0,o.source$)(),this.subscribe=this._source.subscribe,this.unsubscribe=this._source.unsubscribe,this.clear=this._source.clear}};j=function(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,u.t)()],j)},7839:(e,t,n)=>{n.d(t,{k:()=>x});var r=n(8858),o=n(612),s=n.n(o),i=n(9411),a=n.n(i),c=n(5795),l=n(466);const u=Symbol("jujulego:jill:Ajv");l.nC.bind(u).toDynamicValue((({container:e})=>{const t=e.get(r.Logger);return new c.default({allErrors:!0,logger:t.child((0,r.withLabel)("ajv")),strict:!0})})).inSingletonScope();var d=n(5050),p=n(6505),f=n(2180),g=n(3843),h=n(6623);const m=JSON.parse('{"$schema":"http://json-schema.org/draft-07/schema","type":"object","additionalProperties":false,"properties":{"jobs":{"type":"number"},"plugins":{"type":"array","items":{"type":"string"}},"verbose":{"type":"string","enum":["info","verbose","debug"]}}}');var j=n(8520);const b=Symbol("jujulego:jill:config-explorer"),y=Symbol("jujulego:jill:config-validator");l.nC.bind(y).toDynamicValue((({container:e})=>e.get(u).compile(m))).inSingletonScope(),l.nC.bind(b).toDynamicValue((()=>(0,h.cosmiconfig)("jill",{loaders:{".cjs":e=>(0,j.y)(e).then((e=>e.default)),".js":e=>(0,j.y)(e).then((e=>e.default)),".json":h.defaultLoaders[".json"],".yaml":h.defaultLoaders[".yaml"],".yml":h.defaultLoaders[".yml"],noExt:h.defaultLoaders.noExt}}))).inSingletonScope();const x=Symbol("jujulego:jill:config");async function w(){const e=l.nC.get(r.Logger).child((0,r.withLabel)("config")),t=l.nC.get(g.c),n=l.nC.get(b),o=l.nC.get(y),i=await n.search(),c=i?.config??{};if(t.jobs&&(c.jobs=t.jobs),t.verbose&&(c.verbose=t.verbose),c.jobs??=s().cpus().length-1,!o(c)){const t=l.nC.get(u).errorsText(o.errors,{separator:"\n- ",dataVar:"config"});throw e.error(`Errors in config file:\n- ${t}`),new p.T(1)}if(c.verbose&&(l.nC.get(d.B).level=r.LogLevel[c.verbose]),i){const t=a().dirname(i.filepath);c.plugins=c.plugins?.map((e=>a().resolve(t,e))),e.verbose(`Loaded ${i.filepath} config file`)}return e.debug`Loaded config:\n#!json:${c}`,c}l.nC.bind(x).toDynamicValue((async()=>await(0,f.F)("jujulego:jill:config",w))).inSingletonScope()},3843:(e,t,n)=>{n.d(t,{N:()=>c,c:()=>i});var r=n(2699),o=n(1091),s=n(466);const i=Symbol("jujulego:jill:config-options"),a={1:"verbose",2:"debug"};function c(e){return e.option("verbose",{alias:"v",type:"count",description:"Set verbosity level",coerce:e=>a[Math.min(e,2)]}).option("jobs",{alias:"j",type:"number",description:"Set maximum parallel job number"})}s.nC.bind(i).toDynamicValue((()=>{const e=(0,r.default)((0,o.hideBin)(process.argv)).help(!1).version(!1);return c(e),e.parse()})).inSingletonScope()},9300:(e,t,n)=>{n.d(t,{W:()=>r});const r="current"},466:(e,t,n)=>{n.d(t,{nC:()=>a,oV:()=>l,yT:()=>c});var r=n(6675),o=n(4088),s=n.n(o),i=(n(2483),n(8520));const a=new r.Container,{lazyInject:c,lazyInjectNamed:l}=(0,i.v)(s())(a)},8727:(e,t,n)=>{n.d(t,{T:()=>m});var r=n(8858),o=n(6675),s=n(2699),i=n(6156),a=n(3843),c=n(9300),l=n(466),u=n(9717),d=n(3617),p=n(7051),f=n(366);const g=JSON.parse('{"i8":"2.4.0-alpha.2"}');function h(e,t){return function(n,r){t(n,r,e)}}let m=class{constructor(e,t,n){this.context=e,this.plugins=t,this.logger=n,this.container=l.nC.createChild(),this.parser=(0,s.default)().scriptName("jill").completion("completion","Generate bash completion script").help("help","Show help for a command").version("version","Show version",g.i8).wrap(process.stdout.columns).exitProcess(!1)}_prepareParser(e){return(0,a.N)(this.parser),this.parser.command(e).recommendCommands().strict().fail(!1)}async _loadPlugins(){this.logger.child((0,r.withLabel)("plugin")).verbose("Loading plugin <core>");const{CorePlugin:e}=await Promise.all([n.e(828),n.e(489)]).then(n.bind(n,489));this.container.load((0,d.rT)(e,!0)),await this.plugins.loadPlugins(this.container)}async run(e){this.context.reset({application:this}),await this._loadPlugins();const t=await this.container.getAllAsync(u.mD);await this._prepareParser(t).parseAsync(e)}async tasksOf(e,t={}){this.context.reset({...t,application:this}),await this._loadPlugins();const n=await this.container.getAllAsync(u.NI);return new Promise(((t,r)=>{const o=[];for(const e of n){const n=(0,u._Y)(e.constructor),r=(0,u.$f)(e,n);r.handler=async n=>{if(e instanceof f.o){const r=[];for await(const t of e.prepare(n))r.push(t);t(r)}else t([])},o.push(r)}this._prepareParser(o).parseAsync(e).catch(r)}))}};m=function(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,o.injectable)(),h(0,(0,o.inject)(i.O)),h(1,(0,o.inject)(p.B)),h(2,(0,o.inject)(r.Logger))],m),l.nC.bind(m).toSelf().inTransientScope().whenTargetIsDefault(),l.nC.bind(m).toDynamicValue((({container:e})=>{const t=e.get(i.O).application;if(!t)throw new Error("Cannot inject current application, it not yet defined");return t})).whenTargetNamed(c.W)},9717:(e,t,n)=>{n.d(t,{$f:()=>f,NI:()=>u,_Y:()=>p,mD:()=>d,mY:()=>g});var r=n(8858),o=n(6675),s=n(466),i=n(3617),a=n(6505),c=n(1632);const l=Symbol("jujulego:jill:command-opts"),u=Symbol("jujulego:jill:command"),d=Symbol("jujulego:jill:command-module");function p(e){const t=Reflect.getMetadata(l,e);if("object"!=typeof t)throw new Error(`No command options found in ${e.name}`);return t}function f(e,t){return{command:t.command,aliases:t.aliases,describe:t.describe,deprecated:t.deprecated,builder:n=>(t.middlewares&&(n=(0,c.S)(n,t.middlewares)),e.builder&&(n=e.builder(n)),n),handler:async t=>{try{await e.handler(t)}catch(e){throw e.message&&s.nC.get(r.Logger).error(e.message),new a.T(1)}}}}function g(e){return t=>{(0,o.decorate)((0,o.injectable)(),t),Reflect.defineMetadata(l,e,t);const n=e.command.split(" ")[0];(0,i.i8)(t,(r=>{r(t).toSelf(),r(u).toDynamicValue((({container:e})=>e.getAsync(t))).whenTargetNamed(n),r(d).toDynamicValue((async({container:n})=>f(await n.getAsync(t),e))).whenTargetNamed(n)}))}}},3893:(e,t,n)=>{n.d(t,{m:()=>p});var r=n(832),o=n(6675),s=n(9149),i=n(4086),a=n.n(i),c=n(466),l=n(5894);const u=Symbol.for("jujulego:jill:ink-app");function d(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}c.nC.bind(u).toDynamicValue((()=>{if(!a().isMainThread)throw new Error("Ink should only be used in main thread");return(0,s.render)((0,r.jsx)(l.Z,{}))})).inSingletonScope();let p=class{builder(e){return e}async handler(e){for await(const t of this.render(e))this.app.rerender((0,r.jsx)(l.Z,{children:t}));await this.app.waitUntilExit()}};d([(0,c.yT)(u)],p.prototype,"app",void 0),p=d([(0,o.injectable)()],p)},1632:(e,t,n)=>{n.d(t,{S:()=>i,d:()=>s});var r=n(6675),o=n(466);function s(){return e=>{(0,r.decorate)((0,r.injectable)(),e),o.nC.bind(e).toSelf().inSingletonScope()}}function i(e,t){let n=e;for(const e of t){const t=o.nC.get(e);t.builder&&(n=t.builder(n)),n.middleware((e=>t.handler(e)))}return n}},3617:(e,t,n)=>{n.d(t,{IY:()=>l,JH:()=>i,i8:()=>a,rT:()=>c});var r=n(6675);const o=Symbol("jujulego:jill:module"),s=Symbol("jujulego:jill:registry");function i(e){const t=Reflect.getMetadata(s,e);if("function"!=typeof t)throw new Error(`No registry found in ${e.name}`);return t}function a(e,t){Reflect.defineMetadata(s,t,e)}function c(e,t=!1){let n=Reflect.getMetadata(o,e);if(!(n&&n instanceof r.ContainerModule)){const o=Reflect.getMetadata(s,e);if("function"!=typeof o){if(t)throw new Error(`No module found in ${e.name}`);return null}n=new r.ContainerModule(o),l(e,n)}return n}function l(e,t){Reflect.defineMetadata(o,t,e)}},7051:(e,t,n)=>{n.d(t,{B:()=>d});var r=n(8858),o=n(6675),s=n(7839),i=n(466),a=n(8520),c=n(3617),l=n(9921);function u(e,t){return function(n,r){t(n,r,e)}}let d=class{constructor(e,t){this._config=e,this._logger=t.child((0,r.withLabel)("plugin"))}async _importPlugin(e){this._logger.verbose`Loading plugin ${e}`;let t=await(0,a.y)(e);for(;t&&"object"==typeof t&&"default"in t;)t=t.default;if(!t)throw new Error(`Invalid plugin ${e}: no plugin class found`);const n=(0,c.rT)(t);if(!n)throw new Error(`Invalid plugin ${e}: invalid plugin class`);return n}async loadPlugins(e=i.nC){if(this._config.plugins)for(const t of this._config.plugins){const n=await this._importPlugin(t);e.load(n)}}};d=function(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,l.t)(),u(0,(0,o.inject)(s.k)),u(1,(0,o.inject)(r.Logger))],d)},9921:(e,t,n)=>{n.d(t,{t:()=>s});var r=n(6675),o=n(466);function s(){return e=>((0,r.decorate)((0,r.injectable)(),e),o.nC.bind(e).toSelf().inSingletonScope().onActivation(((e,t)=>("onServiceActivate"in t&&t.onServiceActivate(e),t))),e)}},366:(e,t,n)=>{n.d(t,{o:()=>b});var r=n(832),o=n(2786),s=n(8858),i=n(3410),a=n(6675),c=n(466),l=n(4244),u=n(6839),d=n(5099),p=n(5740),f=n(4887),g=n(6505),h=n(5472),m=n(3893);function j(e,t,n,r){var o,s=arguments.length,i=s<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(s<3?o(i):s>3?o(t,n,i):o(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}let b=class extends m.m{addTaskOptions(e){return e.option("plan",{type:"boolean",desc:"Only prints tasks to be run",default:!1}).option("plan-mode",{type:"string",desc:"Plan output mode",choices:["json","list"],default:"list"})}async*render(e){const t=new i.TaskSet;for await(const n of this.prepare(e))t.add(n);if(e.plan){const n=Array.from((0,i.plan)(t));if("json"===e.planMode)(0,h.i)(n);else{const e=n.map((e=>({id:e.id.substring(0,6),name:e.name,workspace:(0,l.g)(e.context)||(0,u.G)(e.context)?e.context.workspace.name:"",group:e.groupId?.substring(0,6),"depends on":e.dependenciesIds.map((e=>e.substring(0,6))).join(", ")})));yield(0,r.jsx)(p.Z,{items:e,headers:!0})}}else if(t.tasks.length>0){if(yield(0,r.jsx)(f.Z,{manager:this.manager}),t.start(this.manager),(await(0,o.waitFor$)(t,"finished")).failed>0)throw new g.T(1)}else c.nC.get(s.Logger).warning("No task found")}};j([(0,c.yT)(d.N)],b.prototype,"manager",void 0),b=j([(0,a.injectable)()],b)},4244:(e,t,n)=>{n.d(t,{F:()=>i,g:()=>s});var r=n(3410),o=n(3265);function s(e){return"workspace"in e&&"command"in e}class i extends r.SpawnTask{constructor(e,t,n,r={}){let o=t;r.superCommand&&("string"==typeof r.superCommand&&(r.superCommand=[r.superCommand]),r.superCommand.length>0&&(o=r.superCommand[0],n=[...r.superCommand.slice(1),t,...n])),super(o,n,{workspace:e,command:t},{...r,cwd:e.cwd,env:{FORCE_COLOR:"1",...r.env}}),this.workspace=e,this._logStreams()}_logStreams(){(0,o.m)(this,"stdout").subscribe((e=>this._logger.info(e))),(0,o.m)(this,"stderr").subscribe((e=>this._logger.info(e)))}}},6839:(e,t,n)=>{n.d(t,{G:()=>l,s:()=>u});var r=n(2786),o=n(3410),s=n(466),i=n(8727),a=n(4244),c=n(6379);function l(e){return"workspace"in e&&"script"in e}class u extends o.GroupTask{constructor(e,t,n,r){super(t,{workspace:e,script:t},r),this.workspace=e,this.script=t,this.args=n}async _runScript(e,t){const n=this.workspace.getScript(e);if(!n)return null;const[r,...o]=(0,c.z)(n);if("jill"===r){this._logger.debug(`Interpreting ${n}`);const e=o.map((e=>e.replace(/^["'](.+)["']$/,"$1"))),t=s.nC.get(i.T),r=await t.tasksOf(e,{project:this.project,workspace:this.workspace});if(r.length)return r}const l=await this.workspace.project.packageManager();return[new a.F(this.workspace,r,[...o,...t],{logger:this._logger,superCommand:"yarn"===l?["yarn","exec"]:void 0})]}async prepare(){const e=await this._runScript(this.script,this.args);if(!e)throw new Error(`No script ${this.script} in ${this.workspace.name}`);this._scriptTasks=new o.TaskSet;for(const t of e)this.add(t),this._scriptTasks.add(t)}async*_orchestrate(){if(!this._scriptTasks)throw new Error("ScriptTask needs to be prepared. Call prepare before starting it");yield*this._scriptTasks;const e=await(0,r.waitFor$)(this._scriptTasks,"finished");this.setStatus(0===e.failed?"done":"failed")}_stop(){if(this._scriptTasks)for(const e of this._scriptTasks)e.stop()}complexity(e=new Map){let t=super.complexity(e);return this._scriptTasks&&(t+=this._scriptTasks.tasks.reduce(((t,n)=>t+n.complexity(e)),0)),e.set(this.id,t),t}get project(){return this.workspace.project}}},5099:(e,t,n)=>{n.d(t,{N:()=>a});var r=n(8858),o=n(3410),s=n(7839),i=n(466);const a=Symbol("jujulego:jill:TaskManager");i.nC.bind(a).toDynamicValue((({container:e})=>{const t=e.get(s.k),n=e.get(r.Logger);return new o.TaskManager({jobs:t.jobs,logger:n})})).inSingletonScope()},6872:(e,t,n)=>{n.d(t,{Z:()=>d});var r=n(832),o=n(3410),s=n(9149),i=n(810),a=n(7839),c=n(466),l=n(4244),u=n(6797);function d({group:e}){const[t,n]=(0,i.useState)(!1),[p,f]=(0,i.useState)(e.status),[g,h]=(0,i.useState)([...e.tasks]),[m,j]=(0,i.useState)(!0),b=(0,i.useMemo)((()=>t||g.some((e=>!(0,l.g)(e.context)))),[t,g]),y=(0,i.useMemo)((()=>!b&&m),[b,m]);return(0,i.useLayoutEffect)((()=>{const e=c.nC.get(a.k);e.verbose&&n(["verbose","debug"].includes(e.verbose))}),[]),(0,i.useLayoutEffect)((()=>e.on("status",(e=>{f(e.status)}))),[e]),(0,i.useLayoutEffect)((()=>{let t=!1;return e.on("task.added",(()=>{t||(t=!0,queueMicrotask((()=>{h([...e.tasks]),t=!1})))}))}),[e]),(0,i.useLayoutEffect)((()=>{"running"===p?j(!1):"done"===p&&j(!0)}),[p]),(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(u.Z,{task:e}),y||(0,r.jsx)(s.Box,{flexDirection:"column",marginLeft:2,children:g.map((e=>(0,r.jsx)(i.Fragment,{children:e instanceof o.GroupTask?(0,r.jsx)(d,{group:e}):(0,r.jsx)(u.Z,{task:e})},e.id)))})]})}},5894:(e,t,n)=>{n.d(t,{Z:()=>l});var r=n(832),o=n(9149),s=n(810),i=n(466),a=n(5050);function c(){const{write:e}=(0,o.useStderr)();return(0,s.useLayoutEffect)((()=>{const t=i.nC.get(a.B),n=t.listeners;t.clear();const r=t.subscribe((t=>{e((0,a.h)(t)+"\n")}));return()=>{r();for(const e of n)t.subscribe(e)}}),[e]),null}function l({children:e}){return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(c,{}),e]})}},5740:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(832),o=n(9149),s=n(6379);function i({items:e,headers:t}){return 0===e.length?null:(0,r.jsx)(o.Box,{children:Object.keys(e[0]).map((n=>(0,r.jsxs)(o.Box,{flexDirection:"column",marginRight:2,children:[t&&(0,r.jsx)(o.Text,{bold:!0,children:(0,s.k)(n)}),e.map(((e,t)=>(0,r.jsx)(o.Text,{children:e[n]||" "},t)))]},n)))})}},4887:(e,t,n)=>{n.d(t,{Z:()=>l});var r=n(832),o=n(3410),s=n(810),i=n(6872),a=n(6797);function c(e){return!(e.group||"hidden"in e.context&&e.context.hidden)}function l({manager:e}){const[t,n]=(0,s.useState)(e.tasks.filter(c));return(0,s.useLayoutEffect)((()=>{let t=!1;return e.on("added",(()=>{t||(t=!0,queueMicrotask((()=>{n(e.tasks.filter(c)),t=!1})))}))}),[e]),(0,r.jsx)(r.Fragment,{children:t.map((e=>e instanceof o.GroupTask?(0,r.jsx)(i.Z,{group:e},e.id):(0,r.jsx)(a.Z,{task:e},e.id)))})}},1562:(e,t,n)=>{n.d(t,{Z:()=>i});var r=n(832),o=n(9149),s=n(6839);function i({task:e}){return(0,s.G)(e.context)?(0,r.jsxs)(o.Text,{children:["Run ",(0,r.jsx)(o.Text,{bold:!0,children:e.context.script})," in ",e.context.workspace.name]}):(0,r.jsx)(o.Text,{children:e.name})}},6797:(e,t,n)=>{n.d(t,{Z:()=>p});var r=n(832),o=n(9149),s=n(9165),i=n(6133),a=n(9321),c=n(810),l=n(4244),u=n(6839),d=n(1562);function p({task:e}){const[t,n]=(0,c.useState)(e.status),[p,f]=(0,c.useState)(0);(0,c.useLayoutEffect)((()=>e.on("status",(e=>{n(e.status)}))),[e]),(0,c.useLayoutEffect)((()=>e.on("completed",(({duration:e})=>{f(e)}))),[e]);const g=(0,l.g)(e.context)&&e.group&&(0,u.G)(e.group.context);switch(t){case"blocked":case"ready":case"starting":return(0,r.jsxs)(o.Box,{children:[(0,r.jsx)(o.Text,{color:"grey",children:"·"}),(0,r.jsx)(o.Box,{paddingLeft:1,children:(0,r.jsx)(o.Text,{color:"grey",wrap:"truncate",children:(0,r.jsx)(d.Z,{task:e})})})]});case"running":return(0,r.jsxs)(o.Box,{children:[(0,r.jsx)(o.Text,{color:g?"dim":void 0,children:(0,r.jsx)(s.default,{})}),(0,r.jsx)(o.Box,{paddingLeft:1,children:(0,r.jsx)(o.Text,{color:g?"dim":void 0,wrap:"truncate",children:(0,r.jsx)(d.Z,{task:e})})})]});case"done":return(0,r.jsxs)(o.Box,{children:[(0,r.jsx)(o.Text,{color:"green",children:i.default.success}),(0,r.jsx)(o.Box,{paddingLeft:1,children:(0,r.jsx)(o.Text,{color:g?"dim":void 0,wrap:"truncate",children:(0,r.jsx)(d.Z,{task:e})})}),(0,r.jsx)(o.Box,{paddingLeft:1,flexShrink:0,children:(0,r.jsxs)(o.Text,{color:g?"grey":"dim",children:["(took ",(0,a.default)(p),")"]})})]});case"failed":return(0,r.jsxs)(o.Box,{children:[(0,r.jsx)(o.Text,{color:"red",children:i.default.error}),(0,r.jsx)(o.Box,{paddingLeft:1,children:(0,r.jsx)(o.Text,{color:g?"dim":void 0,wrap:"truncate",children:(0,r.jsx)(d.Z,{task:e})})}),(0,r.jsx)(o.Box,{paddingLeft:1,flexShrink:0,children:(0,r.jsxs)(o.Text,{color:g?"grey":"dim",children:["(took ",(0,a.default)(p),")"]})})]})}}},3265:(e,t,n)=>{n.d(t,{m:()=>o});var r=n(2786);function o(e,t){const n=(0,r.source$)();if(e.completed)return n;let o="";const s=e.on(`stream.${t}`,(e=>{const t=(o+e.data.toString("utf-8")).split(/\r?\n/);o=t.pop()??"";for(const e of t)n.next(e)}));return(0,r.once$)(e,"completed",(()=>{s(),o&&n.next(o)})),n}},6505:(e,t,n)=>{n.d(t,{T:()=>r});class r extends Error{constructor(e,t){super(t),this.code=e}}},8520:(e,t,n)=>{async function r(e){return import("win32"===process.platform?`file://${e}`:e)}function o(e){return e}n.d(t,{v:()=>o,y:()=>r})},5472:(e,t,n)=>{function r(e,t=process.stdout){t.isTTY?t.write(JSON.stringify(e,null,2)):t.write(JSON.stringify(e))}n.d(t,{i:()=>r})},6379:(e,t,n)=>{function r(e){return e.charAt(0).toUpperCase()+e.substring(1).toLowerCase()}function o(e){e=e.trim();const t=[];let n="",r=0;for(let o=1;o<e.length;++o){const s=e[o];n?s===n&&(n=""):['"',"'"].includes(s)?n=s:" "===s&&(t.push(e.slice(r,o)),r=o+1)}return t.push(e.slice(r)),t}n.d(t,{k:()=>r,z:()=>o})},2180:(e,t,n)=>{n.d(t,{F:()=>s});var r=n(4086);const o=new r.BroadcastChannel("jujulego:jill:worker-cache");async function s(e,t){const n=(0,r.getEnvironmentData)(e);if(void 0!==n)return n;const s=await t();return(0,r.setEnvironmentData)(e,s),o.postMessage({key:e,value:s}),s}o.unref(),o.onmessage=e=>{const t=e;(function(e){return"object"==typeof e&&null!==e&&"key"in e&&"value"in e})(t.data)&&(0,r.setEnvironmentData)(t.data.key,t.data.value)}}};
1
+ export const id=71;export const ids=[71];export const modules={6156:(e,t,n)=>{n.d(t,{O:()=>a});var o=n(8858),r=n(6675),s=n(2761),i=n(9921);let a=class{constructor(e){this._storage=new s.AsyncLocalStorage,this._logger=e.child((0,o.withLabel)("context")),this.reset()}reset(e={}){this._storage.enterWith(e)}_getContext(){return this._storage.getStore()||(this._logger.warning("Trying to access uninitialized context"),{})}_updateContext(e){Object.assign(this._getContext(),e)}get application(){return this._getContext().application}set application(e){this._updateContext({application:e})}get project(){return this._getContext().project}set project(e){this._updateContext({project:e})}get workspace(){return this._getContext().workspace}set workspace(e){this._updateContext({workspace:e})}};var c;a=function(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,i.t)(),(0,c=(0,r.inject)(o.Logger),function(e,t){c(e,t,0)})],a)},9060:(e,t,n)=>{var o=n(8858),r=n(466),s=n(5050);r.nC.bind(o.Logger).toDynamicValue((()=>(0,o.logger$)((0,o.withTimestamp)()))).inSingletonScope().onActivation((({container:e},t)=>(e.get(s.B).connect(t),t)))},5050:(e,t,n)=>{n.d(t,{B:()=>j,h:()=>m});var o=n(8490),r=n(2786),s=n(8858),i=n(8984),a=n(4308),c=n(4086),l=n.n(c),u=n(9921),d=n(6675),p=n(466);const h=Symbol.for("jujulego:jill:log-broadcast-channel");p.nC.bind(h).toConstantValue("jujulego:jill:logger");let f=class{constructor(e){this._source=(0,r.source$)(),this.subscribe=this._source.subscribe,this.unsubscribe=this._source.unsubscribe,this.clear=this._source.clear,this.channel=new c.BroadcastChannel(e),this.channel.unref(),this.channel.onmessage=e=>{this._source.next(e.data)},this.channel.onmessageerror=e=>{this._source.next((0,s.withTimestamp)()({level:s.LogLevel.error,message:s.quick.string`Unable to read message: #!json:${e.data}`}))}}next(e){this.channel.postMessage(e)}};var g;f=function(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,u.t)(),(0,g=(0,d.inject)(h),function(e,t){g(e,t,0)})],f);const m=(0,s.qlevelColor)(s.quick.wrap(a.chalkTemplateStderr).function`#?:${(0,i.qprop)("label")}{grey [#$]} ?#${(0,i.qprop)("message")}`);let j=class{onServiceActivate({container:e}){const t=e.get(f);l().isMainThread?((0,o.flow$)(this._source,(0,s.toStderr)(m)),this.connect(t)):(0,o.flow$)(this._source,t)}connect(e){return(0,o.flow$)(e,(0,o.filter$)((e=>e.level>=this.level)),this._source)}get listeners(){return Array.from(this._source.listeners)}get level(){return this.level$.read()}set level(e){this.level$.mutate(e)}constructor(){this.level$=(0,o.var$)(s.LogLevel.info),this._source=(0,r.source$)(),this.subscribe=this._source.subscribe,this.unsubscribe=this._source.unsubscribe,this.clear=this._source.clear}};j=function(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,u.t)()],j)},7839:(e,t,n)=>{n.d(t,{k:()=>w});var o=n(8858),r=n(612),s=n.n(r),i=n(9411),a=n.n(i),c=n(5795),l=n(466);const u=Symbol("jujulego:jill:Ajv");l.nC.bind(u).toDynamicValue((({container:e})=>{const t=e.get(o.Logger);return new c.default({allErrors:!0,logger:t.child((0,o.withLabel)("ajv")),strict:!0})})).inSingletonScope();var d=n(5050),p=n(6505),h=n(2180),f=n(3843),g=n(6623);const m=JSON.parse('{"$schema":"http://json-schema.org/draft-07/schema","type":"object","additionalProperties":false,"properties":{"jobs":{"type":"number"},"hooks":{"type":"boolean","default":true,"description":"Run hook scripts"},"plugins":{"type":"array","items":{"type":"string"}},"verbose":{"type":"string","enum":["info","verbose","debug"]}}}');var j=n(8520);const b=Symbol("jujulego:jill:config-explorer"),y=Symbol("jujulego:jill:config-validator");l.nC.bind(y).toDynamicValue((({container:e})=>e.get(u).compile(m))).inSingletonScope(),l.nC.bind(b).toDynamicValue((()=>(0,g.cosmiconfig)("jill",{loaders:{".cjs":e=>(0,j.y)(e).then((e=>e.default)),".js":e=>(0,j.y)(e).then((e=>e.default)),".json":g.defaultLoaders[".json"],".yaml":g.defaultLoaders[".yaml"],".yml":g.defaultLoaders[".yml"],noExt:g.defaultLoaders.noExt}}))).inSingletonScope();const w=Symbol("jujulego:jill:config");async function k(){const e=l.nC.get(o.Logger).child((0,o.withLabel)("config")),t=l.nC.get(f.c),n=l.nC.get(b),r=l.nC.get(y),i=await n.search(),c=i?.config??{};if(t.jobs&&(c.jobs=t.jobs),t.verbose&&(c.verbose=t.verbose),void 0!==t.hooks&&(c.hooks=t.hooks),c.jobs??=s().cpus().length-1,c.hooks??=!0,!r(c)){const t=l.nC.get(u).errorsText(r.errors,{separator:"\n- ",dataVar:"config"});throw e.error(`Errors in config file:\n- ${t}`),new p.T(1)}if(c.verbose&&(l.nC.get(d.B).level=o.LogLevel[c.verbose]),i){const t=a().dirname(i.filepath);c.plugins=c.plugins?.map((e=>a().resolve(t,e))),e.verbose(`Loaded ${i.filepath} config file`)}return e.debug`Loaded config:\n#!json:${c}`,c}l.nC.bind(w).toDynamicValue((async()=>await(0,h.F)("jujulego:jill:config",k))).inSingletonScope()},3843:(e,t,n)=>{n.d(t,{N:()=>c,c:()=>i});var o=n(2699),r=n(1091),s=n(466);const i=Symbol("jujulego:jill:config-options"),a={1:"verbose",2:"debug"};function c(e){return e.option("verbose",{alias:"v",type:"count",description:"Set verbosity level",coerce:e=>a[Math.min(e,2)]}).option("jobs",{alias:"j",type:"number",description:"Set maximum parallel job number"}).option("hooks",{type:"boolean",description:"Run hook scripts"})}s.nC.bind(i).toDynamicValue((()=>{const e=(0,o.default)((0,r.hideBin)(process.argv)).help(!1).version(!1);return c(e),e.parse()})).inSingletonScope()},9300:(e,t,n)=>{n.d(t,{W:()=>o});const o="current"},466:(e,t,n)=>{n.d(t,{nC:()=>a,oV:()=>l,yT:()=>c});var o=n(6675),r=n(4088),s=n.n(r),i=(n(2483),n(8520));const a=new o.Container,{lazyInject:c,lazyInjectNamed:l}=(0,i.v)(s())(a)},8727:(e,t,n)=>{n.d(t,{T:()=>m});var o=n(8858),r=n(6675),s=n(2699),i=n(6156),a=n(3843),c=n(9300),l=n(466),u=n(9717),d=n(3617),p=n(7051),h=n(366);const f=JSON.parse('{"i8":"2.4.0-alpha.3"}');function g(e,t){return function(n,o){t(n,o,e)}}let m=class{constructor(e,t,n){this.context=e,this.plugins=t,this.logger=n,this.container=l.nC.createChild(),this.parser=(0,s.default)().scriptName("jill").completion("completion","Generate bash completion script").help("help","Show help for a command").version("version","Show version",f.i8).wrap(process.stdout.columns).exitProcess(!1)}_prepareParser(e){return(0,a.N)(this.parser),this.parser.command(e).recommendCommands().strict().fail(!1)}async _loadPlugins(){this.logger.child((0,o.withLabel)("plugin")).verbose("Loading plugin <core>");const{CorePlugin:e}=await Promise.all([n.e(828),n.e(489)]).then(n.bind(n,489));this.container.load((0,d.rT)(e,!0)),await this.plugins.loadPlugins(this.container)}async run(e){this.context.reset({application:this}),await this._loadPlugins();const t=await this.container.getAllAsync(u.mD);await this._prepareParser(t).parseAsync(e)}async tasksOf(e,t={}){this.context.reset({...t,application:this}),await this._loadPlugins();const n=await this.container.getAllAsync(u.NI);return new Promise(((t,o)=>{const r=[];for(const e of n){const n=(0,u._Y)(e.constructor),o=(0,u.$f)(e,n);o.handler=async n=>{if(e instanceof h.o){const o=[];for await(const t of e.prepare(n))o.push(t);t(o)}else t([])},r.push(o)}this._prepareParser(r).parseAsync(e).catch(o)}))}};m=function(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,r.injectable)(),g(0,(0,r.inject)(i.O)),g(1,(0,r.inject)(p.B)),g(2,(0,r.inject)(o.Logger))],m),l.nC.bind(m).toSelf().inTransientScope().whenTargetIsDefault(),l.nC.bind(m).toDynamicValue((({container:e})=>{const t=e.get(i.O).application;if(!t)throw new Error("Cannot inject current application, it not yet defined");return t})).whenTargetNamed(c.W)},9717:(e,t,n)=>{n.d(t,{$f:()=>h,NI:()=>u,_Y:()=>p,mD:()=>d,mY:()=>f});var o=n(8858),r=n(6675),s=n(466),i=n(3617),a=n(6505),c=n(1632);const l=Symbol("jujulego:jill:command-opts"),u=Symbol("jujulego:jill:command"),d=Symbol("jujulego:jill:command-module");function p(e){const t=Reflect.getMetadata(l,e);if("object"!=typeof t)throw new Error(`No command options found in ${e.name}`);return t}function h(e,t){return{command:t.command,aliases:t.aliases,describe:t.describe,deprecated:t.deprecated,builder:n=>(t.middlewares&&(n=(0,c.S)(n,t.middlewares)),e.builder&&(n=e.builder(n)),n),handler:async t=>{try{await e.handler(t)}catch(e){throw e.message&&s.nC.get(o.Logger).error(e.message),new a.T(1)}}}}function f(e){return t=>{(0,r.decorate)((0,r.injectable)(),t),Reflect.defineMetadata(l,e,t);const n=e.command.split(" ")[0];(0,i.i8)(t,(o=>{o(t).toSelf(),o(u).toDynamicValue((({container:e})=>e.getAsync(t))).whenTargetNamed(n),o(d).toDynamicValue((async({container:n})=>h(await n.getAsync(t),e))).whenTargetNamed(n)}))}}},3893:(e,t,n)=>{n.d(t,{m:()=>p});var o=n(832),r=n(6675),s=n(9149),i=n(4086),a=n.n(i),c=n(466),l=n(5894);const u=Symbol.for("jujulego:jill:ink-app");function d(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}c.nC.bind(u).toDynamicValue((()=>{if(!a().isMainThread)throw new Error("Ink should only be used in main thread");return(0,s.render)((0,o.jsx)(l.Z,{}))})).inSingletonScope();let p=class{builder(e){return e}async handler(e){for await(const t of this.render(e))this.app.rerender((0,o.jsx)(l.Z,{children:t}));await this.app.waitUntilExit()}};d([(0,c.yT)(u)],p.prototype,"app",void 0),p=d([(0,r.injectable)()],p)},1632:(e,t,n)=>{n.d(t,{S:()=>i,d:()=>s});var o=n(6675),r=n(466);function s(){return e=>{(0,o.decorate)((0,o.injectable)(),e),r.nC.bind(e).toSelf().inSingletonScope()}}function i(e,t){let n=e;for(const e of t){const t=r.nC.get(e);t.builder&&(n=t.builder(n)),n.middleware((e=>t.handler(e)))}return n}},3617:(e,t,n)=>{n.d(t,{IY:()=>l,JH:()=>i,i8:()=>a,rT:()=>c});var o=n(6675);const r=Symbol("jujulego:jill:module"),s=Symbol("jujulego:jill:registry");function i(e){const t=Reflect.getMetadata(s,e);if("function"!=typeof t)throw new Error(`No registry found in ${e.name}`);return t}function a(e,t){Reflect.defineMetadata(s,t,e)}function c(e,t=!1){let n=Reflect.getMetadata(r,e);if(!(n&&n instanceof o.ContainerModule)){const r=Reflect.getMetadata(s,e);if("function"!=typeof r){if(t)throw new Error(`No module found in ${e.name}`);return null}n=new o.ContainerModule(r),l(e,n)}return n}function l(e,t){Reflect.defineMetadata(r,t,e)}},7051:(e,t,n)=>{n.d(t,{B:()=>d});var o=n(8858),r=n(6675),s=n(7839),i=n(466),a=n(8520),c=n(3617),l=n(9921);function u(e,t){return function(n,o){t(n,o,e)}}let d=class{constructor(e,t){this._config=e,this._logger=t.child((0,o.withLabel)("plugin"))}async _importPlugin(e){this._logger.verbose`Loading plugin ${e}`;let t=await(0,a.y)(e);for(;t&&"object"==typeof t&&"default"in t;)t=t.default;if(!t)throw new Error(`Invalid plugin ${e}: no plugin class found`);const n=(0,c.rT)(t);if(!n)throw new Error(`Invalid plugin ${e}: invalid plugin class`);return n}async loadPlugins(e=i.nC){if(this._config.plugins)for(const t of this._config.plugins){const n=await this._importPlugin(t);e.load(n)}}};d=function(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}([(0,l.t)(),u(0,(0,r.inject)(s.k)),u(1,(0,r.inject)(o.Logger))],d)},9921:(e,t,n)=>{n.d(t,{t:()=>s});var o=n(6675),r=n(466);function s(){return e=>((0,o.decorate)((0,o.injectable)(),e),r.nC.bind(e).toSelf().inSingletonScope().onActivation(((e,t)=>("onServiceActivate"in t&&t.onServiceActivate(e),t))),e)}},366:(e,t,n)=>{n.d(t,{o:()=>b});var o=n(832),r=n(2786),s=n(8858),i=n(3410),a=n(6675),c=n(466),l=n(4244),u=n(6839),d=n(5099),p=n(5740),h=n(4887),f=n(6505),g=n(5472),m=n(3893);function j(e,t,n,o){var r,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,n):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(s<3?r(i):s>3?r(t,n,i):r(t,n))||i);return s>3&&i&&Object.defineProperty(t,n,i),i}let b=class extends m.m{addTaskOptions(e){return e.option("plan",{type:"boolean",desc:"Only prints tasks to be run",default:!1}).option("plan-mode",{type:"string",desc:"Plan output mode",choices:["json","list"],default:"list"})}async*render(e){const t=new i.TaskSet;for await(const n of this.prepare(e))t.add(n);if(e.plan){const n=Array.from((0,i.plan)(t));if("json"===e.planMode)(0,g.i)(n);else{const e=n.map((e=>({id:e.id.substring(0,6),name:e.name,workspace:(0,l.g)(e.context)||(0,u.G)(e.context)?e.context.workspace.name:"",group:e.groupId?.substring(0,6),"depends on":e.dependenciesIds.map((e=>e.substring(0,6))).join(", ")})));yield(0,o.jsx)(p.Z,{items:e,headers:!0})}}else if(t.tasks.length>0){if(yield(0,o.jsx)(h.Z,{manager:this.manager}),t.start(this.manager),(await(0,r.waitFor$)(t,"finished")).failed>0)throw new f.T(1)}else c.nC.get(s.Logger).warning("No task found")}};j([(0,c.yT)(d.N)],b.prototype,"manager",void 0),b=j([(0,a.injectable)()],b)},4244:(e,t,n)=>{n.d(t,{F:()=>i,g:()=>s});var o=n(3410),r=n(3265);function s(e){return"workspace"in e&&"command"in e}class i extends o.SpawnTask{constructor(e,t,n,o={}){let r=t;o.superCommand&&("string"==typeof o.superCommand&&(o.superCommand=[o.superCommand]),o.superCommand.length>0&&(r=o.superCommand[0],n=[...o.superCommand.slice(1),t,...n])),super(r,n,{workspace:e,command:t},{...o,cwd:e.cwd,env:{FORCE_COLOR:"1",...o.env}}),this.workspace=e,this._logStreams()}_logStreams(){(0,r.m)(this,"stdout").subscribe((e=>this._logger.info(e))),(0,r.m)(this,"stderr").subscribe((e=>this._logger.info(e)))}}},6839:(e,t,n)=>{n.d(t,{G:()=>l,s:()=>u});var o=n(2786),r=n(3410),s=n(466),i=n(8727),a=n(4244),c=n(6379);function l(e){return"workspace"in e&&"script"in e}class u extends r.GroupTask{constructor(e,t,n,o){super(t,{workspace:e,script:t},o),this.workspace=e,this.script=t,this.args=n,this._preHookTasks=null,this._postHookTasks=null,this._scriptTasks=null,this._runHooks=o?.runHooks??!0}async _runScript(e,t){const n=this.workspace.getScript(e);if(!n)return null;const[o,...l]=(0,c.z)(n);if("jill"===o){this._logger.debug(`Interpreting ${n}`);const e=l.map((e=>e.replace(/^["'](.+)["']$/,"$1"))),t=s.nC.get(i.T),o=await t.tasksOf(e,{project:this.project,workspace:this.workspace});if(o.length){const e=new r.TaskSet;for(const t of o)e.add(t);return e}}const u=await this.workspace.project.packageManager(),d=new r.TaskSet;return d.add(new a.F(this.workspace,o,[...l,...t],{logger:this._logger,superCommand:"yarn"===u?["yarn","exec"]:void 0})),d}async prepare(){if(this._scriptTasks=await this._runScript(this.script,this.args),!this._scriptTasks)throw new Error(`No script ${this.script} in ${this.workspace.name}`);if(this._runHooks&&(this._preHookTasks=await this._runScript(`pre${this.script}`,[]),this._postHookTasks=await this._runScript(`post${this.script}`,[])),this._preHookTasks){this._logger.verbose(`Found pre-hook script "pre${this.script}"`);for(const e of this._preHookTasks)this.add(e)}for(const e of this._scriptTasks)this.add(e);if(this._postHookTasks){this._logger.verbose(`Found post-hook script "post${this.script}"`);for(const e of this._postHookTasks)this.add(e)}}async*_orchestrate(){if(!this._scriptTasks)throw new Error("ScriptTask needs to be prepared. Call prepare before starting it");return this._preHookTasks&&(yield*this._preHookTasks,await this._hasFailed(this._preHookTasks))?this.setStatus("failed"):(yield*this._scriptTasks,await this._hasFailed(this._scriptTasks)||this._postHookTasks&&(yield*this._postHookTasks,await this._hasFailed(this._postHookTasks))?this.setStatus("failed"):void this.setStatus("done"))}async _hasFailed(e){return(await(0,o.waitFor$)(e,"finished")).failed>0}_stop(){if(this._scriptTasks)for(const e of this._scriptTasks)e.stop()}complexity(e=new Map){let t=super.complexity(e);return this._scriptTasks&&(t+=this._scriptTasks.tasks.reduce(((t,n)=>t+n.complexity(e)),0)),e.set(this.id,t),t}get project(){return this.workspace.project}}},5099:(e,t,n)=>{n.d(t,{N:()=>a});var o=n(8858),r=n(3410),s=n(7839),i=n(466);const a=Symbol("jujulego:jill:TaskManager");i.nC.bind(a).toDynamicValue((({container:e})=>{const t=e.get(s.k),n=e.get(o.Logger);return new r.TaskManager({jobs:t.jobs,logger:n})})).inSingletonScope()},6872:(e,t,n)=>{n.d(t,{Z:()=>d});var o=n(832),r=n(3410),s=n(9149),i=n(810),a=n(7839),c=n(466),l=n(4244),u=n(6797);function d({group:e}){const[t,n]=(0,i.useState)(!1),[p,h]=(0,i.useState)(e.status),[f,g]=(0,i.useState)([...e.tasks]),[m,j]=(0,i.useState)(!0),b=(0,i.useMemo)((()=>t||f.some((e=>!(0,l.g)(e.context)))),[t,f]),y=(0,i.useMemo)((()=>!b&&m),[b,m]);return(0,i.useLayoutEffect)((()=>{const e=c.nC.get(a.k);e.verbose&&n(["verbose","debug"].includes(e.verbose))}),[]),(0,i.useLayoutEffect)((()=>e.on("status",(e=>{h(e.status)}))),[e]),(0,i.useLayoutEffect)((()=>{let t=!1;return e.on("task.added",(()=>{t||(t=!0,queueMicrotask((()=>{g([...e.tasks]),t=!1})))}))}),[e]),(0,i.useLayoutEffect)((()=>{"running"===p?j(!1):"done"===p&&j(!0)}),[p]),(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(u.Z,{task:e}),y||(0,o.jsx)(s.Box,{flexDirection:"column",marginLeft:2,children:f.map((e=>(0,o.jsx)(i.Fragment,{children:e instanceof r.GroupTask?(0,o.jsx)(d,{group:e}):(0,o.jsx)(u.Z,{task:e})},e.id)))})]})}},5894:(e,t,n)=>{n.d(t,{Z:()=>l});var o=n(832),r=n(9149),s=n(810),i=n(466),a=n(5050);function c(){const{write:e}=(0,r.useStderr)();return(0,s.useLayoutEffect)((()=>{const t=i.nC.get(a.B),n=t.listeners;t.clear();const o=t.subscribe((t=>{e((0,a.h)(t)+"\n")}));return()=>{o();for(const e of n)t.subscribe(e)}}),[e]),null}function l({children:e}){return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(c,{}),e]})}},5740:(e,t,n)=>{n.d(t,{Z:()=>i});var o=n(832),r=n(9149),s=n(6379);function i({items:e,headers:t}){return 0===e.length?null:(0,o.jsx)(r.Box,{children:Object.keys(e[0]).map((n=>(0,o.jsxs)(r.Box,{flexDirection:"column",marginRight:2,children:[t&&(0,o.jsx)(r.Text,{bold:!0,children:(0,s.k)(n)}),e.map(((e,t)=>(0,o.jsx)(r.Text,{children:e[n]||" "},t)))]},n)))})}},4887:(e,t,n)=>{n.d(t,{Z:()=>l});var o=n(832),r=n(3410),s=n(810),i=n(6872),a=n(6797);function c(e){return!(e.group||"hidden"in e.context&&e.context.hidden)}function l({manager:e}){const[t,n]=(0,s.useState)(e.tasks.filter(c));return(0,s.useLayoutEffect)((()=>{let t=!1;return e.on("added",(()=>{t||(t=!0,queueMicrotask((()=>{n(e.tasks.filter(c)),t=!1})))}))}),[e]),(0,o.jsx)(o.Fragment,{children:t.map((e=>e instanceof r.GroupTask?(0,o.jsx)(i.Z,{group:e},e.id):(0,o.jsx)(a.Z,{task:e},e.id)))})}},1562:(e,t,n)=>{n.d(t,{Z:()=>i});var o=n(832),r=n(9149),s=n(6839);function i({task:e}){return(0,s.G)(e.context)?(0,o.jsxs)(r.Text,{children:["Run ",(0,o.jsx)(r.Text,{bold:!0,children:e.context.script})," in ",e.context.workspace.name]}):(0,o.jsx)(r.Text,{children:e.name})}},6797:(e,t,n)=>{n.d(t,{Z:()=>p});var o=n(832),r=n(9149),s=n(9165),i=n(6133),a=n(9321),c=n(810),l=n(4244),u=n(6839),d=n(1562);function p({task:e}){const[t,n]=(0,c.useState)(e.status),[p,h]=(0,c.useState)(0);(0,c.useLayoutEffect)((()=>e.on("status",(e=>{n(e.status)}))),[e]),(0,c.useLayoutEffect)((()=>e.on("completed",(({duration:e})=>{h(e)}))),[e]);const f=(0,l.g)(e.context)&&e.group&&(0,u.G)(e.group.context);switch(t){case"blocked":case"ready":case"starting":return(0,o.jsxs)(r.Box,{children:[(0,o.jsx)(r.Text,{color:"grey",children:"·"}),(0,o.jsx)(r.Box,{paddingLeft:1,children:(0,o.jsx)(r.Text,{color:"grey",wrap:"truncate",children:(0,o.jsx)(d.Z,{task:e})})})]});case"running":return(0,o.jsxs)(r.Box,{children:[(0,o.jsx)(r.Text,{color:f?"dim":void 0,children:(0,o.jsx)(s.default,{})}),(0,o.jsx)(r.Box,{paddingLeft:1,children:(0,o.jsx)(r.Text,{color:f?"dim":void 0,wrap:"truncate",children:(0,o.jsx)(d.Z,{task:e})})})]});case"done":return(0,o.jsxs)(r.Box,{children:[(0,o.jsx)(r.Text,{color:"green",children:i.default.success}),(0,o.jsx)(r.Box,{paddingLeft:1,children:(0,o.jsx)(r.Text,{color:f?"dim":void 0,wrap:"truncate",children:(0,o.jsx)(d.Z,{task:e})})}),(0,o.jsx)(r.Box,{paddingLeft:1,flexShrink:0,children:(0,o.jsxs)(r.Text,{color:f?"grey":"dim",children:["(took ",(0,a.default)(p),")"]})})]});case"failed":return(0,o.jsxs)(r.Box,{children:[(0,o.jsx)(r.Text,{color:"red",children:i.default.error}),(0,o.jsx)(r.Box,{paddingLeft:1,children:(0,o.jsx)(r.Text,{color:f?"dim":void 0,wrap:"truncate",children:(0,o.jsx)(d.Z,{task:e})})}),(0,o.jsx)(r.Box,{paddingLeft:1,flexShrink:0,children:(0,o.jsxs)(r.Text,{color:f?"grey":"dim",children:["(took ",(0,a.default)(p),")"]})})]})}}},3265:(e,t,n)=>{n.d(t,{m:()=>r});var o=n(2786);function r(e,t){const n=(0,o.source$)();if(e.completed)return n;let r="";const s=e.on(`stream.${t}`,(e=>{const t=(r+e.data.toString("utf-8")).split(/\r?\n/);r=t.pop()??"";for(const e of t)n.next(e)}));return(0,o.once$)(e,"completed",(()=>{s(),r&&n.next(r)})),n}},6505:(e,t,n)=>{n.d(t,{T:()=>o});class o extends Error{constructor(e,t){super(t),this.code=e}}},8520:(e,t,n)=>{async function o(e){return import("win32"===process.platform?`file://${e}`:e)}function r(e){return e}n.d(t,{v:()=>r,y:()=>o})},5472:(e,t,n)=>{function o(e,t=process.stdout){t.isTTY?t.write(JSON.stringify(e,null,2)):t.write(JSON.stringify(e))}n.d(t,{i:()=>o})},6379:(e,t,n)=>{function o(e){return e.charAt(0).toUpperCase()+e.substring(1).toLowerCase()}function r(e){e=e.trim();const t=[];let n="",o=0;for(let r=1;r<e.length;++r){const s=e[r];n?s===n&&(n=""):['"',"'"].includes(s)?n=s:" "===s&&(t.push(e.slice(o,r)),o=r+1)}return t.push(e.slice(o)),t}n.d(t,{k:()=>o,z:()=>r})},2180:(e,t,n)=>{n.d(t,{F:()=>s});var o=n(4086);const r=new o.BroadcastChannel("jujulego:jill:worker-cache");async function s(e,t){const n=(0,o.getEnvironmentData)(e);if(void 0!==n)return n;const s=await t();return(0,o.setEnvironmentData)(e,s),r.postMessage({key:e,value:s}),s}r.unref(),r.onmessage=e=>{const t=e;(function(e){return"object"==typeof e&&null!==e&&"key"in e&&"value"in e})(t.data)&&(0,o.setEnvironmentData)(t.data.key,t.data.value)}}};
2
2
  //# sourceMappingURL=71.mjs.map
package/dist/71.mjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"71.mjs","mappings":"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","sources":["webpack://@jujulego/jill/./src/commons/context.service.ts","webpack://@jujulego/jill/./src/commons/logger.service.ts","webpack://@jujulego/jill/./src/commons/logger/parameters.ts","webpack://@jujulego/jill/./src/commons/logger/thread.gateway.ts","webpack://@jujulego/jill/./src/commons/logger/log.gateway.ts","webpack://@jujulego/jill/./src/ajv.config.ts","webpack://@jujulego/jill/./src/config/utils.ts","webpack://@jujulego/jill/./src/config/config-loader.ts","webpack://@jujulego/jill/./src/config/config-options.ts","webpack://@jujulego/jill/./src/constants.ts","webpack://@jujulego/jill/./src/inversify.config.ts","webpack://@jujulego/jill/./src/jill.application.ts","webpack://@jujulego/jill/./src/modules/command.ts","webpack://@jujulego/jill/./src/ink.config.tsx","webpack://@jujulego/jill/./src/modules/ink-command.tsx","webpack://@jujulego/jill/./src/modules/middleware.ts","webpack://@jujulego/jill/./src/modules/module.ts","webpack://@jujulego/jill/./src/modules/plugin-loader.service.ts","webpack://@jujulego/jill/./src/modules/service.ts","webpack://@jujulego/jill/./src/modules/task-command.tsx","webpack://@jujulego/jill/./src/tasks/command-task.ts","webpack://@jujulego/jill/./src/tasks/script-task.ts","webpack://@jujulego/jill/./src/tasks/task-manager.config.ts","webpack://@jujulego/jill/./src/ui/group-task-spinner.tsx","webpack://@jujulego/jill/./src/ui/static-logs.tsx","webpack://@jujulego/jill/./src/ui/layout.tsx","webpack://@jujulego/jill/./src/ui/list.tsx","webpack://@jujulego/jill/./src/ui/task-manager-spinner.tsx","webpack://@jujulego/jill/./src/ui/task-name.tsx","webpack://@jujulego/jill/./src/ui/task-spinner.tsx","webpack://@jujulego/jill/./src/utils/events.ts","webpack://@jujulego/jill/./src/utils/exit.ts","webpack://@jujulego/jill/./src/utils/import.ts","webpack://@jujulego/jill/./src/utils/json.ts","webpack://@jujulego/jill/./src/utils/string.ts","webpack://@jujulego/jill/./src/utils/worker-cache.ts"],"sourcesContent":["import { Logger, withLabel } from '@jujulego/logger';\nimport { inject } from 'inversify';\nimport { AsyncLocalStorage } from 'node:async_hooks';\n\nimport { Service } from '@/src/modules/service.ts';\nimport { type Project } from '@/src/project/project.ts';\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { type JillApplication } from '@/src/jill.application.ts';\n\n// Types\nexport interface Context {\n application?: JillApplication;\n project?: Project;\n workspace?: Workspace;\n}\n\n// Service\n@Service()\nexport class ContextService implements Context {\n // Attributes\n private readonly _logger: Logger;\n private readonly _storage = new AsyncLocalStorage<Context>();\n\n // Constructor\n constructor(@inject(Logger) logger: Logger) {\n this._logger = logger.child(withLabel('context'));\n this.reset();\n }\n\n // Methods\n reset(context: Context = {}): void {\n this._storage.enterWith(context);\n }\n\n private _getContext(): Context {\n const ctx = this._storage.getStore();\n\n if (!ctx) {\n this._logger.warning('Trying to access uninitialized context');\n return {};\n }\n\n return ctx;\n }\n\n private _updateContext(update: Partial<Context>): void {\n Object.assign(this._getContext(), update);\n }\n\n // Properties\n get application(): JillApplication | undefined {\n return this._getContext().application;\n }\n\n set application(application: JillApplication | undefined) {\n this._updateContext({ application });\n }\n\n get project(): Project | undefined {\n return this._getContext().project;\n }\n\n set project(project: Project | undefined) {\n this._updateContext({ project });\n }\n\n get workspace(): Workspace | undefined {\n return this._getContext().workspace;\n }\n\n set workspace(workspace: Workspace | undefined) {\n this._updateContext({ workspace });\n }\n}\n","import { Logger, logger$, withTimestamp } from '@jujulego/logger';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { LogGateway } from '@/src/commons/logger/log.gateway.ts';\n\n// Service\ncontainer.bind(Logger).toDynamicValue(() => logger$(withTimestamp()))\n .inSingletonScope()\n .onActivation(({ container }, logger) => {\n const gateway = container.get(LogGateway);\n gateway.connect(logger);\n\n return logger;\n });\n","import { type interfaces as int } from 'inversify';\n\nimport { container } from '@/src/inversify.config.ts';\n\n// Constants\nexport const LOG_BROADCAST_CHANNEL: int.ServiceIdentifier<string> = Symbol.for('jujulego:jill:log-broadcast-channel');\n\n// Parameters\ncontainer.bind(LOG_BROADCAST_CHANNEL).toConstantValue('jujulego:jill:logger');\n","import { Source, source$ } from '@jujulego/event-tree';\nimport { LogLevel, quick, withTimestamp } from '@jujulego/logger';\nimport { inject } from 'inversify';\nimport { BroadcastChannel } from 'node:worker_threads';\n\nimport { Service } from '@/src/modules/service.ts';\n\nimport { LOG_BROADCAST_CHANNEL } from './parameters.ts';\nimport { JillLog } from './types.ts';\n\n// Gateway\n@Service()\nexport class ThreadGateway implements Source<JillLog> {\n // Attributes\n readonly channel: BroadcastChannel;\n\n private readonly _source = source$<JillLog>();\n\n // Constructor\n constructor(\n @inject(LOG_BROADCAST_CHANNEL) channel: string\n ) {\n this.channel = new BroadcastChannel(channel);\n this.channel.unref();\n\n this.channel.onmessage = (log) => {\n this._source.next((log as MessageEvent<JillLog>).data);\n };\n\n this.channel.onmessageerror = (data) => {\n this._source.next(withTimestamp()({\n level: LogLevel.error,\n message: quick.string`Unable to read message: #!json:${(data as MessageEvent).data}`\n }));\n };\n }\n\n // Methods\n next(data: JillLog): void {\n this.channel.postMessage(data);\n }\n\n readonly subscribe = this._source.subscribe;\n readonly unsubscribe = this._source.unsubscribe;\n readonly clear = this._source.clear;\n}\n","import { filter$, flow$, var$ } from '@jujulego/aegis';\nimport { Listener, Observable, OffFn, source$ } from '@jujulego/event-tree';\nimport { LogLevel, qlevelColor, quick, toStderr } from '@jujulego/logger';\nimport { qprop } from '@jujulego/quick-tag';\nimport { chalkTemplateStderr } from 'chalk-template';\nimport { interfaces as int } from 'inversify';\nimport wt from 'node:worker_threads';\n\nimport { OnServiceActivate, Service } from '@/src/modules/service.ts';\n\nimport { ThreadGateway } from './thread.gateway.ts';\nimport { JillLog } from './types.ts';\n\n// Utils\nexport const jillLogFormat = qlevelColor(\n quick.wrap(chalkTemplateStderr)\n .function<JillLog>`#?:${qprop('label')}{grey [#$]} ?#${qprop('message')}`\n);\n\n// Service\n@Service()\nexport class LogGateway implements Observable<JillLog>, OnServiceActivate {\n // Attributes\n readonly level$ = var$(LogLevel.info);\n\n private readonly _source = source$<JillLog>();\n\n // Lifecycle\n onServiceActivate({ container }: int.Context) {\n const threadGtw = container.get(ThreadGateway);\n\n if (wt.isMainThread) {\n // Redirect logs to stderr\n flow$(\n this._source,\n toStderr(jillLogFormat),\n );\n\n // Add thread gateway as input\n this.connect(threadGtw);\n } else {\n // Redirect logs to thread gateway\n flow$(this._source,\n threadGtw\n );\n }\n }\n\n // Methods\n readonly subscribe = this._source.subscribe;\n readonly unsubscribe = this._source.unsubscribe;\n readonly clear = this._source.clear;\n\n connect(origin: Observable<JillLog>): OffFn {\n return flow$(origin,\n filter$((log) => log.level >= this.level),\n this._source\n );\n }\n\n // Properties\n get listeners(): readonly Listener<JillLog>[] {\n return Array.from(this._source.listeners);\n }\n\n get level(): LogLevel {\n return this.level$.read();\n }\n\n set level(level: LogLevel) {\n this.level$.mutate(level);\n }\n}\n","import { Logger, withLabel } from '@jujulego/logger';\nimport Ajv from 'ajv';\nimport { type interfaces as int } from 'inversify';\n\nimport { container } from './inversify.config.ts';\n\n// Symbols\nexport const AJV: int.ServiceIdentifier<Ajv.default> = Symbol('jujulego:jill:Ajv');\n\n// Setup\ncontainer\n .bind(AJV)\n .toDynamicValue(({ container }) => {\n const logger = container.get(Logger);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return new (Ajv as any)({\n allErrors: true,\n logger: logger.child(withLabel('ajv')),\n strict: process.env.NODE_ENV === 'development' ? 'log' : true,\n });\n })\n .inSingletonScope();\n\n","import { type interfaces as int } from 'inversify';\nimport { type ValidateFunction } from 'ajv';\nimport { cosmiconfig, defaultLoaders } from 'cosmiconfig';\n\nimport { AJV } from '@/src/ajv.config.ts';\nimport schema from '@/src/config/schema.json';\nimport { container } from '@/src/inversify.config.ts';\nimport { dynamicImport } from '@/src/utils/import.ts';\n\nimport { type IConfig, type IConfigExplorer } from './types.ts';\n\n// Symbols\nexport const CONFIG_EXPLORER: int.ServiceIdentifier<IConfigExplorer> = Symbol('jujulego:jill:config-explorer');\nexport const CONFIG_VALIDATOR: int.ServiceIdentifier<ValidateFunction<IConfig>> = Symbol('jujulego:jill:config-validator');\n\n// Setup\ncontainer\n .bind(CONFIG_VALIDATOR)\n .toDynamicValue(({ container }) => {\n const ajv = container.get(AJV);\n return ajv.compile<IConfig>(schema);\n })\n .inSingletonScope();\n\ncontainer\n .bind(CONFIG_EXPLORER)\n .toDynamicValue(() => {\n return cosmiconfig('jill', {\n loaders: {\n '.cjs': (filepath) => dynamicImport(filepath).then((mod) => mod.default),\n '.js': (filepath) => dynamicImport(filepath).then((mod) => mod.default),\n '.json': defaultLoaders['.json'],\n '.yaml': defaultLoaders['.yaml'],\n '.yml': defaultLoaders['.yml'],\n noExt: defaultLoaders.noExt,\n }\n });\n })\n .inSingletonScope();\n","import { Logger, LogLevel, withLabel } from '@jujulego/logger';\nimport { type interfaces as int } from 'inversify';\nimport os from 'node:os';\nimport path from 'node:path';\n\nimport { AJV } from '@/src/ajv.config.ts';\nimport { LogGateway } from '@/src/commons/logger/log.gateway.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { ExitException } from '@/src/utils/exit.ts';\nimport { workerCache } from '@/src/utils/worker-cache.ts';\n\nimport { CONFIG_OPTIONS } from './config-options.ts';\nimport { type IConfig } from './types.ts';\nimport { CONFIG_EXPLORER, CONFIG_VALIDATOR } from './utils.ts';\n\n// Symbols\nexport const CONFIG: int.ServiceIdentifier<IConfig> = Symbol('jujulego:jill:config');\n\n// Loader\nexport async function configLoader() {\n const logger = container.get(Logger).child(withLabel('config'));\n\n const options = container.get(CONFIG_OPTIONS);\n const explorer = container.get(CONFIG_EXPLORER);\n const validator = container.get(CONFIG_VALIDATOR);\n\n // Load file\n const loaded = await explorer.search();\n const config = loaded?.config ?? {};\n\n // Apply options from cli\n if (options.jobs) config.jobs = options.jobs;\n if (options.verbose) config.verbose = options.verbose;\n\n // Apply default\n config.jobs ??= (os.cpus().length - 1);\n\n // Validate\n if (!validator(config)) {\n const ajv = container.get(AJV);\n const errors = ajv.errorsText(validator.errors, { separator: '\\n- ', dataVar: 'config' });\n\n logger.error(`Errors in config file:\\n- ${errors}`);\n throw new ExitException(1);\n }\n\n // Apply on logger\n if (config.verbose) {\n container.get(LogGateway).level = LogLevel[config.verbose];\n }\n\n if (loaded) {\n // Resolve paths relative to config file\n const base = path.dirname(loaded.filepath);\n config.plugins = config.plugins?.map((plugin) => path.resolve(base, plugin));\n\n logger.verbose(`Loaded ${loaded.filepath} config file`);\n }\n\n logger.debug`Loaded config:\\n#!json:${config}`;\n\n return config;\n}\n\ncontainer\n .bind(CONFIG)\n .toDynamicValue(async () => await workerCache('jujulego:jill:config', configLoader))\n .inSingletonScope();\n","import yargs, { type Argv } from 'yargs';\nimport { type interfaces as int } from 'inversify';\nimport { hideBin } from 'yargs/helpers';\n\nimport { container } from '@/src/inversify.config.ts';\n\nimport { type IConfig } from './types.ts';\n\n// Symbols\nexport const CONFIG_OPTIONS: int.ServiceIdentifier<IConfig> = Symbol('jujulego:jill:config-options');\n\n// Constants\nconst VERBOSITY_LEVEL: Record<number, IConfig['verbose']> = {\n 1: 'verbose',\n 2: 'debug',\n};\n\n// Options\nexport function applyConfigOptions(parser: Argv): Argv<Omit<IConfig, 'plugins'>> {\n return parser\n .option('verbose', {\n alias: 'v',\n type: 'count',\n description: 'Set verbosity level',\n coerce: (cnt) => VERBOSITY_LEVEL[Math.min(cnt, 2)]\n })\n .option('jobs', {\n alias: 'j',\n type: 'number',\n description: 'Set maximum parallel job number',\n });\n}\n\ncontainer\n .bind(CONFIG_OPTIONS)\n .toDynamicValue(() => {\n const parser = yargs(hideBin(process.argv))\n .help(false)\n .version(false);\n\n applyConfigOptions(parser);\n\n return parser.parse();\n })\n .inSingletonScope();\n","// Constants\nexport const CURRENT = 'current';\n","import { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\n\nimport 'reflect-metadata';\n\nimport { fixDefaultExport } from './utils/import.ts';\n\n// Container\nexport const container = new Container();\n\n// Utilities\nexport const { lazyInject, lazyInjectNamed } = fixDefaultExport(getDecorators)(container);\n","import { Logger, withLabel } from '@jujulego/logger';\nimport { type Task } from '@jujulego/tasks';\nimport { inject, injectable, type interfaces as int } from 'inversify';\nimport yargs, { type Argv, type CommandModule } from 'yargs';\n\nimport { ContextService, type Context } from '@/src/commons/context.service.ts';\nimport { applyConfigOptions } from '@/src/config/config-options.ts';\nimport { CURRENT } from '@/src/constants.ts';\nimport { container, lazyInjectNamed } from '@/src/inversify.config.ts';\nimport { buildCommandModule, COMMAND, COMMAND_MODULE, getCommandOpts, type ICommand } from '@/src/modules/command.ts';\nimport { getModule } from '@/src/modules/module.ts';\nimport { PluginLoaderService } from '@/src/modules/plugin-loader.service.ts';\nimport { TaskCommand } from '@/src/modules/task-command.tsx';\nimport { type Class } from '@/src/types.ts';\n\n// @ts-ignore: Outside of typescript's rootDir in build\nimport pkg from '../package.json';\n\n// Application\n@injectable()\nexport class JillApplication {\n // Attributes\n readonly container: int.Container;\n readonly parser: Argv;\n\n // Constructor\n constructor(\n @inject(ContextService)\n private readonly context: ContextService,\n @inject(PluginLoaderService)\n private readonly plugins: PluginLoaderService,\n @inject(Logger)\n private readonly logger: Logger,\n ) {\n // Create container\n this.container = container.createChild();\n\n // Create parser\n this.parser = yargs()\n .scriptName('jill')\n .completion('completion', 'Generate bash completion script')\n .help('help', 'Show help for a command')\n .version('version', 'Show version', pkg.version)\n .wrap(process.stdout.columns)\n .exitProcess(false);\n }\n\n // Methods\n private _prepareParser(commands: CommandModule[]): Argv {\n applyConfigOptions(this.parser);\n\n return this.parser\n .command(commands)\n .recommendCommands()\n .strict()\n .fail(false);\n }\n\n private async _loadPlugins(): Promise<void> {\n this.logger.child(withLabel('plugin')).verbose('Loading plugin <core>');\n\n const { CorePlugin } = await import('@/src/core.plugin.ts');\n this.container.load(getModule(CorePlugin, true));\n\n await this.plugins.loadPlugins(this.container);\n }\n\n async run(argv: string | readonly string[]): Promise<void> {\n this.context.reset({ application: this });\n await this._loadPlugins();\n\n // Parse command\n const commands = await this.container.getAllAsync(COMMAND_MODULE);\n\n await this._prepareParser(commands).parseAsync(argv);\n }\n\n async tasksOf(argv: string[], ctx: Omit<Context, 'application'> = {}): Promise<Task[]> {\n this.context.reset({ ...ctx, application: this });\n await this._loadPlugins();\n\n // Prepare commands\n const commands = await this.container.getAllAsync(COMMAND);\n\n return new Promise<Task[]>((resolve, reject) => {\n const modules: CommandModule[] = [];\n\n for (const cmd of commands) {\n const opts = getCommandOpts(cmd.constructor as Class<ICommand>);\n const mod = buildCommandModule(cmd, opts);\n\n mod.handler = async (args) => {\n if (cmd instanceof TaskCommand) {\n const tasks: Task[] = [];\n\n for await (const tsk of cmd.prepare(args)) {\n tasks.push(tsk);\n }\n\n resolve(tasks);\n } else {\n resolve([]);\n }\n };\n\n modules.push(mod);\n }\n\n // Parse command\n this._prepareParser(modules)\n .parseAsync(argv)\n .catch(reject);\n });\n }\n}\n\ncontainer.bind(JillApplication)\n .toSelf()\n .inTransientScope()\n .whenTargetIsDefault();\n\n// Lazy injection\nexport function LazyCurrentApplication() {\n return lazyInjectNamed(JillApplication, CURRENT);\n}\n\ncontainer.bind(JillApplication)\n .toDynamicValue(({ container }) => {\n const ctx = container.get(ContextService);\n const app = ctx.application;\n\n if (!app) {\n throw new Error('Cannot inject current application, it not yet defined');\n }\n\n return app;\n })\n .whenTargetNamed(CURRENT);\n","import { Logger } from '@jujulego/logger';\nimport { decorate, injectable, type interfaces as int } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv, type CommandModule } from 'yargs';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { setRegistry } from '@/src/modules/module.ts';\nimport { type Awaitable, type Class, type Type } from '@/src/types.ts';\nimport { ExitException } from '@/src/utils/exit.ts';\n\nimport { applyMiddlewares, type IMiddleware } from './middleware.ts';\n\n// Symbols\nconst COMMAND_OPTS = Symbol('jujulego:jill:command-opts');\n\nexport const COMMAND: int.ServiceIdentifier<ICommand> = Symbol('jujulego:jill:command');\nexport const COMMAND_MODULE: int.ServiceIdentifier<CommandModule> = Symbol('jujulego:jill:command-module');\n\n// Types\nexport interface ICommand<A = unknown> {\n builder?: (parser: Argv) => Argv<A>;\n handler(args: ArgumentsCamelCase<A>): Awaitable<void>;\n}\n\nexport interface ICommandOpts {\n readonly command: string;\n readonly aliases?: string | readonly string[];\n readonly describe?: string;\n readonly deprecated?: boolean;\n readonly middlewares?: Type<IMiddleware>[];\n}\n\n// Utils\nexport function getCommandOpts(target: Class<ICommand>): ICommandOpts {\n const opts = Reflect.getMetadata(COMMAND_OPTS, target);\n\n if (typeof opts !== 'object') {\n throw new Error(`No command options found in ${target.name}`);\n }\n\n return opts;\n}\n\nexport function buildCommandModule(cmd: ICommand, opts: ICommandOpts): CommandModule {\n return {\n command: opts.command,\n aliases: opts.aliases,\n describe: opts.describe,\n deprecated: opts.deprecated,\n\n builder(parser: Argv) {\n if (opts.middlewares) {\n parser = applyMiddlewares(parser, opts.middlewares);\n }\n\n if (cmd.builder) {\n parser = cmd.builder(parser);\n }\n\n return parser;\n },\n handler: async (args) => {\n try {\n await cmd.handler(args);\n } catch (err) {\n if (err.message) {\n const logger = container.get(Logger);\n logger.error(err.message);\n }\n\n throw new ExitException(1);\n }\n },\n };\n}\n\n// Decorator\nexport function Command(opts: ICommandOpts) {\n return (target: Class<ICommand>) => {\n decorate(injectable(), target);\n\n Reflect.defineMetadata(COMMAND_OPTS, opts, target);\n\n const cmd = opts.command.split(' ')[0];\n setRegistry(target, (bind) => {\n bind(target).toSelf();\n\n bind(COMMAND)\n .toDynamicValue(({ container }) => container.getAsync(target))\n .whenTargetNamed(cmd);\n\n bind(COMMAND_MODULE)\n .toDynamicValue(async ({ container }) => {\n const cmd = await container.getAsync(target);\n return buildCommandModule(cmd, opts);\n })\n .whenTargetNamed(cmd);\n });\n };\n}\n","import { type Instance } from 'ink';\nimport { render } from 'ink';\nimport { type interfaces as int } from 'inversify';\nimport wt from 'node:worker_threads';\n\nimport { container } from '@/src/inversify.config.ts';\nimport Layout from '@/src/ui/layout.tsx';\n\n// Constants\nexport const INK_APP: int.ServiceIdentifier<Instance> = Symbol.for('jujulego:jill:ink-app');\n\n// Setup\ncontainer\n .bind(INK_APP)\n .toDynamicValue(() => {\n if (!wt.isMainThread) {\n throw new Error('Ink should only be used in main thread');\n }\n\n return render(<Layout />);\n })\n .inSingletonScope();\n","import { type Instance} from 'ink';\nimport { injectable } from 'inversify';\nimport { type ReactNode } from 'react';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { INK_APP } from '@/src/ink.config.tsx';\nimport { lazyInject } from '@/src/inversify.config.ts';\nimport { type AwaitableGenerator } from '@/src/types.ts';\nimport Layout from '@/src/ui/layout.tsx';\n\nimport { type ICommand } from './command.ts';\n\n// Class\n@injectable()\nexport abstract class InkCommand<A = unknown> implements ICommand<A> {\n // Lazy injections\n @lazyInject(INK_APP)\n readonly app: Instance;\n\n // Methods\n abstract render(args: ArgumentsCamelCase<A>): AwaitableGenerator<ReactNode>;\n\n builder(parser: Argv): Argv<A> {\n return parser as Argv<A>;\n }\n\n async handler(args: ArgumentsCamelCase<A>): Promise<void> {\n for await (const children of this.render(args)) {\n this.app.rerender(\n <Layout>\n { children }\n </Layout>\n );\n }\n\n await this.app.waitUntilExit();\n }\n}\n","import { decorate, injectable } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { type Awaitable, type Type } from '@/src/types.ts';\n\n// Types\nexport interface IMiddleware<A = unknown> {\n builder?: (parser: Argv) => Argv<A>;\n handler(args: ArgumentsCamelCase<A>): Awaitable<void>;\n}\n\n// Decorator\nexport function Middleware() {\n return (target: Type<IMiddleware>) => {\n decorate(injectable(), target);\n container.bind(target).toSelf().inSingletonScope();\n };\n}\n\n// Utils\nexport function applyMiddlewares(parser: Argv, middlewares: Type<IMiddleware>[]): Argv {\n let tmp = parser;\n\n for (const cls of middlewares) {\n const middleware = container.get(cls);\n\n if (middleware.builder) {\n tmp = middleware.builder(tmp);\n }\n\n tmp.middleware((args) => middleware.handler(args));\n }\n\n return tmp;\n}\n","import { ContainerModule, type interfaces as int } from 'inversify';\n\nimport { type Class } from '@/src/types.ts';\n\n// Symbols\nconst MODULE = Symbol('jujulego:jill:module');\nconst REGISTRY = Symbol('jujulego:jill:registry');\n\n// Utils\nexport function getRegistry(target: Class): int.ContainerModuleCallBack {\n const registry = Reflect.getMetadata(REGISTRY, target);\n\n if (typeof registry !== 'function') {\n throw new Error(`No registry found in ${target.name}`);\n }\n\n return registry;\n}\n\nexport function setRegistry(target: Class, registry: int.ContainerModuleCallBack) {\n Reflect.defineMetadata(REGISTRY, registry, target);\n}\n\nexport function getModule(target: Class): ContainerModule | null;\nexport function getModule(target: Class, assert: true): ContainerModule;\nexport function getModule(target: Class, assert = false): ContainerModule | null {\n let module = Reflect.getMetadata(MODULE, target);\n\n if (!module || !(module instanceof ContainerModule)) {\n const registry = Reflect.getMetadata(REGISTRY, target);\n\n if (typeof registry !== 'function') {\n if (assert) {\n throw new Error(`No module found in ${target.name}`);\n }\n\n return null;\n }\n\n module = new ContainerModule(registry);\n setModule(target, module);\n }\n\n return module;\n}\n\nexport function setModule(target: Class, module: ContainerModule) {\n Reflect.defineMetadata(MODULE, module, target);\n}\n","import { Logger, withLabel } from '@jujulego/logger';\nimport { type ContainerModule, inject, type interfaces as int } from 'inversify';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { type IConfig } from '@/src/config/types.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { dynamicImport } from '@/src/utils/import.ts';\n\nimport { getModule } from './module.ts';\nimport { Service } from './service.ts';\n\n// Class\n@Service()\nexport class PluginLoaderService {\n // Attributes\n private readonly _logger: Logger;\n\n // Constructor\n constructor(\n @inject(CONFIG)\n private readonly _config: IConfig,\n @inject(Logger)\n logger: Logger,\n ) {\n this._logger = logger.child(withLabel('plugin'));\n }\n\n // Methods\n private async _importPlugin(filepath: string): Promise<ContainerModule> {\n this._logger.verbose`Loading plugin ${filepath}`;\n\n // Load plugin\n let plugin = await dynamicImport(filepath);\n\n while (plugin && typeof plugin === 'object' && 'default' in plugin) {\n plugin = plugin.default;\n }\n\n if (!plugin) {\n throw new Error(`Invalid plugin ${filepath}: no plugin class found`);\n }\n\n // Load module from plugin\n const module = getModule(plugin);\n\n if (!module) {\n throw new Error(`Invalid plugin ${filepath}: invalid plugin class`);\n }\n\n return module;\n }\n\n async loadPlugins(ctn: int.Container = container): Promise<void> {\n if (!this._config.plugins) return;\n\n for (const path of this._config.plugins) {\n const plugin = await this._importPlugin(path);\n ctn.load(plugin);\n }\n }\n}\n","import { decorate, injectable, interfaces as int } from 'inversify';\n\nimport { container } from '@/src/inversify.config.ts';\n\n// Types\nexport interface OnServiceActivate {\n onServiceActivate(context: int.Context): void;\n}\n\n// Decorators\n/**\n * Register class as a service\n */\nexport function Service(): ClassDecorator {\n return (cls) => {\n decorate(injectable(), cls);\n container.bind(cls).toSelf().inSingletonScope()\n .onActivation((ctx, service) => {\n if ('onServiceActivate' in service) {\n service.onServiceActivate(ctx);\n }\n\n return service;\n });\n\n return cls;\n };\n}\n","import { waitFor$ } from '@jujulego/event-tree';\nimport { Logger } from '@jujulego/logger';\nimport { plan as extractPlan, type Task, type TaskManager, TaskSet, type TaskSummary } from '@jujulego/tasks';\nimport { injectable } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { container, lazyInject } from '@/src/inversify.config.ts';\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\nimport { TASK_MANAGER } from '@/src/tasks/task-manager.config.ts';\nimport { type AwaitableGenerator } from '@/src/types.ts';\nimport List from '@/src/ui/list.tsx';\nimport TaskManagerSpinner from '@/src/ui/task-manager-spinner.tsx';\nimport { ExitException } from '@/src/utils/exit.ts';\nimport { printJson } from '@/src/utils/json.ts';\n\nimport { InkCommand } from './ink-command.tsx';\n\n// Types\nexport interface ITaskCommandArgs {\n plan: boolean;\n 'plan-mode': 'json' | 'list';\n}\n\n// Class\n@injectable()\nexport abstract class TaskCommand<A = unknown> extends InkCommand<A> {\n // Attributes\n @lazyInject(TASK_MANAGER)\n readonly manager: TaskManager;\n\n // Methods\n abstract prepare(args: ArgumentsCamelCase<A>): AwaitableGenerator<Task>;\n\n protected addTaskOptions(parser: Argv): Argv<ITaskCommandArgs> {\n return parser\n .option('plan', {\n type: 'boolean',\n desc: 'Only prints tasks to be run',\n default: false,\n })\n .option('plan-mode', {\n type: 'string',\n desc: 'Plan output mode',\n choices: ['json', 'list'] as const,\n default: 'list' as const\n });\n }\n\n async* render(args: ArgumentsCamelCase<A & ITaskCommandArgs>) {\n // Prepare tasks\n const tasks = new TaskSet();\n\n for await (const tsk of this.prepare(args)) {\n tasks.add(tsk);\n }\n\n if (args.plan) {\n const plan: TaskSummary[] = Array.from(extractPlan(tasks));\n\n if (args.planMode === 'json') {\n printJson(plan);\n } else {\n const data = plan.map((tsk) => ({\n id: tsk.id.substring(0, 6),\n name: tsk.name,\n workspace: isCommandCtx(tsk.context) || isScriptCtx(tsk.context) ? tsk.context.workspace.name : '',\n group: tsk.groupId?.substring(0, 6),\n 'depends on': tsk.dependenciesIds.map(id => id.substring(0, 6)).join(', ')\n }));\n\n yield <List items={data} headers/>;\n }\n } else if (tasks.tasks.length > 0) {\n // Render\n yield <TaskManagerSpinner manager={this.manager} />;\n\n // Start tasks\n tasks.start(this.manager);\n\n const result = await waitFor$(tasks, 'finished');\n\n if (result.failed > 0) {\n throw new ExitException(1);\n }\n } else {\n const logger = container.get(Logger);\n logger.warning('No task found');\n }\n }\n}\n","import { SpawnTask, type SpawnTaskOptions, type TaskContext } from '@jujulego/tasks';\n\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { linesFrom } from '@/src/utils/events.ts';\n\n// Types\nexport interface CommandContext extends TaskContext {\n workspace: Workspace;\n command: string;\n}\n\nexport interface CommandOptions extends Omit<SpawnTaskOptions, 'cwd'> {\n superCommand?: string | string[];\n}\n\n// Utils\nexport function isCommandCtx(ctx: Readonly<TaskContext>): ctx is Readonly<CommandContext> {\n return 'workspace' in ctx && 'command' in ctx;\n}\n\n// Class\nexport class CommandTask extends SpawnTask<CommandContext> {\n // Constructor\n constructor(readonly workspace: Workspace, command: string, args: string[], opts: CommandOptions = {}) {\n let cmd = command;\n\n if (opts.superCommand) {\n if (typeof opts.superCommand === 'string') {\n opts.superCommand = [opts.superCommand];\n }\n\n if (opts.superCommand.length > 0) {\n cmd = opts.superCommand[0];\n args = [...opts.superCommand.slice(1), command, ...args];\n }\n }\n\n super(cmd, args, { workspace, command }, {\n ...opts,\n cwd: workspace.cwd,\n env: {\n FORCE_COLOR: '1',\n ...opts.env\n }\n });\n\n this._logStreams();\n }\n\n // Methods\n private _logStreams() {\n // TODO: clean up this subscriptions\n linesFrom(this, 'stdout').subscribe((line) => this._logger.info(line));\n linesFrom(this, 'stderr').subscribe((line) => this._logger.info(line));\n }\n}\n","import { waitFor$ } from '@jujulego/event-tree';\nimport { GroupTask, type Task, type TaskContext, type TaskOptions, TaskSet } from '@jujulego/tasks';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { JillApplication } from '@/src/jill.application.ts';\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { CommandTask } from '@/src/tasks/command-task.ts';\nimport { splitCommandLine } from '@/src/utils/string.ts';\n\n// Types\nexport interface ScriptContext extends TaskContext {\n workspace: Workspace;\n script: string;\n}\n\n// Utils\nexport function isScriptCtx(ctx: Readonly<TaskContext>): ctx is Readonly<ScriptContext> {\n return 'workspace' in ctx && 'script' in ctx;\n}\n\n// Class\nexport class ScriptTask extends GroupTask<ScriptContext> {\n // Attributes\n private _scriptTasks?: TaskSet;\n\n // Constructor\n constructor(\n readonly workspace: Workspace,\n readonly script: string,\n readonly args: string[],\n opts?: TaskOptions\n ) {\n super(script, { workspace, script }, opts);\n }\n\n // Methods\n private async _runScript(script: string, args: string[]): Promise<Task[] | null> {\n const line = this.workspace.getScript(script);\n\n if (!line) {\n return null;\n }\n\n // Create command task for script\n const [command, ...commandArgs] = splitCommandLine(line);\n\n if (command === 'jill') {\n this._logger.debug(`Interpreting ${line}`);\n const argv = commandArgs.map(arg => arg.replace(/^[\"'](.+)[\"']$/, '$1'));\n\n const app = container.get(JillApplication);\n const tasks = await app.tasksOf(argv, {\n project: this.project,\n workspace: this.workspace,\n });\n\n if (tasks.length) {\n return tasks;\n }\n }\n\n const pm = await this.workspace.project.packageManager();\n\n return [\n new CommandTask(this.workspace, command, [...commandArgs, ...args], {\n logger: this._logger,\n superCommand: pm === 'yarn' ? ['yarn', 'exec'] : undefined,\n })\n ];\n }\n\n async prepare(): Promise<void> {\n const tasks = await this._runScript(this.script, this.args);\n\n if (!tasks) {\n throw new Error(`No script ${this.script} in ${this.workspace.name}`);\n }\n\n this._scriptTasks = new TaskSet();\n\n for (const tsk of tasks) {\n this.add(tsk);\n this._scriptTasks.add(tsk);\n }\n }\n\n protected async *_orchestrate(): AsyncGenerator<Task, void, undefined> {\n if (!this._scriptTasks) {\n throw new Error('ScriptTask needs to be prepared. Call prepare before starting it');\n }\n\n yield* this._scriptTasks;\n\n const results = await waitFor$(this._scriptTasks, 'finished');\n this.setStatus(results.failed === 0 ? 'done' : 'failed');\n }\n\n protected _stop(): void {\n if (!this._scriptTasks) return;\n\n for (const tsk of this._scriptTasks) {\n tsk.stop();\n }\n }\n\n complexity(cache = new Map<string, number>()): number {\n let complexity = super.complexity(cache);\n\n if (this._scriptTasks) {\n complexity += this._scriptTasks.tasks.reduce((cpl, tsk) => cpl + tsk.complexity(cache), 0);\n }\n\n cache.set(this.id, complexity);\n\n return complexity;\n }\n\n // Properties\n get project() {\n return this.workspace.project;\n }\n}\n","import { Logger } from '@jujulego/logger';\nimport { TaskManager } from '@jujulego/tasks';\nimport { type interfaces as int } from 'inversify';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { container } from '@/src/inversify.config.ts';\n\n// Symbols\nexport const TASK_MANAGER: int.ServiceIdentifier<TaskManager> = Symbol('jujulego:jill:TaskManager');\n\n// Service\ncontainer.bind(TASK_MANAGER)\n .toDynamicValue(({ container }) => {\n const config = container.get(CONFIG);\n const logger = container.get(Logger);\n\n return new TaskManager({ jobs: config.jobs, logger });\n })\n .inSingletonScope();\n","import { GroupTask } from '@jujulego/tasks';\nimport { Box } from 'ink';\nimport { Fragment, useLayoutEffect, useMemo, useState } from 'react';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\n\nimport TaskSpinner from './task-spinner.tsx';\n\n// Types\nexport interface GroupTaskSpinnerProps {\n group: GroupTask;\n}\n\n// Components\nexport default function GroupTaskSpinner({ group }: GroupTaskSpinnerProps) {\n // State\n const [verbose, setVerbose] = useState(false);\n const [status, setStatus] = useState(group.status);\n const [tasks, setTasks] = useState([...group.tasks]);\n const [canReduce, setCanReduce] = useState(true);\n\n // Memo\n const forceExtended = useMemo(() => verbose || tasks.some((tsk) => !isCommandCtx(tsk.context)), [verbose, tasks]);\n const isReduced = useMemo(() => !forceExtended && canReduce, [forceExtended, canReduce]);\n\n // Effects\n useLayoutEffect(() => {\n const config = container.get(CONFIG);\n\n if (config.verbose) {\n setVerbose(['verbose', 'debug'].includes(config.verbose));\n }\n }, []);\n\n useLayoutEffect(() => {\n return group.on('status', (event) => {\n setStatus(event.status);\n });\n }, [group]);\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return group.on('task.added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks([...group.tasks]);\n dirty = false;\n });\n }\n });\n }, [group]);\n\n useLayoutEffect(() => {\n if (status === 'running') {\n setCanReduce(false);\n } else if (status === 'done') {\n setCanReduce(true);\n }\n }, [status]);\n\n // Render\n return (\n <>\n <TaskSpinner task={group} />\n { isReduced || (\n <Box flexDirection=\"column\" marginLeft={2}>\n { tasks.map((task) => (\n <Fragment key={task.id}>\n { (task instanceof GroupTask) ? (\n <GroupTaskSpinner group={task} />\n ) : (\n <TaskSpinner task={task} />\n ) }\n </Fragment>\n )) }\n </Box>\n ) }\n </>\n );\n}\n","import { useStderr } from 'ink';\nimport { useLayoutEffect, } from 'react';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { jillLogFormat, LogGateway } from '@/src/commons/logger/log.gateway.ts';\n\n// Component\nexport default function StaticLogs() {\n // State\n const { write } = useStderr();\n\n // Effect\n useLayoutEffect(() => {\n const gateway = container.get(LogGateway);\n\n // Remove Console transport\n const listeners = gateway.listeners;\n gateway.clear();\n\n // Add custom transport\n const off = gateway.subscribe((log) => {\n write(jillLogFormat(log) + '\\n');\n });\n\n return () => {\n off();\n\n // Restore previous listeners\n for (const lst of listeners) {\n gateway.subscribe(lst);\n }\n };\n }, [write]);\n\n return null;\n}\n","import { type ReactNode } from 'react';\n\nimport StaticLogs from './static-logs.tsx';\n\n// Types\nexport interface LayoutProps {\n children?: ReactNode;\n}\n\n// Component\nexport default function Layout({ children }: LayoutProps) {\n return (\n <>\n <StaticLogs />\n { children }\n </>\n );\n}\n","import { Box, Text } from 'ink';\n\nimport { capitalize } from '@/src/utils/string.ts';\n\n// Types\nexport interface ListProps<T extends Record<string, unknown>> {\n items: T[];\n headers?: boolean;\n}\n\n// Component\nexport default function List<T extends Record<string, unknown>>({ items, headers }: ListProps<T>) {\n if (items.length === 0) {\n return null;\n }\n\n return (\n <Box>\n { Object.keys(items[0]).map((key) => (\n <Box key={key} flexDirection=\"column\" marginRight={2}>\n { headers && (\n <Text bold>{ capitalize(key) }</Text>\n ) }\n { items.map((item, idx) => (\n <Text key={idx}>{ item[key] as string || ' ' }</Text>\n )) }\n </Box>\n )) }\n </Box>\n );\n}\n","import { GroupTask, Task, type TaskManager } from '@jujulego/tasks';\nimport { useLayoutEffect, useState } from 'react';\n\nimport GroupTaskSpinner from './group-task-spinner.tsx';\nimport TaskSpinner from './task-spinner.tsx';\n\n// Types\nexport interface TasksSpinnerProps {\n manager: TaskManager;\n}\n\n// Utils\nfunction taskPredicate(task: Task): boolean {\n if (task.group) {\n return false;\n }\n\n if ('hidden' in task.context && task.context.hidden) {\n return false;\n }\n\n return true;\n}\n\n// Components\nexport default function TaskManagerSpinner({ manager }: TasksSpinnerProps) {\n const [tasks, setTasks] = useState(manager.tasks.filter(taskPredicate));\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return manager.on('added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks(manager.tasks.filter(taskPredicate));\n dirty = false;\n });\n }\n });\n }, [manager]);\n\n return (\n <>\n { tasks.map((task) =>\n (task instanceof GroupTask) ? (\n <GroupTaskSpinner key={task.id} group={task} />\n ) : (\n <TaskSpinner key={task.id} task={task} />\n )\n ) }\n </>\n );\n}\n","import { type Task } from '@jujulego/tasks';\nimport { Text } from 'ink';\n\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\n\n// Types\nexport interface TaskNameProps {\n task: Task;\n}\n\n// Components\nexport default function TaskName({ task }: TaskNameProps) {\n if (isScriptCtx(task.context)) {\n return (\n <Text>\n Run <Text bold>{ task.context.script }</Text> in { task.context.workspace.name }\n </Text>\n );\n } else {\n return <Text>{ task.name }</Text>;\n }\n}\n","import { type Task } from '@jujulego/tasks';\nimport { Box, Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport ms from 'pretty-ms';\nimport { useLayoutEffect, useState } from 'react';\n\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\n\nimport TaskName from './task-name.tsx';\n\n// Types\nexport interface TaskSpinnerProps {\n task: Task;\n}\n\n// Components\nexport default function TaskSpinner({ task }: TaskSpinnerProps) {\n // State\n const [status, setStatus] = useState(task.status);\n const [time, setTime] = useState(0);\n\n // Effects\n useLayoutEffect(() => {\n return task.on('status', (event) => {\n setStatus(event.status);\n });\n }, [task]);\n\n useLayoutEffect(() => {\n return task.on('completed', ({ duration }) => {\n setTime(duration);\n });\n }, [task]);\n\n // Render\n const isScriptChild = isCommandCtx(task.context) && task.group && isScriptCtx(task.group.context);\n\n switch (status) {\n case 'blocked':\n case 'ready':\n case 'starting':\n return (\n <Box>\n <Text color=\"grey\">{'\\u00B7'}</Text>\n <Box paddingLeft={1}>\n <Text color=\"grey\" wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n </Box>\n );\n\n case 'running':\n return (\n <Box>\n <Text color={isScriptChild ? 'dim' : undefined}>\n <Spinner />\n </Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\">\n <TaskName task={task} />\n </Text>\n </Box>\n </Box>\n );\n\n case 'done':\n return (\n <Box>\n <Text color=\"green\">{ symbols.success }</Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n <Box paddingLeft={1} flexShrink={0}>\n <Text color={isScriptChild ? 'grey' : 'dim'}>(took {ms(time)})</Text>\n </Box>\n </Box>\n );\n\n case 'failed':\n return (\n <Box>\n <Text color=\"red\">{ symbols.error }</Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n <Box paddingLeft={1} flexShrink={0}>\n <Text color={isScriptChild ? 'grey' : 'dim'}>(took {ms(time)})</Text>\n </Box>\n </Box>\n );\n }\n}\n","import { once$, source$, type Source } from '@jujulego/event-tree';\nimport { type SpawnTask, type SpawnTaskStream } from '@jujulego/tasks';\n\n// Utils\nexport function linesFrom(task: SpawnTask, stream: SpawnTaskStream): Source<string> {\n const inner = source$<string>();\n\n if (task.completed) {\n return inner;\n }\n\n // Listen to stream\n let current = '';\n\n const stop = task.on(`stream.${stream}`, (chunk) => {\n const data = current + chunk.data.toString('utf-8');\n const lines = data.split(/\\r?\\n/);\n\n current = lines.pop() ?? '';\n\n for (const line of lines) {\n inner.next(line);\n }\n });\n\n // Listen to end of task\n once$(task, 'completed', () => {\n stop();\n\n if (current) {\n inner.next(current);\n }\n });\n\n return inner;\n}\n","// Class\nexport class ExitException extends Error {\n // Constructor\n constructor(readonly code: number, message?: string) {\n super(message);\n }\n}\n","// Utils\nexport async function dynamicImport(filepath: string) {\n return import(/* webpackIgnore: true */ process.platform === 'win32' ? `file://${filepath}` : filepath);\n}\n\nexport function fixDefaultExport<T extends { default: unknown }>(mod: T): T['default'] {\n return mod as T['default'];\n}","// Utils\nexport function printJson(data: unknown, stream: NodeJS.WriteStream = process.stdout): void {\n if (stream.isTTY) { // Pretty print for ttys\n stream.write(JSON.stringify(data, null, 2));\n } else {\n stream.write(JSON.stringify(data));\n }\n}\n","// Utils\nexport function capitalize(txt: string): string {\n return txt.charAt(0).toUpperCase() + txt.substring(1).toLowerCase();\n}\n\nexport function splitCommandLine(line: string): string[] {\n line = line.trim();\n\n const parts: string[] = [];\n let current_cote = '';\n let last = 0;\n\n for (let i = 1; i < line.length; ++i) {\n const c = line[i];\n\n if (current_cote) {\n if (c === current_cote) {\n current_cote = '';\n }\n } else {\n if (['\"', '\\''].includes(c)) {\n current_cote = c;\n } else if (c === ' ') {\n parts.push(line.slice(last, i));\n\n last = i + 1;\n }\n }\n }\n\n parts.push(line.slice(last));\n\n return parts;\n}\n","import { BroadcastChannel, getEnvironmentData, type Serializable, setEnvironmentData } from 'node:worker_threads';\n\nimport { type Awaitable } from '@/src/types.ts';\n\n// Types\ninterface CacheUpdate {\n key: Serializable;\n value: Serializable;\n}\n\nfunction isCacheUpdate(msg: unknown): msg is CacheUpdate {\n return typeof msg === 'object' && msg !== null && 'key' in msg && 'value' in msg;\n}\n\n// Chanel\nconst channel = new BroadcastChannel('jujulego:jill:worker-cache');\nchannel.unref();\n\nchannel.onmessage = (arg) => {\n const msg = arg as MessageEvent;\n\n if (isCacheUpdate(msg.data)) {\n setEnvironmentData(msg.data.key, msg.data.value);\n }\n};\n\n// Utils\nexport async function workerCache<R extends Serializable>(key: Serializable, compute: () => Awaitable<R>): Promise<R> {\n const cache = getEnvironmentData(key) as R | undefined;\n if (cache !== undefined) return cache;\n\n // Compute it\n const result = await compute();\n\n setEnvironmentData(key, result);\n channel.postMessage({ key, value: result });\n\n return result;\n}\n"],"names":["ContextService","constructor","_storage","AsyncLocalStorage","this","_logger","logger","child","withLabel","reset","context","enterWith","_getContext","getStore","warning","_updateContext","update","Object","assign","application","project","workspace","Service","inject","Logger","container","bind","toDynamicValue","logger$","withTimestamp","inSingletonScope","onActivation","get","LogGateway","connect","LOG_BROADCAST_CHANNEL","Symbol","for","toConstantValue","ThreadGateway","_source","source$","subscribe","unsubscribe","clear","channel","BroadcastChannel","unref","onmessage","log","next","data","onmessageerror","level","LogLevel","error","message","quick","string","postMessage","jillLogFormat","qlevelColor","wrap","chalkTemplateStderr","function","qprop","onServiceActivate","threadGtw","wt","flow$","toStderr","origin","filter$","listeners","Array","from","level$","read","mutate","var$","info","AJV","Ajv","allErrors","strict","CONFIG_EXPLORER","CONFIG_VALIDATOR","compile","schema","cosmiconfig","loaders","filepath","dynamicImport","then","mod","default","defaultLoaders","noExt","CONFIG","async","configLoader","options","CONFIG_OPTIONS","explorer","validator","loaded","search","config","jobs","verbose","os","length","errors","errorsText","separator","dataVar","ExitException","base","path","plugins","map","plugin","debug","workerCache","VERBOSITY_LEVEL","applyConfigOptions","parser","option","alias","type","description","coerce","cnt","Math","min","yargs","hideBin","process","argv","help","version","parse","CURRENT","Container","lazyInject","lazyInjectNamed","fixDefaultExport","getDecorators","JillApplication","createChild","scriptName","completion","pkg","stdout","columns","exitProcess","_prepareParser","commands","command","recommendCommands","fail","_loadPlugins","CorePlugin","load","getModule","loadPlugins","run","getAllAsync","COMMAND_MODULE","parseAsync","tasksOf","ctx","COMMAND","Promise","resolve","reject","modules","cmd","opts","getCommandOpts","buildCommandModule","handler","args","TaskCommand","tasks","tsk","prepare","push","catch","injectable","PluginLoaderService","toSelf","inTransientScope","whenTargetIsDefault","app","Error","whenTargetNamed","COMMAND_OPTS","target","Reflect","getMetadata","name","aliases","describe","deprecated","builder","middlewares","applyMiddlewares","err","Command","decorate","defineMetadata","split","setRegistry","getAsync","INK_APP","render","Layout","InkCommand","children","rerender","waitUntilExit","Middleware","tmp","cls","middleware","MODULE","REGISTRY","getRegistry","registry","assert","module","ContainerModule","setModule","_config","_importPlugin","ctn","service","addTaskOptions","desc","choices","TaskSet","add","plan","extractPlan","planMode","printJson","id","substring","isCommandCtx","isScriptCtx","group","groupId","dependenciesIds","join","List","items","headers","TaskManagerSpinner","manager","start","waitFor$","failed","TASK_MANAGER","CommandTask","SpawnTask","superCommand","slice","super","cwd","env","FORCE_COLOR","_logStreams","linesFrom","line","ScriptTask","GroupTask","script","_runScript","getScript","commandArgs","splitCommandLine","arg","replace","pm","packageManager","undefined","_scriptTasks","_orchestrate","results","setStatus","_stop","stop","complexity","cache","Map","reduce","cpl","set","TaskManager","GroupTaskSpinner","setVerbose","useState","status","setTasks","canReduce","setCanReduce","forceExtended","useMemo","some","isReduced","useLayoutEffect","includes","on","event","dirty","queueMicrotask","TaskSpinner","task","Box","flexDirection","marginLeft","Fragment","StaticLogs","write","useStderr","gateway","off","lst","keys","key","marginRight","Text","bold","capitalize","item","idx","taskPredicate","hidden","filter","TaskName","time","setTime","duration","isScriptChild","color","paddingLeft","Spinner","symbols","flexShrink","ms","stream","inner","completed","current","chunk","lines","toString","pop","once$","code","import","platform","isTTY","JSON","stringify","txt","charAt","toUpperCase","toLowerCase","trim","parts","current_cote","last","i","c","compute","getEnvironmentData","result","setEnvironmentData","value","msg","isCacheUpdate"],"sourceRoot":""}
1
+ {"version":3,"file":"71.mjs","mappings":"2IAkBO,IAAMA,EAAN,MAMLC,WAAAA,CAAY,G,KAHKC,SAAW,IAAIC,EAAAA,kBAI9BC,KAAKC,QAAUC,EAAOC,OAAMC,EAAAA,EAAAA,WAAU,YACtCJ,KAAKK,OACP,CAGAA,KAAAA,CAAMC,EAAmB,CAAC,GACxBN,KAAKF,SAASS,UAAUD,EAC1B,CAEQE,WAAAA,GAGN,OAFYR,KAAKF,SAASW,aAGxBT,KAAKC,QAAQS,QAAQ,0CACd,CAAC,EAIZ,CAEQC,cAAAA,CAAeC,GACrBC,OAAOC,OAAOd,KAAKQ,cAAeI,EACpC,CAGA,eAAIG,GACF,OAAOf,KAAKQ,cAAcO,WAC5B,CAEA,eAAIA,CAAYA,GACdf,KAAKW,eAAe,CAAEI,eACxB,CAEA,WAAIC,GACF,OAAOhB,KAAKQ,cAAcQ,OAC5B,CAEA,WAAIA,CAAQA,GACVhB,KAAKW,eAAe,CAAEK,WACxB,CAEA,aAAIC,GACF,OAAOjB,KAAKQ,cAAcS,SAC5B,CAEA,aAAIA,CAAUA,GACZjB,KAAKW,eAAe,CAAEM,aACxB,G,MAtDWrB,E,mUAAAA,CAAAA,EADZsB,EAAAA,EAAAA,MAOcC,E,GAAAA,EAAAA,EAAAA,QAAOC,EAAAA,Q,oBAAPD,E,IANFvB,E,kDCZbyB,EAAAA,GAAUC,KAAKF,EAAAA,QAAQG,gBAAe,KAAMC,EAAAA,EAAAA,UAAQC,EAAAA,EAAAA,oBACjDC,mBACAC,cAAa,EAAGN,aAAanB,KACZmB,EAAUO,IAAIC,EAAAA,GACtBC,QAAQ5B,GAETA,I,gJCPJ,MAAM6B,EAAuDC,OAAOC,IAAI,uCAG/EZ,EAAAA,GAAUC,KAAKS,GAAuBG,gBAAgB,wBCI/C,IAAMC,EAAN,MAOLtC,WAAAA,CACE,G,KAJeuC,SAAUC,EAAAA,EAAAA,W,KA0BlBC,UAAYtC,KAAKoC,QAAQE,U,KACzBC,YAAcvC,KAAKoC,QAAQG,Y,KAC3BC,MAAQxC,KAAKoC,QAAQI,MAtB5BxC,KAAKyC,QAAU,IAAIC,EAAAA,iBAAiBD,GACpCzC,KAAKyC,QAAQE,QAEb3C,KAAKyC,QAAQG,UAAaC,IACxB7C,KAAKoC,QAAQU,KAAK,EAA+BC,KAAK,EAGxD/C,KAAKyC,QAAQO,eAAkBD,IAC7B/C,KAAKoC,QAAQU,MAAKrB,EAAAA,EAAAA,gBAAAA,CAAgB,CAChCwB,MAAOC,EAAAA,SAASC,MAChBC,QAASC,EAAAA,MAAMC,MAAM,kCAAkC,EAAuBP,SAC7E,CAEP,CAGAD,IAAAA,CAAKC,GACH/C,KAAKyC,QAAQc,YAAYR,EAC3B,G,MA5BWZ,E,mUAAAA,CAAAA,EADZjB,EAAAA,EAAAA,MASIC,E,GAAAA,EAAAA,EAAAA,QAAOY,G,oBAAPZ,E,IARQgB,GCEN,MAAMqB,GAAgBC,EAAAA,EAAAA,aAC3BJ,EAAAA,MAAMK,KAAKC,EAAAA,qBACRC,QAAQ,OAAeC,EAAAA,EAAAA,OAAM,0BAAyBA,EAAAA,EAAAA,OAAM,cAK1D,IAAMhC,EAAN,MAOLiC,iBAAAA,EAAkB,UAAEzC,IAClB,MAAM0C,EAAY1C,EAAUO,IAAIO,GAE5B6B,IAAAA,eAEFC,EAAAA,EAAAA,OACEjE,KAAKoC,SACL8B,EAAAA,EAAAA,UAASV,IAIXxD,KAAK8B,QAAQiC,KAGbE,EAAAA,EAAAA,OAAMjE,KAAKoC,QACT2B,EAGN,CAOAjC,OAAAA,CAAQqC,GACN,OAAOF,EAAAA,EAAAA,OAAME,GACXC,EAAAA,EAAAA,UAASvB,GAAQA,EAAII,OAASjD,KAAKiD,QACnCjD,KAAKoC,QAET,CAGA,aAAIiC,GACF,OAAOC,MAAMC,KAAKvE,KAAKoC,QAAQiC,UACjC,CAEA,SAAIpB,GACF,OAAOjD,KAAKwE,OAAOC,MACrB,CAEA,SAAIxB,CAAMA,GACRjD,KAAKwE,OAAOE,OAAOzB,EACrB,C,mBAhDSuB,QAASG,EAAAA,EAAAA,MAAKzB,EAAAA,SAAS0B,M,KAEfxC,SAAUC,EAAAA,EAAAA,W,KAwBlBC,UAAYtC,KAAKoC,QAAQE,U,KACzBC,YAAcvC,KAAKoC,QAAQG,Y,KAC3BC,MAAQxC,KAAKoC,QAAQI,K,GA9BnBX,E,mUAAAA,CAAAA,EADZX,EAAAA,EAAAA,MACYW,E,wGCdN,MAAMgD,EAA0C7C,OAAO,qBAG9DX,EAAAA,GACGC,KAAKuD,GACLtD,gBAAe,EAAGF,gBACjB,MAAMnB,EAASmB,EAAUO,IAAIR,EAAAA,QAG7B,OAAO,IAAK0D,EAAAA,QAAY,CACtBC,WAAW,EACX7E,OAAQA,EAAOC,OAAMC,EAAAA,EAAAA,WAAU,QAC/B4E,QAAyD,GACzD,IAEHtD,mB,kaCVI,MAAMuD,EAA0DjD,OAAO,iCACjEkD,EAAqElD,OAAO,kCAGzFX,EAAAA,GACGC,KAAK4D,GACL3D,gBAAe,EAAGF,eACLA,EAAUO,IAAIiD,GACfM,QAAiBC,KAE7B1D,mBAEHL,EAAAA,GACGC,KAAK2D,GACL1D,gBAAe,KACP8D,EAAAA,EAAAA,aAAY,OAAQ,CACzBC,QAAS,CACP,OAASC,IAAaC,EAAAA,EAAAA,GAAcD,GAAUE,MAAMC,GAAQA,EAAIC,UAChE,MAAQJ,IAAaC,EAAAA,EAAAA,GAAcD,GAAUE,MAAMC,GAAQA,EAAIC,UAC/D,QAASC,EAAAA,eAAe,SACxB,QAASA,EAAAA,eAAe,SACxB,OAAQA,EAAAA,eAAe,QACvBC,MAAOD,EAAAA,eAAeC,WAI3BnE,mBCtBI,MAAMoE,EAAyC9D,OAAO,wBAGtD+D,eAAeC,IACpB,MAAM9F,EAASmB,EAAAA,GAAUO,IAAIR,EAAAA,QAAQjB,OAAMC,EAAAA,EAAAA,WAAU,WAE/C6F,EAAU5E,EAAAA,GAAUO,IAAIsE,EAAAA,GACxBC,EAAW9E,EAAAA,GAAUO,IAAIqD,GACzBmB,EAAY/E,EAAAA,GAAUO,IAAIsD,GAG1BmB,QAAeF,EAASG,SACxBC,EAASF,GAAQE,QAAU,CAAC,EAYlC,GATIN,EAAQO,OAAMD,EAAOC,KAAOP,EAAQO,MACpCP,EAAQQ,UAASF,EAAOE,QAAUR,EAAQQ,cACxBC,IAAlBT,EAAQU,QAAqBJ,EAAOI,MAAQV,EAAQU,OAGxDJ,EAAOC,OAAUI,IAAAA,OAAUC,OAAS,EACpCN,EAAOI,SAAU,GAGZP,EAAUG,GAAS,CACtB,MACMO,EADMzF,EAAAA,GAAUO,IAAIiD,GACPkC,WAAWX,EAAUU,OAAQ,CAAEE,UAAW,OAAQC,QAAS,WAG9E,MADA/G,EAAOiD,MAAM,6BAA6B2D,KACpC,IAAII,EAAAA,EAAc,EAC1B,CAOA,GAJIX,EAAOE,UACTpF,EAAAA,GAAUO,IAAIC,EAAAA,GAAYoB,MAAQC,EAAAA,SAASqD,EAAOE,UAGhDJ,EAAQ,CAEV,MAAMc,EAAOC,IAAAA,QAAaf,EAAOd,UACjCgB,EAAOc,QAAUd,EAAOc,SAASC,KAAKC,GAAWH,IAAAA,QAAaD,EAAMI,KAEpErH,EAAOuG,QAAQ,UAAUJ,EAAOd,uBAClC,CAIA,OAFArF,EAAOsH,KAAK,0BAA0BjB,IAE/BA,CACT,CAEAlF,EAAAA,GACGC,KAAKwE,GACLvE,gBAAewE,eAAkB0B,EAAAA,EAAAA,GAAY,uBAAwBzB,KACrEtE,kB,2EC5DI,MAAMwE,EAAiDlE,OAAO,gCAG/D0F,EAAsD,CAC1D,EAAG,UACH,EAAG,SAIE,SAASC,EAAmBC,GACjC,OAAOA,EACJC,OAAO,UAAW,CACjBC,MAAO,IACPC,KAAM,QACNC,YAAa,sBACbC,OAASC,GAAQR,EAAgBS,KAAKC,IAAIF,EAAK,MAEhDL,OAAO,OAAQ,CACdC,MAAO,IACPC,KAAM,SACNC,YAAa,oCAEdH,OAAO,QAAS,CACfE,KAAM,UACNC,YAAa,oBAEnB,CAEA3G,EAAAA,GACGC,KAAK4E,GACL3E,gBAAe,KACd,MAAMqG,GAASS,EAAAA,EAAAA,UAAMC,EAAAA,EAAAA,SAAQC,QAAQC,OAClCC,MAAK,GACLC,SAAQ,GAIX,OAFAf,EAAmBC,GAEZA,EAAOe,OAAO,IAEtBjH,kB,kCC/CI,MAAMkH,EAAU,S,yGCOhB,MAAMvH,EAAY,IAAIwH,EAAAA,WAGhB,WAAEC,EAAU,gBAAEC,IAAoBC,EAAAA,EAAAA,GAAiBC,IAAjBD,CAAgC3H,E,8OCSxE,IAAM6H,EAAN,MAMLrJ,WAAAA,CACE,EAEA,EAEA,G,KAHiBS,QAAAA,E,KAEA+G,QAAAA,E,KAEAnH,OAAAA,EAGjBF,KAAKqB,UAAYA,EAAAA,GAAU8H,cAG3BnJ,KAAK4H,QAASS,EAAAA,EAAAA,WACXe,WAAW,QACXC,WAAW,aAAc,mCACzBZ,KAAK,OAAQ,2BACbC,QAAQ,UAAW,eAAgBY,EAAAA,IACnC5F,KAAK6E,QAAQgB,OAAOC,SACpBC,aAAY,EACjB,CAGQC,cAAAA,CAAeC,GAGrB,OAFAhC,EAAAA,EAAAA,GAAmB3H,KAAK4H,QAEjB5H,KAAK4H,OACTgC,QAAQD,GACRE,oBACA7E,SACA8E,MAAK,EACV,CAEA,kBAAcC,GACZ/J,KAAKE,OAAOC,OAAMC,EAAAA,EAAAA,WAAU,WAAWqG,QAAQ,yBAE/C,MAAM,WAAEuD,SAAqB,qDAC7BhK,KAAKqB,UAAU4I,MAAKC,EAAAA,EAAAA,IAAUF,GAAY,UAEpChK,KAAKqH,QAAQ8C,YAAYnK,KAAKqB,UACtC,CAEA,SAAM+I,CAAI5B,GACRxI,KAAKM,QAAQD,MAAM,CAAEU,YAAaf,aAC5BA,KAAK+J,eAGX,MAAMJ,QAAiB3J,KAAKqB,UAAUgJ,YAAYC,EAAAA,UAE5CtK,KAAK0J,eAAeC,GAAUY,WAAW/B,EACjD,CAEA,aAAMgC,CAAQhC,EAAgBiC,EAAoC,CAAC,GACjEzK,KAAKM,QAAQD,MAAM,IAAKoK,EAAK1J,YAAaf,aACpCA,KAAK+J,eAGX,MAAMJ,QAAiB3J,KAAKqB,UAAUgJ,YAAYK,EAAAA,IAElD,OAAO,IAAIC,SAAgB,CAACC,EAASC,KACnC,MAAMC,EAA2B,GAEjC,IAAK,MAAMC,KAAOpB,EAAU,CAC1B,MAAMqB,GAAOC,EAAAA,EAAAA,IAAeF,EAAIlL,aAC1B6F,GAAMwF,EAAAA,EAAAA,IAAmBH,EAAKC,GAEpCtF,EAAIyF,QAAUpF,MAAOqF,IACnB,GAAIL,aAAeM,EAAAA,EAAa,CAC9B,MAAMC,EAAgB,GAEtB,UAAW,MAAMC,KAAOR,EAAIS,QAAQJ,GAClCE,EAAMG,KAAKF,GAGbX,EAAQU,EACV,MACEV,EAAQ,GACV,EAGFE,EAAQW,KAAK/F,EACf,CAGA1F,KAAK0J,eAAeoB,GACjBP,WAAW/B,GACXkD,MAAMb,EAAO,GAEpB,GA7FW3B,E,mUAAAA,CAAAA,EADZyC,EAAAA,EAAAA,cAQIxK,EAAAA,GAAAA,EAAAA,EAAAA,QAAOvB,EAAAA,IAEPuB,EAAAA,GAAAA,EAAAA,EAAAA,QAAOyK,EAAAA,IAEPzK,EAAAA,GAAAA,EAAAA,EAAAA,QAAOC,EAAAA,UAXC8H,GAgGb7H,EAAAA,GAAUC,KAAK4H,GACZ2C,SACAC,mBACAC,sBAOH1K,EAAAA,GAAUC,KAAK4H,GACZ3H,gBAAe,EAAGF,gBACjB,MACM2K,EADM3K,EAAUO,IAAIhC,EAAAA,GACVmB,YAEhB,IAAKiL,EACH,MAAM,IAAIC,MAAM,yDAGlB,OAAOD,CAAG,IAEXE,gBAAgBtD,EAAAA,E,sIC7HnB,MAAMuD,EAAenK,OAAO,8BAEf0I,EAA2C1I,OAAO,yBAClDsI,EAAuDtI,OAAO,gCAiBpE,SAASiJ,EAAemB,GAC7B,MAAMpB,EAAOqB,QAAQC,YAAYH,EAAcC,GAE/C,GAAoB,iBAATpB,EACT,MAAM,IAAIiB,MAAM,+BAA+BG,EAAOG,QAGxD,OAAOvB,CACT,CAEO,SAASE,EAAmBH,EAAeC,GAChD,MAAO,CACLpB,QAASoB,EAAKpB,QACd4C,QAASxB,EAAKwB,QACdC,SAAUzB,EAAKyB,SACfC,WAAY1B,EAAK0B,WAEjBC,QAAQ/E,IACFoD,EAAK4B,cACPhF,GAASiF,EAAAA,EAAAA,GAAiBjF,EAAQoD,EAAK4B,cAGrC7B,EAAI4B,UACN/E,EAASmD,EAAI4B,QAAQ/E,IAGhBA,GAETuD,QAASpF,MAAOqF,IACd,UACQL,EAAII,QAAQC,EACpB,CAAE,MAAO0B,GAMP,MALIA,EAAI1J,SACS/B,EAAAA,GAAUO,IAAIR,EAAAA,QACtB+B,MAAM2J,EAAI1J,SAGb,IAAI8D,EAAAA,EAAc,EAC1B,GAGN,CAGO,SAAS6F,EAAQ/B,GACtB,OAAQoB,KACNY,EAAAA,EAAAA,WAASrB,EAAAA,EAAAA,cAAcS,GAEvBC,QAAQY,eAAed,EAAcnB,EAAMoB,GAE3C,MAAMrB,EAAMC,EAAKpB,QAAQsD,MAAM,KAAK,IACpCC,EAAAA,EAAAA,IAAYf,GAAS9K,IACnBA,EAAK8K,GAAQP,SAEbvK,EAAKoJ,GACFnJ,gBAAe,EAAGF,eAAgBA,EAAU+L,SAAShB,KACrDF,gBAAgBnB,GAEnBzJ,EAAKgJ,GACF/I,gBAAewE,OAAS1E,eAEhB6J,QADW7J,EAAU+L,SAAShB,GACNpB,KAEhCkB,gBAAgBnB,EAAI,GACvB,CAEN,C,yGCzFO,MAAMsC,EAA2CrL,OAAOC,IAAI,yB,qUAGnEZ,EAAAA,GACGC,KAAK+L,GACL9L,gBAAe,KACd,IAAKyC,IAAAA,aACH,MAAM,IAAIiI,MAAM,0CAGlB,OAAOqB,EAAAA,EAAAA,SAAO,SAACC,EAAAA,EAAMA,CAAAA,GAAAA,IAEtB7L,mBCPI,IAAe8L,EAAf,MAQLb,OAAAA,CAAQ/E,GACN,OAAOA,CACT,CAEA,aAAMuD,CAAQC,GACZ,UAAW,MAAMqC,KAAYzN,KAAKsN,OAAOlC,GACvCpL,KAAKgM,IAAI0B,UACP,SAACH,EAAAA,EAAMA,C,SACHE,WAKFzN,KAAKgM,IAAI2B,eACjB,G,IApBC7E,EAAAA,EAAAA,IAAWuE,IAFQG,EAAAA,UAAAA,WAAAA,GAAAA,EAAAA,EAAAA,EADrB7B,EAAAA,EAAAA,eACqB6B,E,iECDf,SAASI,IACd,OAAQxB,KACNY,EAAAA,EAAAA,WAASrB,EAAAA,EAAAA,cAAcS,GACvB/K,EAAAA,GAAUC,KAAK8K,GAAQP,SAASnK,kBAAkB,CAEtD,CAGO,SAASmL,EAAiBjF,EAAcgF,GAC7C,IAAIiB,EAAMjG,EAEV,IAAK,MAAMkG,KAAOlB,EAAa,CAC7B,MAAMmB,EAAa1M,EAAAA,GAAUO,IAAIkM,GAE7BC,EAAWpB,UACbkB,EAAME,EAAWpB,QAAQkB,IAG3BA,EAAIE,YAAY3C,GAAS2C,EAAW5C,QAAQC,IAC9C,CAEA,OAAOyC,CACT,C,4EC9BA,MAAMG,EAAShM,OAAO,wBAChBiM,EAAWjM,OAAO,0BAGjB,SAASkM,EAAY9B,GAC1B,MAAM+B,EAAW9B,QAAQC,YAAY2B,EAAU7B,GAE/C,GAAwB,mBAAb+B,EACT,MAAM,IAAIlC,MAAM,wBAAwBG,EAAOG,QAGjD,OAAO4B,CACT,CAEO,SAAShB,EAAYf,EAAe+B,GACzC9B,QAAQY,eAAegB,EAAUE,EAAU/B,EAC7C,CAIO,SAASlC,EAAUkC,EAAegC,GAAS,GAChD,IAAIC,EAAShC,QAAQC,YAAY0B,EAAQ5B,GAEzC,KAAKiC,GAAYA,aAAkBC,EAAAA,iBAAkB,CACnD,MAAMH,EAAW9B,QAAQC,YAAY2B,EAAU7B,GAE/C,GAAwB,mBAAb+B,EAAyB,CAClC,GAAIC,EACF,MAAM,IAAInC,MAAM,sBAAsBG,EAAOG,QAG/C,OAAO,IACT,CAEA8B,EAAS,IAAIC,EAAAA,gBAAgBH,GAC7BI,EAAUnC,EAAQiC,EACpB,CAEA,OAAOA,CACT,CAEO,SAASE,EAAUnC,EAAeiC,GACvChC,QAAQY,eAAee,EAAQK,EAAQjC,EACzC,C,0JCnCO,IAAMR,EAAN,MAKL/L,WAAAA,CACE,EAEA,G,KADiB2O,QAAAA,EAIjBxO,KAAKC,QAAUC,EAAOC,OAAMC,EAAAA,EAAAA,WAAU,UACxC,CAGA,mBAAcqO,CAAclJ,GAC1BvF,KAAKC,QAAQwG,OAAO,kBAAkBlB,IAGtC,IAAIgC,QAAe/B,EAAAA,EAAAA,GAAcD,GAEjC,KAAOgC,GAA4B,iBAAXA,GAAuB,YAAaA,GAC1DA,EAASA,EAAO5B,QAGlB,IAAK4B,EACH,MAAM,IAAI0E,MAAM,kBAAkB1G,4BAIpC,MAAM8I,GAASnE,EAAAA,EAAAA,IAAU3C,GAEzB,IAAK8G,EACH,MAAM,IAAIpC,MAAM,kBAAkB1G,2BAGpC,OAAO8I,CACT,CAEA,iBAAMlE,CAAYuE,EAAqBrN,EAAAA,IACrC,GAAKrB,KAAKwO,QAAQnH,QAElB,IAAK,MAAMD,KAAQpH,KAAKwO,QAAQnH,QAAS,CACvC,MAAME,QAAevH,KAAKyO,cAAcrH,GACxCsH,EAAIzE,KAAK1C,EACX,CACF,GA9CWqE,E,mUAAAA,CAAAA,EADZ1K,EAAAA,EAAAA,KAOIC,EAAAA,GAAAA,EAAAA,EAAAA,QAAO2E,EAAAA,IAEP3E,EAAAA,GAAAA,EAAAA,EAAAA,QAAOC,EAAAA,UARCwK,E,yDCAN,SAAS1K,IACd,OAAQ4M,KACNd,EAAAA,EAAAA,WAASrB,EAAAA,EAAAA,cAAcmC,GACvBzM,EAAAA,GAAUC,KAAKwM,GAAKjC,SAASnK,mBAC1BC,cAAa,CAAC8I,EAAKkE,KACd,sBAAuBA,GACzBA,EAAQ7K,kBAAkB2G,GAGrBkE,KAGJb,EAEX,C,ofCDO,IAAezC,EAAf,cAAgDmC,EAAAA,EAQ3CoB,cAAAA,CAAehH,GACvB,OAAOA,EACJC,OAAO,OAAQ,CACdE,KAAM,UACN8G,KAAM,8BACNlJ,SAAS,IAEVkC,OAAO,YAAa,CACnBE,KAAM,SACN8G,KAAM,mBACNC,QAAS,CAAC,OAAQ,QAClBnJ,QAAS,QAEf,CAEA,YAAO2H,CAAOlC,GAEZ,MAAME,EAAQ,IAAIyD,EAAAA,QAElB,UAAW,MAAMxD,KAAOvL,KAAKwL,QAAQJ,GACnCE,EAAM0D,IAAIzD,GAGZ,GAAIH,EAAK6D,KAAM,CACb,MAAMA,EAAsB3K,MAAMC,MAAK2K,EAAAA,EAAAA,MAAY5D,IAEnD,GAAsB,SAAlBF,EAAK+D,UACPC,EAAAA,EAAAA,GAAUH,OACL,CACL,MAAMlM,EAAOkM,EAAK3H,KAAKiE,IAAS,CAC9B8D,GAAI9D,EAAI8D,GAAGC,UAAU,EAAG,GACxB/C,KAAMhB,EAAIgB,KACVtL,WAAWsO,EAAAA,EAAAA,GAAahE,EAAIjL,WAAYkP,EAAAA,EAAAA,GAAYjE,EAAIjL,SAAWiL,EAAIjL,QAAQW,UAAUsL,KAAO,GAChGkD,MAAOlE,EAAImE,SAASJ,UAAU,EAAG,GACjC,aAAc/D,EAAIoE,gBAAgBrI,KAAI+H,GAAMA,EAAGC,UAAU,EAAG,KAAIM,KAAK,gBAGjE,SAACC,EAAAA,EAAIA,CAACC,MAAO/M,EAAMgN,SAAO,GAClC,CACF,MAAO,GAAIzE,EAAMA,MAAMzE,OAAS,GAS9B,SAPM,SAACmJ,EAAAA,EAAkBA,CAACC,QAASjQ,KAAKiQ,UAGxC3E,EAAM4E,MAAMlQ,KAAKiQ,gBAEIE,EAAAA,EAAAA,UAAS7E,EAAO,aAE1B8E,OAAS,EAClB,MAAM,IAAIlJ,EAAAA,EAAc,QAGX7F,EAAAA,GAAUO,IAAIR,EAAAA,QACtBV,QAAQ,gBAEnB,G,IA7DCoI,EAAAA,EAAAA,IAAWuH,EAAAA,IAFQhF,EAAAA,UAAAA,eAAAA,GAAAA,EAAAA,EAAAA,EADrBM,EAAAA,EAAAA,eACqBN,E,kECVf,SAASkE,EAAa9E,GAC3B,MAAO,cAAeA,GAAO,YAAaA,CAC5C,CAGO,MAAM6F,UAAoBC,EAAAA,UAE/B1Q,WAAAA,CAAY,EAA+B+J,EAAiBwB,EAAgBJ,EAAuB,CAAC,GAClG,IAAID,EAAMnB,EAENoB,EAAKwF,eAC0B,iBAAtBxF,EAAKwF,eACdxF,EAAKwF,aAAe,CAACxF,EAAKwF,eAGxBxF,EAAKwF,aAAa3J,OAAS,IAC7BkE,EAAMC,EAAKwF,aAAa,GACxBpF,EAAO,IAAIJ,EAAKwF,aAAaC,MAAM,GAAI7G,KAAYwB,KAIvDsF,MAAM3F,EAAKK,EAAM,CAAEnK,YAAW2I,WAAW,IACpCoB,EACH2F,IAAK1P,EAAU0P,IACfC,IAAK,CACHC,YAAa,OACV7F,EAAK4F,O,KAnBO3P,UAAAA,EAuBnBjB,KAAK8Q,aACP,CAGQA,WAAAA,IAENC,EAAAA,EAAAA,GAAU/Q,KAAM,UAAUsC,WAAW0O,GAAShR,KAAKC,QAAQ2E,KAAKoM,MAChED,EAAAA,EAAAA,GAAU/Q,KAAM,UAAUsC,WAAW0O,GAAShR,KAAKC,QAAQ2E,KAAKoM,IAClE,E,yGClCK,SAASxB,EAAY/E,GAC1B,MAAO,cAAeA,GAAO,WAAYA,CAC3C,CAGO,MAAMwG,UAAmBC,EAAAA,UAQ9BrR,WAAAA,CACE,EACA,EACA,EACAmL,GAEA0F,MAAMS,EAAQ,CAAElQ,YAAWkQ,UAAUnG,G,KAL5B/J,UAAAA,E,KACAkQ,OAAAA,E,KACA/F,KAAAA,E,KATHgG,cAAgC,K,KAChCC,eAAiC,K,KACjCC,aAA+B,KAWrCtR,KAAKuR,UAAYvG,GAAMwG,WAAY,CACrC,CAGA,gBAAcC,CAAWN,EAAgB/F,GACvC,MAAM4F,EAAOhR,KAAKiB,UAAUyQ,UAAUP,GAEtC,IAAKH,EACH,OAAO,KAIT,MAAOpH,KAAY+H,IAAeC,EAAAA,EAAAA,GAAiBZ,GAEnD,GAAgB,SAAZpH,EAAoB,CACtB5J,KAAKC,QAAQuH,MAAM,gBAAgBwJ,KACnC,MAAMxI,EAAOmJ,EAAYrK,KAAIuK,GAAOA,EAAIC,QAAQ,iBAAkB,QAE5D9F,EAAM3K,EAAAA,GAAUO,IAAIsH,EAAAA,GACpBoC,QAAcU,EAAIxB,QAAQhC,EAAM,CACpCxH,QAAShB,KAAKgB,QACdC,UAAWjB,KAAKiB,YAGlB,GAAIqK,EAAMzE,OAAQ,CAChB,MAAMkL,EAAM,IAAIhD,EAAAA,QAEhB,IAAK,MAAMxD,KAAOD,EAChByG,EAAI/C,IAAIzD,GAGV,OAAOwG,CACT,CACF,CAEA,MAAMC,QAAWhS,KAAKiB,UAAUD,QAAQiR,iBAElCF,EAAM,IAAIhD,EAAAA,QAQhB,OAPAgD,EAAI/C,IACF,IAAIsB,EAAAA,EAAYtQ,KAAKiB,UAAW2I,EAAS,IAAI+H,KAAgBvG,GAAO,CAClElL,OAAQF,KAAKC,QACbuQ,aAAqB,SAAPwB,EAAgB,CAAC,OAAQ,aAAUtL,KAI9CqL,CACT,CAEA,aAAMvG,GAIJ,GAFAxL,KAAKsR,mBAAqBtR,KAAKyR,WAAWzR,KAAKmR,OAAQnR,KAAKoL,OAEvDpL,KAAKsR,aACR,MAAM,IAAIrF,MAAM,aAAajM,KAAKmR,aAAanR,KAAKiB,UAAUsL,QAUhE,GANIvM,KAAKuR,YACPvR,KAAKoR,oBAAsBpR,KAAKyR,WAAW,MAAMzR,KAAKmR,SAAU,IAChEnR,KAAKqR,qBAAuBrR,KAAKyR,WAAW,OAAOzR,KAAKmR,SAAU,KAIhEnR,KAAKoR,cAAe,CACtBpR,KAAKC,QAAQwG,QAAQ,6BAA6BzG,KAAKmR,WAEvD,IAAK,MAAM5F,KAAOvL,KAAKoR,cACrBpR,KAAKgP,IAAIzD,EAEb,CAEA,IAAK,MAAMA,KAAOvL,KAAKsR,aACrBtR,KAAKgP,IAAIzD,GAGX,GAAIvL,KAAKqR,eAAgB,CACvBrR,KAAKC,QAAQwG,QAAQ,+BAA+BzG,KAAKmR,WAEzD,IAAK,MAAM5F,KAAOvL,KAAKqR,eACrBrR,KAAKgP,IAAIzD,EAEb,CACF,CAEA,kBAAiB2G,GACf,IAAKlS,KAAKsR,aACR,MAAM,IAAIrF,MAAM,oEAIlB,OAAIjM,KAAKoR,sBACApR,KAAKoR,oBAEFpR,KAAKmS,WAAWnS,KAAKoR,gBACtBpR,KAAKoS,UAAU,iBAKnBpS,KAAKsR,mBAEFtR,KAAKmS,WAAWnS,KAAKsR,eAK3BtR,KAAKqR,uBACArR,KAAKqR,qBAEFrR,KAAKmS,WAAWnS,KAAKqR,iBAPxBrR,KAAKoS,UAAU,eAYxBpS,KAAKoS,UAAU,QACjB,CAEA,gBAAcD,CAAWJ,GAEvB,aADsB5B,EAAAA,EAAAA,UAAS4B,EAAK,aACrB3B,OAAS,CAC1B,CAEUiC,KAAAA,GACR,GAAKrS,KAAKsR,aAEV,IAAK,MAAM/F,KAAOvL,KAAKsR,aACrB/F,EAAI+G,MAER,CAEAC,UAAAA,CAAWC,EAAQ,IAAIC,KACrB,IAAIF,EAAa7B,MAAM6B,WAAWC,GAQlC,OANIxS,KAAKsR,eACPiB,GAAcvS,KAAKsR,aAAahG,MAAMoH,QAAO,CAACC,EAAKpH,IAAQoH,EAAMpH,EAAIgH,WAAWC,IAAQ,IAG1FA,EAAMT,IAAI/R,KAAKqP,GAAIkD,GAEZA,CACT,CAGA,WAAIvR,GACF,OAAOhB,KAAKiB,UAAUD,OACxB,E,6ECjLK,MAAMqP,EAAmDrO,OAAO,6BAGvEX,EAAAA,GAAUC,KAAK+O,GACZ9O,gBAAe,EAAGF,gBACjB,MAAMkF,EAASlF,EAAUO,IAAIkE,EAAAA,GACvB5F,EAASmB,EAAUO,IAAIR,EAAAA,QAE7B,OAAO,IAAIwR,EAAAA,YAAY,CAAEpM,KAAMD,EAAOC,KAAMtG,UAAS,IAEtDwB,kB,mHCFY,SAASmR,GAAiB,MAAEpD,IAEzC,MAAOhJ,EAASqM,IAAcC,EAAAA,EAAAA,WAAS,IAChCC,EAAQZ,IAAaW,EAAAA,EAAAA,UAAStD,EAAMuD,SACpC1H,EAAO2H,IAAYF,EAAAA,EAAAA,UAAS,IAAItD,EAAMnE,SACtC4H,EAAWC,IAAgBJ,EAAAA,EAAAA,WAAS,GAGrCK,GAAgBC,EAAAA,EAAAA,UAAQ,IAAM5M,GAAW6E,EAAMgI,MAAM/H,KAASgE,EAAAA,EAAAA,GAAahE,EAAIjL,YAAW,CAACmG,EAAS6E,IACpGiI,GAAYF,EAAAA,EAAAA,UAAQ,KAAOD,GAAiBF,GAAW,CAACE,EAAeF,IAyC7E,OAtCAM,EAAAA,EAAAA,kBAAgB,KACd,MAAMjN,EAASlF,EAAAA,GAAUO,IAAIkE,EAAAA,GAEzBS,EAAOE,SACTqM,EAAW,CAAC,UAAW,SAASW,SAASlN,EAAOE,SAClD,GACC,KAEH+M,EAAAA,EAAAA,kBAAgB,IACP/D,EAAMiE,GAAG,UAAWC,IACzBvB,EAAUuB,EAAMX,OAAO,KAExB,CAACvD,KAEJ+D,EAAAA,EAAAA,kBAAgB,KACd,IAAII,GAAQ,EAEZ,OAAOnE,EAAMiE,GAAG,cAAc,KACvBE,IACHA,GAAQ,EAERC,gBAAe,KACbZ,EAAS,IAAIxD,EAAMnE,QACnBsI,GAAQ,CAAK,IAEjB,GACA,GACD,CAACnE,KAEJ+D,EAAAA,EAAAA,kBAAgB,KACC,YAAXR,EACFG,GAAa,GACO,SAAXH,GACTG,GAAa,EACf,GACC,CAACH,KAIF,sB,WACE,SAACc,EAAAA,EAAWA,CAACC,KAAMtE,IACjB8D,IACA,SAACS,EAAAA,IAAGA,CAACC,cAAc,SAASC,WAAY,E,SACpC5I,EAAMhE,KAAKyM,IACX,SAACI,EAAAA,SAAQA,C,SACL,aAAiBjD,EAAAA,WACjB,SAAC2B,EAAAA,CAAiBpD,MAAOsE,KAEzB,SAACD,EAAAA,EAAWA,CAACC,KAAMA,KAJRA,EAAK1E,UAYhC,C,qFC7Ee,SAAS+E,IAEtB,MAAM,MAAEC,IAAUC,EAAAA,EAAAA,aAyBlB,OAtBAd,EAAAA,EAAAA,kBAAgB,KACd,MAAMe,EAAUlT,EAAAA,GAAUO,IAAIC,EAAAA,GAGxBwC,EAAYkQ,EAAQlQ,UAC1BkQ,EAAQ/R,QAGR,MAAMgS,EAAMD,EAAQjS,WAAWO,IAC7BwR,GAAM7Q,EAAAA,EAAAA,GAAcX,GAAO,SAG7B,MAAO,KACL2R,IAGA,IAAK,MAAMC,KAAOpQ,EAChBkQ,EAAQjS,UAAUmS,EACpB,CACD,GACA,CAACJ,IAEG,IACT,CCzBe,SAAS9G,GAAO,SAAEE,IAC/B,OACE,sB,WACE,SAAC2G,EAAUA,CAAAA,GACT3G,IAGR,C,mECNe,SAASoC,GAAwC,MAAEC,EAAK,QAAEC,IACvE,OAAqB,IAAjBD,EAAMjJ,OACD,MAIP,SAACmN,EAAAA,IAAGA,C,SACAnT,OAAO6T,KAAK5E,EAAM,IAAIxI,KAAKqN,IAC3B,UAACX,EAAAA,IAAGA,CAAWC,cAAc,SAASW,YAAa,E,UAC/C7E,IACA,SAAC8E,EAAAA,KAAIA,CAACC,MAAI,E,UAAGC,EAAAA,EAAAA,GAAWJ,KAExB7E,EAAMxI,KAAI,CAAC0N,EAAMC,KACjB,SAACJ,EAAAA,KAAIA,C,SAAaG,EAAKL,IAAkB,KAA9BM,OALLN,MAWlB,C,sFClBA,SAASO,EAAcnB,GACrB,QAAIA,EAAKtE,OAIL,WAAYsE,EAAKzT,SAAWyT,EAAKzT,QAAQ6U,OAK/C,CAGe,SAASnF,GAAmB,QAAEC,IAC3C,MAAO3E,EAAO2H,IAAYF,EAAAA,EAAAA,UAAS9C,EAAQ3E,MAAM8J,OAAOF,IAiBxD,OAfA1B,EAAAA,EAAAA,kBAAgB,KACd,IAAII,GAAQ,EAEZ,OAAO3D,EAAQyD,GAAG,SAAS,KACpBE,IACHA,GAAQ,EAERC,gBAAe,KACbZ,EAAShD,EAAQ3E,MAAM8J,OAAOF,IAC9BtB,GAAQ,CAAK,IAEjB,GACA,GACD,CAAC3D,KAGF,qB,SACI3E,EAAMhE,KAAKyM,GACX,aAAiB7C,EAAAA,WACf,SAAC2B,EAAAA,EAAgBA,CAAepD,MAAOsE,GAAhBA,EAAK1E,KAE5B,SAACyE,EAAAA,EAAWA,CAAeC,KAAMA,GAAfA,EAAK1E,OAKjC,C,mEC3Ce,SAASgG,GAAS,KAAEtB,IACjC,OAAIvE,EAAAA,EAAAA,GAAYuE,EAAKzT,UAEjB,UAACuU,EAAAA,KAAIA,C,UAAC,QACA,SAACA,EAAAA,KAAIA,CAACC,MAAI,E,SAAGf,EAAKzT,QAAQ6Q,SAAe,OAAM4C,EAAKzT,QAAQW,UAAUsL,SAIvE,SAACsI,EAAAA,KAAIA,C,SAAGd,EAAKxH,MAExB,C,8HCHe,SAASuH,GAAY,KAAEC,IAEpC,MAAOf,EAAQZ,IAAaW,EAAAA,EAAAA,UAASgB,EAAKf,SACnCsC,EAAMC,IAAWxC,EAAAA,EAAAA,UAAS,IAGjCS,EAAAA,EAAAA,kBAAgB,IACPO,EAAKL,GAAG,UAAWC,IACxBvB,EAAUuB,EAAMX,OAAO,KAExB,CAACe,KAEJP,EAAAA,EAAAA,kBAAgB,IACPO,EAAKL,GAAG,aAAa,EAAG8B,eAC7BD,EAAQC,EAAS,KAElB,CAACzB,IAGJ,MAAM0B,GAAgBlG,EAAAA,EAAAA,GAAawE,EAAKzT,UAAYyT,EAAKtE,QAASD,EAAAA,EAAAA,GAAYuE,EAAKtE,MAAMnP,SAEzF,OAAQ0S,GACN,IAAK,UACL,IAAK,QACL,IAAK,WACH,OACE,UAACgB,EAAAA,IAAGA,C,WACF,SAACa,EAAAA,KAAIA,CAACa,MAAM,O,SAAQ,OACpB,SAAC1B,EAAAA,IAAGA,CAAC2B,YAAa,E,UAChB,SAACd,EAAAA,KAAIA,CAACa,MAAM,OAAOhS,KAAK,W,UAAW,SAAC2R,EAAAA,EAAQA,CAACtB,KAAMA,WAK3D,IAAK,UACH,OACE,UAACC,EAAAA,IAAGA,C,WACF,SAACa,EAAAA,KAAIA,CAACa,MAAOD,EAAgB,WAAQ/O,E,UACnC,SAACkP,EAAAA,QAAOA,CAAAA,MAEV,SAAC5B,EAAAA,IAAGA,CAAC2B,YAAa,E,UAChB,SAACd,EAAAA,KAAIA,CAACa,MAAOD,EAAgB,WAAQ/O,EAAWhD,KAAK,W,UACnD,SAAC2R,EAAAA,EAAQA,CAACtB,KAAMA,WAM1B,IAAK,OACH,OACE,UAACC,EAAAA,IAAGA,C,WACF,SAACa,EAAAA,KAAIA,CAACa,MAAM,Q,SAAUG,EAAAA,QAAAA,WACtB,SAAC7B,EAAAA,IAAGA,CAAC2B,YAAa,E,UAChB,SAACd,EAAAA,KAAIA,CAACa,MAAOD,EAAgB,WAAQ/O,EAAWhD,KAAK,W,UAAW,SAAC2R,EAAAA,EAAQA,CAACtB,KAAMA,SAElF,SAACC,EAAAA,IAAGA,CAAC2B,YAAa,EAAGG,WAAY,E,UAC/B,UAACjB,EAAAA,KAAIA,CAACa,MAAOD,EAAgB,OAAS,M,UAAO,UAAOM,EAAAA,EAAAA,SAAGT,GAAM,YAKrE,IAAK,SACH,OACE,UAACtB,EAAAA,IAAGA,C,WACF,SAACa,EAAAA,KAAIA,CAACa,MAAM,M,SAAQG,EAAAA,QAAAA,SACpB,SAAC7B,EAAAA,IAAGA,CAAC2B,YAAa,E,UAChB,SAACd,EAAAA,KAAIA,CAACa,MAAOD,EAAgB,WAAQ/O,EAAWhD,KAAK,W,UAAW,SAAC2R,EAAAA,EAAQA,CAACtB,KAAMA,SAElF,SAACC,EAAAA,IAAGA,CAAC2B,YAAa,EAAGG,WAAY,E,UAC/B,UAACjB,EAAAA,KAAIA,CAACa,MAAOD,EAAgB,OAAS,M,UAAO,UAAOM,EAAAA,EAAAA,SAAGT,GAAM,YAKzE,C,gDCxFO,SAASvE,EAAUgD,EAAiBiC,GACzC,MAAMC,GAAQ5T,EAAAA,EAAAA,WAEd,GAAI0R,EAAKmC,UACP,OAAOD,EAIT,IAAIE,EAAU,GAEd,MAAM7D,EAAOyB,EAAKL,GAAG,UAAUsC,KAAWI,IACxC,MACMC,GADOF,EAAUC,EAAMrT,KAAKuT,SAAS,UACxBpJ,MAAM,SAEzBiJ,EAAUE,EAAME,OAAS,GAEzB,IAAK,MAAMvF,KAAQqF,EACjBJ,EAAMnT,KAAKkO,EACb,IAYF,OARAwF,EAAAA,EAAAA,OAAMzC,EAAM,aAAa,KACvBzB,IAEI6D,GACFF,EAAMnT,KAAKqT,EACb,IAGKF,CACT,C,kCClCO,MAAM/O,UAAsB+E,MAEjCpM,WAAAA,CAAY,EAAuBuD,GACjCsN,MAAMtN,G,KADaqT,KAAAA,CAErB,E,iBCJK1Q,eAAeP,EAAcD,GAClC,OAAOmR,OAAsD,UAArBnO,QAAQoO,SAAuB,UAAUpR,IAAaA,EAChG,CAEO,SAASyD,EAAiDtD,GAC/D,OAAOA,CACT,C,yCCNO,SAAS0J,EAAUrM,EAAeiT,EAA6BzN,QAAQgB,QACxEyM,EAAOY,MACTZ,EAAO3B,MAAMwC,KAAKC,UAAU/T,EAAM,KAAM,IAExCiT,EAAO3B,MAAMwC,KAAKC,UAAU/T,GAEhC,C,iCCNO,SAASgS,EAAWgC,GACzB,OAAOA,EAAIC,OAAO,GAAGC,cAAgBF,EAAIzH,UAAU,GAAG4H,aACxD,CAEO,SAAStF,EAAiBZ,GAC/BA,EAAOA,EAAKmG,OAEZ,MAAMC,EAAkB,GACxB,IAAIC,EAAe,GACfC,EAAO,EAEX,IAAK,IAAIC,EAAI,EAAGA,EAAIvG,EAAKnK,SAAU0Q,EAAG,CACpC,MAAMC,EAAIxG,EAAKuG,GAEXF,EACEG,IAAMH,IACRA,EAAe,IAGb,CAAC,IAAK,KAAM5D,SAAS+D,GACvBH,EAAeG,EACA,MAANA,IACTJ,EAAM3L,KAAKuF,EAAKP,MAAM6G,EAAMC,IAE5BD,EAAOC,EAAI,EAGjB,CAIA,OAFAH,EAAM3L,KAAKuF,EAAKP,MAAM6G,IAEfF,CACT,C,wEClBA,MAAM3U,EAAU,IAAIC,EAAAA,iBAAiB,8BAY9BqD,eAAe0B,EAAoCkN,EAAmB8C,GAC3E,MAAMjF,GAAQkF,EAAAA,EAAAA,oBAAmB/C,GACjC,QAAcjO,IAAV8L,EAAqB,OAAOA,EAGhC,MAAMmF,QAAeF,IAKrB,OAHAG,EAAAA,EAAAA,oBAAmBjD,EAAKgD,GACxBlV,EAAQc,YAAY,CAAEoR,MAAKkD,MAAOF,IAE3BA,CACT,CAtBAlV,EAAQE,QAERF,EAAQG,UAAaiP,IACnB,MAAMiG,EAAMjG,GATd,SAAuBiG,GACrB,MAAsB,iBAARA,GAA4B,OAARA,GAAgB,QAASA,GAAO,UAAWA,CAC/E,EASMC,CAAcD,EAAI/U,QACpB6U,EAAAA,EAAAA,oBAAmBE,EAAI/U,KAAK4R,IAAKmD,EAAI/U,KAAK8U,MAC5C,C","sources":["webpack://@jujulego/jill/./src/commons/context.service.ts","webpack://@jujulego/jill/./src/commons/logger.service.ts","webpack://@jujulego/jill/./src/commons/logger/parameters.ts","webpack://@jujulego/jill/./src/commons/logger/thread.gateway.ts","webpack://@jujulego/jill/./src/commons/logger/log.gateway.ts","webpack://@jujulego/jill/./src/ajv.config.ts","webpack://@jujulego/jill/./src/config/utils.ts","webpack://@jujulego/jill/./src/config/config-loader.ts","webpack://@jujulego/jill/./src/config/config-options.ts","webpack://@jujulego/jill/./src/constants.ts","webpack://@jujulego/jill/./src/inversify.config.ts","webpack://@jujulego/jill/./src/jill.application.ts","webpack://@jujulego/jill/./src/modules/command.ts","webpack://@jujulego/jill/./src/ink.config.tsx","webpack://@jujulego/jill/./src/modules/ink-command.tsx","webpack://@jujulego/jill/./src/modules/middleware.ts","webpack://@jujulego/jill/./src/modules/module.ts","webpack://@jujulego/jill/./src/modules/plugin-loader.service.ts","webpack://@jujulego/jill/./src/modules/service.ts","webpack://@jujulego/jill/./src/modules/task-command.tsx","webpack://@jujulego/jill/./src/tasks/command-task.ts","webpack://@jujulego/jill/./src/tasks/script-task.ts","webpack://@jujulego/jill/./src/tasks/task-manager.config.ts","webpack://@jujulego/jill/./src/ui/group-task-spinner.tsx","webpack://@jujulego/jill/./src/ui/static-logs.tsx","webpack://@jujulego/jill/./src/ui/layout.tsx","webpack://@jujulego/jill/./src/ui/list.tsx","webpack://@jujulego/jill/./src/ui/task-manager-spinner.tsx","webpack://@jujulego/jill/./src/ui/task-name.tsx","webpack://@jujulego/jill/./src/ui/task-spinner.tsx","webpack://@jujulego/jill/./src/utils/events.ts","webpack://@jujulego/jill/./src/utils/exit.ts","webpack://@jujulego/jill/./src/utils/import.ts","webpack://@jujulego/jill/./src/utils/json.ts","webpack://@jujulego/jill/./src/utils/string.ts","webpack://@jujulego/jill/./src/utils/worker-cache.ts"],"sourcesContent":["import { Logger, withLabel } from '@jujulego/logger';\nimport { inject } from 'inversify';\nimport { AsyncLocalStorage } from 'node:async_hooks';\n\nimport { Service } from '@/src/modules/service.ts';\nimport { type Project } from '@/src/project/project.ts';\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { type JillApplication } from '@/src/jill.application.ts';\n\n// Types\nexport interface Context {\n application?: JillApplication;\n project?: Project;\n workspace?: Workspace;\n}\n\n// Service\n@Service()\nexport class ContextService implements Context {\n // Attributes\n private readonly _logger: Logger;\n private readonly _storage = new AsyncLocalStorage<Context>();\n\n // Constructor\n constructor(@inject(Logger) logger: Logger) {\n this._logger = logger.child(withLabel('context'));\n this.reset();\n }\n\n // Methods\n reset(context: Context = {}): void {\n this._storage.enterWith(context);\n }\n\n private _getContext(): Context {\n const ctx = this._storage.getStore();\n\n if (!ctx) {\n this._logger.warning('Trying to access uninitialized context');\n return {};\n }\n\n return ctx;\n }\n\n private _updateContext(update: Partial<Context>): void {\n Object.assign(this._getContext(), update);\n }\n\n // Properties\n get application(): JillApplication | undefined {\n return this._getContext().application;\n }\n\n set application(application: JillApplication | undefined) {\n this._updateContext({ application });\n }\n\n get project(): Project | undefined {\n return this._getContext().project;\n }\n\n set project(project: Project | undefined) {\n this._updateContext({ project });\n }\n\n get workspace(): Workspace | undefined {\n return this._getContext().workspace;\n }\n\n set workspace(workspace: Workspace | undefined) {\n this._updateContext({ workspace });\n }\n}\n","import { Logger, logger$, withTimestamp } from '@jujulego/logger';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { LogGateway } from '@/src/commons/logger/log.gateway.ts';\n\n// Service\ncontainer.bind(Logger).toDynamicValue(() => logger$(withTimestamp()))\n .inSingletonScope()\n .onActivation(({ container }, logger) => {\n const gateway = container.get(LogGateway);\n gateway.connect(logger);\n\n return logger;\n });\n","import { type interfaces as int } from 'inversify';\n\nimport { container } from '@/src/inversify.config.ts';\n\n// Constants\nexport const LOG_BROADCAST_CHANNEL: int.ServiceIdentifier<string> = Symbol.for('jujulego:jill:log-broadcast-channel');\n\n// Parameters\ncontainer.bind(LOG_BROADCAST_CHANNEL).toConstantValue('jujulego:jill:logger');\n","import { Source, source$ } from '@jujulego/event-tree';\nimport { LogLevel, quick, withTimestamp } from '@jujulego/logger';\nimport { inject } from 'inversify';\nimport { BroadcastChannel } from 'node:worker_threads';\n\nimport { Service } from '@/src/modules/service.ts';\n\nimport { LOG_BROADCAST_CHANNEL } from './parameters.ts';\nimport { JillLog } from './types.ts';\n\n// Gateway\n@Service()\nexport class ThreadGateway implements Source<JillLog> {\n // Attributes\n readonly channel: BroadcastChannel;\n\n private readonly _source = source$<JillLog>();\n\n // Constructor\n constructor(\n @inject(LOG_BROADCAST_CHANNEL) channel: string\n ) {\n this.channel = new BroadcastChannel(channel);\n this.channel.unref();\n\n this.channel.onmessage = (log) => {\n this._source.next((log as MessageEvent<JillLog>).data);\n };\n\n this.channel.onmessageerror = (data) => {\n this._source.next(withTimestamp()({\n level: LogLevel.error,\n message: quick.string`Unable to read message: #!json:${(data as MessageEvent).data}`\n }));\n };\n }\n\n // Methods\n next(data: JillLog): void {\n this.channel.postMessage(data);\n }\n\n readonly subscribe = this._source.subscribe;\n readonly unsubscribe = this._source.unsubscribe;\n readonly clear = this._source.clear;\n}\n","import { filter$, flow$, var$ } from '@jujulego/aegis';\nimport { Listener, Observable, OffFn, source$ } from '@jujulego/event-tree';\nimport { LogLevel, qlevelColor, quick, toStderr } from '@jujulego/logger';\nimport { qprop } from '@jujulego/quick-tag';\nimport { chalkTemplateStderr } from 'chalk-template';\nimport { interfaces as int } from 'inversify';\nimport wt from 'node:worker_threads';\n\nimport { OnServiceActivate, Service } from '@/src/modules/service.ts';\n\nimport { ThreadGateway } from './thread.gateway.ts';\nimport { JillLog } from './types.ts';\n\n// Utils\nexport const jillLogFormat = qlevelColor(\n quick.wrap(chalkTemplateStderr)\n .function<JillLog>`#?:${qprop('label')}{grey [#$]} ?#${qprop('message')}`\n);\n\n// Service\n@Service()\nexport class LogGateway implements Observable<JillLog>, OnServiceActivate {\n // Attributes\n readonly level$ = var$(LogLevel.info);\n\n private readonly _source = source$<JillLog>();\n\n // Lifecycle\n onServiceActivate({ container }: int.Context) {\n const threadGtw = container.get(ThreadGateway);\n\n if (wt.isMainThread) {\n // Redirect logs to stderr\n flow$(\n this._source,\n toStderr(jillLogFormat),\n );\n\n // Add thread gateway as input\n this.connect(threadGtw);\n } else {\n // Redirect logs to thread gateway\n flow$(this._source,\n threadGtw\n );\n }\n }\n\n // Methods\n readonly subscribe = this._source.subscribe;\n readonly unsubscribe = this._source.unsubscribe;\n readonly clear = this._source.clear;\n\n connect(origin: Observable<JillLog>): OffFn {\n return flow$(origin,\n filter$((log) => log.level >= this.level),\n this._source\n );\n }\n\n // Properties\n get listeners(): readonly Listener<JillLog>[] {\n return Array.from(this._source.listeners);\n }\n\n get level(): LogLevel {\n return this.level$.read();\n }\n\n set level(level: LogLevel) {\n this.level$.mutate(level);\n }\n}\n","import { Logger, withLabel } from '@jujulego/logger';\nimport Ajv from 'ajv';\nimport { type interfaces as int } from 'inversify';\n\nimport { container } from './inversify.config.ts';\n\n// Symbols\nexport const AJV: int.ServiceIdentifier<Ajv.default> = Symbol('jujulego:jill:Ajv');\n\n// Setup\ncontainer\n .bind(AJV)\n .toDynamicValue(({ container }) => {\n const logger = container.get(Logger);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return new (Ajv as any)({\n allErrors: true,\n logger: logger.child(withLabel('ajv')),\n strict: process.env.NODE_ENV === 'development' ? 'log' : true,\n });\n })\n .inSingletonScope();\n\n","import { type interfaces as int } from 'inversify';\nimport { type ValidateFunction } from 'ajv';\nimport { cosmiconfig, defaultLoaders } from 'cosmiconfig';\n\nimport { AJV } from '@/src/ajv.config.ts';\nimport schema from '@/src/config/schema.json';\nimport { container } from '@/src/inversify.config.ts';\nimport { dynamicImport } from '@/src/utils/import.ts';\n\nimport { type IConfig, type IConfigExplorer } from './types.ts';\n\n// Symbols\nexport const CONFIG_EXPLORER: int.ServiceIdentifier<IConfigExplorer> = Symbol('jujulego:jill:config-explorer');\nexport const CONFIG_VALIDATOR: int.ServiceIdentifier<ValidateFunction<IConfig>> = Symbol('jujulego:jill:config-validator');\n\n// Setup\ncontainer\n .bind(CONFIG_VALIDATOR)\n .toDynamicValue(({ container }) => {\n const ajv = container.get(AJV);\n return ajv.compile<IConfig>(schema);\n })\n .inSingletonScope();\n\ncontainer\n .bind(CONFIG_EXPLORER)\n .toDynamicValue(() => {\n return cosmiconfig('jill', {\n loaders: {\n '.cjs': (filepath) => dynamicImport(filepath).then((mod) => mod.default),\n '.js': (filepath) => dynamicImport(filepath).then((mod) => mod.default),\n '.json': defaultLoaders['.json'],\n '.yaml': defaultLoaders['.yaml'],\n '.yml': defaultLoaders['.yml'],\n noExt: defaultLoaders.noExt,\n }\n });\n })\n .inSingletonScope();\n","import { Logger, LogLevel, withLabel } from '@jujulego/logger';\nimport { type interfaces as int } from 'inversify';\nimport os from 'node:os';\nimport path from 'node:path';\n\nimport { AJV } from '@/src/ajv.config.ts';\nimport { LogGateway } from '@/src/commons/logger/log.gateway.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { ExitException } from '@/src/utils/exit.ts';\nimport { workerCache } from '@/src/utils/worker-cache.ts';\n\nimport { CONFIG_OPTIONS } from './config-options.ts';\nimport { type IConfig } from './types.ts';\nimport { CONFIG_EXPLORER, CONFIG_VALIDATOR } from './utils.ts';\n\n// Symbols\nexport const CONFIG: int.ServiceIdentifier<IConfig> = Symbol('jujulego:jill:config');\n\n// Loader\nexport async function configLoader() {\n const logger = container.get(Logger).child(withLabel('config'));\n\n const options = container.get(CONFIG_OPTIONS);\n const explorer = container.get(CONFIG_EXPLORER);\n const validator = container.get(CONFIG_VALIDATOR);\n\n // Load file\n const loaded = await explorer.search();\n const config = loaded?.config ?? {};\n\n // Apply options from cli\n if (options.jobs) config.jobs = options.jobs;\n if (options.verbose) config.verbose = options.verbose;\n if (options.hooks !== undefined) config.hooks = options.hooks;\n\n // Apply defaults\n config.jobs ??= (os.cpus().length - 1);\n config.hooks ??= true;\n\n // Validate\n if (!validator(config)) {\n const ajv = container.get(AJV);\n const errors = ajv.errorsText(validator.errors, { separator: '\\n- ', dataVar: 'config' });\n\n logger.error(`Errors in config file:\\n- ${errors}`);\n throw new ExitException(1);\n }\n\n // Apply on logger\n if (config.verbose) {\n container.get(LogGateway).level = LogLevel[config.verbose];\n }\n\n if (loaded) {\n // Resolve paths relative to config file\n const base = path.dirname(loaded.filepath);\n config.plugins = config.plugins?.map((plugin) => path.resolve(base, plugin));\n\n logger.verbose(`Loaded ${loaded.filepath} config file`);\n }\n\n logger.debug`Loaded config:\\n#!json:${config}`;\n\n return config;\n}\n\ncontainer\n .bind(CONFIG)\n .toDynamicValue(async () => await workerCache('jujulego:jill:config', configLoader))\n .inSingletonScope();\n","import yargs, { type Argv } from 'yargs';\nimport { type interfaces as int } from 'inversify';\nimport { hideBin } from 'yargs/helpers';\n\nimport { container } from '@/src/inversify.config.ts';\n\nimport { type IConfig } from './types.ts';\n\n// Symbols\nexport const CONFIG_OPTIONS: int.ServiceIdentifier<IConfig> = Symbol('jujulego:jill:config-options');\n\n// Constants\nconst VERBOSITY_LEVEL: Record<number, IConfig['verbose']> = {\n 1: 'verbose',\n 2: 'debug',\n};\n\n// Options\nexport function applyConfigOptions(parser: Argv): Argv<Omit<IConfig, 'plugins'>> {\n return parser\n .option('verbose', {\n alias: 'v',\n type: 'count',\n description: 'Set verbosity level',\n coerce: (cnt) => VERBOSITY_LEVEL[Math.min(cnt, 2)]\n })\n .option('jobs', {\n alias: 'j',\n type: 'number',\n description: 'Set maximum parallel job number',\n })\n .option('hooks', {\n type: 'boolean',\n description: 'Run hook scripts',\n });\n}\n\ncontainer\n .bind(CONFIG_OPTIONS)\n .toDynamicValue(() => {\n const parser = yargs(hideBin(process.argv))\n .help(false)\n .version(false);\n\n applyConfigOptions(parser);\n\n return parser.parse();\n })\n .inSingletonScope();\n","// Constants\nexport const CURRENT = 'current';\n","import { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\n\nimport 'reflect-metadata';\n\nimport { fixDefaultExport } from './utils/import.ts';\n\n// Container\nexport const container = new Container();\n\n// Utilities\nexport const { lazyInject, lazyInjectNamed } = fixDefaultExport(getDecorators)(container);\n","import { Logger, withLabel } from '@jujulego/logger';\nimport { type Task } from '@jujulego/tasks';\nimport { inject, injectable, type interfaces as int } from 'inversify';\nimport yargs, { type Argv, type CommandModule } from 'yargs';\n\nimport { ContextService, type Context } from '@/src/commons/context.service.ts';\nimport { applyConfigOptions } from '@/src/config/config-options.ts';\nimport { CURRENT } from '@/src/constants.ts';\nimport { container, lazyInjectNamed } from '@/src/inversify.config.ts';\nimport { buildCommandModule, COMMAND, COMMAND_MODULE, getCommandOpts, type ICommand } from '@/src/modules/command.ts';\nimport { getModule } from '@/src/modules/module.ts';\nimport { PluginLoaderService } from '@/src/modules/plugin-loader.service.ts';\nimport { TaskCommand } from '@/src/modules/task-command.tsx';\nimport { type Class } from '@/src/types.ts';\n\n// @ts-ignore: Outside of typescript's rootDir in build\nimport pkg from '../package.json';\n\n// Application\n@injectable()\nexport class JillApplication {\n // Attributes\n readonly container: int.Container;\n readonly parser: Argv;\n\n // Constructor\n constructor(\n @inject(ContextService)\n private readonly context: ContextService,\n @inject(PluginLoaderService)\n private readonly plugins: PluginLoaderService,\n @inject(Logger)\n private readonly logger: Logger,\n ) {\n // Create container\n this.container = container.createChild();\n\n // Create parser\n this.parser = yargs()\n .scriptName('jill')\n .completion('completion', 'Generate bash completion script')\n .help('help', 'Show help for a command')\n .version('version', 'Show version', pkg.version)\n .wrap(process.stdout.columns)\n .exitProcess(false);\n }\n\n // Methods\n private _prepareParser(commands: CommandModule[]): Argv {\n applyConfigOptions(this.parser);\n\n return this.parser\n .command(commands)\n .recommendCommands()\n .strict()\n .fail(false);\n }\n\n private async _loadPlugins(): Promise<void> {\n this.logger.child(withLabel('plugin')).verbose('Loading plugin <core>');\n\n const { CorePlugin } = await import('@/src/core.plugin.ts');\n this.container.load(getModule(CorePlugin, true));\n\n await this.plugins.loadPlugins(this.container);\n }\n\n async run(argv: string | readonly string[]): Promise<void> {\n this.context.reset({ application: this });\n await this._loadPlugins();\n\n // Parse command\n const commands = await this.container.getAllAsync(COMMAND_MODULE);\n\n await this._prepareParser(commands).parseAsync(argv);\n }\n\n async tasksOf(argv: string[], ctx: Omit<Context, 'application'> = {}): Promise<Task[]> {\n this.context.reset({ ...ctx, application: this });\n await this._loadPlugins();\n\n // Prepare commands\n const commands = await this.container.getAllAsync(COMMAND);\n\n return new Promise<Task[]>((resolve, reject) => {\n const modules: CommandModule[] = [];\n\n for (const cmd of commands) {\n const opts = getCommandOpts(cmd.constructor as Class<ICommand>);\n const mod = buildCommandModule(cmd, opts);\n\n mod.handler = async (args) => {\n if (cmd instanceof TaskCommand) {\n const tasks: Task[] = [];\n\n for await (const tsk of cmd.prepare(args)) {\n tasks.push(tsk);\n }\n\n resolve(tasks);\n } else {\n resolve([]);\n }\n };\n\n modules.push(mod);\n }\n\n // Parse command\n this._prepareParser(modules)\n .parseAsync(argv)\n .catch(reject);\n });\n }\n}\n\ncontainer.bind(JillApplication)\n .toSelf()\n .inTransientScope()\n .whenTargetIsDefault();\n\n// Lazy injection\nexport function LazyCurrentApplication() {\n return lazyInjectNamed(JillApplication, CURRENT);\n}\n\ncontainer.bind(JillApplication)\n .toDynamicValue(({ container }) => {\n const ctx = container.get(ContextService);\n const app = ctx.application;\n\n if (!app) {\n throw new Error('Cannot inject current application, it not yet defined');\n }\n\n return app;\n })\n .whenTargetNamed(CURRENT);\n","import { Logger } from '@jujulego/logger';\nimport { decorate, injectable, type interfaces as int } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv, type CommandModule } from 'yargs';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { setRegistry } from '@/src/modules/module.ts';\nimport { type Awaitable, type Class, type Type } from '@/src/types.ts';\nimport { ExitException } from '@/src/utils/exit.ts';\n\nimport { applyMiddlewares, type IMiddleware } from './middleware.ts';\n\n// Symbols\nconst COMMAND_OPTS = Symbol('jujulego:jill:command-opts');\n\nexport const COMMAND: int.ServiceIdentifier<ICommand> = Symbol('jujulego:jill:command');\nexport const COMMAND_MODULE: int.ServiceIdentifier<CommandModule> = Symbol('jujulego:jill:command-module');\n\n// Types\nexport interface ICommand<A = unknown> {\n builder?: (parser: Argv) => Argv<A>;\n handler(args: ArgumentsCamelCase<A>): Awaitable<void>;\n}\n\nexport interface ICommandOpts {\n readonly command: string;\n readonly aliases?: string | readonly string[];\n readonly describe?: string;\n readonly deprecated?: boolean;\n readonly middlewares?: Type<IMiddleware>[];\n}\n\n// Utils\nexport function getCommandOpts(target: Class<ICommand>): ICommandOpts {\n const opts = Reflect.getMetadata(COMMAND_OPTS, target);\n\n if (typeof opts !== 'object') {\n throw new Error(`No command options found in ${target.name}`);\n }\n\n return opts;\n}\n\nexport function buildCommandModule(cmd: ICommand, opts: ICommandOpts): CommandModule {\n return {\n command: opts.command,\n aliases: opts.aliases,\n describe: opts.describe,\n deprecated: opts.deprecated,\n\n builder(parser: Argv) {\n if (opts.middlewares) {\n parser = applyMiddlewares(parser, opts.middlewares);\n }\n\n if (cmd.builder) {\n parser = cmd.builder(parser);\n }\n\n return parser;\n },\n handler: async (args) => {\n try {\n await cmd.handler(args);\n } catch (err) {\n if (err.message) {\n const logger = container.get(Logger);\n logger.error(err.message);\n }\n\n throw new ExitException(1);\n }\n },\n };\n}\n\n// Decorator\nexport function Command(opts: ICommandOpts) {\n return (target: Class<ICommand>) => {\n decorate(injectable(), target);\n\n Reflect.defineMetadata(COMMAND_OPTS, opts, target);\n\n const cmd = opts.command.split(' ')[0];\n setRegistry(target, (bind) => {\n bind(target).toSelf();\n\n bind(COMMAND)\n .toDynamicValue(({ container }) => container.getAsync(target))\n .whenTargetNamed(cmd);\n\n bind(COMMAND_MODULE)\n .toDynamicValue(async ({ container }) => {\n const cmd = await container.getAsync(target);\n return buildCommandModule(cmd, opts);\n })\n .whenTargetNamed(cmd);\n });\n };\n}\n","import { type Instance } from 'ink';\nimport { render } from 'ink';\nimport { type interfaces as int } from 'inversify';\nimport wt from 'node:worker_threads';\n\nimport { container } from '@/src/inversify.config.ts';\nimport Layout from '@/src/ui/layout.tsx';\n\n// Constants\nexport const INK_APP: int.ServiceIdentifier<Instance> = Symbol.for('jujulego:jill:ink-app');\n\n// Setup\ncontainer\n .bind(INK_APP)\n .toDynamicValue(() => {\n if (!wt.isMainThread) {\n throw new Error('Ink should only be used in main thread');\n }\n\n return render(<Layout />);\n })\n .inSingletonScope();\n","import { type Instance} from 'ink';\nimport { injectable } from 'inversify';\nimport { type ReactNode } from 'react';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { INK_APP } from '@/src/ink.config.tsx';\nimport { lazyInject } from '@/src/inversify.config.ts';\nimport { type AwaitableGenerator } from '@/src/types.ts';\nimport Layout from '@/src/ui/layout.tsx';\n\nimport { type ICommand } from './command.ts';\n\n// Class\n@injectable()\nexport abstract class InkCommand<A = unknown> implements ICommand<A> {\n // Lazy injections\n @lazyInject(INK_APP)\n readonly app: Instance;\n\n // Methods\n abstract render(args: ArgumentsCamelCase<A>): AwaitableGenerator<ReactNode>;\n\n builder(parser: Argv): Argv<A> {\n return parser as Argv<A>;\n }\n\n async handler(args: ArgumentsCamelCase<A>): Promise<void> {\n for await (const children of this.render(args)) {\n this.app.rerender(\n <Layout>\n { children }\n </Layout>\n );\n }\n\n await this.app.waitUntilExit();\n }\n}\n","import { decorate, injectable } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { type Awaitable, type Type } from '@/src/types.ts';\n\n// Types\nexport interface IMiddleware<A = unknown> {\n builder?: (parser: Argv) => Argv<A>;\n handler(args: ArgumentsCamelCase<A>): Awaitable<void>;\n}\n\n// Decorator\nexport function Middleware() {\n return (target: Type<IMiddleware>) => {\n decorate(injectable(), target);\n container.bind(target).toSelf().inSingletonScope();\n };\n}\n\n// Utils\nexport function applyMiddlewares(parser: Argv, middlewares: Type<IMiddleware>[]): Argv {\n let tmp = parser;\n\n for (const cls of middlewares) {\n const middleware = container.get(cls);\n\n if (middleware.builder) {\n tmp = middleware.builder(tmp);\n }\n\n tmp.middleware((args) => middleware.handler(args));\n }\n\n return tmp;\n}\n","import { ContainerModule, type interfaces as int } from 'inversify';\n\nimport { type Class } from '@/src/types.ts';\n\n// Symbols\nconst MODULE = Symbol('jujulego:jill:module');\nconst REGISTRY = Symbol('jujulego:jill:registry');\n\n// Utils\nexport function getRegistry(target: Class): int.ContainerModuleCallBack {\n const registry = Reflect.getMetadata(REGISTRY, target);\n\n if (typeof registry !== 'function') {\n throw new Error(`No registry found in ${target.name}`);\n }\n\n return registry;\n}\n\nexport function setRegistry(target: Class, registry: int.ContainerModuleCallBack) {\n Reflect.defineMetadata(REGISTRY, registry, target);\n}\n\nexport function getModule(target: Class): ContainerModule | null;\nexport function getModule(target: Class, assert: true): ContainerModule;\nexport function getModule(target: Class, assert = false): ContainerModule | null {\n let module = Reflect.getMetadata(MODULE, target);\n\n if (!module || !(module instanceof ContainerModule)) {\n const registry = Reflect.getMetadata(REGISTRY, target);\n\n if (typeof registry !== 'function') {\n if (assert) {\n throw new Error(`No module found in ${target.name}`);\n }\n\n return null;\n }\n\n module = new ContainerModule(registry);\n setModule(target, module);\n }\n\n return module;\n}\n\nexport function setModule(target: Class, module: ContainerModule) {\n Reflect.defineMetadata(MODULE, module, target);\n}\n","import { Logger, withLabel } from '@jujulego/logger';\nimport { type ContainerModule, inject, type interfaces as int } from 'inversify';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { type IConfig } from '@/src/config/types.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { dynamicImport } from '@/src/utils/import.ts';\n\nimport { getModule } from './module.ts';\nimport { Service } from './service.ts';\n\n// Class\n@Service()\nexport class PluginLoaderService {\n // Attributes\n private readonly _logger: Logger;\n\n // Constructor\n constructor(\n @inject(CONFIG)\n private readonly _config: IConfig,\n @inject(Logger)\n logger: Logger,\n ) {\n this._logger = logger.child(withLabel('plugin'));\n }\n\n // Methods\n private async _importPlugin(filepath: string): Promise<ContainerModule> {\n this._logger.verbose`Loading plugin ${filepath}`;\n\n // Load plugin\n let plugin = await dynamicImport(filepath);\n\n while (plugin && typeof plugin === 'object' && 'default' in plugin) {\n plugin = plugin.default;\n }\n\n if (!plugin) {\n throw new Error(`Invalid plugin ${filepath}: no plugin class found`);\n }\n\n // Load module from plugin\n const module = getModule(plugin);\n\n if (!module) {\n throw new Error(`Invalid plugin ${filepath}: invalid plugin class`);\n }\n\n return module;\n }\n\n async loadPlugins(ctn: int.Container = container): Promise<void> {\n if (!this._config.plugins) return;\n\n for (const path of this._config.plugins) {\n const plugin = await this._importPlugin(path);\n ctn.load(plugin);\n }\n }\n}\n","import { decorate, injectable, interfaces as int } from 'inversify';\n\nimport { container } from '@/src/inversify.config.ts';\n\n// Types\nexport interface OnServiceActivate {\n onServiceActivate(context: int.Context): void;\n}\n\n// Decorators\n/**\n * Register class as a service\n */\nexport function Service(): ClassDecorator {\n return (cls) => {\n decorate(injectable(), cls);\n container.bind(cls).toSelf().inSingletonScope()\n .onActivation((ctx, service) => {\n if ('onServiceActivate' in service) {\n service.onServiceActivate(ctx);\n }\n\n return service;\n });\n\n return cls;\n };\n}\n","import { waitFor$ } from '@jujulego/event-tree';\nimport { Logger } from '@jujulego/logger';\nimport { plan as extractPlan, type Task, type TaskManager, TaskSet, type TaskSummary } from '@jujulego/tasks';\nimport { injectable } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { container, lazyInject } from '@/src/inversify.config.ts';\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\nimport { TASK_MANAGER } from '@/src/tasks/task-manager.config.ts';\nimport { type AwaitableGenerator } from '@/src/types.ts';\nimport List from '@/src/ui/list.tsx';\nimport TaskManagerSpinner from '@/src/ui/task-manager-spinner.tsx';\nimport { ExitException } from '@/src/utils/exit.ts';\nimport { printJson } from '@/src/utils/json.ts';\n\nimport { InkCommand } from './ink-command.tsx';\n\n// Types\nexport interface ITaskCommandArgs {\n plan: boolean;\n 'plan-mode': 'json' | 'list';\n}\n\n// Class\n@injectable()\nexport abstract class TaskCommand<A = unknown> extends InkCommand<A> {\n // Attributes\n @lazyInject(TASK_MANAGER)\n readonly manager: TaskManager;\n\n // Methods\n abstract prepare(args: ArgumentsCamelCase<A>): AwaitableGenerator<Task>;\n\n protected addTaskOptions(parser: Argv): Argv<ITaskCommandArgs> {\n return parser\n .option('plan', {\n type: 'boolean',\n desc: 'Only prints tasks to be run',\n default: false,\n })\n .option('plan-mode', {\n type: 'string',\n desc: 'Plan output mode',\n choices: ['json', 'list'] as const,\n default: 'list' as const\n });\n }\n\n async* render(args: ArgumentsCamelCase<A & ITaskCommandArgs>) {\n // Prepare tasks\n const tasks = new TaskSet();\n\n for await (const tsk of this.prepare(args)) {\n tasks.add(tsk);\n }\n\n if (args.plan) {\n const plan: TaskSummary[] = Array.from(extractPlan(tasks));\n\n if (args.planMode === 'json') {\n printJson(plan);\n } else {\n const data = plan.map((tsk) => ({\n id: tsk.id.substring(0, 6),\n name: tsk.name,\n workspace: isCommandCtx(tsk.context) || isScriptCtx(tsk.context) ? tsk.context.workspace.name : '',\n group: tsk.groupId?.substring(0, 6),\n 'depends on': tsk.dependenciesIds.map(id => id.substring(0, 6)).join(', ')\n }));\n\n yield <List items={data} headers/>;\n }\n } else if (tasks.tasks.length > 0) {\n // Render\n yield <TaskManagerSpinner manager={this.manager} />;\n\n // Start tasks\n tasks.start(this.manager);\n\n const result = await waitFor$(tasks, 'finished');\n\n if (result.failed > 0) {\n throw new ExitException(1);\n }\n } else {\n const logger = container.get(Logger);\n logger.warning('No task found');\n }\n }\n}\n","import { SpawnTask, type SpawnTaskOptions, type TaskContext } from '@jujulego/tasks';\n\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { linesFrom } from '@/src/utils/events.ts';\n\n// Types\nexport interface CommandContext extends TaskContext {\n workspace: Workspace;\n command: string;\n}\n\nexport interface CommandOptions extends Omit<SpawnTaskOptions, 'cwd'> {\n superCommand?: string | string[];\n}\n\n// Utils\nexport function isCommandCtx(ctx: Readonly<TaskContext>): ctx is Readonly<CommandContext> {\n return 'workspace' in ctx && 'command' in ctx;\n}\n\n// Class\nexport class CommandTask extends SpawnTask<CommandContext> {\n // Constructor\n constructor(readonly workspace: Workspace, command: string, args: string[], opts: CommandOptions = {}) {\n let cmd = command;\n\n if (opts.superCommand) {\n if (typeof opts.superCommand === 'string') {\n opts.superCommand = [opts.superCommand];\n }\n\n if (opts.superCommand.length > 0) {\n cmd = opts.superCommand[0];\n args = [...opts.superCommand.slice(1), command, ...args];\n }\n }\n\n super(cmd, args, { workspace, command }, {\n ...opts,\n cwd: workspace.cwd,\n env: {\n FORCE_COLOR: '1',\n ...opts.env\n }\n });\n\n this._logStreams();\n }\n\n // Methods\n private _logStreams() {\n // TODO: clean up this subscriptions\n linesFrom(this, 'stdout').subscribe((line) => this._logger.info(line));\n linesFrom(this, 'stderr').subscribe((line) => this._logger.info(line));\n }\n}\n","import { waitFor$ } from '@jujulego/event-tree';\nimport { GroupTask, type Task, type TaskContext, type TaskOptions, TaskSet } from '@jujulego/tasks';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { JillApplication } from '@/src/jill.application.ts';\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { CommandTask } from '@/src/tasks/command-task.ts';\nimport { splitCommandLine } from '@/src/utils/string.ts';\n\n// Types\nexport interface ScriptContext extends TaskContext {\n workspace: Workspace;\n script: string;\n}\n\nexport interface ScriptOpts extends TaskOptions {\n runHooks?: boolean;\n}\n\n// Utils\nexport function isScriptCtx(ctx: Readonly<TaskContext>): ctx is Readonly<ScriptContext> {\n return 'workspace' in ctx && 'script' in ctx;\n}\n\n// Class\nexport class ScriptTask extends GroupTask<ScriptContext> {\n // Attributes\n private _preHookTasks: TaskSet | null = null;\n private _postHookTasks: TaskSet | null = null;\n private _scriptTasks: TaskSet | null = null;\n private readonly _runHooks: boolean;\n\n // Constructor\n constructor(\n readonly workspace: Workspace,\n readonly script: string,\n readonly args: string[],\n opts?: ScriptOpts\n ) {\n super(script, { workspace, script }, opts);\n this._runHooks = opts?.runHooks ?? true;\n }\n\n // Methods\n private async _runScript(script: string, args: string[]): Promise<TaskSet | null> {\n const line = this.workspace.getScript(script);\n\n if (!line) {\n return null;\n }\n\n // Create command task for script\n const [command, ...commandArgs] = splitCommandLine(line);\n\n if (command === 'jill') {\n this._logger.debug(`Interpreting ${line}`);\n const argv = commandArgs.map(arg => arg.replace(/^[\"'](.+)[\"']$/, '$1'));\n\n const app = container.get(JillApplication);\n const tasks = await app.tasksOf(argv, {\n project: this.project,\n workspace: this.workspace,\n });\n\n if (tasks.length) {\n const set = new TaskSet();\n\n for (const tsk of tasks) {\n set.add(tsk);\n }\n\n return set;\n }\n }\n\n const pm = await this.workspace.project.packageManager();\n\n const set = new TaskSet();\n set.add(\n new CommandTask(this.workspace, command, [...commandArgs, ...args], {\n logger: this._logger,\n superCommand: pm === 'yarn' ? ['yarn', 'exec'] : undefined,\n })\n );\n\n return set;\n }\n\n async prepare(): Promise<void> {\n // Prepare script run\n this._scriptTasks = await this._runScript(this.script, this.args);\n\n if (!this._scriptTasks) {\n throw new Error(`No script ${this.script} in ${this.workspace.name}`);\n }\n\n // Prepare hooks run\n if (this._runHooks) {\n this._preHookTasks = await this._runScript(`pre${this.script}`, []);\n this._postHookTasks = await this._runScript(`post${this.script}`, []);\n }\n\n // Add tasks to group\n if (this._preHookTasks) {\n this._logger.verbose(`Found pre-hook script \"pre${this.script}\"`);\n\n for (const tsk of this._preHookTasks) {\n this.add(tsk);\n }\n }\n\n for (const tsk of this._scriptTasks) {\n this.add(tsk);\n }\n\n if (this._postHookTasks) {\n this._logger.verbose(`Found post-hook script \"post${this.script}\"`);\n\n for (const tsk of this._postHookTasks) {\n this.add(tsk);\n }\n }\n }\n\n protected async *_orchestrate(): AsyncGenerator<Task, void, undefined> {\n if (!this._scriptTasks) {\n throw new Error('ScriptTask needs to be prepared. Call prepare before starting it');\n }\n\n // Run pre-hook\n if (this._preHookTasks) {\n yield* this._preHookTasks;\n\n if (await this._hasFailed(this._preHookTasks)) {\n return this.setStatus('failed');\n }\n }\n\n // Run script\n yield* this._scriptTasks;\n\n if (await this._hasFailed(this._scriptTasks)) {\n return this.setStatus('failed');\n }\n\n // Run post-hook\n if (this._postHookTasks) {\n yield* this._postHookTasks;\n\n if (await this._hasFailed(this._postHookTasks)) {\n return this.setStatus('failed');\n }\n }\n\n this.setStatus('done');\n }\n\n private async _hasFailed(set: TaskSet): Promise<boolean> {\n const results = await waitFor$(set, 'finished');\n return results.failed > 0;\n }\n\n protected _stop(): void {\n if (!this._scriptTasks) return;\n\n for (const tsk of this._scriptTasks) {\n tsk.stop();\n }\n }\n\n complexity(cache = new Map<string, number>()): number {\n let complexity = super.complexity(cache);\n\n if (this._scriptTasks) {\n complexity += this._scriptTasks.tasks.reduce((cpl, tsk) => cpl + tsk.complexity(cache), 0);\n }\n\n cache.set(this.id, complexity);\n\n return complexity;\n }\n\n // Properties\n get project() {\n return this.workspace.project;\n }\n}\n","import { Logger } from '@jujulego/logger';\nimport { TaskManager } from '@jujulego/tasks';\nimport { type interfaces as int } from 'inversify';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { container } from '@/src/inversify.config.ts';\n\n// Symbols\nexport const TASK_MANAGER: int.ServiceIdentifier<TaskManager> = Symbol('jujulego:jill:TaskManager');\n\n// Service\ncontainer.bind(TASK_MANAGER)\n .toDynamicValue(({ container }) => {\n const config = container.get(CONFIG);\n const logger = container.get(Logger);\n\n return new TaskManager({ jobs: config.jobs, logger });\n })\n .inSingletonScope();\n","import { GroupTask } from '@jujulego/tasks';\nimport { Box } from 'ink';\nimport { Fragment, useLayoutEffect, useMemo, useState } from 'react';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\n\nimport TaskSpinner from './task-spinner.tsx';\n\n// Types\nexport interface GroupTaskSpinnerProps {\n group: GroupTask;\n}\n\n// Components\nexport default function GroupTaskSpinner({ group }: GroupTaskSpinnerProps) {\n // State\n const [verbose, setVerbose] = useState(false);\n const [status, setStatus] = useState(group.status);\n const [tasks, setTasks] = useState([...group.tasks]);\n const [canReduce, setCanReduce] = useState(true);\n\n // Memo\n const forceExtended = useMemo(() => verbose || tasks.some((tsk) => !isCommandCtx(tsk.context)), [verbose, tasks]);\n const isReduced = useMemo(() => !forceExtended && canReduce, [forceExtended, canReduce]);\n\n // Effects\n useLayoutEffect(() => {\n const config = container.get(CONFIG);\n\n if (config.verbose) {\n setVerbose(['verbose', 'debug'].includes(config.verbose));\n }\n }, []);\n\n useLayoutEffect(() => {\n return group.on('status', (event) => {\n setStatus(event.status);\n });\n }, [group]);\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return group.on('task.added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks([...group.tasks]);\n dirty = false;\n });\n }\n });\n }, [group]);\n\n useLayoutEffect(() => {\n if (status === 'running') {\n setCanReduce(false);\n } else if (status === 'done') {\n setCanReduce(true);\n }\n }, [status]);\n\n // Render\n return (\n <>\n <TaskSpinner task={group} />\n { isReduced || (\n <Box flexDirection=\"column\" marginLeft={2}>\n { tasks.map((task) => (\n <Fragment key={task.id}>\n { (task instanceof GroupTask) ? (\n <GroupTaskSpinner group={task} />\n ) : (\n <TaskSpinner task={task} />\n ) }\n </Fragment>\n )) }\n </Box>\n ) }\n </>\n );\n}\n","import { useStderr } from 'ink';\nimport { useLayoutEffect, } from 'react';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { jillLogFormat, LogGateway } from '@/src/commons/logger/log.gateway.ts';\n\n// Component\nexport default function StaticLogs() {\n // State\n const { write } = useStderr();\n\n // Effect\n useLayoutEffect(() => {\n const gateway = container.get(LogGateway);\n\n // Remove Console transport\n const listeners = gateway.listeners;\n gateway.clear();\n\n // Add custom transport\n const off = gateway.subscribe((log) => {\n write(jillLogFormat(log) + '\\n');\n });\n\n return () => {\n off();\n\n // Restore previous listeners\n for (const lst of listeners) {\n gateway.subscribe(lst);\n }\n };\n }, [write]);\n\n return null;\n}\n","import { type ReactNode } from 'react';\n\nimport StaticLogs from './static-logs.tsx';\n\n// Types\nexport interface LayoutProps {\n children?: ReactNode;\n}\n\n// Component\nexport default function Layout({ children }: LayoutProps) {\n return (\n <>\n <StaticLogs />\n { children }\n </>\n );\n}\n","import { Box, Text } from 'ink';\n\nimport { capitalize } from '@/src/utils/string.ts';\n\n// Types\nexport interface ListProps<T extends Record<string, unknown>> {\n items: T[];\n headers?: boolean;\n}\n\n// Component\nexport default function List<T extends Record<string, unknown>>({ items, headers }: ListProps<T>) {\n if (items.length === 0) {\n return null;\n }\n\n return (\n <Box>\n { Object.keys(items[0]).map((key) => (\n <Box key={key} flexDirection=\"column\" marginRight={2}>\n { headers && (\n <Text bold>{ capitalize(key) }</Text>\n ) }\n { items.map((item, idx) => (\n <Text key={idx}>{ item[key] as string || ' ' }</Text>\n )) }\n </Box>\n )) }\n </Box>\n );\n}\n","import { GroupTask, Task, type TaskManager } from '@jujulego/tasks';\nimport { useLayoutEffect, useState } from 'react';\n\nimport GroupTaskSpinner from './group-task-spinner.tsx';\nimport TaskSpinner from './task-spinner.tsx';\n\n// Types\nexport interface TasksSpinnerProps {\n manager: TaskManager;\n}\n\n// Utils\nfunction taskPredicate(task: Task): boolean {\n if (task.group) {\n return false;\n }\n\n if ('hidden' in task.context && task.context.hidden) {\n return false;\n }\n\n return true;\n}\n\n// Components\nexport default function TaskManagerSpinner({ manager }: TasksSpinnerProps) {\n const [tasks, setTasks] = useState(manager.tasks.filter(taskPredicate));\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return manager.on('added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks(manager.tasks.filter(taskPredicate));\n dirty = false;\n });\n }\n });\n }, [manager]);\n\n return (\n <>\n { tasks.map((task) =>\n (task instanceof GroupTask) ? (\n <GroupTaskSpinner key={task.id} group={task} />\n ) : (\n <TaskSpinner key={task.id} task={task} />\n )\n ) }\n </>\n );\n}\n","import { type Task } from '@jujulego/tasks';\nimport { Text } from 'ink';\n\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\n\n// Types\nexport interface TaskNameProps {\n task: Task;\n}\n\n// Components\nexport default function TaskName({ task }: TaskNameProps) {\n if (isScriptCtx(task.context)) {\n return (\n <Text>\n Run <Text bold>{ task.context.script }</Text> in { task.context.workspace.name }\n </Text>\n );\n } else {\n return <Text>{ task.name }</Text>;\n }\n}\n","import { type Task } from '@jujulego/tasks';\nimport { Box, Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport ms from 'pretty-ms';\nimport { useLayoutEffect, useState } from 'react';\n\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\n\nimport TaskName from './task-name.tsx';\n\n// Types\nexport interface TaskSpinnerProps {\n task: Task;\n}\n\n// Components\nexport default function TaskSpinner({ task }: TaskSpinnerProps) {\n // State\n const [status, setStatus] = useState(task.status);\n const [time, setTime] = useState(0);\n\n // Effects\n useLayoutEffect(() => {\n return task.on('status', (event) => {\n setStatus(event.status);\n });\n }, [task]);\n\n useLayoutEffect(() => {\n return task.on('completed', ({ duration }) => {\n setTime(duration);\n });\n }, [task]);\n\n // Render\n const isScriptChild = isCommandCtx(task.context) && task.group && isScriptCtx(task.group.context);\n\n switch (status) {\n case 'blocked':\n case 'ready':\n case 'starting':\n return (\n <Box>\n <Text color=\"grey\">{'\\u00B7'}</Text>\n <Box paddingLeft={1}>\n <Text color=\"grey\" wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n </Box>\n );\n\n case 'running':\n return (\n <Box>\n <Text color={isScriptChild ? 'dim' : undefined}>\n <Spinner />\n </Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\">\n <TaskName task={task} />\n </Text>\n </Box>\n </Box>\n );\n\n case 'done':\n return (\n <Box>\n <Text color=\"green\">{ symbols.success }</Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n <Box paddingLeft={1} flexShrink={0}>\n <Text color={isScriptChild ? 'grey' : 'dim'}>(took {ms(time)})</Text>\n </Box>\n </Box>\n );\n\n case 'failed':\n return (\n <Box>\n <Text color=\"red\">{ symbols.error }</Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n <Box paddingLeft={1} flexShrink={0}>\n <Text color={isScriptChild ? 'grey' : 'dim'}>(took {ms(time)})</Text>\n </Box>\n </Box>\n );\n }\n}\n","import { once$, source$, type Source } from '@jujulego/event-tree';\nimport { type SpawnTask, type SpawnTaskStream } from '@jujulego/tasks';\n\n// Utils\nexport function linesFrom(task: SpawnTask, stream: SpawnTaskStream): Source<string> {\n const inner = source$<string>();\n\n if (task.completed) {\n return inner;\n }\n\n // Listen to stream\n let current = '';\n\n const stop = task.on(`stream.${stream}`, (chunk) => {\n const data = current + chunk.data.toString('utf-8');\n const lines = data.split(/\\r?\\n/);\n\n current = lines.pop() ?? '';\n\n for (const line of lines) {\n inner.next(line);\n }\n });\n\n // Listen to end of task\n once$(task, 'completed', () => {\n stop();\n\n if (current) {\n inner.next(current);\n }\n });\n\n return inner;\n}\n","// Class\nexport class ExitException extends Error {\n // Constructor\n constructor(readonly code: number, message?: string) {\n super(message);\n }\n}\n","// Utils\nexport async function dynamicImport(filepath: string) {\n return import(/* webpackIgnore: true */ process.platform === 'win32' ? `file://${filepath}` : filepath);\n}\n\nexport function fixDefaultExport<T extends { default: unknown }>(mod: T): T['default'] {\n return mod as T['default'];\n}","// Utils\nexport function printJson(data: unknown, stream: NodeJS.WriteStream = process.stdout): void {\n if (stream.isTTY) { // Pretty print for ttys\n stream.write(JSON.stringify(data, null, 2));\n } else {\n stream.write(JSON.stringify(data));\n }\n}\n","// Utils\nexport function capitalize(txt: string): string {\n return txt.charAt(0).toUpperCase() + txt.substring(1).toLowerCase();\n}\n\nexport function splitCommandLine(line: string): string[] {\n line = line.trim();\n\n const parts: string[] = [];\n let current_cote = '';\n let last = 0;\n\n for (let i = 1; i < line.length; ++i) {\n const c = line[i];\n\n if (current_cote) {\n if (c === current_cote) {\n current_cote = '';\n }\n } else {\n if (['\"', '\\''].includes(c)) {\n current_cote = c;\n } else if (c === ' ') {\n parts.push(line.slice(last, i));\n\n last = i + 1;\n }\n }\n }\n\n parts.push(line.slice(last));\n\n return parts;\n}\n","import { BroadcastChannel, getEnvironmentData, type Serializable, setEnvironmentData } from 'node:worker_threads';\n\nimport { type Awaitable } from '@/src/types.ts';\n\n// Types\ninterface CacheUpdate {\n key: Serializable;\n value: Serializable;\n}\n\nfunction isCacheUpdate(msg: unknown): msg is CacheUpdate {\n return typeof msg === 'object' && msg !== null && 'key' in msg && 'value' in msg;\n}\n\n// Chanel\nconst channel = new BroadcastChannel('jujulego:jill:worker-cache');\nchannel.unref();\n\nchannel.onmessage = (arg) => {\n const msg = arg as MessageEvent;\n\n if (isCacheUpdate(msg.data)) {\n setEnvironmentData(msg.data.key, msg.data.value);\n }\n};\n\n// Utils\nexport async function workerCache<R extends Serializable>(key: Serializable, compute: () => Awaitable<R>): Promise<R> {\n const cache = getEnvironmentData(key) as R | undefined;\n if (cache !== undefined) return cache;\n\n // Compute it\n const result = await compute();\n\n setEnvironmentData(key, result);\n channel.postMessage({ key, value: result });\n\n return result;\n}\n"],"names":["ContextService","constructor","_storage","AsyncLocalStorage","this","_logger","logger","child","withLabel","reset","context","enterWith","_getContext","getStore","warning","_updateContext","update","Object","assign","application","project","workspace","Service","inject","Logger","container","bind","toDynamicValue","logger$","withTimestamp","inSingletonScope","onActivation","get","LogGateway","connect","LOG_BROADCAST_CHANNEL","Symbol","for","toConstantValue","ThreadGateway","_source","source$","subscribe","unsubscribe","clear","channel","BroadcastChannel","unref","onmessage","log","next","data","onmessageerror","level","LogLevel","error","message","quick","string","postMessage","jillLogFormat","qlevelColor","wrap","chalkTemplateStderr","function","qprop","onServiceActivate","threadGtw","wt","flow$","toStderr","origin","filter$","listeners","Array","from","level$","read","mutate","var$","info","AJV","Ajv","allErrors","strict","CONFIG_EXPLORER","CONFIG_VALIDATOR","compile","schema","cosmiconfig","loaders","filepath","dynamicImport","then","mod","default","defaultLoaders","noExt","CONFIG","async","configLoader","options","CONFIG_OPTIONS","explorer","validator","loaded","search","config","jobs","verbose","undefined","hooks","os","length","errors","errorsText","separator","dataVar","ExitException","base","path","plugins","map","plugin","debug","workerCache","VERBOSITY_LEVEL","applyConfigOptions","parser","option","alias","type","description","coerce","cnt","Math","min","yargs","hideBin","process","argv","help","version","parse","CURRENT","Container","lazyInject","lazyInjectNamed","fixDefaultExport","getDecorators","JillApplication","createChild","scriptName","completion","pkg","stdout","columns","exitProcess","_prepareParser","commands","command","recommendCommands","fail","_loadPlugins","CorePlugin","load","getModule","loadPlugins","run","getAllAsync","COMMAND_MODULE","parseAsync","tasksOf","ctx","COMMAND","Promise","resolve","reject","modules","cmd","opts","getCommandOpts","buildCommandModule","handler","args","TaskCommand","tasks","tsk","prepare","push","catch","injectable","PluginLoaderService","toSelf","inTransientScope","whenTargetIsDefault","app","Error","whenTargetNamed","COMMAND_OPTS","target","Reflect","getMetadata","name","aliases","describe","deprecated","builder","middlewares","applyMiddlewares","err","Command","decorate","defineMetadata","split","setRegistry","getAsync","INK_APP","render","Layout","InkCommand","children","rerender","waitUntilExit","Middleware","tmp","cls","middleware","MODULE","REGISTRY","getRegistry","registry","assert","module","ContainerModule","setModule","_config","_importPlugin","ctn","service","addTaskOptions","desc","choices","TaskSet","add","plan","extractPlan","planMode","printJson","id","substring","isCommandCtx","isScriptCtx","group","groupId","dependenciesIds","join","List","items","headers","TaskManagerSpinner","manager","start","waitFor$","failed","TASK_MANAGER","CommandTask","SpawnTask","superCommand","slice","super","cwd","env","FORCE_COLOR","_logStreams","linesFrom","line","ScriptTask","GroupTask","script","_preHookTasks","_postHookTasks","_scriptTasks","_runHooks","runHooks","_runScript","getScript","commandArgs","splitCommandLine","arg","replace","set","pm","packageManager","_orchestrate","_hasFailed","setStatus","_stop","stop","complexity","cache","Map","reduce","cpl","TaskManager","GroupTaskSpinner","setVerbose","useState","status","setTasks","canReduce","setCanReduce","forceExtended","useMemo","some","isReduced","useLayoutEffect","includes","on","event","dirty","queueMicrotask","TaskSpinner","task","Box","flexDirection","marginLeft","Fragment","StaticLogs","write","useStderr","gateway","off","lst","keys","key","marginRight","Text","bold","capitalize","item","idx","taskPredicate","hidden","filter","TaskName","time","setTime","duration","isScriptChild","color","paddingLeft","Spinner","symbols","flexShrink","ms","stream","inner","completed","current","chunk","lines","toString","pop","once$","code","import","platform","isTTY","JSON","stringify","txt","charAt","toUpperCase","toLowerCase","trim","parts","current_cote","last","i","c","compute","getEnvironmentData","result","setEnvironmentData","value","msg","isCacheUpdate"],"sourceRoot":""}