@jujulego/jill 2.1.1 → 2.2.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/554.js +2 -0
  2. package/dist/554.js.map +1 -0
  3. package/dist/719.js +9 -0
  4. package/dist/{748.js.LICENSE.txt → 719.js.LICENSE.txt} +0 -0
  5. package/dist/719.js.map +1 -0
  6. package/dist/{services/ajv.config.d.ts → ajv.config.d.ts} +1 -1
  7. package/dist/commands/each.d.ts +22 -14
  8. package/dist/commands/group.d.ts +18 -8
  9. package/dist/commands/list.d.ts +20 -21
  10. package/dist/commands/run.d.ts +19 -6
  11. package/dist/commands/tree.d.ts +7 -3
  12. package/dist/commons/git.service.d.ts +61 -0
  13. package/dist/{services → commons}/logger.service.d.ts +0 -0
  14. package/dist/{services → commons}/spinner.service.d.ts +0 -0
  15. package/dist/config/config-loader.d.ts +4 -0
  16. package/dist/config/config-options.d.ts +5 -0
  17. package/dist/config/types.d.ts +7 -0
  18. package/dist/config/utils.d.ts +5 -0
  19. package/dist/core.plugin.d.ts +2 -0
  20. package/dist/filters/affected.filter.d.ts +3 -2
  21. package/dist/filters/pipeline.d.ts +2 -2
  22. package/dist/filters/private.filter.d.ts +2 -2
  23. package/dist/filters/scripts.filter.d.ts +2 -2
  24. package/dist/index.d.ts +17 -12
  25. package/dist/index.js +1 -1
  26. package/dist/index.js.map +1 -1
  27. package/dist/ink.config.d.ts +3 -0
  28. package/dist/inversify.config.d.ts +4 -0
  29. package/dist/main.js +1 -1
  30. package/dist/main.js.map +1 -1
  31. package/dist/middlewares/load-project.d.ts +17 -4
  32. package/dist/middlewares/load-workspace.d.ts +16 -3
  33. package/dist/modules/command.d.ts +19 -0
  34. package/dist/modules/ink-command.d.ts +11 -0
  35. package/dist/modules/middleware.d.ts +8 -0
  36. package/dist/modules/module.d.ts +7 -0
  37. package/dist/modules/plugin-loader.service.d.ts +9 -0
  38. package/dist/modules/plugin.d.ts +14 -0
  39. package/dist/modules/service.d.ts +4 -0
  40. package/dist/project/constants.d.ts +1 -0
  41. package/dist/project/project.d.ts +1 -0
  42. package/dist/project/workspace.d.ts +4 -2
  43. package/dist/{services → tasks}/task-expr.service.d.ts +5 -2
  44. package/dist/{services → tasks}/task-manager.config.d.ts +1 -1
  45. package/dist/tsconfig.build.tsbuildinfo +1 -1
  46. package/dist/types.d.ts +7 -0
  47. package/dist/ui/layout.d.ts +1 -1
  48. package/dist/ui/task-manager-spinner.d.ts +1 -1
  49. package/dist/ui/task-name.d.ts +1 -1
  50. package/dist/ui/task-spinner.d.ts +1 -1
  51. package/dist/ui/workspace-tree.d.ts +2 -2
  52. package/dist/utils/streams.d.ts +1 -1
  53. package/package.json +3 -3
  54. package/dist/748.js +0 -9
  55. package/dist/748.js.map +0 -1
  56. package/dist/784.js +0 -2
  57. package/dist/784.js.map +0 -1
  58. package/dist/commands/index.d.ts +0 -40
  59. package/dist/git.d.ts +0 -16
  60. package/dist/middlewares/config-options.d.ts +0 -5
  61. package/dist/middlewares/setup-ink.d.ts +0 -1
  62. package/dist/services/config/explorer.d.ts +0 -4
  63. package/dist/services/config/loader.d.ts +0 -4
  64. package/dist/services/config/types.d.ts +0 -5
  65. package/dist/services/config/validator.d.ts +0 -4
  66. package/dist/services/inversify.config.d.ts +0 -11
  67. package/dist/services/plugins/plugin-loader.service.d.ts +0 -10
  68. package/dist/services/plugins/types.d.ts +0 -5
  69. package/dist/services/plugins/utils.d.ts +0 -3
  70. package/dist/utils/yargs.d.ts +0 -9
package/dist/554.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";exports.id=554,exports.ids=[554],exports.modules={90236:(e,t,s)=>{s.d(t,{F:()=>d});var r=s(28344),n=s(29724),o=s(79060),a=s(85099),i=s(95960),c=s(29921),l=function(e,t){return function(s,r){t(s,r,e)}};let d=class{constructor(e,t){this.manager=e,this.logger=t}command(e,t,s={}){const n={logger:this.logger,...s},o=new r.m("git",[e,...t],{command:e},n);return o.subscribe("stream",(({data:e})=>n.logger.debug(e.toString("utf-8")))),this.manager.add(o),o}branch(e,t){return this.command("branch",e,t)}diff(e,t){return this.command("diff",e,t)}tag(e,t){return this.command("tag",e,t)}isAffected(e,t=[],s){return new Promise(((r,n)=>{const o=this.diff(["--quiet",e,"--",...t],s);o.subscribe("status.done",(()=>r(!1))),o.subscribe("status.failed",(()=>{o.exitCode?r(!0):n(new Error(`Task ${o.name} failed`))}))}))}async listBranches(e=[],t){const s=this.branch(["-l",...e],t),r=[];for await(const e of(0,i.F)(s,"stdout"))r.push(e.replace(/^[ *] /,""));return r}async listTags(e=[],t){const s=this.tag(["-l",...e],t),r=[];for await(const e of(0,i.F)(s,"stdout"))r.push(e);return r}};d=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a}([(0,c.t)(),l(0,(0,n.f)(a.N)),l(1,(0,n.f)(o.Y))],d)},79060:(e,t,s)=>{s.d(t,{D:()=>i,Y:()=>c});var r=s(9),n=s(41429),o=s.n(n),a=s(10466);const i=o().format.combine(o().format.colorize({message:!0,colors:{debug:"grey",verbose:"blue",info:"white",error:"red"}}),o().format.printf((({label:e,message:t,stack:s})=>{s&&(t=r.ZP.red(s));const n=t.split("\n");let o="",a=n[0];e&&(o=" ".repeat(e.length+3),a=`${r.ZP.grey(`[${e}]`)} ${n[0]}`);for(let e=1;e<n.length;++e)a+=`\n${o}${n[e]}`;return a})));class c{}a.nC.bind(c).toDynamicValue((()=>o().createLogger({format:o().format.combine(o().format.timestamp(),o().format.errors({stack:!1})),transports:[new(o().transports.Console)({format:i})]}))).inSingletonScope()},53565:(e,t,s)=>{s.d(t,{V:()=>i});var r=s(36793),n=s(26844),o=s(19694),a=s(29921);(0,n.GW)((0,o.b)(),r.n);let i=class extends r.n{_status="stop";_label="";spin(e){this._status="spin",this._label=e,this.emit("update.spin",this.state)}success(e){this._status="success",this._label=e,this.emit("update.success",this.state)}failed(e){this._status="failed",this._label=e,this.emit("update.failed",this.state)}stop(){"spin"===this._status&&(this._status="stop",this.emit("update.stop",this.state))}get state(){return{status:this._status,label:this._label}}};i=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a}([(0,a.t)()],i)},77839:(e,t,s)=>{s.d(t,{k:()=>y});var r=s(70612),n=s.n(r),o=s(49411),a=s.n(o),i=s(69670),c=s.n(i),l=s(10466),d=s(79060);const u=Symbol("jujulego:jill:Ajv");l.nC.bind(u).toDynamicValue((()=>{const e=l.nC.get(d.Y);return new(c())({allErrors:!0,logger:e.child({label:"ajv"}),strict:!0})})).inSingletonScope();var f=s(13843),p=s(2925);const h=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 g=s(18520);const m=Symbol("jujulego:jill:config-explorer"),b=Symbol("jujulego:jill:config-validator");l.nC.bind(b).toDynamicValue((e=>e.container.get(u).compile(h))).inSingletonScope(),l.nC.bind(m).toDynamicValue((()=>(0,p.oG)("jill",{loaders:{".cjs":e=>(0,g.y)(e).then((e=>e.default)),".js":e=>(0,g.y)(e).then((e=>e.default)),".json":p.Jq[".json"],".yaml":p.Jq[".yaml"],".yml":p.Jq[".yml"],noExt:p.Jq.noExt}}))).inSingletonScope();const y=Symbol("jujulego:jill:config");l.nC.bind(y).toDynamicValue((async function(){const e=l.nC.get(d.Y).child({label:"config"}),t=l.nC.get(f.c),s=l.nC.get(m),r=l.nC.get(b),o=await s.search(),i=o?.config??{};if(t.jobs&&(i.jobs=t.jobs),t.verbose&&(i.verbose=t.verbose),i.jobs??=n().cpus().length-1,!r(i)){const t=l.nC.get(u).errorsText(r.errors,{separator:"\n- ",dataVar:"config"});return e.error(`Errors in config file:\n- ${t}`),process.exit(1),{}}if(o){const t=a().dirname(o.filepath);i.plugins=i.plugins?.map((e=>a().resolve(t,e))),i.verbose&&(l.nC.get(d.Y).level=i.verbose),e.verbose(`Loaded ${o.filepath} config file`)}return e.debug(`Loaded config:\n${JSON.stringify(i,null,2)}`),i})).inSingletonScope()},13843:(e,t,s)=>{s.d(t,{N:()=>c,c:()=>a});var r=s(26627),n=s(54346),o=s(10466);const a=Symbol("jujulego:jill:config-options"),i={1:"verbose",2:"debug"};function c(e){return e.option("verbose",{alias:"v",type:"count",description:"Set verbosity level",coerce:e=>i[Math.min(e,2)]}).option("jobs",{alias:"j",type:"number",description:"Set maximum parallel job number"})}o.nC.bind(a).toDynamicValue((()=>{const e=(0,r.Z)((0,n.bA)(process.argv)).help(!1).version(!1);return c(e),e.parse()})).inSingletonScope()},48652:(e,t,s)=>{s.d(t,{L:()=>i});var r=s(90236),n=s(10466),o=s(79060),a=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a};class i{constructor(e,t,s){this.format=e,this.fallback=t,this.sort=s}async _formatRevision(e){const t=this._logger.child({label:e.name});let s=this.format;s=s.replace(/(?<!\\)((?:\\\\)*)%name/g,`$1${e.name}`),s=s.replace(/\\(.)/g,"$1");const r=this.sort?["--sort",this.sort]:[];if(s.includes("*")){const n=await this._git.listBranches([...r,s],{cwd:e.cwd,logger:t});n.length>0&&(s=n[n.length-1])}if(s.includes("*")){const n=await this._git.listTags([...r,s],{cwd:e.cwd,logger:t});n.length>0&&(s=n[n.length-1])}return s!==this.format&&t.verbose(`Resolved ${this.format} into ${s}`),s.includes("*")?(t.warn(`No revision found matching ${s}, using fallback ${this.fallback}`),this.fallback):s}async test(e){const t=await this._formatRevision(e);return await e.isAffected(t)}}a([(0,n.yT)(o.Y)],i.prototype,"_logger",void 0),a([(0,n.yT)(r.F)],i.prototype,"_git",void 0)},72999:(e,t,s)=>{s.d(t,{B:()=>r});class r{_filters=[];add(e){this._filters.push(e)}async _test(e){for(const t of this._filters)if(!await t.test(e))return!1;return!0}async*filter(e){for await(const t of e)await this._test(t)&&(yield t)}}},40307:(e,t,s)=>{s.d(t,{N:()=>r});class r{constructor(e){this.value=e}test(e){return(e.manifest.private??!1)===this.value}}},84203:(e,t,s)=>{s.d(t,{f:()=>r});class r{constructor(e){this.scripts=e}test(e){const t=Object.keys(e.manifest.scripts||{});return this.scripts.some((e=>t.includes(e)))}}},10466:(e,t,s)=>{s.d(t,{nC:()=>o,oV:()=>i,yT:()=>a});var r=s(26403),n=s(44147);s(52866);const o=new r.W,{lazyInject:a,lazyInjectNamed:i}=(0,n.Z)(o)},8754:(e,t,s)=>{s.d(t,{r:()=>l});var r=s(29724),n=s(81632),o=s(53565),a=s(10466),i=s(1284),c=s(97672);let l=class{constructor(e){this.spinner=e}builder(e){return e.option("project",{alias:"p",type:"string",default:process.cwd(),description:"Project root directory"}).option("package-manager",{choices:["yarn","npm"],type:"string",description:"Force package manager"})}async handler(e){try{this.spinner.spin("Loading project ...");const t=e.project=await c.I.searchProjectRoot(e.project);a.nC.bind(c.I).toDynamicValue((()=>new c.I(t,{packageManager:e.packageManager}))).whenTargetNamed(i.W)}finally{this.spinner.stop()}}};var d,u;l=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a}([(0,n.d)(),(d=0,u=(0,r.f)(o.V),function(e,t){u(e,t,d)})],l)},72419:(e,t,s)=>{s.d(t,{S:()=>f});var r=s(29724),n=s(26627),o=s(81632),a=s(53565),i=s(10466),c=s(97672),l=s(1284),d=s(28410),u=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a};let f=class{constructor(e){this.spinner=e}builder(e){return e.option("workspace",{alias:"w",type:"string",desc:"Workspace to use"})}async handler(e){try{this.spinner.spin(`Loading "${e.workspace||"."}" workspace ...`);const t=await this.project.workspace(e.workspace);t?i.nC.bind(d.j).toConstantValue(t).whenTargetNamed(l.W):(this.spinner.failed(`Workspace "${e.workspace||"."}" not found`),n.Z.exit(1,new Error("Workspace not found")))}finally{this.spinner.stop()}}};var p,h;u([(0,c.P)()],f.prototype,"project",void 0),f=u([(0,o.d)(),(p=0,h=(0,r.f)(a.V),function(e,t){h(e,t,p)})],f)},39717:(e,t,s)=>{s.d(t,{$f:()=>d,NI:()=>c,_Y:()=>l,mY:()=>u});var r=s(26844),n=s(19694),o=s(81632),a=s(23617);const i=Symbol("jujulego:jill:command-opts"),c=Symbol("jujulego:jill:command");function l(e){const t=Reflect.getMetadata(i,e);if("object"!=typeof t)throw new Error(`No command options found in ${e.name}`);return t}function d(e,t){return{command:t.command,aliases:t.aliases,describe:t.describe,deprecated:t.deprecated,builder:async s=>(t.middlewares&&(s=(0,o.S)(s,t.middlewares)),e.builder&&(s=await e.builder(s)),s),handler:(...t)=>e.handler(...t)}}function u(e){return t=>{(0,r.GW)((0,n.b)(),t),Reflect.defineMetadata(i,e,t),(0,a.i8)(t,(s=>{s(t).toSelf(),s(c).toDynamicValue((async({container:s})=>d(await s.getAsync(t),e))).whenTargetNamed(e.command.split(" ")[0])}))}}},63893:(e,t,s)=>{s.d(t,{m:()=>u});var r=s(52010),n=s(29724),o=s(19694),a=s(81119),i=s(10466),c=s(58348);const l=Symbol.for("jujulego:jill:ink-app");i.nC.bind(l).toDynamicValue((()=>(0,a.render)((0,r.jsx)(c.Z,{}),{stdout:process.stdout.isTTY?process.stdout:process.stderr}))).inSingletonScope();var d=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a};let u=class{builder(e){return e}async handler(e){for await(const t of this.render(e))this.app.rerender((0,r.jsx)(c.Z,{children:t}));return this.app.waitUntilExit()}};d([(0,n.f)(l)],u.prototype,"app",void 0),u=d([(0,o.b)()],u)},81632:(e,t,s)=>{s.d(t,{S:()=>i,d:()=>a});var r=s(26844),n=s(19694),o=s(10466);function a(){return e=>{(0,r.GW)((0,n.b)(),e),o.nC.bind(e).toSelf().inSingletonScope()}}function i(e,t){let s=e;for(const e of t){const t=o.nC.get(e);t.builder&&(s=t.builder(s)),s.middleware((e=>t.handler(e)))}return s}},23617:(e,t,s)=>{s.d(t,{IY:()=>l,JH:()=>a,i8:()=>i,rT:()=>c});var r=s(20328);const n=Symbol("jujulego:jill:module"),o=Symbol("jujulego:jill:registry");function a(e){const t=Reflect.getMetadata(o,e);if("function"!=typeof t)throw new Error(`No registry found in ${e.name}`);return t}function i(e,t){Reflect.defineMetadata(o,t,e)}function c(e,t=!1){let s=Reflect.getMetadata(n,e);if(!(s&&s instanceof r.n)){const n=Reflect.getMetadata(o,e);if("function"!=typeof n){if(t)throw new Error(`No module found in ${e.name}`);return null}s=new r.n(n),l(e,s)}return s}function l(e,t){Reflect.defineMetadata(n,t,e)}},77051:(e,t,s)=>{s.d(t,{B:()=>u});var r=s(29724),n=s(77839),o=s(79060),a=s(10466),i=s(18520),c=s(23617),l=s(29921),d=function(e,t){return function(s,r){t(s,r,e)}};let u=class{constructor(e,t){this._config=e,this._logger=t.child({label:"plugin"})}async _importPlugin(e){this._logger.verbose(`Loading plugin ${e}`);let t=await(0,i.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 s=(0,c.rT)(t);if(!s)throw new Error(`Invalid plugin ${e}: invalid plugin class`);return s}async loadPlugins(){if(this._config.plugins)for(const e of this._config.plugins){const t=await this._importPlugin(e);a.nC.load(t)}}};u=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a}([(0,l.t)(),d(0,(0,r.f)(n.k)),d(1,(0,r.f)(o.Y))],u)},75756:(e,t,s)=>{s.d(t,{S:()=>i,p:()=>a});var r=s(20328),n=s(66150),o=s(23617);class a extends r.n{constructor(e,t){super(((...e)=>{for(const t of this.commands)(0,o.JH)(t)(...e)})),this.name=e,this.commands=t,this.id=(0,n.id)()}}function i(e){return t=>{const s=e.name??t.name,r=new a(s,e.commands);(0,o.IY)(t,r)}}},29921:(e,t,s)=>{s.d(t,{t:()=>a});var r=s(26844),n=s(19694),o=s(10466);function a(){return e=>((0,r.GW)((0,n.b)(),e),o.nC.bind(e).toSelf().inSingletonScope(),e)}},1284:(e,t,s)=>{s.d(t,{W:()=>r});const r="current"},97672:(e,t,s)=>{s.d(t,{I:()=>w,P:()=>j});var r=s(36489),n=s.n(r),o=s(19694),a=s(93977),i=s.n(a),c=s(49411),l=s.n(c),d=s(74782),u=s.n(d),f=s(18799),p=s.n(f),h=s(10466),g=s(79060),m=s(1284),b=s(28410),y=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a};let w=class{constructor(e,t={}){this._root=e,this._names=new Map,this._workspaces=new Map,this._isFullyLoaded=!1,this._lock=new(n()),t.packageManager&&(this._logger.debug(`Forced use of ${t.packageManager} in ${l().relative(process.cwd(),this.root)||"."}`),this._packageManager=t.packageManager)}static async searchProjectRoot(e){const t=h.nC.get(g.Y);let s=!1,r=e;e=l().resolve(e);do{const n=await i().readdir(e);if(n.includes("package.json")&&(r=e,s=!0),["package-lock.json","yarn.lock"].some((e=>n.includes(e))))return t.debug(`Project root found at ${l().relative(process.cwd(),e)||"."}`),e;e=l().dirname(e)}while(e!==l().dirname(e));return s?t.debug(`Project root found at ${l().relative(process.cwd(),r)||"."}`):t.debug(`Project root not found, keeping ${l().relative(process.cwd(),r)||"."}`),r}async _loadManifest(e){const t=l().resolve(this.root,e,"package.json"),s=l().relative(this.root,l().dirname(t)),r=this._logger.child({label:s?`project@${s}`:"project"});r.verbose("Loading package.json ...");const n=await i().readFile(t,"utf-8"),o=JSON.parse(n);return u()(o,(e=>r.verbose(e))),o}async _loadWorkspace(e){return await this._lock.acquire("workspaces",(async()=>{let t=this._workspaces.get(e);if(!t){const s=await this._loadManifest(e);t=new b.j(e,s,this),this._workspaces.set(e,t),this._names.set(t.name,t)}return t}))}async packageManager(){if(!this._packageManager){const e=await i().readdir(this.root);e.includes("yarn.lock")?(this._logger.debug(`Detected yarn in ${l().relative(process.cwd(),this.root)||"."}`),this._packageManager="yarn"):e.includes("package-lock.json")?(this._logger.debug(`Detected npm in ${l().relative(process.cwd(),this.root)||"."}`),this._packageManager="npm"):(this._logger.debug(`No package manager recognized in ${l().relative(process.cwd(),this.root)||"."}, defaults to npm`),this._packageManager="npm")}return this._packageManager}async mainWorkspace(){if(!this._mainWorkspace){const e=await this._loadManifest(".");this._mainWorkspace=new b.j(".",e,this),this._names.set(this._mainWorkspace.name,this._mainWorkspace)}return this._mainWorkspace}async currentWorkspace(e=process.cwd()){let t=null;e=l().resolve(e);for await(const s of this.workspaces())if(e.startsWith(s.cwd)&&(t=s,s.cwd!==this.root))return s;return t}async*workspaces(){const e=await this.mainWorkspace();if(yield e,this._isFullyLoaded)for(const t of this._names.values())t.name!==e.name&&(yield t);else{const{workspaces:t=[]}=e.manifest;for(const e of t)for(const t of await p()(e,{cwd:this.root}))try{const e=l().resolve(this.root,t);(await i().stat(e)).isDirectory()&&(yield await this._loadWorkspace(t))}catch(e){if("ENOENT"===e.code)continue;throw e}this._isFullyLoaded=!0}}async workspace(e){if(!e){const e=l().relative(this.root,process.cwd());return this._loadWorkspace(e)}const t=this._names.get(e);if(t)return t;if(this._isFullyLoaded)return null;for await(const t of this.workspaces())if(t.name===e)return t;return this._isFullyLoaded=!0,null}get root(){return l().resolve(this._root)}};function j(){return(0,h.oV)(w,m.W)}y([(0,h.yT)(g.Y)],w.prototype,"_logger",void 0),w=y([(0,o.b)()],w)},28410:(e,t,s)=>{s.d(t,{H:()=>g,j:()=>h});var r=s(28344),n=s(19694),o=s(49411),a=s.n(o),i=s(67329),c=s(90236),l=s(10466),d=s(79060),u=s(95960),f=s(1284),p=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a};let h=class{constructor(e,t,s){this._cwd=e,this.manifest=t,this.project=s,this._affectedCache=new Map,this._tasks=new Map;const r=l.nC.get(d.Y);this._logger=r.child({label:this.manifest.name})}_satisfies(e,t){return t.startsWith("file:")?a().resolve(e.cwd,t.substring(5))===this.cwd:(t.startsWith("workspace:")&&(t=t.substring(10)),!this.version||(0,i.satisfies)(this.version,t))}async _buildDependencies(e,t="all"){const s=[];switch(t){case"all":s.unshift(this.devDependencies());case"prod":s.unshift(this.dependencies())}for await(const t of(0,u.$)(...s)){const s=await t.build();s&&e.dependsOn(s)}}async _isAffected(e){if(await this._git.isAffected(e,[this.cwd],{cwd:this.project.root,logger:this._logger}))return!0;const t=[];for await(const s of(0,u.$)(this.dependencies(),this.devDependencies()))t.push(s.isAffected(e));return(await Promise.all(t)).some((e=>e))}async isAffected(e){let t=this._affectedCache.get(e);return t||(t=this._isAffected(e),this._affectedCache.set(e,t)),await t}async*_loadDependencies(e,t){for(const[s,r]of Object.entries(e)){const e=await this.project.workspace(s);e&&(e._satisfies(this,r)?yield e:this._logger.verbose(`Ignoring ${t} ${e.reference} as it does not match requirement ${r}`))}}async*dependencies(){if(this.manifest.dependencies)for await(const e of this._loadDependencies(this.manifest.dependencies,"dependency"))yield e}async*devDependencies(){if(this.manifest.devDependencies)for await(const e of this._loadDependencies(this.manifest.devDependencies,"devDependency"))yield e}async _streamLogs(e,t,s){try{for await(const r of(0,u.F)(e,t))this._logger.log(s,r,{label:`${this.name}#${e.context.script}`})}catch(s){s&&this._logger.warn(`Error while streaming task ${t}`,s,{label:`${this.name}#${e.context.script}`})}}async run(e,t=[],s={}){let n=this._tasks.get(e);if(!n){const o=await this.project.packageManager();n=new r.m(o,["run",e,...t],{workspace:this,script:e},{...s,cwd:this.cwd,logger:this._logger.child({label:`${this.name}#${e}`}),env:{FORCE_COLOR:"1",...s.env}}),this._streamLogs(n,"stdout","info"),this._streamLogs(n,"stderr","info"),await this._buildDependencies(n,s.buildDeps),this._tasks.set(e,n)}return n}async build(e){const{scripts:t={}}=this.manifest;return t.build?await this.run("build",[],e):(this._logger.warn("Will not be built (no build script)"),null)}get name(){return this.manifest.name}get version(){return this.manifest.version}get reference(){return this.version?`${this.name}@${this.version}`:this.name}get cwd(){return a().resolve(this.project.root,this._cwd)}};function g(){return(0,l.oV)(h,f.W)}p([(0,l.yT)(c.F)],h.prototype,"_git",void 0),h=p([(0,n.b)()],h)},3678:(e,t,s)=>{s.d(t,{P:()=>d});var r=s(36204),n=s(79445),o=s(73480),a=s.n(o),i=s(79060),c=s(29724),l=s(29921);let d=class{static isTaskNode(e){return"script"in e}constructor(e){this._logger=e}_lexer(){return a().states({task:{lparen:"(",whitespace:/[ \t]+/,string:[{match:/[:a-zA-Z0-9]+/,push:"operator"},{match:/'(?:\\['\\]|[^\n'\\])+'/,push:"operator",value:e=>e.slice(1,-1).replace(/\\(['\\])/g,"$1")},{match:/"(?:\\["\\]|[^\n"\\])+"/,push:"operator",value:e=>e.slice(1,-1).replace(/\\(["\\])/g,"$1")}]},operator:{whitespace:/[ \t]+/,rparen:")",operator:{match:["->","//"],pop:1}}})}_nextNode(e,t=0){let s=null;for(const r of e){if("whitespace"===r.type)continue;if("rparen"===r.type)break;if("operator"===r.type){const t=r.value;if(s){if(d.isTaskNode(s)){s={operator:t,tasks:[s]};continue}s.operator!==t&&(s={operator:t,tasks:[s]});continue}throw new Error(e.formatError(r,"Unexpected operator"))}let n;if("string"===r.type)n={script:r.value};else{if("lparen"!==r.type)throw new Error(e.formatError(r,"Unexpected token"));{const s=this._nextNode(e,t+1);if(!s)throw new Error(e.formatError(r,"Empty group found"));n=s}}if(s){if(d.isTaskNode(s))throw new Error(e.formatError(r,"Unexpected token, expected an operator"));s.tasks.push(n)}else s=n}return s}parse(e){const t=this._lexer().reset(e),s={roots:[]};for(;;){const e=this._nextNode(t);if(!e)break;s.roots.push(e)}return s}async buildTask(e,t,s){if(d.isTaskNode(e))return t.run(e.script,[],s);{let o;o="//"===e.operator?new r.W("In parallel",{},{logger:this._logger}):new n.h("In sequence",{},{logger:this._logger});for(const r of e.tasks)o.add(await this.buildTask(r,t,s));return o}}};var u,f;d=function(e,t,s,r){var n,o=arguments.length,a=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,s,r);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(a=(o<3?n(a):o>3?n(t,s,a):n(t,s))||a);return o>3&&a&&Object.defineProperty(t,s,a),a}([(0,l.t)(),(u=0,f=(0,c.f)(i.Y),function(e,t){f(e,t,u)})],d)},85099:(e,t,s)=>{s.d(t,{N:()=>i});var r=s(61626),n=s(79060),o=s(77839),a=s(10466);const i=Symbol("jujulego:jill:TaskManager");a.nC.bind(i).toDynamicValue((e=>{const t=e.container.get(o.k),s=e.container.get(n.Y);return new r.q({jobs:t.jobs,logger:s})})).inSingletonScope()},36872:(e,t,s)=>{s.d(t,{Z:()=>c});var r=s(52010),n=s(78487),o=s(81119),a=s(76687),i=s(76797);function c({group:e}){const[t,s]=(0,a.useState)([...e.tasks]);return(0,a.useLayoutEffect)((()=>{let t=!1;return e.subscribe("task.added",(()=>{t||(t=!0,queueMicrotask((()=>{s([...e.tasks]),t=!1})))}))}),[e]),(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(i.Z,{task:e}),(0,r.jsx)(o.Box,{flexDirection:"column",marginLeft:2,children:t.map((e=>(0,r.jsx)(a.Fragment,{children:e instanceof n.O?(0,r.jsx)(c,{group:e}):(0,r.jsx)(i.Z,{task:e})},e.id)))})]})}},58348:(e,t,s)=>{s.d(t,{Z:()=>y});var r=s(52010),n=s(81119),o=s(96122),a=s(40427),i=s(76687),c=s(10466),l=s(53565);function d(){const[e,t]=(0,i.useState)({status:"stop",label:""});switch((0,i.useLayoutEffect)((()=>{const e=c.nC.get(l.V);return t(e.state),e.subscribe("update",t)}),[]),e.status){case"spin":return(0,r.jsxs)(n.Text,{children:[(0,r.jsx)(o.Z,{})," "+e.label]});case"success":return(0,r.jsxs)(n.Text,{color:"green",children:[a.Z.success," ",e.label]});case"failed":return(0,r.jsxs)(n.Text,{color:"red",children:[a.Z.error," ",e.label]});default:return null}}var u=s(41429),f=s.n(u),p=s(86709),h=s.n(p),g=s(79060);const m=Symbol.for("message");function b(){const{write:e}=(0,n.useStderr)();return(0,i.useLayoutEffect)((()=>{const t=c.nC.get(g.Y);for(const e of t.transports)e instanceof f().transports.Console&&t.remove(e);const s=new class extends(h()){constructor(){super({format:g.D})}log(t,s){setTimeout((()=>{this.emit("logged",t)}),0),e(t[m]+"\n"),s()}};return t.add(s),()=>{t.remove(s),t.add(new(f().transports.Console)({format:g.D}))}}),[e]),null}function y({children:e}){return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)(b,{}),(0,r.jsx)(d,{}),e]})}},75740:(e,t,s)=>{s.d(t,{Z:()=>a});var r=s(52010),n=s(81119),o=s(46379);function a({items:e,headers:t}){return 0===e.length?null:(0,r.jsx)(n.Box,{children:Object.keys(e[0]).map((s=>(0,r.jsxs)(n.Box,{flexDirection:"column",marginRight:2,children:[t&&(0,r.jsx)(n.Text,{bold:!0,children:(0,o.k)(s)}),e.map(((e,t)=>(0,r.jsx)(n.Text,{children:e[s]||" "},t)))]},s)))})}},4887:(e,t,s)=>{s.d(t,{Z:()=>c});var r=s(52010),n=s(78487),o=s(76687),a=s(36872),i=s(76797);function c({manager:e}){const[t,s]=(0,o.useState)(e.tasks.filter((e=>!e.context.groupTask)));return(0,o.useLayoutEffect)((()=>{let t=!1;return e.subscribe("added",(()=>{t||(t=!0,queueMicrotask((()=>{s(e.tasks.filter((e=>!e.context.groupTask))),t=!1})))}))}),[e]),(0,r.jsx)(r.Fragment,{children:t.map((e=>e instanceof n.O?(0,r.jsx)(a.Z,{group:e},e.id):(0,r.jsx)(i.Z,{task:e},e.id)))})}},51562:(e,t,s)=>{s.d(t,{Z:()=>o});var r=s(52010),n=s(81119);function o({task:e}){return"workspace"in e.context?(0,r.jsxs)(n.Text,{children:["Running ",(0,r.jsx)(n.Text,{bold:!0,children:e.context.script})," in ",e.context.workspace.name]}):(0,r.jsx)(n.Text,{children:e.name})}},76797:(e,t,s)=>{s.d(t,{Z:()=>d});var r=s(52010),n=s(81119),o=s(96122),a=s(40427),i=s(21061),c=s(76687),l=s(51562);function d({task:e}){const[t,s]=(0,c.useState)(e.status),[d,u]=(0,c.useState)(0);switch((0,c.useLayoutEffect)((()=>e.subscribe("status",(e=>{s(e.status)}))),[e]),(0,c.useLayoutEffect)((()=>e.subscribe("completed",(({duration:e})=>{u(e)}))),[e]),t){case"blocked":case"ready":return(0,r.jsxs)(n.Text,{color:"grey",children:[(0,r.jsx)(o.Z,{type:"line2"})," ",(0,r.jsx)(l.Z,{task:e})]});case"running":return(0,r.jsxs)(n.Text,{children:[(0,r.jsx)(o.Z,{})," ",(0,r.jsx)(l.Z,{task:e})]});case"done":return(0,r.jsxs)(n.Text,{children:[(0,r.jsxs)(n.Text,{color:"green",children:[a.Z.success," ",(0,r.jsx)(l.Z,{task:e})]}),(0,r.jsxs)(n.Text,{color:"magenta",children:[" ","(took ",(0,i.Z)(d),")"]})]});case"failed":return(0,r.jsxs)(n.Text,{children:[(0,r.jsxs)(n.Text,{color:"red",children:[a.Z.error," ",(0,r.jsx)(l.Z,{task:e})]}),(0,r.jsxs)(n.Text,{color:"magenta",children:[" ","(took ",(0,i.Z)(d),")"]})]})}}},66238:(e,t,s)=>{s.d(t,{Z:()=>i});var r=s(52010),n=s(81119),o=s(76687);const a=e=>({color:e?"blue":""});function i(e){const{workspace:t,dev:s=!1,level:c=""}=e,[l,d]=(0,o.useState)([]);return(0,o.useEffect)((()=>{(async()=>{const e=[];for await(const s of t.dependencies())e.push([s,null]);for await(const s of t.devDependencies())e.push([s,!0]);d(e)})()}),[t]),(0,r.jsxs)(n.Text,{children:[(0,r.jsx)(n.Text,{...a(s),children:t.name}),t.version&&(0,r.jsxs)(n.Text,{color:"grey",children:["@",t.version]}),l.length>0&&(0,r.jsx)(n.Newline,{}),l.map((([e,t],o)=>(0,r.jsxs)(n.Text,{children:[c,(0,r.jsxs)(n.Text,{...a(s),children:[o===l.length-1?"└":"├","─"," "]}),(0,r.jsx)(i,{workspace:e,dev:t??s,level:(0,r.jsxs)(r.Fragment,{children:[c,(0,r.jsxs)(n.Text,{...a(s),children:[o===l.length-1?" ":"│"," "]})]})}),o<l.length-1&&(0,r.jsx)(n.Newline,{})]},e.name)))]})}},18520:(e,t,s)=>{async function r(e){return import("win32"===process.platform?`file://${e}`:e)}s.d(t,{y:()=>r})},95960:(e,t,s)=>{s.d(t,{$:()=>n,F:()=>o});var r=s(94415);async function*n(...e){for(const t of e)yield*t}async function*o(e,t){const s=new AbortController,n=new Error("aborted");e.subscribe("completed",(()=>s.abort(n)));let o="";try{for await(const n of(0,r.Vq)(e,`stream.${t}`,{signal:s.signal})){const e=(o+n.data.toString("utf-8")).split(/\r?\n/);o=e.pop()??"";for(const t of e)yield t}}catch(e){if(e!==n)throw e;o&&(yield o)}}},46379:(e,t,s)=>{function r(e){return e.charAt(0).toUpperCase()+e.substring(1).toLowerCase()}s.d(t,{k:()=>r})}};
2
+ //# sourceMappingURL=554.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"554.js","mappings":"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","sources":["webpack://@jujulego/jill/./src/commons/git.service.ts","webpack://@jujulego/jill/./src/commons/logger.service.ts","webpack://@jujulego/jill/./src/commons/spinner.service.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/filters/affected.filter.ts","webpack://@jujulego/jill/./src/filters/pipeline.ts","webpack://@jujulego/jill/./src/filters/private.filter.ts","webpack://@jujulego/jill/./src/filters/scripts.filter.ts","webpack://@jujulego/jill/./src/inversify.config.ts","webpack://@jujulego/jill/./src/middlewares/load-project.ts","webpack://@jujulego/jill/./src/middlewares/load-workspace.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/plugin.ts","webpack://@jujulego/jill/./src/modules/service.ts","webpack://@jujulego/jill/./src/project/constants.ts","webpack://@jujulego/jill/./src/project/project.ts","webpack://@jujulego/jill/./src/project/workspace.ts","webpack://@jujulego/jill/./src/tasks/task-expr.service.ts","webpack://@jujulego/jill/./src/tasks/task-manager.config.ts","webpack://@jujulego/jill/./src/ui/group-task-spinner.tsx","webpack://@jujulego/jill/./src/ui/global-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/ui/workspace-tree.tsx","webpack://@jujulego/jill/./src/utils/import.ts","webpack://@jujulego/jill/./src/utils/streams.ts","webpack://@jujulego/jill/./src/utils/string.ts"],"sourcesContent":["import { SpawnTask, type SpawnTaskOptions, type TaskContext, type TaskManager } from '@jujulego/tasks';\nimport { inject } from 'inversify';\n\nimport { Logger } from '@/src/commons/logger.service';\nimport { TASK_MANAGER } from '@/src/tasks/task-manager.config';\nimport { streamLines } from '@/src/utils/streams';\nimport { Service } from '@/src/modules/service';\n\n// Types\nexport interface GitContext extends TaskContext {\n command: string;\n}\n\n// Git commands\n@Service()\nexport class GitService {\n // Constructor\n constructor(\n @inject(TASK_MANAGER)\n private readonly manager: TaskManager,\n @inject(Logger)\n private readonly logger: Logger,\n ) {}\n\n // Methods\n /**\n * Runs a git command inside a SpawnTask\n *\n * @param cmd\n * @param args\n * @param options\n */\n command(cmd: string, args: string[], options: SpawnTaskOptions = {}): SpawnTask<GitContext> {\n const opts = { logger: this.logger, ...options };\n\n // Create task\n const task = new SpawnTask('git', [cmd, ...args], { command: cmd }, opts);\n task.subscribe('stream', ({ data }) => opts.logger.debug(data.toString('utf-8')));\n\n this.manager.add(task);\n\n return task;\n }\n\n /**\n * Runs git branch\n *\n * @param args\n * @param options\n */\n branch(args: string[], options?: SpawnTaskOptions): SpawnTask<GitContext> {\n return this.command('branch', args, options);\n }\n\n /**\n * Runs git diff\n *\n * @param args\n * @param options\n */\n diff(args: string[], options?: SpawnTaskOptions): SpawnTask<GitContext> {\n return this.command('diff', args, options);\n }\n\n /**\n * Runs git tag\n *\n * @param args\n * @param options\n */\n tag(args: string[], options?: SpawnTaskOptions): SpawnTask<GitContext> {\n return this.command('tag', args, options);\n }\n\n /**\n * Uses git diff to detect if given files have been affected since given reference\n *\n * @param reference\n * @param files\n * @param opts\n */\n isAffected(reference: string, files: string[] = [], opts?: SpawnTaskOptions): Promise<boolean> {\n return new Promise((resolve, reject) => {\n const task = this.diff(['--quiet', reference, '--', ...files], opts);\n\n task.subscribe('status.done', () => resolve(false));\n task.subscribe('status.failed', () => {\n if (task.exitCode) {\n resolve(true);\n } else {\n reject(new Error(`Task ${task.name} failed`));\n }\n });\n });\n }\n\n /**\n * List git branches\n *\n * @param args\n * @param opts\n */\n async listBranches(args: string[] = [], opts?: SpawnTaskOptions): Promise<string[]> {\n const task = this.branch(['-l', ...args], opts);\n const result: string[] = [];\n\n for await (const line of streamLines(task, 'stdout')) {\n result.push(line.replace(/^[ *] /, ''));\n }\n\n return result;\n }\n\n /**\n * List git tags\n *\n * @param args\n * @param opts\n */\n async listTags(args: string[] = [], opts?: SpawnTaskOptions): Promise<string[]> {\n const task = this.tag(['-l', ...args], opts);\n const result: string[] = [];\n\n for await (const line of streamLines(task, 'stdout')) {\n result.push(line);\n }\n\n return result;\n }\n}\n","import chalk from 'chalk';\nimport winston from 'winston';\n\nimport { container } from '../inversify.config';\n\n// Utils\nexport const consoleFormat = winston.format.combine(\n winston.format.colorize({\n message: true,\n colors: { debug: 'grey', verbose: 'blue', info: 'white', error: 'red' }\n }),\n winston.format.printf(({ label, message, stack }) => {\n if (stack) message = chalk.red(stack);\n const lines = message.split('\\n');\n\n // Format\n let spaces = '';\n let formatted = lines[0];\n\n if (label) {\n spaces = ' '.repeat(label.length + 3);\n formatted = `${chalk.grey(`[${label}]`)} ${lines[0]}`;\n }\n\n for (let i = 1; i < lines.length; ++i) {\n formatted += `\\n${spaces}${lines[i]}`;\n }\n\n return formatted;\n }),\n);\n\n// Service\nexport class Logger {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface Logger extends winston.Logger {}\n\ncontainer.bind(Logger)\n .toDynamicValue(() => {\n return winston.createLogger({\n format: winston.format.combine(\n winston.format.timestamp(),\n winston.format.errors({\n stack: process.env.NODE_ENV === 'development'\n }),\n ),\n transports: [\n new winston.transports.Console({\n format: consoleFormat\n })\n ]\n });\n })\n .inSingletonScope();\n","import { EventSource } from '@jujulego/event-tree';\nimport { decorate, injectable } from 'inversify';\n\nimport { Service } from '@/src/modules/service';\n\n// Setup\ndecorate(injectable(), EventSource);\n\n// Interface\nexport type SpinnerStatus = 'spin' | 'stop' | 'success' | 'failed';\nexport interface SpinnerState {\n status: SpinnerStatus;\n label: string;\n}\n\nexport type SpinnerEventMap = Record<`update.${SpinnerStatus}`, SpinnerState>;\n\n// Service\n@Service()\nexport class SpinnerService extends EventSource<SpinnerEventMap> {\n // Attributes\n private _status: SpinnerStatus = 'stop';\n private _label = '';\n\n // Methods\n spin(label: string) {\n this._status = 'spin';\n this._label = label;\n\n this.emit('update.spin', this.state);\n }\n\n success(label: string) {\n this._status = 'success';\n this._label = label;\n\n this.emit('update.success', this.state);\n }\n\n failed(label: string) {\n this._status = 'failed';\n this._label = label;\n\n this.emit('update.failed', this.state);\n }\n\n stop() {\n if (this._status === 'spin') {\n this._status = 'stop';\n\n this.emit('update.stop', this.state);\n }\n }\n\n // Properties\n get state(): SpinnerState {\n return {\n status: this._status,\n label: this._label,\n };\n }\n}\n","import Ajv from 'ajv';\nimport { type interfaces as int } from 'inversify';\n\nimport { container } from './inversify.config';\nimport { Logger } from './commons/logger.service';\n\n// Symbols\nexport const AJV: int.ServiceIdentifier<Ajv> = Symbol('jujulego:jill:Ajv');\n\n// Setup\ncontainer\n .bind(AJV)\n .toDynamicValue(() => {\n const logger = container.get(Logger);\n\n return new Ajv({\n allErrors: true,\n logger: logger.child({ label: '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';\nimport schema from '@/src/config/schema.json';\nimport { container } from '@/src/inversify.config';\nimport { dynamicImport } from '@/src/utils/import';\n\nimport { type IConfig, type IConfigExplorer } from './types';\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((context) => {\n const ajv = context.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 { type interfaces as int } from 'inversify';\nimport os from 'node:os';\nimport path from 'node:path';\n\nimport { AJV } from '@/src/ajv.config';\nimport { container } from '@/src/inversify.config';\nimport { Logger } from '@/src/commons/logger.service';\n\nimport { CONFIG_OPTIONS } from './config-options';\nimport { type IConfig } from './types';\nimport { CONFIG_EXPLORER, CONFIG_VALIDATOR } from './utils';\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({ label: '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 process.exit(1);\n\n return {};\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 // Apply on logger\n if (config.verbose) {\n container.get(Logger).level = config.verbose;\n }\n\n logger.verbose(`Loaded ${loaded.filepath} config file`);\n }\n\n logger.debug(`Loaded config:\\n${JSON.stringify(config, null, 2)}`);\n\n return config;\n}\n\ncontainer\n .bind(CONFIG)\n .toDynamicValue(configLoader)\n .inSingletonScope();\n","import yargs, { type Argv } from 'yargs';\nimport { type interfaces as int } from 'inversify';\nimport { hideBin } from 'yargs/helpers';\n\nimport { type IConfig } from '@/src/config/types';\nimport { container } from '@/src/inversify.config';\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","import { GitService } from '@/src/commons/git.service';\nimport { type Workspace } from '@/src/project/workspace';\nimport { lazyInject } from '@/src/inversify.config';\nimport { Logger } from '@/src/commons/logger.service';\n\nimport { type PipelineFilter } from './pipeline';\n\n// Class\nexport class AffectedFilter implements PipelineFilter {\n // Properties\n @lazyInject(Logger)\n private readonly _logger: Logger;\n\n @lazyInject(GitService)\n private readonly _git: GitService;\n\n // Constructor\n constructor(\n readonly format: string,\n readonly fallback: string,\n readonly sort?: string,\n ) {}\n\n // Methods\n private async _formatRevision(wks: Workspace): Promise<string> {\n const logger = this._logger.child({ label: wks.name });\n\n // Format revision\n let result = this.format;\n result = result.replace(/(?<!\\\\)((?:\\\\\\\\)*)%name/g, `$1${wks.name}`);\n result = result.replace(/\\\\(.)/g, '$1');\n\n // Ask git to complete it\n const sortArgs = this.sort ? ['--sort', this.sort] : [];\n\n // - search in branches\n if (result.includes('*')) {\n const branches = await this._git.listBranches([...sortArgs, result], { cwd: wks.cwd, logger: logger });\n\n if (branches.length > 0) {\n result = branches[branches.length - 1];\n }\n }\n\n // - search in tags\n if (result.includes('*')) {\n const tags = await this._git.listTags([...sortArgs, result], { cwd: wks.cwd, logger: logger });\n\n if (tags.length > 0) {\n result = tags[tags.length - 1];\n }\n }\n\n if (result !== this.format) {\n logger.verbose(`Resolved ${this.format} into ${result}`);\n }\n\n if (result.includes('*')) {\n logger.warn(`No revision found matching ${result}, using fallback ${this.fallback}`);\n\n return this.fallback;\n }\n\n return result;\n }\n\n async test(workspace: Workspace): Promise<boolean> {\n const rev = await this._formatRevision(workspace);\n return await workspace.isAffected(rev);\n }\n}\n","import { type Workspace } from '@/src/project/workspace';\nimport { type Awaitable } from '@/src/types';\n\n// Interface\nexport interface PipelineFilter {\n // Methods\n test(workspace: Workspace): Awaitable<boolean>;\n}\n\n// Class\nexport class Pipeline {\n // Attributes\n private _filters: PipelineFilter[] = [];\n\n // Methods\n add(filter: PipelineFilter): void {\n this._filters.push(filter);\n }\n\n private async _test(workspace: Workspace): Promise<boolean> {\n for (const filter of this._filters) {\n const res = await filter.test(workspace);\n\n if (!res) {\n return false;\n }\n }\n\n return true;\n }\n\n async *filter(workspaces: Iterable<Workspace> | AsyncIterable<Workspace>): AsyncGenerator<Workspace> {\n for await (const wks of workspaces) {\n if (await this._test(wks)) {\n yield wks;\n }\n }\n }\n}\n","import { type Workspace } from '@/src/project/workspace';\n\nimport { type PipelineFilter } from './pipeline';\n\n// Filter\nexport class PrivateFilter implements PipelineFilter {\n // Constructor\n constructor(readonly value: boolean) {}\n\n // Methods\n test(workspace: Workspace): boolean {\n return (workspace.manifest.private ?? false) === this.value;\n }\n}\n","import { type Workspace } from '@/src/project/workspace';\n\nimport { type PipelineFilter } from './pipeline';\n\n// Filter\nexport class ScriptsFilter implements PipelineFilter {\n // Constructor\n constructor(readonly scripts: string[]) {}\n\n // Methods\n test(workspace: Workspace): boolean {\n const scripts = Object.keys(workspace.manifest.scripts || {});\n return this.scripts.some((scr) => scripts.includes(scr));\n }\n}\n","import { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\n\nimport 'reflect-metadata';\n\n// Container\nexport const container = new Container();\n\n// Utilities\nexport const { lazyInject, lazyInjectNamed } = getDecorators(container);\n","import { inject } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { type IMiddleware, Middleware } from '@/src/modules/middleware';\nimport { SpinnerService } from '@/src/commons/spinner.service';\nimport { container } from '@/src/inversify.config';\nimport { CURRENT } from '@/src/project/constants';\nimport { Project, type PackageManager } from '@/src/project/project';\n\n// Types\nexport interface ILoadProjectArgs {\n project: string;\n 'package-manager'?: PackageManager;\n}\n\n// Middleware\n@Middleware()\nexport class LoadProject implements IMiddleware<ILoadProjectArgs> {\n // Constructor\n constructor(\n @inject(SpinnerService)\n private readonly spinner: SpinnerService\n ) {}\n\n // Methods\n builder(parser: Argv) {\n return parser\n .option('project', {\n alias: 'p',\n type: 'string',\n default: process.cwd(),\n description: 'Project root directory'\n })\n .option('package-manager', {\n choices: ['yarn', 'npm'] as const,\n type: 'string',\n description: 'Force package manager'\n });\n }\n\n async handler(args: ArgumentsCamelCase<ILoadProjectArgs>): Promise<void> {\n try {\n this.spinner.spin('Loading project ...');\n const root = args.project = await Project.searchProjectRoot(args.project);\n\n container.bind(Project)\n .toDynamicValue(() => new Project(root, {\n packageManager: args.packageManager\n }))\n .whenTargetNamed(CURRENT);\n } finally {\n this.spinner.stop();\n }\n }\n}\n","import { inject } from 'inversify';\nimport yargs, { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { type IMiddleware, Middleware } from '@/src/modules/middleware';\nimport { SpinnerService } from '@/src/commons/spinner.service';\nimport { container } from '@/src/inversify.config';\nimport { lazyCurrentProject, type Project } from '@/src/project/project';\nimport { CURRENT } from '@/src/project/constants';\nimport { Workspace } from '@/src/project/workspace';\n\n// Types\nexport interface ILoadWorkspaceArgs {\n workspace?: string;\n}\n\n// Middleware\n@Middleware()\nexport class LoadWorkspace implements IMiddleware<ILoadWorkspaceArgs> {\n // Lazy injections\n @lazyCurrentProject()\n readonly project: Project;\n\n // Constructor\n constructor(\n @inject(SpinnerService)\n private readonly spinner: SpinnerService\n ) {}\n\n // Methods\n builder(parser: Argv) {\n return parser\n .option('workspace', {\n alias: 'w',\n type: 'string',\n desc: 'Workspace to use'\n });\n }\n\n async handler(args: ArgumentsCamelCase<ILoadWorkspaceArgs>): Promise<void> {\n try {\n this.spinner.spin(`Loading \"${args.workspace || '.'}\" workspace ...`);\n const workspace = await this.project.workspace(args.workspace);\n\n if (!workspace) {\n this.spinner.failed(`Workspace \"${args.workspace || '.'}\" not found`);\n yargs.exit(1, new Error('Workspace not found'));\n } else {\n container\n .bind(Workspace)\n .toConstantValue(workspace)\n .whenTargetNamed(CURRENT);\n }\n } finally {\n this.spinner.stop();\n }\n }\n}\n","import { decorate, injectable, type interfaces as int } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv, type CommandModule } from 'yargs';\n\nimport { type Awaitable, type Class, type Type } from '@/src/types';\n\nimport { applyMiddlewares, type IMiddleware } from './middleware';\nimport { setRegistry } from '@/src/modules/module';\n\n// Symbols\nconst COMMAND_OPTS = Symbol('jujulego:jill:command-opts');\n\nexport const COMMAND: int.ServiceIdentifier<CommandModule> = Symbol('jujulego:jill:command');\n\n// Types\nexport interface ICommand<A = unknown> {\n builder?: (parser: Argv) => Awaitable<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: async (parser: Argv) => {\n if (opts.middlewares) {\n parser = applyMiddlewares(parser, opts.middlewares);\n }\n\n if (cmd.builder) {\n parser = await cmd.builder(parser);\n }\n\n return parser;\n },\n handler: (...args) => cmd.handler(...args),\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 setRegistry(target, (bind) => {\n bind(target).toSelf();\n bind(COMMAND)\n .toDynamicValue(async ({ container }) => {\n const cmd = await container.getAsync(target);\n return buildCommandModule(cmd, opts);\n })\n .whenTargetNamed(opts.command.split(' ')[0]);\n });\n };\n}\n","import type ink from 'ink';\nimport { render } from 'ink';\nimport { type interfaces as int } from 'inversify';\n\nimport { container } from '@/src/inversify.config';\nimport Layout from '@/src/ui/layout';\n\n// Constants\nexport const INK_APP: int.ServiceIdentifier<ink.Instance> = Symbol.for('jujulego:jill:ink-app');\n\n// Setup\ncontainer\n .bind(INK_APP)\n .toDynamicValue(() => {\n return render(\n <Layout/>,\n {\n stdout: process.stdout.isTTY ? process.stdout : process.stderr,\n }\n );\n })\n .inSingletonScope();\n","import type ink from 'ink';\nimport { inject, injectable } from 'inversify';\nimport { type ReactNode } from 'react';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { INK_APP } from '@/src/ink.config';\nimport { type Awaitable, type AwaitableGenerator } from '@/src/types';\nimport Layout from '@/src/ui/layout';\n\nimport { type ICommand } from './command';\n\n// Class\n@injectable()\nexport abstract class InkCommand<A = unknown> implements ICommand<A> {\n // Lazy injections\n @inject(INK_APP)\n readonly app: ink.Instance;\n\n // Methods\n abstract render(args: ArgumentsCamelCase<A>): AwaitableGenerator<ReactNode>;\n\n builder(parser: Argv): Awaitable<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 return 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';\nimport { type Awaitable, type Type } from '@/src/types';\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';\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 { type ContainerModule, inject } from 'inversify';\n\nimport { CONFIG } from '@/src/config/config-loader';\nimport { type IConfig } from '@/src/config/types';\nimport { Logger } from '@/src/commons/logger.service';\nimport { container } from '@/src/inversify.config';\nimport { dynamicImport } from '@/src/utils/import';\n\nimport { getModule } from './module';\nimport { Service } from './service';\n\n// Class\n@Service()\nexport class PluginLoaderService {\n // Attributes\n private readonly _logger: Logger;\n\n // Constructor\n constructor(\n @inject(CONFIG) private readonly _config: IConfig,\n @inject(Logger) logger: Logger,\n ) {\n this._logger = logger.child({ label: '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(): 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 container.load(plugin);\n }\n }\n}\n","import { ContainerModule, id, type interfaces as int } from 'inversify';\n\nimport { type Class, type Type } from '@/src/types';\n\nimport { type ICommand } from './command';\nimport { getRegistry, setModule } from './module';\n\n// Types\nexport interface IPluginOpts {\n readonly name?: string;\n readonly commands: Type<ICommand>[];\n}\n\nexport class PluginModule extends ContainerModule implements IPluginOpts {\n // Attributes\n readonly id = id();\n\n // Constructor\n constructor(\n readonly name: string,\n readonly commands: Type<ICommand>[],\n ) {\n super((...args: Parameters<int.ContainerModuleCallBack>) => {\n for (const command of this.commands) {\n const registry = getRegistry(command);\n registry(...args);\n }\n });\n }\n}\n\n// Decorator\nexport function Plugin(opts: IPluginOpts) {\n return (target: Class) => {\n const name = opts.name ?? target.name;\n const module = new PluginModule(name, opts.commands);\n\n setModule(target, module);\n };\n}\n","import { decorate, injectable } from 'inversify';\nimport { container } from '@/src/inversify.config';\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\n return cls;\n };\n}\n","// Constants\nexport const CURRENT = 'current';\n","import AsyncLock from 'async-lock';\nimport { injectable } from 'inversify';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport normalize, { type Package } from 'normalize-package-data';\nimport glob from 'tiny-glob';\n\nimport { container, lazyInject, lazyInjectNamed } from '@/src/inversify.config';\nimport { Logger } from '@/src/commons/logger.service';\n\nimport { CURRENT } from './constants';\nimport { Workspace } from './workspace';\n\n// Types\nexport type PackageManager = 'npm' | 'yarn';\nexport interface ProjectOptions {\n packageManager?: PackageManager | undefined;\n}\n\n// Class\n@injectable()\nexport class Project {\n // Attributes\n private _mainWorkspace?: Workspace;\n private readonly _names = new Map<string, Workspace>();\n private readonly _workspaces = new Map<string, Workspace>();\n\n private _packageManager?: PackageManager;\n private _isFullyLoaded = false;\n private _lock = new AsyncLock();\n\n @lazyInject(Logger)\n private readonly _logger: Logger;\n\n // Constructor\n constructor(\n private readonly _root: string,\n opts: ProjectOptions = {}\n ) {\n if (opts.packageManager) {\n this._logger.debug(`Forced use of ${opts.packageManager} in ${path.relative(process.cwd(), this.root) || '.'}`);\n this._packageManager = opts.packageManager;\n }\n }\n\n // Statics\n static async searchProjectRoot(dir: string): Promise<string> {\n const logger = container.get(Logger);\n\n // Will process directories from dir to root\n let found = false;\n let last = dir;\n dir = path.resolve(dir);\n\n do {\n const files = await fs.readdir(dir);\n\n if (files.includes('package.json')) {\n last = dir;\n found = true;\n }\n\n if (['package-lock.json', 'yarn.lock'].some(lock => files.includes(lock))) {\n logger.debug(`Project root found at ${path.relative(process.cwd(), dir) || '.'}`);\n return dir;\n }\n\n dir = path.dirname(dir);\n } while (dir !== path.dirname(dir));\n\n if (found) {\n logger.debug(`Project root found at ${path.relative(process.cwd(), last) || '.'}`);\n } else {\n logger.debug(`Project root not found, keeping ${path.relative(process.cwd(), last) || '.'}`);\n }\n\n return last;\n }\n\n // Methods\n private async _loadManifest(dir: string): Promise<Package> {\n const file = path.resolve(this.root, dir, 'package.json');\n\n const relative = path.relative(this.root, path.dirname(file));\n const logger = this._logger.child({ label: relative ? `project@${relative}` : 'project' });\n\n logger.verbose('Loading package.json ...');\n\n const data = await fs.readFile(file, 'utf-8');\n const mnf = JSON.parse(data);\n normalize(mnf, (msg) => logger.verbose(msg));\n\n return mnf;\n }\n\n private async _loadWorkspace(dir: string): Promise<Workspace> {\n return await this._lock.acquire('workspaces', async () => {\n let wks = this._workspaces.get(dir);\n\n if (!wks) {\n const manifest = await this._loadManifest(dir);\n wks = new Workspace(dir, manifest, this);\n\n this._workspaces.set(dir, wks);\n this._names.set(wks.name, wks);\n }\n\n return wks;\n });\n }\n\n async packageManager(): Promise<PackageManager> {\n if (!this._packageManager) {\n const files = await fs.readdir(this.root);\n\n if (files.includes('yarn.lock')) {\n this._logger.debug(`Detected yarn in ${path.relative(process.cwd(), this.root) || '.'}`);\n this._packageManager = 'yarn';\n } else if (files.includes('package-lock.json')) {\n this._logger.debug(`Detected npm in ${path.relative(process.cwd(), this.root) || '.'}`);\n this._packageManager = 'npm';\n } else {\n this._logger.debug(`No package manager recognized in ${path.relative(process.cwd(), this.root) || '.'}, defaults to npm`);\n this._packageManager = 'npm';\n }\n }\n\n return this._packageManager;\n }\n\n async mainWorkspace(): Promise<Workspace> {\n if (!this._mainWorkspace) {\n const manifest = await this._loadManifest('.');\n this._mainWorkspace = new Workspace('.', manifest, this);\n\n this._names.set(this._mainWorkspace.name, this._mainWorkspace);\n }\n\n return this._mainWorkspace;\n }\n\n async currentWorkspace(cwd = process.cwd()): Promise<Workspace | null> {\n let workspace: Workspace | null = null;\n cwd = path.resolve(cwd);\n\n for await (const wks of this.workspaces()) {\n if (cwd.startsWith(wks.cwd)) {\n workspace = wks;\n\n if (wks.cwd !== this.root) return wks;\n }\n }\n\n return workspace;\n }\n\n async* workspaces(): AsyncGenerator<Workspace, void> {\n const main = await this.mainWorkspace();\n yield main;\n\n if (this._isFullyLoaded) {\n for (const wks of this._names.values()) {\n if (wks.name !== main.name) yield wks;\n }\n } else {\n // Load child workspaces\n const { workspaces = [] } = main.manifest;\n\n for (const pattern of workspaces) {\n for (const dir of await glob(pattern, { cwd: this.root })) {\n try {\n // Check if dir is a directory exists\n const file = path.resolve(this.root, dir);\n const stat = await fs.stat(file);\n\n if (stat.isDirectory()) {\n yield await this._loadWorkspace(dir);\n }\n\n } catch (error) {\n if (error.code === 'ENOENT') {\n continue;\n }\n\n throw error;\n }\n }\n }\n\n this._isFullyLoaded = true;\n }\n }\n\n async workspace(name?: string): Promise<Workspace | null> {\n // With current directory\n if (!name) {\n const dir = path.relative(this.root, process.cwd());\n return this._loadWorkspace(dir);\n }\n\n // Try name index\n const wks = this._names.get(name);\n if (wks) return wks;\n\n if (this._isFullyLoaded) {\n return null;\n }\n\n // Load workspaces\n for await (const ws of this.workspaces()) {\n if (ws.name === name) {\n return ws;\n }\n }\n\n this._isFullyLoaded = true;\n return null;\n }\n\n // Properties\n get root(): string {\n return path.resolve(this._root);\n }\n}\n\n// Decorators\nexport function lazyCurrentProject() {\n return lazyInjectNamed(Project, CURRENT);\n}\n","import { SpawnTask, type SpawnTaskOptions, type SpawnTaskStream, type TaskContext } from '@jujulego/tasks';\nimport { injectable } from 'inversify';\nimport path from 'node:path';\nimport { type Package } from 'normalize-package-data';\nimport { satisfies } from 'semver';\n\nimport { GitService } from '@/src/commons/git.service';\nimport { container, lazyInject, lazyInjectNamed } from '@/src/inversify.config';\nimport { Logger } from '@/src/commons/logger.service';\nimport { combine, streamLines } from '@/src/utils/streams';\n\nimport { CURRENT } from './constants';\nimport { type Project } from './project';\n\n// Types\nexport type WorkspaceDepsMode = 'all' | 'prod' | 'none';\n\nexport interface WorkspaceContext extends TaskContext {\n workspace: Workspace;\n script: string;\n}\n\nexport interface WorkspaceRunOptions extends Omit<SpawnTaskOptions, 'cwd'> {\n buildDeps?: WorkspaceDepsMode;\n}\n\n// Class\n@injectable()\nexport class Workspace {\n // Attributes\n private readonly _logger: Logger;\n private readonly _affectedCache = new Map<string, Promise<boolean>>();\n private readonly _tasks = new Map<string, SpawnTask<WorkspaceContext>>();\n\n @lazyInject(GitService)\n private readonly _git: GitService;\n\n // Constructor\n constructor(\n private readonly _cwd: string,\n readonly manifest: Package,\n readonly project: Project\n ) {\n const logger = container.get(Logger);\n this._logger = logger.child({ label: this.manifest.name });\n }\n\n // Methods\n private _satisfies(from: Workspace, range: string): boolean {\n if (range.startsWith('file:')) {\n return path.resolve(from.cwd, range.substring(5)) === this.cwd;\n }\n\n if (range.startsWith('workspace:')) {\n range = range.substring(10);\n }\n\n return !this.version || satisfies(this.version, range);\n }\n\n private async _buildDependencies(task: SpawnTask, deps: WorkspaceDepsMode = 'all') {\n // Generators\n const generators: AsyncGenerator<Workspace, void>[] = [];\n\n switch (deps) {\n case 'all':\n generators.unshift(this.devDependencies());\n\n // eslint-disable-next no-fallthrough\n case 'prod':\n generators.unshift(this.dependencies());\n }\n\n // Build deps\n for await (const dep of combine(...generators)) {\n const build = await dep.build();\n\n if (build) {\n task.dependsOn(build);\n }\n }\n }\n\n private async _isAffected(reference: string): Promise<boolean> {\n const isAffected = await this._git.isAffected(reference, [this.cwd], {\n cwd: this.project.root,\n logger: this._logger,\n });\n\n if (isAffected) {\n return true;\n }\n\n // Test dependencies\n const proms: Promise<boolean>[] = [];\n\n for await (const dep of combine(this.dependencies(), this.devDependencies())) {\n proms.push(dep.isAffected(reference));\n }\n\n const results = await Promise.all(proms);\n return results.some(r => r);\n }\n\n async isAffected(reference: string): Promise<boolean> {\n let isAffected = this._affectedCache.get(reference);\n\n if (!isAffected) {\n isAffected = this._isAffected(reference);\n this._affectedCache.set(reference, isAffected);\n }\n\n return await isAffected;\n }\n\n private async* _loadDependencies(dependencies: Record<string, string>, kind: string): AsyncGenerator<Workspace, void> {\n for (const [dep, range] of Object.entries(dependencies)) {\n const ws = await this.project.workspace(dep);\n\n if (ws) {\n if (ws._satisfies(this, range)) {\n yield ws;\n } else {\n this._logger.verbose(`Ignoring ${kind} ${ws.reference} as it does not match requirement ${range}`);\n }\n }\n }\n }\n\n async* dependencies(): AsyncGenerator<Workspace, void> {\n if (!this.manifest.dependencies) return;\n\n for await (const ws of this._loadDependencies(this.manifest.dependencies, 'dependency')) {\n yield ws;\n }\n }\n\n async* devDependencies(): AsyncGenerator<Workspace, void> {\n if (!this.manifest.devDependencies) return;\n\n for await (const ws of this._loadDependencies(this.manifest.devDependencies, 'devDependency')) {\n yield ws;\n }\n }\n\n private async _streamLogs(task: SpawnTask<WorkspaceContext>, stream: SpawnTaskStream, level: string) {\n try {\n for await (const line of streamLines(task, stream)) {\n this._logger.log(level, line, { label: `${this.name}#${task.context.script}` });\n }\n } catch (err) {\n if (err) {\n this._logger.warn(`Error while streaming task ${stream}`, err, { label: `${this.name}#${task.context.script}` });\n }\n }\n }\n\n async run(script: string, args: string[] = [], opts: WorkspaceRunOptions = {}): Promise<SpawnTask<WorkspaceContext>> {\n let task = this._tasks.get(script);\n\n if (!task) {\n const pm = await this.project.packageManager();\n\n task = new SpawnTask(pm, ['run', script, ...args], { workspace: this, script }, {\n ...opts,\n cwd: this.cwd,\n logger: this._logger.child({ label: `${this.name}#${script}`}),\n env: {\n FORCE_COLOR: '1',\n ...opts.env\n }\n });\n\n this._streamLogs(task, 'stdout', 'info');\n this._streamLogs(task, 'stderr', 'info');\n\n await this._buildDependencies(task, opts.buildDeps);\n\n this._tasks.set(script, task);\n }\n\n return task;\n }\n\n async build(opts?: WorkspaceRunOptions): Promise<SpawnTask | null> {\n const { scripts = {} } = this.manifest;\n\n if (!scripts.build) {\n this._logger.warn('Will not be built (no build script)');\n return null;\n }\n\n return await this.run('build', [], opts);\n }\n\n // Properties\n get name(): string {\n return this.manifest.name;\n }\n\n get version(): string {\n return this.manifest.version;\n }\n\n get reference(): string {\n return this.version ? `${this.name}@${this.version}` : this.name;\n }\n\n get cwd(): string {\n return path.resolve(this.project.root, this._cwd);\n }\n}\n\n// Decorators\nexport function lazyCurrentWorkspace() {\n return lazyInjectNamed(Workspace, CURRENT);\n}\n","import { type GroupTask, ParallelGroup, SequenceGroup, type Task } from '@jujulego/tasks';\nimport moo from 'moo';\n\nimport { Logger } from '@/src/commons/logger.service';\nimport { type Workspace, type WorkspaceRunOptions } from '@/src/project/workspace';\nimport { inject } from 'inversify';\nimport { Service } from '@/src/modules/service';\n\n// Interfaces\nexport interface TaskNode {\n script: string;\n}\n\nexport interface GroupNode {\n operator: string;\n tasks: (TaskNode | GroupNode)[];\n}\n\nexport interface TaskTree {\n roots: (TaskNode | GroupNode)[];\n}\n\n// Service\n@Service()\nexport class TaskExprService {\n // Statics\n static isTaskNode(node: TaskNode | GroupNode): node is TaskNode {\n return 'script' in node;\n }\n\n // Constructor\n constructor(\n @inject(Logger)\n private readonly _logger: Logger\n ) {}\n\n // Methods\n private _lexer(): moo.Lexer {\n return moo.states({\n task: {\n lparen: '(',\n whitespace: /[ \\t]+/,\n string: [\n // inline\n { match: /[:a-zA-Z0-9]+/, push: 'operator' },\n // single cotted\n {\n match: /'(?:\\\\['\\\\]|[^\\n'\\\\])+'/,\n push: 'operator',\n value: x => x.slice(1, -1).replace(/\\\\(['\\\\])/g, '$1')\n },\n // double cotted\n {\n match: /\"(?:\\\\[\"\\\\]|[^\\n\"\\\\])+\"/,\n push: 'operator',\n value: x => x.slice(1, -1).replace(/\\\\([\"\\\\])/g, '$1')\n }\n ],\n },\n operator: {\n whitespace: /[ \\t]+/,\n rparen: ')',\n operator: { match: ['->', '//'], pop: 1 },\n }\n });\n }\n\n private _nextNode(lexer: moo.Lexer, i = 0): TaskNode | GroupNode | null {\n let node: TaskNode | GroupNode | null = null;\n\n for (const token of lexer) {\n // Ignore whitespaces\n if (token.type === 'whitespace') {\n continue;\n }\n\n // rparen = end of group\n if (token.type === 'rparen') {\n break;\n }\n\n // Handle operator\n if (token.type === 'operator') {\n const operator = token.value;\n\n if (!node) {\n throw new Error(lexer.formatError(token, 'Unexpected operator'));\n } else if (TaskExprService.isTaskNode(node)) {\n node = { operator, tasks: [node] };\n\n continue;\n } else {\n if (node.operator !== operator) {\n node = { operator, tasks: [node] };\n }\n\n continue;\n }\n }\n\n // Build \"child\"\n let child: TaskNode | GroupNode;\n\n if (token.type === 'string') {\n child = { script: token.value };\n } else if (token.type === 'lparen') {\n const res = this._nextNode(lexer, i+1);\n\n if (!res) {\n throw new Error(lexer.formatError(token, 'Empty group found'));\n }\n\n child = res;\n } else {\n throw new Error(lexer.formatError(token, 'Unexpected token'));\n }\n\n if (!node) {\n node = child;\n } else if (TaskExprService.isTaskNode(node)) {\n throw new Error(lexer.formatError(token, 'Unexpected token, expected an operator'));\n } else {\n node.tasks.push(child);\n }\n }\n\n return node;\n }\n\n parse(expr: string): TaskTree {\n const lexer = this._lexer().reset(expr);\n\n const tree: TaskTree = {\n roots: [],\n };\n\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const node = this._nextNode(lexer);\n\n if (node) {\n tree.roots.push(node);\n } else {\n break;\n }\n }\n\n return tree;\n }\n\n async buildTask(node: TaskNode | GroupNode, workspace: Workspace, opts?: WorkspaceRunOptions): Promise<Task> {\n if (TaskExprService.isTaskNode(node)) {\n return workspace.run(node.script, [], opts);\n } else {\n let group: GroupTask;\n\n if (node.operator === '//') {\n group = new ParallelGroup('In parallel', {}, {\n logger: this._logger,\n });\n } else {\n group = new SequenceGroup('In sequence', {}, {\n logger: this._logger,\n });\n }\n\n for (const child of node.tasks) {\n group.add(await this.buildTask(child, workspace, opts));\n }\n\n return group;\n }\n }\n}\n","import { TaskManager } from '@jujulego/tasks';\nimport { type interfaces as int } from 'inversify';\n\nimport { Logger } from '@/src/commons/logger.service';\nimport { CONFIG } from '@/src/config/config-loader';\nimport { container } from '@/src/inversify.config';\n\n// Symbols\nexport const TASK_MANAGER: int.ServiceIdentifier<TaskManager> = Symbol('jujulego:jill:TaskManager');\n\n// Service\ncontainer.bind(TASK_MANAGER)\n .toDynamicValue((context) => {\n const config = context.container.get(CONFIG);\n const logger = context.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, useState } from 'react';\n\nimport TaskSpinner from './task-spinner';\n\n// Types\nexport interface GroupTaskSpinnerProps {\n group: GroupTask;\n}\n\n// Components\nexport default function GroupTaskSpinner({ group }: GroupTaskSpinnerProps) {\n const [tasks, setTasks] = useState([...group.tasks]);\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return group.subscribe('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 return (\n <>\n <TaskSpinner task={group} />\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","import { Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport { useLayoutEffect, useState } from 'react';\n\nimport { container } from '@/src/inversify.config';\nimport { SpinnerService, type SpinnerState } from '@/src/commons/spinner.service';\n\n// Components\nexport default function GlobalSpinner() {\n // State\n const [state, setState] = useState<SpinnerState>({ status: 'stop', label: '' });\n\n // Effect\n useLayoutEffect(() => {\n const spinner = container.get(SpinnerService);\n setState(spinner.state);\n\n return spinner.subscribe('update', setState);\n }, []);\n\n // Render\n switch (state.status) {\n case 'spin':\n return (\n <Text>\n <Spinner />{' ' + state.label}\n </Text>\n );\n\n case 'success':\n return (\n <Text color=\"green\">\n {symbols.success} {state.label}\n </Text>\n );\n\n case 'failed':\n return (\n <Text color=\"red\">\n {symbols.error} {state.label}\n </Text>\n );\n\n case 'stop':\n default:\n return null;\n }\n}\n","import { useStderr } from 'ink';\nimport { useLayoutEffect, } from 'react';\nimport winston from 'winston';\nimport Transport from 'winston-transport';\n\nimport { container } from '@/src/inversify.config';\nimport { consoleFormat, Logger } from '@/src/commons/logger.service';\n\n// Constants\nconst MESSAGE = Symbol.for('message');\n\n// Types\ninterface Info extends Record<string, unknown> {\n [MESSAGE]: string;\n}\n\n// Component\nexport default function StaticLogs() {\n // State\n const { write } = useStderr();\n\n // Effect\n useLayoutEffect(() => {\n const logger = container.get(Logger);\n\n // Remove Console transport\n for (const transport of logger.transports) {\n if (transport instanceof winston.transports.Console) {\n logger.remove(transport);\n }\n }\n\n // Add custom transport\n const transport = new class extends Transport {\n // Constructor\n constructor() {\n super({\n format: consoleFormat\n });\n }\n\n // Methods\n log(info: Info, next: () => void): void {\n setTimeout(() => {\n this.emit('logged', info);\n }, 0);\n\n write(info[MESSAGE] + '\\n');\n\n next();\n }\n };\n\n logger.add(transport);\n\n return () => {\n logger.remove(transport);\n logger.add(new winston.transports.Console({\n format: consoleFormat\n }));\n };\n }, [write]);\n\n return null;\n}\n","import { type ReactNode } from 'react';\n\nimport GlobalSpinner from './global-spinner';\nimport StaticLogs from './static-logs';\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 <GlobalSpinner />\n { children }\n </>\n );\n}\n","import { Box, Text } from 'ink';\n\nimport { capitalize } from '@/src/utils/string';\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] || ' ' }</Text>\n )) }\n </Box>\n )) }\n </Box>\n );\n}\n","import { GroupTask, type TaskManager } from '@jujulego/tasks';\nimport { useLayoutEffect, useState } from 'react';\n\nimport GroupTaskSpinner from './group-task-spinner';\nimport TaskSpinner from './task-spinner';\n\n// Types\nexport interface TasksSpinnerProps {\n manager: TaskManager;\n}\n\n// Components\nexport default function TaskManagerSpinner({ manager }: TasksSpinnerProps) {\n const [tasks, setTasks] = useState(manager.tasks.filter((tsk) => !tsk.context.groupTask));\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return manager.subscribe('added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks(manager.tasks.filter((tsk) => !tsk.context.groupTask));\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, type TaskContext } from '@jujulego/tasks';\nimport { Text } from 'ink';\n\nimport { type WorkspaceContext } from '@/src/project/workspace';\n\n// Types\nexport interface TaskNameProps {\n task: Task;\n}\n\n// Utils\nfunction isWorkspaceCtx(ctx: Readonly<TaskContext>): ctx is Readonly<WorkspaceContext> {\n return 'workspace' in ctx;\n}\n\n// Components\nexport default function TaskName({ task }: TaskNameProps) {\n if (isWorkspaceCtx(task.context)) {\n return (\n <Text>\n Running <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 { 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 TaskName from './task-name';\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.subscribe('status', (event) => {\n setStatus(event.status);\n });\n }, [task]);\n\n useLayoutEffect(() => {\n return task.subscribe('completed', ({ duration }) => {\n setTime(duration);\n });\n }, [task]);\n\n // Render\n switch (status) {\n case 'blocked':\n case 'ready':\n return (\n <Text color=\"grey\">\n <Spinner type=\"line2\"/>{' '}<TaskName task={task}/>\n </Text>\n );\n\n case 'running':\n return (\n <Text>\n <Spinner/>{' '}<TaskName task={task}/>\n </Text>\n );\n\n case 'done':\n return (\n <Text>\n <Text color=\"green\">{symbols.success}{' '}<TaskName task={task}/></Text>\n <Text color=\"magenta\">{' '}(took {ms(time)})</Text>\n </Text>\n );\n\n case 'failed':\n return (\n <Text>\n <Text color=\"red\">{symbols.error}{' '}<TaskName task={task}/></Text>\n <Text color=\"magenta\">{' '}(took {ms(time)})</Text>\n </Text>\n );\n }\n}\n","import { Newline, Text, type TextProps } from 'ink';\nimport { type ReactElement, useEffect, useState } from 'react';\n\nimport { type Workspace } from '@/src/project/workspace';\n\n// Types\nexport interface WorkspaceTreeProps {\n workspace: Workspace;\n dev?: boolean;\n level?: ReactElement;\n}\n\n// Utils\nconst style = (dev: boolean): TextProps => ({ color: dev ? 'blue' : '' });\n\n// Component\nexport default function WorkspaceTree(props: WorkspaceTreeProps) {\n const { workspace: wks, dev = false, level = '' } = props;\n\n // State\n const [deps, setDeps] = useState<[Workspace, boolean | null][]>([]);\n\n // Effects\n useEffect(() => void (async () => {\n const deps: [Workspace, boolean | null][] = [];\n\n for await (const dep of wks.dependencies()) {\n deps.push([dep, null]);\n }\n\n for await (const dep of wks.devDependencies()) {\n deps.push([dep, true]);\n }\n\n setDeps(deps);\n })(), [wks]);\n\n // Render\n return (\n <Text>\n <Text {...style(dev)}>{wks.name}</Text>\n {wks.version && <Text color=\"grey\">@{wks.version}</Text>}\n {(deps.length > 0) && <Newline/>}\n\n {deps.map(([dep, isDev], idx) => (\n <Text key={dep.name}>\n {level}<Text {...style(dev)}>{idx === deps.length - 1 ? '└' : '├'}─{' '}</Text>\n <WorkspaceTree\n workspace={dep}\n dev={isDev ?? dev}\n level={<>{level}<Text {...style(dev)}>{idx === deps.length - 1 ? ' ' : '│'}{' '}</Text></>}\n />\n {(idx < deps.length - 1) && <Newline/>}\n </Text>\n ))}\n </Text>\n );\n}\n","// Utils\nexport async function dynamicImport(filepath: string) {\n return import(/* webpackIgnore: true */ process.platform === 'win32' ? `file://${filepath}` : filepath);\n}\n","import { type SpawnTask, type SpawnTaskStream } from '@jujulego/tasks';\nimport { streamEvents } from '@jujulego/event-tree';\n\n// Utils\nexport async function* combine<T>(...generators: AsyncGenerator<T>[]): AsyncGenerator<T> {\n for (const gen of generators) {\n yield* gen;\n }\n}\n\nexport async function *streamLines(task: SpawnTask, stream: SpawnTaskStream): AsyncGenerator<string> {\n // Abort\n const ctrl = new AbortController();\n const reason = new Error('aborted');\n\n task.subscribe('completed', () => ctrl.abort(reason));\n\n // Stream\n let current = '';\n\n try {\n for await (const chunk of streamEvents(task, `stream.${stream}`, { signal: ctrl.signal })) {\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 yield line;\n }\n }\n } catch (err) {\n if (err !== reason) {\n throw err;\n }\n\n if (current) {\n yield current;\n }\n }\n}\n","// Utils\nexport function capitalize(txt: string): string {\n return txt.charAt(0).toUpperCase() + txt.substring(1).toLowerCase();\n}\n"],"names":["GitService","constructor","manager","logger","command","cmd","args","options","opts","this","task","SpawnTask","subscribe","data","debug","toString","add","branch","diff","tag","isAffected","reference","files","Promise","resolve","reject","exitCode","Error","name","async","result","line","streamLines","push","replace","Service","inject","TASK_MANAGER","Logger","consoleFormat","winston","message","colors","verbose","info","error","label","stack","chalk","lines","split","spaces","formatted","repeat","length","i","container","toDynamicValue","format","process","transports","inSingletonScope","decorate","injectable","EventSource","SpinnerService","_status","_label","spin","emit","state","success","failed","stop","status","AJV","Symbol","Ajv","allErrors","child","strict","CONFIG_EXPLORER","CONFIG_VALIDATOR","context","get","compile","schema","cosmiconfig","loaders","filepath","dynamicImport","then","mod","default","defaultLoaders","noExt","CONFIG","CONFIG_OPTIONS","explorer","validator","loaded","search","config","jobs","os","errors","errorsText","separator","dataVar","exit","base","path","plugins","map","plugin","level","JSON","stringify","VERBOSITY_LEVEL","applyConfigOptions","parser","option","alias","type","description","coerce","cnt","Math","min","yargs","hideBin","argv","help","version","parse","AffectedFilter","fallback","sort","wks","_logger","sortArgs","includes","branches","_git","listBranches","cwd","tags","listTags","warn","workspace","rev","_formatRevision","lazyInject","Pipeline","_filters","filter","test","workspaces","_test","PrivateFilter","value","manifest","private","ScriptsFilter","scripts","Object","keys","some","scr","Container","lazyInjectNamed","getDecorators","LoadProject","spinner","builder","choices","root","project","Project","packageManager","whenTargetNamed","CURRENT","Middleware","LoadWorkspace","desc","Workspace","toConstantValue","lazyCurrentProject","COMMAND_OPTS","COMMAND","getCommandOpts","target","Reflect","getMetadata","buildCommandModule","aliases","describe","deprecated","middlewares","applyMiddlewares","handler","Command","defineMetadata","setRegistry","bind","toSelf","getAsync","INK_APP","for","render","Layout","stdout","isTTY","stderr","InkCommand","children","app","rerender","waitUntilExit","tmp","cls","middleware","MODULE","REGISTRY","getRegistry","registry","getModule","assert","module","ContainerModule","setModule","PluginLoaderService","_config","_importPlugin","PluginModule","commands","super","id","Plugin","_root","_names","Map","_workspaces","_isFullyLoaded","_lock","AsyncLock","_packageManager","static","dir","found","last","fs","lock","file","relative","mnf","normalize","msg","acquire","_loadManifest","set","_mainWorkspace","startsWith","main","mainWorkspace","values","pattern","glob","isDirectory","_loadWorkspace","code","ws","_cwd","_affectedCache","_tasks","_satisfies","from","range","substring","satisfies","deps","generators","unshift","devDependencies","dependencies","dep","combine","build","dependsOn","proms","all","r","_isAffected","kind","entries","_loadDependencies","stream","log","script","err","pm","env","FORCE_COLOR","_streamLogs","_buildDependencies","buildDeps","run","lazyCurrentWorkspace","TaskExprService","node","_lexer","moo","lparen","whitespace","string","match","x","slice","operator","rparen","pop","_nextNode","lexer","token","isTaskNode","tasks","formatError","res","expr","reset","tree","roots","group","ParallelGroup","SequenceGroup","buildTask","TaskManager","GroupTaskSpinner","setTasks","useState","useLayoutEffect","dirty","queueMicrotask","TaskSpinner","Box","flexDirection","marginLeft","Fragment","GroupTask","GlobalSpinner","setState","Text","Spinner","color","symbols","MESSAGE","StaticLogs","write","useStderr","transport","remove","Transport","next","setTimeout","List","items","headers","key","marginRight","bold","capitalize","item","idx","TaskManagerSpinner","tsk","groupTask","TaskName","setStatus","time","setTime","event","duration","ms","style","dev","WorkspaceTree","props","setDeps","useEffect","Newline","isDev","import","platform","gen","ctrl","AbortController","reason","abort","current","chunk","streamEvents","signal","txt","charAt","toUpperCase","toLowerCase"],"sourceRoot":""}