@jujulego/jill 2.4.0-alpha.1 → 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 +13 -1
- package/dist/489.mjs +1 -1
- package/dist/489.mjs.map +1 -1
- package/dist/71.mjs +1 -1
- package/dist/71.mjs.map +1 -1
- package/dist/828.mjs +1 -1
- package/dist/828.mjs.map +1 -1
- package/dist/commands/each.d.ts +1 -3
- package/dist/commons/logger/parameters.d.ts +2 -0
- package/dist/commons/logger/thread.gateway.d.ts +1 -1
- package/dist/config/types.d.ts +1 -0
- package/dist/index.d.ts +0 -1
- package/dist/index.mjs +1 -1
- package/dist/index.mjs.map +1 -1
- package/dist/main.mjs +1 -1
- package/dist/main.mjs.map +1 -1
- package/dist/middlewares/load-project.d.ts +1 -3
- package/dist/middlewares/load-workspace.d.ts +3 -3
- package/dist/project/workspace.d.ts +1 -0
- package/dist/tasks/script-task.d.ts +9 -2
- package/dist/tasks/task-expr.service.d.ts +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +19 -18
- package/dist/commons/spinner.service.d.ts +0 -21
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/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/ink.config.tsx","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/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 { Source, source$ } from '@jujulego/event-tree';\nimport { LogLevel, quick, withTimestamp } from '@jujulego/logger';\nimport { BroadcastChannel } from 'node:worker_threads';\n\nimport { Service } from '@/src/modules/service.ts';\n\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 this.channel = new BroadcastChannel('jujulego:jill:logger');\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 { 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 { 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 { decorate, injectable, type interfaces as int } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv, type CommandModule } from 'yargs';\n\nimport { setRegistry } from '@/src/modules/module.ts';\nimport { type Awaitable, type Class, type Type } from '@/src/types.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: (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 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 { 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","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","Symbol","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","INK_APP","for","Error","render","Layout","Container","lazyInject","lazyInjectNamed","fixDefaultExport","getDecorators","JillApplication","createChild","scriptName","completion","pkg","stdout","columns","exitProcess","_prepareParser","commands","command","recommendCommands","fail","CorePlugin","load","getModule","loadPlugins","_loadPlugins","getAllAsync","COMMAND_MODULE","parseAsync","ctx","COMMAND","Promise","resolve","reject","modules","cmd","opts","getCommandOpts","buildCommandModule","handler","args","TaskCommand","tasks","tsk","prepare","push","catch","injectable","PluginLoaderService","toSelf","inTransientScope","whenTargetIsDefault","app","whenTargetNamed","COMMAND_OPTS","target","Reflect","getMetadata","name","aliases","describe","deprecated","builder","middlewares","applyMiddlewares","Command","decorate","defineMetadata","split","setRegistry","getAsync","InkCommand","children","rerender","waitUntilExit","Middleware","tmp","cls","middleware","MODULE","REGISTRY","getRegistry","registry","assert","module","ContainerModule","setModule","_config","ctn","_importPlugin","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","getScript","commandArgs","splitCommandLine","arg","replace","tasksOf","pm","packageManager","undefined","_runScript","_scriptTasks","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":"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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 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":""}
|
package/dist/828.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export const id=828;export const ids=[828];export const modules={236:(e,t,s)=>{s.d(t,{F:()=>d});var r=s(2786),n=s(8858),o=s(3410),i=s(6675),a=s(5099),c=s(5960),l=s(9921);function h(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 r={logger:this.logger,...s},n=new o.SpawnTask("git",[e,...t],{command:e,hidden:!0},r);return n.on("stream",(({data:e})=>r.logger.debug(e.toString("utf-8")))),this.manager.add(n),n}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(((n,o)=>{const i=this.diff(["--quiet",e,"--",...t],s);(0,r.once$)(i,"status.done",(()=>n(!1))),(0,r.once$)(i,"status.failed",(()=>{i.exitCode?n(!0):o(new Error(`Task ${i.name} failed`))}))}))}async listBranches(e=[],t){const s=this.branch(["-l",...e],t),r=[];for await(const e of(0,c.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,c.F)(s,"stdout"))r.push(e);return r}};d=function(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}([(0,l.t)(),h(0,(0,i.inject)(a.N)),h(1,(0,i.inject)(n.Logger))],d)},3565:(e,t,s)=>{s.d(t,{V:()=>l});var r=s(8858),n=s(2786),o=s(6675),i=s(466),a=s(2561),c=s(9921);let l=class{constructor(e){this._status="stop",this._label="",this._events=(0,n.multiplexer$)({state:(0,n.source$)()}),this._logger=e.child((0,r.withLabel)("spinner"))}_awakeInk(){i.nC.get(a.I)}spin(e){this._logger.debug(`spin: ${e}`),this._status="spin",this._label=e,this._events.emit("state",this.state),this._awakeInk()}success(e){this._logger.debug(`success: ${e}`),this._status="success",this._label=e,this._events.emit("state",this.state),this._awakeInk()}failed(e){this._logger.debug(`failed: ${e}`),this._status="failed",this._label=e,this._events.emit("state",this.state),this._awakeInk()}stop(){"spin"===this._status&&(this._logger.debug(`stop: ${this._label}`),this._status="stop",this._events.emit("state",this.state))}get on(){return this._events.on}get off(){return this._events.off}get state(){return{status:this._status,label:this._label}}};var h;l=function(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}([(0,c.t)(),(0,h=(0,o.inject)(r.Logger),function(e,t){h(e,t,0)})],l)},8652:(e,t,s)=>{s.d(t,{L:()=>a});var r=s(8858),n=s(236),o=s(466);function i(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}class a{constructor(e,t,s){this.format=e,this.fallback=t,this.sort=s}async _formatRevision(e){const t=this._logger.child((0,r.withLabel)(e.name));let s=this.format;s=s.replace(/(?<!\\)((?:\\\\)*)%name/g,`$1${e.name}`),s=s.replace(/\\(.)/g,"$1");const n=this.sort?["--sort",this.sort]:[];if(s.includes("*")){const r=await this._git.listBranches([...n,s],{cwd:e.cwd,logger:t});r.length>0&&(s=r[r.length-1])}if(s.includes("*")){const r=await this._git.listTags([...n,s],{cwd:e.cwd,logger:t});r.length>0&&(s=r[r.length-1])}return s!==this.format&&t.verbose`Resolved ${this.format} into ${s}`,s.includes("*")?(t.warning(`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)}}i([(0,o.yT)(r.Logger)],a.prototype,"_logger",void 0),i([(0,o.yT)(n.F)],a.prototype,"_git",void 0)},2999:(e,t,s)=>{s.d(t,{B:()=>r});class r{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)}constructor(){this._filters=[]}}},307:(e,t,s)=>{s.d(t,{N:()=>r});class r{constructor(e){this.value=e}test(e){return(e.manifest.private??!1)===this.value}}},4203:(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)))}}},8754:(e,t,s)=>{s.d(t,{_:()=>f,r:()=>p});var r=s(6675),n=s(6156),o=s(3565),i=s(9300),a=s(466),c=s(1632),l=s(7672),h=s(9808);function d(e,t){return function(s,r){t(s,r,e)}}let p=class{constructor(e,t,s){this.spinner=e,this.projects=t,this.context=s}builder(e){return e.option("project",{alias:"p",type:"string",description:"Project root directory"}).option("package-manager",{choices:["yarn","npm"],type:"string",description:"Force package manager"})}async handler(e){if(!this.context.project||e.project)try{this.spinner.spin("Loading project ..."),e.project=await this.projects.searchProjectRoot(e.project??process.cwd()),this.context.project=this.projects.getProject(e.project,{packageManager:e.packageManager})}finally{this.spinner.stop()}else e.project=this.context.project.root}};function f(){return(0,a.oV)(l.I,i.W)}p=function(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}([(0,c.d)(),d(0,(0,r.inject)(o.V)),d(1,(0,r.inject)(h.Z)),d(2,(0,r.inject)(n.O))],p),a.nC.bind(l.I).toDynamicValue((({container:e})=>{const t=e.get(n.O).project;if(!t)throw new Error("Cannot inject current project, it not yet defined");return t})).whenTargetNamed(i.W)},2419:(e,t,s)=>{s.d(t,{I:()=>g,S:()=>u});var r=s(6675),n=s(6156),o=s(3565),i=s(9300),a=s(466),c=s(1632),l=s(8410),h=s(6505),d=s(8754);function p(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}function f(e,t){return function(s,r){t(s,r,e)}}let u=class{constructor(e,t){this.spinner=e,this.context=t}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 ...`);let t=this.context.workspace??null;if(t&&!e.workspace||(t=e.workspace?await this.project.workspace(e.workspace):process.cwd().startsWith(this.project.root)?await this.project.currentWorkspace():await this.project.mainWorkspace()),!t)throw this.spinner.failed(`Workspace "${e.workspace||"."}" not found`),new h.T(1,"Workspace not found");this.context.workspace=t}finally{this.spinner.stop()}}};function g(){return(0,a.oV)(l.j,i.W)}p([(0,d._)()],u.prototype,"project",void 0),u=p([(0,c.d)(),f(0,(0,r.inject)(o.V)),f(1,(0,r.inject)(n.O))],u),a.nC.bind(l.j).toDynamicValue((({container:e})=>{const t=e.get(n.O).workspace;if(!t)throw new Error("Cannot inject current workspace, it not yet defined");return t})).whenTargetNamed(i.W)},5756:(e,t,s)=>{s.d(t,{S:()=>i,p:()=>o});var r=s(6675),n=s(3617);class o extends r.ContainerModule{constructor(e,t){super(((...e)=>{for(const t of this.commands)(0,n.JH)(t)(...e)})),this.name=e,this.commands=t,this.id=(0,r.id)()}}function i(e){return t=>{const s=e.name??t.name,r=new o(s,e.commands);(0,n.IY)(t,r)}}},9808:(e,t,s)=>{s.d(t,{Z:()=>p});var r=s(8858),n=s(6675),o=s(3977),i=s.n(o),a=s(9411),c=s.n(a),l=s(9921),h=s(7672);const d=["package-lock.json","yarn.lock"];let p=class{constructor(e){this._cache=new Map,this._roots=new Map,this._logger=e.child((0,r.withLabel)("projects"))}async isProjectRoot(e){const t=await i().readdir(e);return{hasManifest:t.includes("package.json"),hasLockFile:d.some((e=>t.includes(e)))}}async searchProjectRoot(e){const t=[];let s=!1,r=e=c().resolve(e),n=e,o=n;do{const e=this._roots.get(n);if(e){r=e,s=!0;break}const{hasManifest:i,hasLockFile:a}=await this.isProjectRoot(n);if(t.push(n),i&&(r=n,s=!0),a)break;o=n,n=c().dirname(n)}while(o!==n);for(const e of t)e.startsWith(r)&&this._roots.set(e,r);return s?this._logger.debug`Project root found at #!cwd:${r}`:this._logger.debug`Project root not found, keeping #!cwd:${r}`,r}getProject(e,t){let s=this._cache.get(e);return s||(s=new h.I(e,this._logger,t),this._cache.set(e,s)),s}};var f;p=function(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}([(0,l.t)(),(0,f=(0,n.inject)(r.Logger),function(e,t){f(e,t,0)})],p)},7672:(e,t,s)=>{s.d(t,{I:()=>f});var r=s(8858),n=s(467),o=s(6675),i=s(3977),a=s.n(i),c=s(9411),l=s.n(c),h=s(5588),d=s(865),p=s(8410);let f=class{constructor(e,t,s={}){this._root=e,this._logger=t,this._names=new Map,this._workspaces=new Map,this._isFullyLoaded=!1,this._lock=new n.Lock,s.packageManager&&(this._logger.debug`Forced use of ${s.packageManager} in #!cwd:${this.root}`,this._packageManager=s.packageManager)}async _loadManifest(e){const t=l().resolve(this.root,e,"package.json"),s=l().relative(this.root,l().dirname(t)),n=this._logger.child((0,r.withLabel)(s?`project@${s}`:"project"));n.debug("Loading package.json ...");const o=await a().readFile(t,"utf-8"),i=JSON.parse(o);return(0,h.default)(i,(e=>n.verbose(e))),i}async _loadWorkspace(e){return await this._lock.with((async()=>{let t=this._workspaces.get(e);if(!t){const s=await this._loadManifest(e);t=new p.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 a().readdir(this.root);e.includes("yarn.lock")?(this._logger.debug`Detected yarn in #!cwd:${this.root}`,this._packageManager="yarn"):e.includes("package-lock.json")?(this._logger.debug`Detected npm in #!cwd:${this.root}`,this._packageManager="npm"):(this._logger.debug`No package manager recognized in #!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 p.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(0,d.default)(e,{cwd:this.root}))try{const e=l().resolve(this.root,t);(await a().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){for await(const t of this.workspaces())if(t.name===e)return t;this._isFullyLoaded=!0}return null}get root(){return l().resolve(this._root)}};f=function(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}([(0,o.injectable)()],f)},8410:(e,t,s)=>{s.d(t,{j:()=>u});var r=s(8858),n=s(6675),o=s(9411),i=s.n(o),a=s(3999),c=s(236),l=s(466),h=s(4244),d=s(6839),p=s(5960);function f(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}let u=class{constructor(e,t,s){this._cwd=e,this.manifest=t,this.project=s,this._affectedCache=new Map,this._tasks=new Map;const n=l.nC.get(r.Logger);this._logger=n.child((0,r.withLabel)(this.manifest.name))}_satisfies(e,t){return t.startsWith("file:")?i().resolve(e.cwd,t.substring(5))===this.cwd:(t.startsWith("workspace:")&&(t=t.substring(10)),!this.version||(0,a.satisfies)(this.version,t))}async _buildDependencies(e,t){const s=[];switch(t.buildDeps??"all"){case"all":s.unshift(this.devDependencies());case"prod":s.unshift(this.dependencies())}for await(const r of(0,p.$)(...s)){const s=await r.build(t);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,p.$)(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.warning(`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 exec(e,t=[],s={}){const n=await this.project.packageManager(),o=new h.F(this,e,t,{...s,logger:this._logger.child((0,r.withLabel)(`${this.name}$${e}`)),superCommand:"yarn"===n?["yarn","exec"]:void 0});return await this._buildDependencies(o,s),o}async run(e,t=[],s={}){if(!this.getScript(e))return null;let n=this._tasks.get(e);return n||(n=new d.s(this,e,t,{...s,logger:this._logger.child((0,r.withLabel)(`${this.name}#${e}`))}),await n.prepare(),await this._buildDependencies(n,s),this._tasks.set(e,n)),n}async build(e={}){const t=await this.run(e?.buildScript??"build",[],e);return t||this._logger.warning("Will not be built (no build script)"),t}getScript(e){const{scripts:t={}}=this.manifest;return t[e]||null}toJSON(){return{name:this.name,version:this.version,cwd:this.cwd}}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 i().resolve(this.project.root,this._cwd)}};f([(0,l.yT)(c.F)],u.prototype,"_git",void 0),u=f([(0,n.injectable)()],u)},3678:(e,t,s)=>{s.d(t,{P:()=>c});var r=s(8858),n=s(3410),o=s(6675),i=s(2535),a=s(9921);let c=class{static isTaskNode(e){return"script"in e}constructor(e){this._logger=e}_lexer(){return i.default.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(c.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(c.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(c.isTaskNode(e)){const r=await t.run(e.script,[],s);if(!r)throw new Error(`Workspace ${t.name} have no ${e.script} script`);return r}{let r;r="//"===e.operator?new n.ParallelGroup("In parallel",{},{logger:this._logger}):new n.SequenceGroup("In sequence",{},{logger:this._logger});for(const n of e.tasks)r.add(await this.buildTask(n,t,s));return r}}};var l;c=function(e,t,s,r){var n,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,s):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,s,r);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(o<3?n(i):o>3?n(t,s,i):n(t,s))||i);return o>3&&i&&Object.defineProperty(t,s,i),i}([(0,a.t)(),(0,l=(0,o.inject)(r.Logger),function(e,t){l(e,t,0)})],c)},6238:(e,t,s)=>{s.d(t,{Z:()=>a});var r=s(832),n=s(9149),o=s(810);const i=e=>({color:e?"blue":""});function a(e){const{workspace:t,dev:s=!1,level:c=""}=e,[l,h]=(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]);h(e)})()}),[t]),(0,r.jsxs)(n.Text,{children:[(0,r.jsx)(n.Text,{...i(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,{...i(s),children:[o===l.length-1?"└":"├","─"," "]}),(0,r.jsx)(a,{workspace:e,dev:t??s,level:(0,r.jsxs)(r.Fragment,{children:[c,(0,r.jsxs)(n.Text,{...i(s),children:[o===l.length-1?" ":"│"," "]})]})}),o<l.length-1&&(0,r.jsx)(n.Newline,{})]},e.name)))]})}},5960:(e,t,s)=>{s.d(t,{$:()=>n,F:()=>o});var r=s(2786);async function*n(...e){for(const t of e)yield*t}async function*o(e,t){const s=(0,r.off$)();(0,r.once$)(e,"completed",s);let n="";try{for await(const o of(0,r.iterate$)(e,`stream.${t}`,{off:s})){const e=(n+o.data.toString("utf-8")).split(/\r?\n/);n=e.pop()??"";for(const t of e)yield t}}catch(e){if("Unsubscribed !"!==e.message)throw e;n&&(yield n)}}}};
|
|
1
|
+
export const id=828;export const ids=[828];export const modules={236:(e,t,r)=>{r.d(t,{F:()=>p});var s=r(2786),o=r(8858),n=r(3410),i=r(6675),a=r(5099),c=r(5960),l=r(9921);function h(e,t){return function(r,s){t(r,s,e)}}let p=class{constructor(e,t){this.manager=e,this.logger=t}command(e,t,r={}){const s={logger:this.logger,...r},o=new n.SpawnTask("git",[e,...t],{command:e,hidden:!0},s);return o.on("stream",(({data:e})=>s.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=[],r){return new Promise(((o,n)=>{const i=this.diff(["--quiet",e,"--",...t],r);(0,s.once$)(i,"status.done",(()=>o(!1))),(0,s.once$)(i,"status.failed",(()=>{i.exitCode?o(!0):n(new Error(`Task ${i.name} failed`))}))}))}async listBranches(e=[],t){const r=this.branch(["-l",...e],t),s=[];for await(const e of(0,c.F)(r,"stdout"))s.push(e.replace(/^[ *] /,""));return s}async listTags(e=[],t){const r=this.tag(["-l",...e],t),s=[];for await(const e of(0,c.F)(r,"stdout"))s.push(e);return s}};p=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([(0,l.t)(),h(0,(0,i.inject)(a.N)),h(1,(0,i.inject)(o.Logger))],p)},8652:(e,t,r)=>{r.d(t,{L:()=>a});var s=r(8858),o=r(236),n=r(466);function i(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}class a{constructor(e,t,r){this.format=e,this.fallback=t,this.sort=r}async _formatRevision(e){const t=this._logger.child((0,s.withLabel)(e.name));let r=this.format;r=r.replace(/(?<!\\)((?:\\\\)*)%name/g,`$1${e.name}`),r=r.replace(/\\(.)/g,"$1");const o=this.sort?["--sort",this.sort]:[];if(r.includes("*")){const s=await this._git.listBranches([...o,r],{cwd:e.cwd,logger:t});s.length>0&&(r=s[s.length-1])}if(r.includes("*")){const s=await this._git.listTags([...o,r],{cwd:e.cwd,logger:t});s.length>0&&(r=s[s.length-1])}return r!==this.format&&t.verbose`Resolved ${this.format} into ${r}`,r.includes("*")?(t.warning(`No revision found matching ${r}, using fallback ${this.fallback}`),this.fallback):r}async test(e){const t=await this._formatRevision(e);return await e.isAffected(t)}}i([(0,n.yT)(s.Logger)],a.prototype,"_logger",void 0),i([(0,n.yT)(o.F)],a.prototype,"_git",void 0)},2999:(e,t,r)=>{r.d(t,{B:()=>s});class s{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)}constructor(){this._filters=[]}}},307:(e,t,r)=>{r.d(t,{N:()=>s});class s{constructor(e){this.value=e}test(e){return(e.manifest.private??!1)===this.value}}},4203:(e,t,r)=>{r.d(t,{f:()=>s});class s{constructor(e){this.scripts=e}test(e){const t=Object.keys(e.manifest.scripts||{});return this.scripts.some((e=>t.includes(e)))}}},8754:(e,t,r)=>{r.d(t,{_:()=>d,r:()=>p});var s=r(6675),o=r(9300),n=r(6156),i=r(466),a=r(1632),c=r(7672),l=r(9808);function h(e,t){return function(r,s){t(r,s,e)}}let p=class{constructor(e,t){this.projects=e,this.context=t}builder(e){return e.option("project",{alias:"p",type:"string",description:"Project root directory"}).option("package-manager",{choices:["yarn","npm"],type:"string",description:"Force package manager"})}async handler(e){!this.context.project||e.project?(e.project=await this.projects.searchProjectRoot(e.project??process.cwd()),this.context.project=this.projects.getProject(e.project,{packageManager:e.packageManager})):e.project=this.context.project.root}};function d(){return(0,i.oV)(c.I,o.W)}p=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([(0,a.d)(),h(0,(0,s.inject)(l.Z)),h(1,(0,s.inject)(n.O))],p),i.nC.bind(c.I).toDynamicValue((({container:e})=>{const t=e.get(n.O).project;if(!t)throw new Error("Cannot inject current project, it not yet defined");return t})).whenTargetNamed(o.W)},2419:(e,t,r)=>{r.d(t,{I:()=>w,S:()=>g});var s=r(8858),o=r(6675),n=r(6133),i=r(6156),a=r(9300),c=r(466),l=r(1632),h=r(8410),p=r(6505),d=r(8754);function f(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}function u(e,t){return function(r,s){t(r,s,e)}}let g=class{constructor(e,t){this.context=e,this.logger=t}builder(e){return e.option("workspace",{alias:"w",type:"string",desc:"Workspace to use"})}async handler(e){let t=this.context.workspace??null;if(t&&!e.workspace||(t=e.workspace?await this.project.workspace(e.workspace):process.cwd().startsWith(this.project.root)?await this.project.currentWorkspace():await this.project.mainWorkspace()),!t)throw this.logger.error(`${n.default.error} Workspace "${e.workspace||"."}" not found`),new p.T(1,"Workspace not found");this.context.workspace=t}};function w(){return(0,c.oV)(h.j,a.W)}f([(0,d._)()],g.prototype,"project",void 0),g=f([(0,l.d)(),u(0,(0,o.inject)(i.O)),u(1,(0,o.inject)(s.Logger))],g),c.nC.bind(h.j).toDynamicValue((({container:e})=>{const t=e.get(i.O).workspace;if(!t)throw new Error("Cannot inject current workspace, it not yet defined");return t})).whenTargetNamed(a.W)},5756:(e,t,r)=>{r.d(t,{S:()=>i,p:()=>n});var s=r(6675),o=r(3617);class n extends s.ContainerModule{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,s.id)()}}function i(e){return t=>{const r=e.name??t.name,s=new n(r,e.commands);(0,o.IY)(t,s)}}},9808:(e,t,r)=>{r.d(t,{Z:()=>d});var s=r(8858),o=r(6675),n=r(3977),i=r.n(n),a=r(9411),c=r.n(a),l=r(9921),h=r(7672);const p=["package-lock.json","yarn.lock"];let d=class{constructor(e){this._cache=new Map,this._roots=new Map,this._logger=e.child((0,s.withLabel)("projects"))}async isProjectRoot(e){const t=await i().readdir(e);return{hasManifest:t.includes("package.json"),hasLockFile:p.some((e=>t.includes(e)))}}async searchProjectRoot(e){const t=[];let r=!1,s=e=c().resolve(e),o=e,n=o;do{const e=this._roots.get(o);if(e){s=e,r=!0;break}const{hasManifest:i,hasLockFile:a}=await this.isProjectRoot(o);if(t.push(o),i&&(s=o,r=!0),a)break;n=o,o=c().dirname(o)}while(n!==o);for(const e of t)e.startsWith(s)&&this._roots.set(e,s);return r?this._logger.debug`Project root found at #!cwd:${s}`:this._logger.debug`Project root not found, keeping #!cwd:${s}`,s}getProject(e,t){let r=this._cache.get(e);return r||(r=new h.I(e,this._logger,t),this._cache.set(e,r)),r}};var f;d=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([(0,l.t)(),(0,f=(0,o.inject)(s.Logger),function(e,t){f(e,t,0)})],d)},7672:(e,t,r)=>{r.d(t,{I:()=>f});var s=r(8858),o=r(467),n=r(6675),i=r(3977),a=r.n(i),c=r(9411),l=r.n(c),h=r(5588),p=r(865),d=r(8410);let f=class{constructor(e,t,r={}){this._root=e,this._logger=t,this._names=new Map,this._workspaces=new Map,this._isFullyLoaded=!1,this._lock=new o.Lock,r.packageManager&&(this._logger.debug`Forced use of ${r.packageManager} in #!cwd:${this.root}`,this._packageManager=r.packageManager)}async _loadManifest(e){const t=l().resolve(this.root,e,"package.json"),r=l().relative(this.root,l().dirname(t)),o=this._logger.child((0,s.withLabel)(r?`project@${r}`:"project"));o.debug("Loading package.json ...");const n=await a().readFile(t,"utf-8"),i=JSON.parse(n);return(0,h.default)(i,(e=>o.verbose(e))),i}async _loadWorkspace(e){return await this._lock.with((async()=>{let t=this._workspaces.get(e);if(!t){const r=await this._loadManifest(e);t=new d.j(e,r,this),this._workspaces.set(e,t),this._names.set(t.name,t)}return t}))}async packageManager(){if(!this._packageManager){const e=await a().readdir(this.root);e.includes("yarn.lock")?(this._logger.debug`Detected yarn in #!cwd:${this.root}`,this._packageManager="yarn"):e.includes("package-lock.json")?(this._logger.debug`Detected npm in #!cwd:${this.root}`,this._packageManager="npm"):(this._logger.debug`No package manager recognized in #!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 d.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 r of this.workspaces())if(e.startsWith(r.cwd)&&(t=r,r.cwd!==this.root))return r;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(0,p.default)(e,{cwd:this.root}))try{const e=l().resolve(this.root,t);(await a().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){for await(const t of this.workspaces())if(t.name===e)return t;this._isFullyLoaded=!0}return null}get root(){return l().resolve(this._root)}};f=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([(0,n.injectable)()],f)},8410:(e,t,r)=>{r.d(t,{j:()=>g});var s=r(8858),o=r(6675),n=r(9411),i=r.n(n),a=r(3999),c=r(236),l=r(7839),h=r(466),p=r(4244),d=r(6839),f=r(5960);function u(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}let g=class{constructor(e,t,r){this._cwd=e,this.manifest=t,this.project=r,this._affectedCache=new Map,this._tasks=new Map;const o=h.nC.get(s.Logger);this._logger=o.child((0,s.withLabel)(this.manifest.name))}_satisfies(e,t){return t.startsWith("file:")?i().resolve(e.cwd,t.substring(5))===this.cwd:(t.startsWith("workspace:")&&(t=t.substring(10)),!this.version||(0,a.satisfies)(this.version,t))}async _buildDependencies(e,t){const r=[];switch(t.buildDeps??"all"){case"all":r.unshift(this.devDependencies());case"prod":r.unshift(this.dependencies())}for await(const s of(0,f.$)(...r)){const r=await s.build(t);r&&e.dependsOn(r)}}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 r of(0,f.$)(this.dependencies(),this.devDependencies()))t.push(r.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[r,s]of Object.entries(e)){const e=await this.project.workspace(r);e&&(e._satisfies(this,s)?yield e:this._logger.warning(`Ignoring ${t} ${e.reference} as it does not match requirement ${s}`))}}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 exec(e,t=[],r={}){const o=await this.project.packageManager(),n=new p.F(this,e,t,{...r,logger:this._logger.child((0,s.withLabel)(`${this.name}$${e}`)),superCommand:"yarn"===o?["yarn","exec"]:void 0});return await this._buildDependencies(n,r),n}async run(e,t=[],r={}){if(!this.getScript(e))return null;let o=this._tasks.get(e);return o||(o=new d.s(this,e,t,{...r,logger:this._logger.child((0,s.withLabel)(`${this.name}#${e}`)),runHooks:this._config.hooks}),await o.prepare(),await this._buildDependencies(o,r),this._tasks.set(e,o)),o}async build(e={}){const t=await this.run(e?.buildScript??"build",[],e);return t||this._logger.warning("Will not be built (no build script)"),t}getScript(e){const{scripts:t={}}=this.manifest;return t[e]||null}toJSON(){return{name:this.name,version:this.version,cwd:this.cwd}}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 i().resolve(this.project.root,this._cwd)}};u([(0,h.yT)(c.F)],g.prototype,"_git",void 0),u([(0,h.yT)(l.k)],g.prototype,"_config",void 0),g=u([(0,o.injectable)()],g)},3678:(e,t,r)=>{r.d(t,{P:()=>c});var s=r(8858),o=r(3410),n=r(6675),i=r(2535),a=r(9921);let c=class{static isTaskNode(e){return"script"in e}constructor(e){this._logger=e}_lexer(){return i.default.states({task:{lparen:"(",whitespace:/[ \t]+/,script:{match:/[-_:a-zA-Z0-9]+/,push:"operatorOrArgument"},string:[{match:/'(?:\\['\\]|[^\r\n'\\])+'/,push:"operator",value:e=>e.slice(1,-1).replace(/\\(['\\])/g,"$1")},{match:/"(?:\\["\\]|[^\r\n"\\])+"/,push:"operator",value:e=>e.slice(1,-1).replace(/\\(["\\])/g,"$1")}]},operator:{rparen:")",whitespace:/[ \t]+/,operator:{match:["->","//","||"],pop:1}},operatorOrArgument:{rparen:")",whitespace:/[ \t]+/,operator:{match:["->","//","||"],pop:1},argument:[{match:/[-_:a-zA-Z0-9]+/},{match:/'(?:\\['\\]|[^\r\n'\\])+'/,value:e=>e.slice(1,-1).replace(/\\(['\\])/g,"$1")},{match:/"(?:\\["\\]|[^\r\n"\\])+"/,value:e=>e.slice(1,-1).replace(/\\(["\\])/g,"$1")}]}})}_nextNode(e,t=0){let r=null;for(const s of e){if("whitespace"===s.type)continue;if("rparen"===s.type)break;if("argument"===s.type){if(!r)throw new Error(e.formatError(s,"Unexpected argument"));if(c.isTaskNode(r))r.args.push(s.value);else{const t=r.tasks[r.tasks.length-1];if(!t||!c.isTaskNode(t))throw new Error(e.formatError(s,"Unexpected argument"));t.args.push(s.value)}continue}if("operator"===s.type){const t=s.value;if(r){if(c.isTaskNode(r)){r={operator:t,tasks:[r]};continue}r.operator!==t&&(r={operator:t,tasks:[r]});continue}throw new Error(e.formatError(s,"Unexpected operator"))}let o;if("script"===s.type)o={script:s.value,args:[]};else if("string"===s.type){const[e,...t]=s.value.split(/ +/);o={script:e,args:t}}else{if("lparen"!==s.type)throw new Error(e.formatError(s,"Unexpected token"));{const r=this._nextNode(e,t+1);if(!r)throw new Error(e.formatError(s,"Empty group found"));o=r}}if(r){if(c.isTaskNode(r))throw new Error(e.formatError(s,"Unexpected token, expected an operator"));r.tasks.push(o)}else r=o}return r}parse(e){const t=this._lexer().reset(e),r={roots:[]};for(;;){const e=this._nextNode(t);if(!e)break;r.roots.push(e)}return r}async buildTask(e,t,r){if(c.isTaskNode(e)){const s=await t.run(e.script,e.args,r);if(!s)throw new Error(`Workspace ${t.name} have no ${e.script} script`);return s}{let s;s="//"===e.operator?new o.ParallelGroup("In parallel",{},{logger:this._logger}):"||"===e.operator?new o.FallbackGroup("Fallbacks",{},{logger:this._logger}):new o.SequenceGroup("In sequence",{},{logger:this._logger});for(const o of e.tasks)s.add(await this.buildTask(o,t,r));return s}}};var l;c=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([(0,a.t)(),(0,l=(0,n.inject)(s.Logger),function(e,t){l(e,t,0)})],c)},6238:(e,t,r)=>{r.d(t,{Z:()=>a});var s=r(832),o=r(9149),n=r(810);const i=e=>({color:e?"blue":""});function a(e){const{workspace:t,dev:r=!1,level:c=""}=e,[l,h]=(0,n.useState)([]);return(0,n.useEffect)((()=>{(async()=>{const e=[];for await(const r of t.dependencies())e.push([r,null]);for await(const r of t.devDependencies())e.push([r,!0]);h(e)})()}),[t]),(0,s.jsxs)(o.Text,{children:[(0,s.jsx)(o.Text,{...i(r),children:t.name}),t.version&&(0,s.jsxs)(o.Text,{color:"grey",children:["@",t.version]}),l.length>0&&(0,s.jsx)(o.Newline,{}),l.map((([e,t],n)=>(0,s.jsxs)(o.Text,{children:[c,(0,s.jsxs)(o.Text,{...i(r),children:[n===l.length-1?"└":"├","─"," "]}),(0,s.jsx)(a,{workspace:e,dev:t??r,level:(0,s.jsxs)(s.Fragment,{children:[c,(0,s.jsxs)(o.Text,{...i(r),children:[n===l.length-1?" ":"│"," "]})]})}),n<l.length-1&&(0,s.jsx)(o.Newline,{})]},e.name)))]})}},5960:(e,t,r)=>{r.d(t,{$:()=>o,F:()=>n});var s=r(2786);async function*o(...e){for(const t of e)yield*t}async function*n(e,t){const r=(0,s.off$)();(0,s.once$)(e,"completed",r);let o="";try{for await(const n of(0,s.iterate$)(e,`stream.${t}`,{off:r})){const e=(o+n.data.toString("utf-8")).split(/\r?\n/);o=e.pop()??"";for(const t of e)yield t}}catch(e){if("Unsubscribed !"!==e.message)throw e;o&&(yield o)}}}};
|
|
2
2
|
//# sourceMappingURL=828.mjs.map
|