@jujulego/jill 2.0.1 → 2.0.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/dist/commands/each.js +7 -7
- package/dist/commands/each.js.map +1 -1
- package/dist/commands/list.js +8 -8
- package/dist/commands/list.js.map +1 -1
- package/dist/commands/run.js +6 -6
- package/dist/commands/run.js.map +1 -1
- package/dist/commands/tree.js +6 -6
- package/dist/commands/tree.js.map +1 -1
- package/dist/filters/affected.filter.js +2 -2
- package/dist/filters/affected.filter.js.map +1 -1
- package/dist/filters/index.js +1 -1
- package/dist/filters/index.js.map +1 -1
- package/dist/filters/pipeline.js +1 -1
- package/dist/filters/pipeline.js.map +1 -1
- package/dist/filters/private.filter.js +1 -1
- package/dist/filters/private.filter.js.map +1 -1
- package/dist/filters/scripts.filter.js +1 -1
- package/dist/filters/scripts.filter.js.map +1 -1
- package/dist/git.js +3 -3
- package/dist/git.js.map +1 -1
- package/dist/main.js +3 -3
- package/dist/main.js.map +1 -1
- package/dist/middlewares/global-config.js +3 -3
- package/dist/middlewares/global-config.js.map +1 -1
- package/dist/middlewares/index.js +1 -1
- package/dist/middlewares/index.js.map +1 -1
- package/dist/middlewares/load-project.js +4 -4
- package/dist/middlewares/load-project.js.map +1 -1
- package/dist/middlewares/load-workspace.js +4 -4
- package/dist/middlewares/load-workspace.js.map +1 -1
- package/dist/middlewares/setup-ink.js +4 -4
- package/dist/middlewares/setup-ink.js.map +1 -1
- package/dist/project/index.js +1 -1
- package/dist/project/index.js.map +1 -1
- package/dist/project/project.js +4 -4
- package/dist/project/project.js.map +1 -1
- package/dist/project/workspace.js +3 -3
- package/dist/project/workspace.js.map +1 -1
- package/dist/services/index.js +1 -1
- package/dist/services/index.js.map +1 -1
- package/dist/services/inversify.config.js +1 -1
- package/dist/services/inversify.config.js.map +1 -1
- package/dist/services/logger.service.js +1 -1
- package/dist/services/logger.service.js.map +1 -1
- package/dist/services/spinner.service.js +1 -1
- package/dist/services/spinner.service.js.map +1 -1
- package/dist/services/task-manager.service.js +1 -1
- package/dist/services/task-manager.service.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types.js +1 -1
- package/dist/types.js.map +1 -1
- package/dist/ui/global-spinner.js +2 -2
- package/dist/ui/global-spinner.js.map +1 -1
- package/dist/ui/index.js +1 -1
- package/dist/ui/index.js.map +1 -1
- package/dist/ui/layout.js +1 -1
- package/dist/ui/layout.js.map +1 -1
- package/dist/ui/list.js +3 -3
- package/dist/ui/list.js.map +1 -1
- package/dist/ui/static-logs.js +2 -2
- package/dist/ui/static-logs.js.map +1 -1
- package/dist/ui/task-name.js +1 -1
- package/dist/ui/task-name.js.map +1 -1
- package/dist/ui/task-spinner.js +1 -1
- package/dist/ui/task-spinner.js.map +1 -1
- package/dist/ui/tasks-spinner.js +1 -1
- package/dist/ui/tasks-spinner.js.map +1 -1
- package/dist/ui/workspace-tree.js +1 -1
- package/dist/ui/workspace-tree.js.map +1 -1
- package/dist/utils/index.js +1 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/streams.js +1 -1
- package/dist/utils/streams.js.map +1 -1
- package/dist/utils/string.js +1 -1
- package/dist/utils/string.js.map +1 -1
- package/dist/utils/yargs.js +1 -1
- package/dist/utils/yargs.js.map +1 -1
- package/package.json +28 -26
- package/dist/commands/each.d.ts +0 -16
- package/dist/commands/each.d.ts.map +0 -1
- package/dist/commands/list.d.ts +0 -23
- package/dist/commands/list.d.ts.map +0 -1
- package/dist/commands/run.d.ts +0 -8
- package/dist/commands/run.d.ts.map +0 -1
- package/dist/commands/tree.d.ts +0 -3
- package/dist/commands/tree.d.ts.map +0 -1
- package/dist/filters/affected.filter.d.ts +0 -11
- package/dist/filters/affected.filter.d.ts.map +0 -1
- package/dist/filters/index.d.ts +0 -4
- package/dist/filters/index.d.ts.map +0 -1
- package/dist/filters/pipeline.d.ts +0 -11
- package/dist/filters/pipeline.d.ts.map +0 -1
- package/dist/filters/private.filter.d.ts +0 -7
- package/dist/filters/private.filter.d.ts.map +0 -1
- package/dist/filters/scripts.filter.d.ts +0 -7
- package/dist/filters/scripts.filter.d.ts.map +0 -1
- package/dist/git.d.ts +0 -16
- package/dist/git.d.ts.map +0 -1
- package/dist/main.d.ts +0 -1
- package/dist/main.d.ts.map +0 -1
- package/dist/middlewares/global-config.d.ts +0 -5
- package/dist/middlewares/global-config.d.ts.map +0 -1
- package/dist/middlewares/index.d.ts +0 -4
- package/dist/middlewares/index.d.ts.map +0 -1
- package/dist/middlewares/load-project.d.ts +0 -6
- package/dist/middlewares/load-project.d.ts.map +0 -1
- package/dist/middlewares/load-workspace.d.ts +0 -3
- package/dist/middlewares/load-workspace.d.ts.map +0 -1
- package/dist/middlewares/setup-ink.d.ts +0 -1
- package/dist/middlewares/setup-ink.d.ts.map +0 -1
- package/dist/project/index.d.ts +0 -2
- package/dist/project/index.d.ts.map +0 -1
- package/dist/project/project.d.ts +0 -25
- package/dist/project/project.d.ts.map +0 -1
- package/dist/project/workspace.d.ts +0 -34
- package/dist/project/workspace.d.ts.map +0 -1
- package/dist/services/index.d.ts +0 -4
- package/dist/services/index.d.ts.map +0 -1
- package/dist/services/inversify.config.d.ts +0 -11
- package/dist/services/inversify.config.d.ts.map +0 -1
- package/dist/services/logger.service.d.ts +0 -6
- package/dist/services/logger.service.d.ts.map +0 -1
- package/dist/services/spinner.service.d.ts +0 -16
- package/dist/services/spinner.service.d.ts.map +0 -1
- package/dist/services/task-manager.service.d.ts +0 -1
- package/dist/services/task-manager.service.d.ts.map +0 -1
- package/dist/types.d.ts +0 -1
- package/dist/types.d.ts.map +0 -1
- package/dist/ui/global-spinner.d.ts +0 -2
- package/dist/ui/global-spinner.d.ts.map +0 -1
- package/dist/ui/index.d.ts +0 -8
- package/dist/ui/index.d.ts.map +0 -1
- package/dist/ui/layout.d.ts +0 -2
- package/dist/ui/layout.d.ts.map +0 -1
- package/dist/ui/list.d.ts +0 -6
- package/dist/ui/list.d.ts.map +0 -1
- package/dist/ui/static-logs.d.ts +0 -2
- package/dist/ui/static-logs.d.ts.map +0 -1
- package/dist/ui/task-name.d.ts +0 -6
- package/dist/ui/task-name.d.ts.map +0 -1
- package/dist/ui/task-spinner.d.ts +0 -6
- package/dist/ui/task-spinner.d.ts.map +0 -1
- package/dist/ui/tasks-spinner.d.ts +0 -6
- package/dist/ui/tasks-spinner.d.ts.map +0 -1
- package/dist/ui/workspace-tree.d.ts +0 -8
- package/dist/ui/workspace-tree.d.ts.map +0 -1
- package/dist/utils/index.d.ts +0 -3
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/streams.d.ts +0 -3
- package/dist/utils/streams.d.ts.map +0 -1
- package/dist/utils/string.d.ts +0 -1
- package/dist/utils/string.d.ts.map +0 -1
- package/dist/utils/yargs.d.ts +0 -9
- package/dist/utils/yargs.d.ts.map +0 -1
package/dist/commands/each.js
CHANGED
|
@@ -11,12 +11,12 @@ const _jsxRuntime = require("react/jsx-runtime");
|
|
|
11
11
|
const _eventTree = require("@jujulego/event-tree");
|
|
12
12
|
const _tasks = require("@jujulego/tasks");
|
|
13
13
|
const _yargs = /*#__PURE__*/ _interopRequireDefault(require("yargs"));
|
|
14
|
-
const _filters = require("../filters");
|
|
15
|
-
const _middlewares = require("../middlewares");
|
|
16
|
-
const _project = require("../project");
|
|
17
|
-
const _services = require("../services");
|
|
18
|
-
const _ui = require("../ui");
|
|
19
|
-
const _utils = require("../utils");
|
|
14
|
+
const _filters = require("../filters/index");
|
|
15
|
+
const _middlewares = require("../middlewares/index");
|
|
16
|
+
const _project = require("../project/index");
|
|
17
|
+
const _services = require("../services/index");
|
|
18
|
+
const _ui = require("../ui/index");
|
|
19
|
+
const _utils = require("../utils/index");
|
|
20
20
|
function _interopRequireDefault(obj) {
|
|
21
21
|
return obj && obj.__esModule ? obj : {
|
|
22
22
|
default: obj
|
|
@@ -115,4 +115,4 @@ const _default = (0, _utils.defineCommand)({
|
|
|
115
115
|
}
|
|
116
116
|
});
|
|
117
117
|
|
|
118
|
-
//# sourceMappingURL=each.js.map
|
|
118
|
+
//# sourceMappingURL=each.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["commands/each.
|
|
1
|
+
{"version":3,"sources":["../../src/commands/each.tsx"],"sourcesContent":["import { waitForEvent } from '@jujulego/event-tree';\nimport { TaskManager, TaskSet } from '@jujulego/tasks';\nimport ink from 'ink';\nimport yargs from 'yargs';\n\nimport { AffectedFilter, Pipeline, PrivateFilter, ScriptsFilter } from '../filters';\nimport { loadProject, setupInk } from '../middlewares';\nimport { Project, WorkspaceDepsMode } from '../project';\nimport { container, CURRENT, INK_APP, SpinnerService } from '../services';\nimport { Layout, TasksSpinner } from '../ui';\nimport { applyMiddlewares, defineCommand } from '../utils';\n\n// Command\nexport default defineCommand({\n command: 'each <script>',\n describe: 'Run script on many workspaces',\n builder: (yargs) =>\n applyMiddlewares(yargs, [\n setupInk,\n loadProject,\n ])\n // Run options\n .positional('script', { type: 'string', demandOption: true })\n .option('deps-mode', {\n choice: ['all', 'prod', 'none'],\n default: 'all' as WorkspaceDepsMode,\n desc: 'Dependency selection mode:\\n' +\n ' - all = dependencies AND devDependencies\\n' +\n ' - prod = dependencies\\n' +\n ' - none = nothing'\n })\n\n // Filters\n .option('private', {\n type: 'boolean',\n group: 'Filters:',\n desc: 'Print only private workspaces',\n })\n\n // Affected filter\n .option('affected', {\n alias: 'a',\n type: 'string',\n coerce: (rev: string) => rev === '' ? 'master' : rev,\n group: 'Affected:',\n desc: 'Print only affected workspaces towards given git revision. If no revision is given, it will check towards master.\\n' +\n 'Replaces %name by workspace name.',\n })\n .option('affected-rev-sort', {\n type: 'string',\n group: 'Affected:',\n desc: 'Sort applied to git tag / git branch command',\n })\n .option('affected-rev-fallback', {\n type: 'string',\n default: 'master',\n group: 'Affected:',\n desc: 'Fallback revision, used if no revision matching the given format is found',\n }),\n async handler(args) {\n const app = container.get<ink.Instance>(INK_APP);\n const project = container.getNamed(Project, CURRENT);\n const manager = container.get(TaskManager);\n const spinner = container.get(SpinnerService);\n\n try {\n spinner.spin('Loading workspaces ...');\n\n // Setup pipeline\n const pipeline = new Pipeline();\n pipeline.add(new ScriptsFilter([args.script]));\n\n if (args.private !== undefined) {\n pipeline.add(new PrivateFilter(args.private));\n }\n\n if (args.affected !== undefined) {\n pipeline.add(new AffectedFilter(\n args.affected,\n args.affectedRevFallback,\n args.affectedRevSort\n ));\n }\n\n // Extract arguments\n const rest = args._.map(arg => arg.toString());\n\n if (rest[0] === 'each') {\n rest.splice(0, 1);\n }\n\n // Create script tasks\n const tasks = new TaskSet(manager);\n\n for await (const wks of pipeline.filter(project.workspaces())) {\n tasks.add(await wks.run(args.script, rest, {\n buildDeps: args.depsMode,\n }));\n }\n\n if (tasks.tasks.length === 0) {\n spinner.failed('No workspace found !');\n return yargs.exit(1, new Error('No workspace found !'));\n }\n\n spinner.stop();\n\n // Render\n app.rerender(\n <Layout>\n <TasksSpinner manager={manager} />\n </Layout>\n );\n\n // Start and wait for result\n tasks.start();\n\n const result = await waitForEvent(tasks, 'finished');\n\n if (result.failed > 0) {\n return yargs.exit(1, new Error(`${result.failed} tasks failed !`));\n }\n } finally {\n spinner.stop();\n }\n }\n});\n"],"names":["defineCommand","command","describe","builder","yargs","applyMiddlewares","setupInk","loadProject","positional","type","demandOption","option","choice","default","desc","group","alias","coerce","rev","handler","args","app","container","get","INK_APP","project","getNamed","Project","CURRENT","manager","TaskManager","spinner","SpinnerService","spin","pipeline","Pipeline","add","ScriptsFilter","script","private","undefined","PrivateFilter","affected","AffectedFilter","affectedRevFallback","affectedRevSort","rest","_","map","arg","toString","splice","tasks","TaskSet","wks","filter","workspaces","run","buildDeps","depsMode","length","failed","exit","Error","stop","rerender","Layout","TasksSpinner","start","result","waitForEvent"],"mappings":"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"}
|
package/dist/commands/list.js
CHANGED
|
@@ -11,12 +11,12 @@ const _jsxRuntime = require("react/jsx-runtime");
|
|
|
11
11
|
const _chalk = /*#__PURE__*/ _interopRequireDefault(require("chalk"));
|
|
12
12
|
const _nodePath = /*#__PURE__*/ _interopRequireDefault(require("node:path"));
|
|
13
13
|
const _slugify = /*#__PURE__*/ _interopRequireDefault(require("slugify"));
|
|
14
|
-
const _filters = require("../filters");
|
|
15
|
-
const _middlewares = require("../middlewares");
|
|
16
|
-
const _project = require("../project");
|
|
17
|
-
const _services = require("../services");
|
|
18
|
-
const _ui = require("../ui");
|
|
19
|
-
const _utils = require("../utils");
|
|
14
|
+
const _filters = require("../filters/index");
|
|
15
|
+
const _middlewares = require("../middlewares/index");
|
|
16
|
+
const _project = require("../project/index");
|
|
17
|
+
const _services = require("../services/index");
|
|
18
|
+
const _ui = require("../ui/index");
|
|
19
|
+
const _utils = require("../utils/index");
|
|
20
20
|
function _interopRequireDefault(obj) {
|
|
21
21
|
return obj && obj.__esModule ? obj : {
|
|
22
22
|
default: obj
|
|
@@ -154,7 +154,7 @@ const _default = (0, _utils.defineCommand)({
|
|
|
154
154
|
const app = _services.container.get(_services.INK_APP);
|
|
155
155
|
for (const d of data){
|
|
156
156
|
if (d.root) {
|
|
157
|
-
d.root = _nodePath.default.relative(process.cwd(), d.root)
|
|
157
|
+
d.root = _nodePath.default.relative(process.cwd(), d.root) || '.';
|
|
158
158
|
}
|
|
159
159
|
}
|
|
160
160
|
app.rerender(/*#__PURE__*/ (0, _jsxRuntime.jsx)(_ui.Layout, {
|
|
@@ -167,4 +167,4 @@ const _default = (0, _utils.defineCommand)({
|
|
|
167
167
|
}
|
|
168
168
|
});
|
|
169
169
|
|
|
170
|
-
//# sourceMappingURL=list.js.map
|
|
170
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["commands/list.
|
|
1
|
+
{"version":3,"sources":["../../src/commands/list.tsx"],"sourcesContent":["import chalk from 'chalk';\nimport path from 'node:path';\nimport ink from 'ink';\nimport slugify from 'slugify';\n\nimport { AffectedFilter, Pipeline, PrivateFilter, ScriptsFilter } from '../filters';\nimport { loadProject, setupInk } from '../middlewares';\nimport { Project, Workspace } from '../project';\nimport { container, CURRENT, INK_APP } from '../services';\nimport { Layout, List } from '../ui';\nimport { applyMiddlewares, defineCommand } from '../utils';\n\n// Types\nexport type Attribute = 'name' | 'version' | 'root' | 'slug';\nexport type Data = Partial<Record<Attribute, string>>;\n\ntype Extractor<T> = (wks: Workspace, json: boolean) => T;\n\n// Constants\nconst LONG_ATTRIBUTES: Attribute[] = ['name', 'version', 'root'];\nconst JSON_ATTRIBUTES: Attribute[] = ['name', 'version', 'slug', 'root'];\nconst DEFAULT_ATTRIBUTES: Attribute[] = ['name'];\n\nconst EXTRACTORS: Record<Attribute, Extractor<string | undefined>> = {\n name: wks => wks.name,\n version: (wks, json) => wks.manifest.version || (json ? undefined : chalk.grey('unset')),\n root: wks => wks.cwd,\n slug: wks => slugify(wks.name)\n};\n\n// Utils\nfunction buildExtractor(attrs: Attribute[]): Extractor<Data> {\n return (wks, json: boolean) => {\n const data: Data = {};\n\n for (const attr of attrs) {\n data[attr] = EXTRACTORS[attr](wks, json);\n }\n\n return data;\n };\n}\n\n// Command\nexport default defineCommand({\n command: ['list', 'ls'],\n describe: 'List workspaces',\n builder: (yargs) =>\n applyMiddlewares(yargs, [\n setupInk,\n loadProject,\n ])\n // Filters\n .option('private', {\n type: 'boolean',\n group: 'Filters:',\n desc: 'Print only private workspaces',\n })\n .option('with-script', {\n type: 'array',\n string: true,\n group: 'Filters:',\n desc: 'Print only workspaces having the given script',\n })\n\n // Affected filter\n .option('affected', {\n alias: 'a',\n type: 'string',\n coerce: (rev: string) => rev === '' ? 'master' : rev,\n group: 'Affected:',\n desc: 'Print only affected workspaces towards given git revision. If no revision is given, it will check towards master.\\n' +\n 'Replaces %name by workspace name.',\n })\n .option('affected-rev-sort', {\n type: 'string',\n group: 'Affected:',\n desc: 'Sort applied to git tag / git branch command',\n })\n .option('affected-rev-fallback', {\n type: 'string',\n default: 'master',\n group: 'Affected:',\n desc: 'Fallback revision, used if no revision matching the given format is found',\n })\n .option('attrs', {\n type: 'array',\n choices: ['name', 'version', 'root', 'slug'],\n default: [] as Attribute[],\n group: 'Format:',\n desc: 'Select printed attributes'\n })\n .option('headers', {\n type: 'boolean',\n group: 'Format:',\n desc: 'Prints columns headers'\n })\n .option('long', {\n alias: 'l',\n type: 'boolean',\n group: 'Format:',\n desc: 'Prints name, version and root of all workspaces',\n })\n .option('json', {\n type: 'boolean',\n group: 'Format:',\n desc: 'Prints data as a JSON array',\n }),\n async handler(args) {\n // Setup pipeline\n const pipeline = new Pipeline();\n\n if (args.private !== undefined) {\n pipeline.add(new PrivateFilter(args.private));\n }\n\n if (args.withScript) {\n pipeline.add(new ScriptsFilter(args.withScript));\n }\n\n if (args.affected !== undefined) {\n pipeline.add(new AffectedFilter(\n args.affected,\n args.affectedRevFallback,\n args.affectedRevSort\n ));\n }\n\n // Load workspaces\n const project = container.getNamed(Project, CURRENT);\n const workspaces: Workspace[] = [];\n\n for await (const wks of pipeline.filter(project.workspaces())) {\n workspaces.push(wks);\n }\n\n // Build data\n let attrs = args.attrs;\n\n if (args.attrs.length === 0) {\n if (args.long) {\n attrs = LONG_ATTRIBUTES;\n } else if (args.json) {\n attrs = JSON_ATTRIBUTES;\n } else {\n attrs = DEFAULT_ATTRIBUTES;\n }\n }\n\n const data = workspaces.map(wks => buildExtractor(attrs)(wks, args.json || false));\n\n // Print list\n if (args.json) {\n if (process.stdout.isTTY) { // Pretty print for ttys\n console.log(JSON.stringify(data, null, 2));\n } else {\n process.stdout.write(JSON.stringify(data));\n }\n } else {\n const app = container.get<ink.Instance>(INK_APP);\n\n for (const d of data) {\n if (d.root) {\n d.root = path.relative(process.cwd(), d.root) || '.';\n }\n }\n\n app.rerender(\n <Layout>\n <List items={data} headers={args.headers ?? (attrs.length > 1)} />\n </Layout>\n );\n }\n }\n});\n"],"names":["LONG_ATTRIBUTES","JSON_ATTRIBUTES","DEFAULT_ATTRIBUTES","EXTRACTORS","name","wks","version","json","manifest","undefined","chalk","grey","root","cwd","slug","slugify","buildExtractor","attrs","data","attr","defineCommand","command","describe","builder","yargs","applyMiddlewares","setupInk","loadProject","option","type","group","desc","string","alias","coerce","rev","default","choices","handler","args","pipeline","Pipeline","private","add","PrivateFilter","withScript","ScriptsFilter","affected","AffectedFilter","affectedRevFallback","affectedRevSort","project","container","getNamed","Project","CURRENT","workspaces","filter","push","length","long","map","process","stdout","isTTY","console","log","JSON","stringify","write","app","get","INK_APP","d","path","relative","rerender","Layout","List","items","headers"],"mappings":"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"}
|
package/dist/commands/run.js
CHANGED
|
@@ -11,11 +11,11 @@ const _jsxRuntime = require("react/jsx-runtime");
|
|
|
11
11
|
const _eventTree = require("@jujulego/event-tree");
|
|
12
12
|
const _tasks = require("@jujulego/tasks");
|
|
13
13
|
const _yargs = /*#__PURE__*/ _interopRequireDefault(require("yargs"));
|
|
14
|
-
const _middlewares = require("../middlewares");
|
|
15
|
-
const _project = require("../project");
|
|
16
|
-
const _services = require("../services");
|
|
17
|
-
const _ui = require("../ui");
|
|
18
|
-
const _utils = require("../utils");
|
|
14
|
+
const _middlewares = require("../middlewares/index");
|
|
15
|
+
const _project = require("../project/index");
|
|
16
|
+
const _services = require("../services/index");
|
|
17
|
+
const _ui = require("../ui/index");
|
|
18
|
+
const _utils = require("../utils/index");
|
|
19
19
|
function _interopRequireDefault(obj) {
|
|
20
20
|
return obj && obj.__esModule ? obj : {
|
|
21
21
|
default: obj
|
|
@@ -68,4 +68,4 @@ const _default = (0, _utils.defineCommand)({
|
|
|
68
68
|
}
|
|
69
69
|
});
|
|
70
70
|
|
|
71
|
-
//# sourceMappingURL=run.js.map
|
|
71
|
+
//# sourceMappingURL=run.js.map
|
package/dist/commands/run.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["commands/run.
|
|
1
|
+
{"version":3,"sources":["../../src/commands/run.tsx"],"sourcesContent":["import { waitForEvent } from '@jujulego/event-tree';\nimport { TaskManager } from '@jujulego/tasks';\nimport ink from 'ink';\nimport yargs from 'yargs';\n\nimport { loadProject, loadWorkspace, setupInk } from '../middlewares';\nimport { Workspace, WorkspaceDepsMode } from '../project';\nimport { container, CURRENT, INK_APP } from '../services';\nimport { Layout, TasksSpinner } from '../ui';\nimport { applyMiddlewares, defineCommand } from '../utils';\n\n// Command\nexport default defineCommand({\n command: 'run <script>',\n describe: 'Run script inside workspace',\n builder: (yargs) =>\n applyMiddlewares(yargs, [\n setupInk,\n loadProject,\n loadWorkspace\n ])\n .positional('script', { type: 'string', demandOption: true })\n .option('deps-mode', {\n choice: ['all', 'prod', 'none'],\n default: 'all' as WorkspaceDepsMode,\n desc: 'Dependency selection mode:\\n' +\n ' - all = dependencies AND devDependencies\\n' +\n ' - prod = dependencies\\n' +\n ' - none = nothing'\n }),\n async handler(args) {\n const app = container.get<ink.Instance>(INK_APP);\n const workspace = container.getNamed(Workspace, CURRENT);\n const manager = container.get(TaskManager);\n\n // Extract arguments\n const rest = args._.map(arg => arg.toString());\n\n if (rest[0] === 'run') {\n rest.splice(0, 1);\n }\n\n // Run script in workspace\n const task = await workspace.run(args.script, rest, {\n buildDeps: args.depsMode,\n });\n manager.add(task);\n\n // Render\n app.rerender(\n <Layout>\n <TasksSpinner manager={manager} />\n </Layout>\n );\n\n // Wait for result\n const result = await waitForEvent(task, 'completed');\n\n if (result.status === 'failed') {\n return yargs.exit(1, new Error('Task failed !'));\n }\n }\n});\n"],"names":["defineCommand","command","describe","builder","yargs","applyMiddlewares","setupInk","loadProject","loadWorkspace","positional","type","demandOption","option","choice","default","desc","handler","args","app","container","get","INK_APP","workspace","getNamed","Workspace","CURRENT","manager","TaskManager","rest","_","map","arg","toString","splice","task","run","script","buildDeps","depsMode","add","rerender","Layout","TasksSpinner","result","waitForEvent","status","exit","Error"],"mappings":"AAAA;;;;+BAWA,UAAU;AACV;;aAAA;;;2BAZ6B;uBACD;4DAEV;6BAEmC;yBACR;0BACD;oBACP;uBACW;;;;;;MAGhD,WAAeA,IAAAA,oBAAa,EAAC;IAC3BC,SAAS;IACTC,UAAU;IACVC,SAAS,CAACC,QACRC,IAAAA,uBAAgB,EAACD,OAAO;YACtBE,qBAAQ;YACRC,wBAAW;YACXC,0BAAa;SACd,EACEC,UAAU,CAAC,UAAU;YAAEC,MAAM;YAAUC,cAAc,IAAI;QAAC,GAC1DC,MAAM,CAAC,aAAa;YACnBC,QAAQ;gBAAC;gBAAO;gBAAQ;aAAO;YAC/BC,SAAS;YACTC,MAAM,iCACJ,gDACA,6BACA;QACJ;IACJ,MAAMC,SAAQC,IAAI,EAAE;QAClB,MAAMC,MAAMC,mBAAS,CAACC,GAAG,CAAeC,iBAAO;QAC/C,MAAMC,YAAYH,mBAAS,CAACI,QAAQ,CAACC,kBAAS,EAAEC,iBAAO;QACvD,MAAMC,UAAUP,mBAAS,CAACC,GAAG,CAACO,kBAAW;QAEzC,oBAAoB;QACpB,MAAMC,OAAOX,KAAKY,CAAC,CAACC,GAAG,CAACC,CAAAA,MAAOA,IAAIC,QAAQ;QAE3C,IAAIJ,IAAI,CAAC,EAAE,KAAK,OAAO;YACrBA,KAAKK,MAAM,CAAC,GAAG;QACjB,CAAC;QAED,0BAA0B;QAC1B,MAAMC,OAAO,MAAMZ,UAAUa,GAAG,CAAClB,KAAKmB,MAAM,EAAER,MAAM;YAClDS,WAAWpB,KAAKqB,QAAQ;QAC1B;QACAZ,QAAQa,GAAG,CAACL;QAEZ,SAAS;QACThB,IAAIsB,QAAQ,eACV,qBAACC,UAAM;sBACL,cAAA,qBAACC,gBAAY;gBAAChB,SAASA;;;QAI3B,kBAAkB;QAClB,MAAMiB,SAAS,MAAMC,IAAAA,uBAAY,EAACV,MAAM;QAExC,IAAIS,OAAOE,MAAM,KAAK,UAAU;YAC9B,OAAOzC,cAAK,CAAC0C,IAAI,CAAC,GAAG,IAAIC,MAAM;QACjC,CAAC;IACH;AACF"}
|
package/dist/commands/tree.js
CHANGED
|
@@ -8,11 +8,11 @@ Object.defineProperty(exports, // Command
|
|
|
8
8
|
get: ()=>_default
|
|
9
9
|
});
|
|
10
10
|
const _jsxRuntime = require("react/jsx-runtime");
|
|
11
|
-
const _middlewares = require("../middlewares");
|
|
12
|
-
const _project = require("../project");
|
|
13
|
-
const _services = require("../services");
|
|
14
|
-
const _ui = require("../ui");
|
|
15
|
-
const _utils = require("../utils");
|
|
11
|
+
const _middlewares = require("../middlewares/index");
|
|
12
|
+
const _project = require("../project/index");
|
|
13
|
+
const _services = require("../services/index");
|
|
14
|
+
const _ui = require("../ui/index");
|
|
15
|
+
const _utils = require("../utils/index");
|
|
16
16
|
const _default = (0, _utils.defineCommand)({
|
|
17
17
|
command: 'tree',
|
|
18
18
|
describe: 'Print workspace dependency tree',
|
|
@@ -32,4 +32,4 @@ const _default = (0, _utils.defineCommand)({
|
|
|
32
32
|
}
|
|
33
33
|
});
|
|
34
34
|
|
|
35
|
-
//# sourceMappingURL=tree.js.map
|
|
35
|
+
//# sourceMappingURL=tree.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["commands/tree.
|
|
1
|
+
{"version":3,"sources":["../../src/commands/tree.tsx"],"sourcesContent":["import ink from 'ink';\n\nimport { loadProject, loadWorkspace, setupInk } from '../middlewares';\nimport { Workspace } from '../project';\nimport { container, CURRENT, INK_APP } from '../services';\nimport { Layout, WorkspaceTree } from '../ui';\nimport { applyMiddlewares, defineCommand } from '../utils';\n\n// Command\nexport default defineCommand({\n command: 'tree',\n describe: 'Print workspace dependency tree',\n builder: (yargs) =>\n applyMiddlewares(yargs, [\n setupInk,\n loadProject,\n loadWorkspace\n ]),\n handler: () => {\n const app = container.get<ink.Instance>(INK_APP);\n const workspace = container.getNamed(Workspace, CURRENT);\n\n app.rerender(\n <Layout>\n <WorkspaceTree workspace={workspace} />\n </Layout>\n );\n }\n});\n"],"names":["defineCommand","command","describe","builder","yargs","applyMiddlewares","setupInk","loadProject","loadWorkspace","handler","app","container","get","INK_APP","workspace","getNamed","Workspace","CURRENT","rerender","Layout","WorkspaceTree"],"mappings":"AAAA;;;;+BAQA,UAAU;AACV;;aAAA;;;6BAPqD;yBAC3B;0BACkB;oBACN;uBACU;MAGhD,WAAeA,IAAAA,oBAAa,EAAC;IAC3BC,SAAS;IACTC,UAAU;IACVC,SAAS,CAACC,QACRC,IAAAA,uBAAgB,EAACD,OAAO;YACtBE,qBAAQ;YACRC,wBAAW;YACXC,0BAAa;SACd;IACHC,SAAS,IAAM;QACb,MAAMC,MAAMC,mBAAS,CAACC,GAAG,CAAeC,iBAAO;QAC/C,MAAMC,YAAYH,mBAAS,CAACI,QAAQ,CAACC,kBAAS,EAAEC,iBAAO;QAEvDP,IAAIQ,QAAQ,eACV,qBAACC,UAAM;sBACL,cAAA,qBAACC,iBAAa;gBAACN,WAAWA;;;IAGhC;AACF"}
|
|
@@ -7,7 +7,7 @@ Object.defineProperty(exports, "AffectedFilter", {
|
|
|
7
7
|
get: ()=>AffectedFilter
|
|
8
8
|
});
|
|
9
9
|
const _git = require("../git");
|
|
10
|
-
const _services = require("../services");
|
|
10
|
+
const _services = require("../services/index");
|
|
11
11
|
var __decorate = (void 0) && (void 0).__decorate || function(decorators, target, key, desc) {
|
|
12
12
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
13
13
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -79,4 +79,4 @@ __decorate([
|
|
|
79
79
|
(0, _services.lazyInject)(_services.Logger)
|
|
80
80
|
], AffectedFilter.prototype, "_logger", void 0);
|
|
81
81
|
|
|
82
|
-
//# sourceMappingURL=affected.filter.js.map
|
|
82
|
+
//# sourceMappingURL=affected.filter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["filters/affected.filter.
|
|
1
|
+
{"version":3,"sources":["../../src/filters/affected.filter.ts"],"sourcesContent":["import { Git } from '../git';\nimport { lazyInject, Logger } from '../services';\nimport { Workspace } from '../project';\n\nimport { PipelineFilter } from './pipeline';\n\n// Class\nexport class AffectedFilter implements PipelineFilter {\n // Properties\n @lazyInject(Logger)\n private readonly _logger: Logger;\n\n // Constructor\n constructor(\n readonly format: string,\n readonly fallback: string,\n readonly sort?: string,\n ) {}\n\n // Methods\n private async _formatRevision(wks: Workspace): Promise<string> {\n const logger = this._logger.child({ label: wks.name });\n\n // Format revision\n let result = this.format;\n result = result.replace(/(?<!\\\\)((?:\\\\\\\\)*)%name/g, `$1${wks.name}`);\n result = result.replace(/\\\\(.)/g, '$1');\n\n // Ask git to complete it\n const sortArgs = this.sort ? ['--sort', this.sort] : [];\n\n // - search in branches\n if (result.includes('*')) {\n const branches = await Git.listBranches([...sortArgs, result], { cwd: wks.cwd, logger: logger });\n\n if (branches.length > 0) {\n result = branches[branches.length - 1];\n }\n }\n\n // - search in tags\n if (result.includes('*')) {\n const tags = await Git.listTags([...sortArgs, result], { cwd: wks.cwd, logger: logger });\n\n if (tags.length > 0) {\n result = tags[tags.length - 1];\n }\n }\n\n if (result !== this.format) {\n logger.verbose(`Resolved ${this.format} into ${result}`);\n }\n\n if (result.includes('*')) {\n logger.warn(`No revision found matching ${result}, using fallback ${this.fallback}`);\n\n return this.fallback;\n }\n\n return result;\n }\n\n async test(workspace: Workspace): Promise<boolean> {\n const rev = await this._formatRevision(workspace);\n return await workspace.isAffected(rev);\n }\n}\n"],"names":["AffectedFilter","constructor","format","fallback","sort","_formatRevision","wks","logger","_logger","child","label","name","result","replace","sortArgs","includes","branches","Git","listBranches","cwd","length","tags","listTags","verbose","warn","test","workspace","rev","isAffected","lazyInject","Logger"],"mappings":"AAAA;;;;+BAOaA;;aAAAA;;qBAPO;0BACe;;;;;;;AAM5B,MAAMA;IAKX,cAAc;IACdC,YACWC,QACAC,UACAC,KACT;sBAHSF;wBACAC;oBACAC;IACR;IAEH,UAAU;IACV,MAAcC,gBAAgBC,GAAc,EAAmB;QAC7D,MAAMC,SAAS,IAAI,CAACC,OAAO,CAACC,KAAK,CAAC;YAAEC,OAAOJ,IAAIK,IAAI;QAAC;QAEpD,kBAAkB;QAClB,IAAIC,SAAS,IAAI,CAACV,MAAM;QACxBU,SAASA,OAAOC,OAAO,CAAC,4BAA4B,CAAC,EAAE,EAAEP,IAAIK,IAAI,CAAC,CAAC;QACnEC,SAASA,OAAOC,OAAO,CAAC,UAAU;QAElC,yBAAyB;QACzB,MAAMC,WAAW,IAAI,CAACV,IAAI,GAAG;YAAC;YAAU,IAAI,CAACA,IAAI;SAAC,GAAG,EAAE;QAEvD,uBAAuB;QACvB,IAAIQ,OAAOG,QAAQ,CAAC,MAAM;YACxB,MAAMC,WAAW,MAAMC,QAAG,CAACC,YAAY,CAAC;mBAAIJ;gBAAUF;aAAO,EAAE;gBAAEO,KAAKb,IAAIa,GAAG;gBAAEZ,QAAQA;YAAO;YAE9F,IAAIS,SAASI,MAAM,GAAG,GAAG;gBACvBR,SAASI,QAAQ,CAACA,SAASI,MAAM,GAAG,EAAE;YACxC,CAAC;QACH,CAAC;QAED,mBAAmB;QACnB,IAAIR,OAAOG,QAAQ,CAAC,MAAM;YACxB,MAAMM,OAAO,MAAMJ,QAAG,CAACK,QAAQ,CAAC;mBAAIR;gBAAUF;aAAO,EAAE;gBAAEO,KAAKb,IAAIa,GAAG;gBAAEZ,QAAQA;YAAO;YAEtF,IAAIc,KAAKD,MAAM,GAAG,GAAG;gBACnBR,SAASS,IAAI,CAACA,KAAKD,MAAM,GAAG,EAAE;YAChC,CAAC;QACH,CAAC;QAED,IAAIR,WAAW,IAAI,CAACV,MAAM,EAAE;YAC1BK,OAAOgB,OAAO,CAAC,CAAC,SAAS,EAAE,IAAI,CAACrB,MAAM,CAAC,MAAM,EAAEU,OAAO,CAAC;QACzD,CAAC;QAED,IAAIA,OAAOG,QAAQ,CAAC,MAAM;YACxBR,OAAOiB,IAAI,CAAC,CAAC,2BAA2B,EAAEZ,OAAO,iBAAiB,EAAE,IAAI,CAACT,QAAQ,CAAC,CAAC;YAEnF,OAAO,IAAI,CAACA,QAAQ;QACtB,CAAC;QAED,OAAOS;IACT;IAEA,MAAMa,KAAKC,SAAoB,EAAoB;QACjD,MAAMC,MAAM,MAAM,IAAI,CAACtB,eAAe,CAACqB;QACvC,OAAO,MAAMA,UAAUE,UAAU,CAACD;IACpC;AACF;;IAzDGE,IAAAA,oBAAU,EAACC,gBAAM;GAFP9B"}
|
package/dist/filters/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["filters/index.
|
|
1
|
+
{"version":3,"sources":["../../src/filters/index.ts"],"sourcesContent":["export * from './affected.filter';\nexport * from './pipeline';\nexport * from './private.filter';\nexport * from './scripts.filter';\n"],"names":[],"mappings":"AAAA;;;;oBAAc;oBACA;oBACA;oBACA"}
|
package/dist/filters/pipeline.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["filters/pipeline.
|
|
1
|
+
{"version":3,"sources":["../../src/filters/pipeline.ts"],"sourcesContent":["import { Workspace } from '../project';\nimport { Awaitable } from '../types';\n\n// Interface\nexport interface PipelineFilter {\n // Methods\n test(workspace: Workspace): Awaitable<boolean>;\n}\n\n// Class\nexport class Pipeline {\n // Attributes\n private _filters: PipelineFilter[] = [];\n\n // Methods\n add(filter: PipelineFilter): void {\n this._filters.push(filter);\n }\n\n private async _test(workspace: Workspace): Promise<boolean> {\n for (const filter of this._filters) {\n const res = await filter.test(workspace);\n\n if (!res) {\n return false;\n }\n }\n\n return true;\n }\n\n async *filter(workspaces: Iterable<Workspace> | AsyncIterable<Workspace>): AsyncGenerator<Workspace> {\n for await (const wks of workspaces) {\n if (await this._test(wks)) {\n yield wks;\n }\n }\n }\n}\n"],"names":["Pipeline","_filters","add","filter","push","_test","workspace","res","test","workspaces","wks"],"mappings":"AAAA;;;;+BAUaA;;aAAAA;;AAAN,MAAMA;IACX,aAAa;IACLC,WAA6B,EAAE,CAAC;IAExC,UAAU;IACVC,IAAIC,MAAsB,EAAQ;QAChC,IAAI,CAACF,QAAQ,CAACG,IAAI,CAACD;IACrB;IAEA,MAAcE,MAAMC,SAAoB,EAAoB;QAC1D,KAAK,MAAMH,UAAU,IAAI,CAACF,QAAQ,CAAE;YAClC,MAAMM,MAAM,MAAMJ,OAAOK,IAAI,CAACF;YAE9B,IAAI,CAACC,KAAK;gBACR,OAAO,KAAK;YACd,CAAC;QACH;QAEA,OAAO,IAAI;IACb;IAEA,OAAOJ,OAAOM,UAA0D,EAA6B;QACnG,WAAW,MAAMC,OAAOD,WAAY;YAClC,IAAI,MAAM,IAAI,CAACJ,KAAK,CAACK,MAAM;gBACzB,MAAMA;YACR,CAAC;QACH;IACF;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["filters/private.filter.
|
|
1
|
+
{"version":3,"sources":["../../src/filters/private.filter.ts"],"sourcesContent":["import { Workspace } from '../project';\n\nimport { PipelineFilter } from './pipeline';\n\n// Filter\nexport class PrivateFilter implements PipelineFilter {\n // Constructor\n constructor(readonly value: boolean) {}\n\n // Methods\n test(workspace: Workspace): boolean {\n return (workspace.manifest.private ?? false) === this.value;\n }\n}\n"],"names":["PrivateFilter","constructor","value","test","workspace","manifest","private"],"mappings":"AAAA;;;;+BAKaA;;aAAAA;;AAAN,MAAMA;IACX,cAAc;IACdC,YAAqBC,MAAgB;qBAAhBA;IAAiB;IAEtC,UAAU;IACVC,KAAKC,SAAoB,EAAW;QAClC,OAAO,AAACA,CAAAA,UAAUC,QAAQ,CAACC,OAAO,IAAI,KAAK,AAAD,MAAO,IAAI,CAACJ,KAAK;IAC7D;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["filters/scripts.filter.
|
|
1
|
+
{"version":3,"sources":["../../src/filters/scripts.filter.ts"],"sourcesContent":["import { Workspace } from '../project';\n\nimport { PipelineFilter } from './pipeline';\n\n// Filter\nexport class ScriptsFilter implements PipelineFilter {\n // Constructor\n constructor(readonly scripts: string[]) {}\n\n // Methods\n test(workspace: Workspace): boolean {\n const scripts = Object.keys(workspace.manifest.scripts || {});\n return this.scripts.some((scr) => scripts.includes(scr));\n }\n}\n"],"names":["ScriptsFilter","constructor","scripts","test","workspace","Object","keys","manifest","some","scr","includes"],"mappings":"AAAA;;;;+BAKaA;;aAAAA;;AAAN,MAAMA;IACX,cAAc;IACdC,YAAqBC,QAAmB;uBAAnBA;IAAoB;IAEzC,UAAU;IACVC,KAAKC,SAAoB,EAAW;QAClC,MAAMF,UAAUG,OAAOC,IAAI,CAACF,UAAUG,QAAQ,CAACL,OAAO,IAAI,CAAC;QAC3D,OAAO,IAAI,CAACA,OAAO,CAACM,IAAI,CAAC,CAACC,MAAQP,QAAQQ,QAAQ,CAACD;IACrD;AACF"}
|
package/dist/git.js
CHANGED
|
@@ -7,8 +7,8 @@ Object.defineProperty(exports, "Git", {
|
|
|
7
7
|
get: ()=>Git
|
|
8
8
|
});
|
|
9
9
|
const _tasks = require("@jujulego/tasks");
|
|
10
|
-
const _services = require("./services");
|
|
11
|
-
const _utils = require("./utils");
|
|
10
|
+
const _services = require("./services/index");
|
|
11
|
+
const _utils = require("./utils/index");
|
|
12
12
|
var __decorate = (void 0) && (void 0).__decorate || function(decorators, target, key, desc) {
|
|
13
13
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
14
14
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
@@ -91,4 +91,4 @@ __decorate([
|
|
|
91
91
|
(0, _services.lazyInject)(_services.Logger)
|
|
92
92
|
], Git, "logger", void 0);
|
|
93
93
|
|
|
94
|
-
//# sourceMappingURL=git.js.map
|
|
94
|
+
//# sourceMappingURL=git.js.map
|
package/dist/git.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["git.
|
|
1
|
+
{"version":3,"sources":["../src/git.ts"],"sourcesContent":["import { SpawnTask, SpawnTaskOptions, TaskContext, TaskManager } from '@jujulego/tasks';\n\nimport { lazyInject, Logger } from './services';\nimport { streamLines } from './utils';\n\n// Types\nexport interface GitContext extends TaskContext {\n command: string;\n}\n\n// Git commands\nexport class Git {\n // Services\n @lazyInject(TaskManager)\n static readonly manager: TaskManager;\n\n @lazyInject(Logger)\n static readonly logger: Logger;\n\n // commons\n static command(cmd: string, args: string[], options: SpawnTaskOptions = {}): SpawnTask<GitContext> {\n const opts = { logger: this.logger, ...options };\n\n // Create task\n const task = new SpawnTask('git', [cmd, ...args], { command: cmd }, opts);\n task.subscribe('stream', ({ data }) => opts.logger.debug(data.toString('utf-8')));\n\n this.manager.add(task);\n\n return task;\n }\n\n // commands\n static branch(args: string[], options?: SpawnTaskOptions): SpawnTask<GitContext> {\n return this.command('branch', args, options);\n }\n\n static diff(args: string[], options?: SpawnTaskOptions): SpawnTask<GitContext> {\n return this.command('diff', args, options);\n }\n\n static tag(args: string[], options?: SpawnTaskOptions): SpawnTask<GitContext> {\n return this.command('tag', args, options);\n }\n\n // high level\n static isAffected(reference: string, args: string[] = [], opts?: SpawnTaskOptions): Promise<boolean> {\n return new Promise((resolve, reject) => {\n const task = this.diff(['--quiet', reference, ...args], opts);\n\n task.subscribe('status.done', () => resolve(false));\n task.subscribe('status.failed', () => {\n if (task.exitCode) {\n resolve(true);\n } else {\n reject(new Error(`Task ${task.name} failed`));\n }\n });\n });\n }\n\n static async listBranches(args: string[] = [], opts?: SpawnTaskOptions): Promise<string[]> {\n const task = this.branch(['-l', ...args], opts);\n const result: string[] = [];\n\n for await (const line of streamLines(task, 'stdout')) {\n result.push(line.replace(/^[ *] /, ''));\n }\n\n return result;\n }\n\n static async listTags(args: string[] = [], opts?: SpawnTaskOptions): Promise<string[]> {\n const task = this.tag(['-l', ...args], opts);\n const result: string[] = [];\n\n for await (const line of streamLines(task, 'stdout')) {\n result.push(line);\n }\n\n return result;\n }\n}\n"],"names":["Git","command","cmd","args","options","opts","logger","task","SpawnTask","subscribe","data","debug","toString","manager","add","branch","diff","tag","isAffected","reference","Promise","resolve","reject","exitCode","Error","name","listBranches","result","line","streamLines","push","replace","listTags","lazyInject","TaskManager","Logger"],"mappings":"AAAA;;;;+BAWaA;;aAAAA;;uBAXyD;0BAEnC;uBACP;;;;;;;AAQrB,MAAMA;IAQX,UAAU;IACV,OAAOC,QAAQC,GAAW,EAAEC,IAAc,EAAEC,UAA4B,CAAC,CAAC,EAAyB;QACjG,MAAMC,OAAO;YAAEC,QAAQ,IAAI,CAACA,MAAM;YAAE,GAAGF,OAAO;QAAC;QAE/C,cAAc;QACd,MAAMG,OAAO,IAAIC,gBAAS,CAAC,OAAO;YAACN;eAAQC;SAAK,EAAE;YAAEF,SAASC;QAAI,GAAGG;QACpEE,KAAKE,SAAS,CAAC,UAAU,CAAC,EAAEC,KAAI,EAAE,GAAKL,KAAKC,MAAM,CAACK,KAAK,CAACD,KAAKE,QAAQ,CAAC;QAEvE,IAAI,CAACC,OAAO,CAACC,GAAG,CAACP;QAEjB,OAAOA;IACT;IAEA,WAAW;IACX,OAAOQ,OAAOZ,IAAc,EAAEC,OAA0B,EAAyB;QAC/E,OAAO,IAAI,CAACH,OAAO,CAAC,UAAUE,MAAMC;IACtC;IAEA,OAAOY,KAAKb,IAAc,EAAEC,OAA0B,EAAyB;QAC7E,OAAO,IAAI,CAACH,OAAO,CAAC,QAAQE,MAAMC;IACpC;IAEA,OAAOa,IAAId,IAAc,EAAEC,OAA0B,EAAyB;QAC5E,OAAO,IAAI,CAACH,OAAO,CAAC,OAAOE,MAAMC;IACnC;IAEA,aAAa;IACb,OAAOc,WAAWC,SAAiB,EAAEhB,OAAiB,EAAE,EAAEE,IAAuB,EAAoB;QACnG,OAAO,IAAIe,QAAQ,CAACC,SAASC,SAAW;YACtC,MAAMf,OAAO,IAAI,CAACS,IAAI,CAAC;gBAAC;gBAAWG;mBAAchB;aAAK,EAAEE;YAExDE,KAAKE,SAAS,CAAC,eAAe,IAAMY,QAAQ,KAAK;YACjDd,KAAKE,SAAS,CAAC,iBAAiB,IAAM;gBACpC,IAAIF,KAAKgB,QAAQ,EAAE;oBACjBF,QAAQ,IAAI;gBACd,OAAO;oBACLC,OAAO,IAAIE,MAAM,CAAC,KAAK,EAAEjB,KAAKkB,IAAI,CAAC,OAAO,CAAC;gBAC7C,CAAC;YACH;QACF;IACF;IAEA,aAAaC,aAAavB,OAAiB,EAAE,EAAEE,IAAuB,EAAqB;QACzF,MAAME,OAAO,IAAI,CAACQ,MAAM,CAAC;YAAC;eAASZ;SAAK,EAAEE;QAC1C,MAAMsB,SAAmB,EAAE;QAE3B,WAAW,MAAMC,QAAQC,IAAAA,kBAAW,EAACtB,MAAM,UAAW;YACpDoB,OAAOG,IAAI,CAACF,KAAKG,OAAO,CAAC,UAAU;QACrC;QAEA,OAAOJ;IACT;IAEA,aAAaK,SAAS7B,OAAiB,EAAE,EAAEE,IAAuB,EAAqB;QACrF,MAAME,OAAO,IAAI,CAACU,GAAG,CAAC;YAAC;eAASd;SAAK,EAAEE;QACvC,MAAMsB,SAAmB,EAAE;QAE3B,WAAW,MAAMC,QAAQC,IAAAA,kBAAW,EAACtB,MAAM,UAAW;YACpDoB,OAAOG,IAAI,CAACF;QACd;QAEA,OAAOD;IACT;AACF;;IArEGM,IAAAA,oBAAU,EAACC,kBAAW;GAFZlC;;IAKViC,IAAAA,oBAAU,EAACE,gBAAM;GALPnC"}
|
package/dist/main.js
CHANGED
|
@@ -5,8 +5,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
const _yargs = /*#__PURE__*/ _interopRequireDefault(require("yargs"));
|
|
6
6
|
const _helpers = require("yargs/helpers");
|
|
7
7
|
const _packageJson = /*#__PURE__*/ _interopRequireDefault(require("../package.json"));
|
|
8
|
-
const _middlewares = require("./middlewares");
|
|
9
|
-
const _utils = require("./utils");
|
|
8
|
+
const _middlewares = require("./middlewares/index");
|
|
9
|
+
const _utils = require("./utils/index");
|
|
10
10
|
function _interopRequireDefault(obj) {
|
|
11
11
|
return obj && obj.__esModule ? obj : {
|
|
12
12
|
default: obj
|
|
@@ -26,4 +26,4 @@ function _interopRequireDefault(obj) {
|
|
|
26
26
|
}).demandCommand().recommendCommands().strict().parse();
|
|
27
27
|
})();
|
|
28
28
|
|
|
29
|
-
//# sourceMappingURL=main.js.map
|
|
29
|
+
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["main.
|
|
1
|
+
{"version":3,"sources":["../src/main.ts"],"sourcesContent":["import yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport pkg from '../package.json';\nimport { globalConfig } from './middlewares';\nimport { applyMiddlewares } from './utils';\n\n// Bootstrap\n(async () => {\n // Setup yargs\n const parser = yargs(hideBin(process.argv))\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(yargs.terminalWidth());\n\n // Middlewares\n applyMiddlewares(parser, [globalConfig]);\n\n // Parse !\n await parser\n .commandDir('commands', {\n visit: obj => obj.default\n })\n .demandCommand()\n .recommendCommands()\n .strict()\n .parse();\n})();\n"],"names":["parser","yargs","hideBin","process","argv","scriptName","completion","help","version","pkg","wrap","terminalWidth","applyMiddlewares","globalConfig","commandDir","visit","obj","default","demandCommand","recommendCommands","strict","parse"],"mappings":"AAAA;;;;4DAAkB;yBACM;kEAER;6BACa;uBACI;;;;;;AAEjC,YAAY;AACX,CAAA,UAAY;IACX,cAAc;IACd,MAAMA,SAASC,IAAAA,cAAK,EAACC,IAAAA,gBAAO,EAACC,QAAQC,IAAI,GACtCC,UAAU,CAAC,QACXC,UAAU,CAAC,cAAc,mCACzBC,IAAI,CAAC,QAAQ,2BACbC,OAAO,CAAC,WAAW,gBAAgBC,oBAAG,CAACD,OAAO,EAC9CE,IAAI,CAACT,cAAK,CAACU,aAAa;IAE3B,cAAc;IACdC,IAAAA,uBAAgB,EAACZ,QAAQ;QAACa,yBAAY;KAAC;IAEvC,UAAU;IACV,MAAMb,OACHc,UAAU,CAAC,YAAY;QACtBC,OAAOC,CAAAA,MAAOA,IAAIC,OAAO;IAC3B,GACCC,aAAa,GACbC,iBAAiB,GACjBC,MAAM,GACNC,KAAK;AACV,CAAA"}
|
|
@@ -7,8 +7,8 @@ Object.defineProperty(exports, "globalConfig", {
|
|
|
7
7
|
get: ()=>globalConfig
|
|
8
8
|
});
|
|
9
9
|
const _nodeOs = /*#__PURE__*/ _interopRequireDefault(require("node:os"));
|
|
10
|
-
const _services = require("../services");
|
|
11
|
-
const _utils = require("../utils");
|
|
10
|
+
const _services = require("../services/index");
|
|
11
|
+
const _utils = require("../utils/index");
|
|
12
12
|
function _interopRequireDefault(obj) {
|
|
13
13
|
return obj && obj.__esModule ? obj : {
|
|
14
14
|
default: obj
|
|
@@ -33,4 +33,4 @@ const globalConfig = (0, _utils.defineMiddleware)({
|
|
|
33
33
|
}
|
|
34
34
|
});
|
|
35
35
|
|
|
36
|
-
//# sourceMappingURL=global-config.js.map
|
|
36
|
+
//# sourceMappingURL=global-config.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["middlewares/global-config.
|
|
1
|
+
{"version":3,"sources":["../../src/middlewares/global-config.ts"],"sourcesContent":["import os from 'node:os';\n\nimport { container, GLOBAL_CONFIG } from '../services';\nimport { defineMiddleware } from '../utils';\n\n// Middleware\nexport const globalConfig = defineMiddleware({\n builder: (yargs) => yargs\n .option('verbose', {\n alias: 'v',\n type: 'count',\n description: 'Set verbosity level',\n })\n .option('jobs', {\n alias: 'j',\n type: 'number',\n default: os.cpus().length - 1,\n description: 'Set maximum parallel job number',\n }),\n handler(args) {\n container.bind(GLOBAL_CONFIG).toConstantValue({\n verbose: args.verbose,\n jobs: args.jobs,\n });\n }\n});\n"],"names":["globalConfig","defineMiddleware","builder","yargs","option","alias","type","description","default","os","cpus","length","handler","args","container","bind","GLOBAL_CONFIG","toConstantValue","verbose","jobs"],"mappings":"AAAA;;;;+BAMaA;;aAAAA;;6DANE;0BAE0B;uBACR;;;;;;AAG1B,MAAMA,eAAeC,IAAAA,uBAAgB,EAAC;IAC3CC,SAAS,CAACC,QAAUA,MACjBC,MAAM,CAAC,WAAW;YACjBC,OAAO;YACPC,MAAM;YACNC,aAAa;QACf,GACCH,MAAM,CAAC,QAAQ;YACdC,OAAO;YACPC,MAAM;YACNE,SAASC,eAAE,CAACC,IAAI,GAAGC,MAAM,GAAG;YAC5BJ,aAAa;QACf;IACFK,SAAQC,IAAI,EAAE;QACZC,mBAAS,CAACC,IAAI,CAACC,uBAAa,EAAEC,eAAe,CAAC;YAC5CC,SAASL,KAAKK,OAAO;YACrBC,MAAMN,KAAKM,IAAI;QACjB;IACF;AACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["middlewares/index.
|
|
1
|
+
{"version":3,"sources":["../../src/middlewares/index.ts"],"sourcesContent":["export * from './global-config';\nexport * from './load-project';\nexport * from './load-workspace';\nexport * from './setup-ink';\n"],"names":[],"mappings":"AAAA;;;;oBAAc;oBACA;oBACA;oBACA"}
|
|
@@ -6,9 +6,9 @@ Object.defineProperty(exports, "loadProject", {
|
|
|
6
6
|
enumerable: true,
|
|
7
7
|
get: ()=>loadProject
|
|
8
8
|
});
|
|
9
|
-
const _services = require("../services");
|
|
10
|
-
const _project = require("../project");
|
|
11
|
-
const _utils = require("../utils");
|
|
9
|
+
const _services = require("../services/index");
|
|
10
|
+
const _project = require("../project/index");
|
|
11
|
+
const _utils = require("../utils/index");
|
|
12
12
|
const loadProject = (0, _utils.defineMiddleware)({
|
|
13
13
|
builder: (yargs)=>yargs.option('project', {
|
|
14
14
|
alias: 'p',
|
|
@@ -38,4 +38,4 @@ const loadProject = (0, _utils.defineMiddleware)({
|
|
|
38
38
|
}
|
|
39
39
|
});
|
|
40
40
|
|
|
41
|
-
//# sourceMappingURL=load-project.js.map
|
|
41
|
+
//# sourceMappingURL=load-project.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["middlewares/load-project.
|
|
1
|
+
{"version":3,"sources":["../../src/middlewares/load-project.ts"],"sourcesContent":["import { container, CURRENT, SpinnerService } from '../services';\nimport { PackageManager, Project } from '../project';\nimport { defineMiddleware } from '../utils';\n\n// Middleware\nexport const loadProject = defineMiddleware({\n builder: (yargs) => yargs\n .option('project', {\n alias: 'p',\n type: 'string',\n default: process.cwd(),\n description: 'Project root directory'\n })\n .option('package-manager', {\n choices: ['yarn', 'npm'],\n default: undefined as PackageManager | undefined,\n type: 'string',\n description: 'Force package manager'\n }),\n async handler(args) {\n const spinner = container.get(SpinnerService);\n\n try {\n spinner.spin('Loading project ...');\n const root = args.project = await Project.searchProjectRoot(args.project);\n\n container.bind(Project)\n .toDynamicValue(() => new Project(root, {\n packageManager: args['package-manager']\n }))\n .whenTargetNamed(CURRENT);\n } finally {\n spinner.stop();\n }\n }\n});\n"],"names":["loadProject","defineMiddleware","builder","yargs","option","alias","type","default","process","cwd","description","choices","undefined","handler","args","spinner","container","get","SpinnerService","spin","root","project","Project","searchProjectRoot","bind","toDynamicValue","packageManager","whenTargetNamed","CURRENT","stop"],"mappings":"AAAA;;;;+BAKaA;;aAAAA;;0BALsC;yBACX;uBACP;AAG1B,MAAMA,cAAcC,IAAAA,uBAAgB,EAAC;IAC1CC,SAAS,CAACC,QAAUA,MACjBC,MAAM,CAAC,WAAW;YACjBC,OAAO;YACPC,MAAM;YACNC,SAASC,QAAQC,GAAG;YACpBC,aAAa;QACf,GACCN,MAAM,CAAC,mBAAmB;YACzBO,SAAS;gBAAC;gBAAQ;aAAM;YACxBJ,SAASK;YACTN,MAAM;YACNI,aAAa;QACf;IACF,MAAMG,SAAQC,IAAI,EAAE;QAClB,MAAMC,UAAUC,mBAAS,CAACC,GAAG,CAACC,wBAAc;QAE5C,IAAI;YACFH,QAAQI,IAAI,CAAC;YACb,MAAMC,OAAON,KAAKO,OAAO,GAAG,MAAMC,gBAAO,CAACC,iBAAiB,CAACT,KAAKO,OAAO;YAExEL,mBAAS,CAACQ,IAAI,CAACF,gBAAO,EACnBG,cAAc,CAAC,IAAM,IAAIH,gBAAO,CAACF,MAAM;oBACtCM,gBAAgBZ,IAAI,CAAC,kBAAkB;gBACzC,IACCa,eAAe,CAACC,iBAAO;QAC5B,SAAU;YACRb,QAAQc,IAAI;QACd;IACF;AACF"}
|
|
@@ -7,9 +7,9 @@ Object.defineProperty(exports, "loadWorkspace", {
|
|
|
7
7
|
get: ()=>loadWorkspace
|
|
8
8
|
});
|
|
9
9
|
const _yargs = /*#__PURE__*/ _interopRequireDefault(require("yargs"));
|
|
10
|
-
const _services = require("../services");
|
|
11
|
-
const _project = require("../project");
|
|
12
|
-
const _utils = require("../utils");
|
|
10
|
+
const _services = require("../services/index");
|
|
11
|
+
const _project = require("../project/index");
|
|
12
|
+
const _utils = require("../utils/index");
|
|
13
13
|
function _interopRequireDefault(obj) {
|
|
14
14
|
return obj && obj.__esModule ? obj : {
|
|
15
15
|
default: obj
|
|
@@ -39,4 +39,4 @@ const loadWorkspace = (0, _utils.defineMiddleware)({
|
|
|
39
39
|
}
|
|
40
40
|
});
|
|
41
41
|
|
|
42
|
-
//# sourceMappingURL=load-workspace.js.map
|
|
42
|
+
//# sourceMappingURL=load-workspace.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["middlewares/load-workspace.
|
|
1
|
+
{"version":3,"sources":["../../src/middlewares/load-workspace.ts"],"sourcesContent":["import yargs from 'yargs';\n\nimport { container, CURRENT, SpinnerService } from '../services';\nimport { Project, Workspace } from '../project';\nimport { defineMiddleware } from '../utils';\n\n// Middleware\nexport const loadWorkspace = defineMiddleware({\n builder: (yargs) => yargs\n .option('workspace', {\n alias: 'w',\n type: 'string',\n desc: 'Workspace to use'\n }),\n async handler(args): Promise<void> {\n const spinner = container.get(SpinnerService);\n const project = container.getNamed(Project, CURRENT);\n\n try {\n spinner.spin(`Loading \"${args.workspace || '.'}\" workspace ...`);\n const workspace = await project.workspace(args.workspace);\n\n if (!workspace) {\n spinner.failed(`Workspace \"${args.workspace || '.'}\" not found`);\n yargs.exit(1, new Error('Workspace not found'));\n } else {\n container.bind(Workspace)\n .toConstantValue(workspace)\n .whenTargetNamed(CURRENT);\n }\n } finally {\n spinner.stop();\n }\n }\n});\n"],"names":["loadWorkspace","defineMiddleware","builder","yargs","option","alias","type","desc","handler","args","spinner","container","get","SpinnerService","project","getNamed","Project","CURRENT","spin","workspace","failed","exit","Error","bind","Workspace","toConstantValue","whenTargetNamed","stop"],"mappings":"AAAA;;;;+BAOaA;;aAAAA;;4DAPK;0BAEiC;yBAChB;uBACF;;;;;;AAG1B,MAAMA,gBAAgBC,IAAAA,uBAAgB,EAAC;IAC5CC,SAAS,CAACC,QAAUA,MACjBC,MAAM,CAAC,aAAa;YACnBC,OAAO;YACPC,MAAM;YACNC,MAAM;QACR;IACF,MAAMC,SAAQC,IAAI,EAAiB;QACjC,MAAMC,UAAUC,mBAAS,CAACC,GAAG,CAACC,wBAAc;QAC5C,MAAMC,UAAUH,mBAAS,CAACI,QAAQ,CAACC,gBAAO,EAAEC,iBAAO;QAEnD,IAAI;YACFP,QAAQQ,IAAI,CAAC,CAAC,SAAS,EAAET,KAAKU,SAAS,IAAI,IAAI,eAAe,CAAC;YAC/D,MAAMA,YAAY,MAAML,QAAQK,SAAS,CAACV,KAAKU,SAAS;YAExD,IAAI,CAACA,WAAW;gBACdT,QAAQU,MAAM,CAAC,CAAC,WAAW,EAAEX,KAAKU,SAAS,IAAI,IAAI,WAAW,CAAC;gBAC/DhB,cAAK,CAACkB,IAAI,CAAC,GAAG,IAAIC,MAAM;YAC1B,OAAO;gBACLX,mBAAS,CAACY,IAAI,CAACC,kBAAS,EACrBC,eAAe,CAACN,WAChBO,eAAe,CAACT,iBAAO;YAC5B,CAAC;QACH,SAAU;YACRP,QAAQiB,IAAI;QACd;IACF;AACF"}
|
|
@@ -8,9 +8,9 @@ Object.defineProperty(exports, "setupInk", {
|
|
|
8
8
|
});
|
|
9
9
|
const _jsxRuntime = require("react/jsx-runtime");
|
|
10
10
|
const _ink = require("ink");
|
|
11
|
-
const _services = require("../services");
|
|
12
|
-
const _ui = require("../ui");
|
|
13
|
-
const _utils = require("../utils");
|
|
11
|
+
const _services = require("../services/index");
|
|
12
|
+
const _ui = require("../ui/index");
|
|
13
|
+
const _utils = require("../utils/index");
|
|
14
14
|
const setupInk = (0, _utils.defineMiddleware)({
|
|
15
15
|
handler () {
|
|
16
16
|
_services.container.bind(_services.INK_APP).toConstantValue((0, _ink.render)(/*#__PURE__*/ (0, _jsxRuntime.jsx)(_ui.Layout, {}), {
|
|
@@ -19,4 +19,4 @@ const setupInk = (0, _utils.defineMiddleware)({
|
|
|
19
19
|
}
|
|
20
20
|
});
|
|
21
21
|
|
|
22
|
-
//# sourceMappingURL=setup-ink.js.map
|
|
22
|
+
//# sourceMappingURL=setup-ink.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["middlewares/setup-ink.
|
|
1
|
+
{"version":3,"sources":["../../src/middlewares/setup-ink.tsx"],"sourcesContent":["import { render } from 'ink';\n\nimport { container, INK_APP } from '../services';\nimport { Layout } from '../ui';\nimport { defineMiddleware } from '../utils';\n\n// Middleware\nexport const setupInk = defineMiddleware({\n handler() {\n container.bind(INK_APP)\n .toConstantValue(render(<Layout/>, {\n stdout: process.stdout.isTTY ? process.stdout : process.stderr,\n }));\n }\n});\n"],"names":["setupInk","defineMiddleware","handler","container","bind","INK_APP","toConstantValue","render","Layout","stdout","process","isTTY","stderr"],"mappings":"AAAA;;;;+BAOaA;;aAAAA;;;qBAPU;0BAEY;oBACZ;uBACU;AAG1B,MAAMA,WAAWC,IAAAA,uBAAgB,EAAC;IACvCC,WAAU;QACRC,mBAAS,CAACC,IAAI,CAACC,iBAAO,EACnBC,eAAe,CAACC,IAAAA,WAAM,gBAAC,qBAACC,UAAM,OAAI;YACjCC,QAAQC,QAAQD,MAAM,CAACE,KAAK,GAAGD,QAAQD,MAAM,GAAGC,QAAQE,MAAM;QAChE;IACJ;AACF"}
|
package/dist/project/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["project/index.
|
|
1
|
+
{"version":3,"sources":["../../src/project/index.ts"],"sourcesContent":["export * from './project';\nexport * from './workspace';\n"],"names":[],"mappings":"AAAA;;;;oBAAc;oBACA"}
|
package/dist/project/project.js
CHANGED
|
@@ -11,7 +11,7 @@ const _promises = /*#__PURE__*/ _interopRequireDefault(require("node:fs/promises
|
|
|
11
11
|
const _nodePath = /*#__PURE__*/ _interopRequireDefault(require("node:path"));
|
|
12
12
|
const _normalizePackageData = /*#__PURE__*/ _interopRequireDefault(require("normalize-package-data"));
|
|
13
13
|
const _tinyGlob = /*#__PURE__*/ _interopRequireDefault(require("tiny-glob"));
|
|
14
|
-
const _services = require("../services");
|
|
14
|
+
const _services = require("../services/index");
|
|
15
15
|
const _workspace = require("./workspace");
|
|
16
16
|
function _interopRequireDefault(obj) {
|
|
17
17
|
return obj && obj.__esModule ? obj : {
|
|
@@ -116,9 +116,9 @@ class Project {
|
|
|
116
116
|
}
|
|
117
117
|
async currentWorkspace(cwd = process.cwd()) {
|
|
118
118
|
let workspace = null;
|
|
119
|
-
cwd = _nodePath.default.
|
|
119
|
+
cwd = _nodePath.default.resolve(cwd);
|
|
120
120
|
for await (const wks of this.workspaces()){
|
|
121
|
-
if (cwd.startsWith(
|
|
121
|
+
if (cwd.startsWith(wks.cwd)) {
|
|
122
122
|
workspace = wks;
|
|
123
123
|
if (wks.cwd !== this.root) return wks;
|
|
124
124
|
}
|
|
@@ -187,4 +187,4 @@ __decorate([
|
|
|
187
187
|
(0, _services.lazyInject)(_services.Logger)
|
|
188
188
|
], Project.prototype, "_logger", void 0);
|
|
189
189
|
|
|
190
|
-
//# sourceMappingURL=project.js.map
|
|
190
|
+
//# sourceMappingURL=project.js.map
|