@jujulego/jill 1.1.14 → 1.1.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/dist/base.command.d.ts +8 -0
  2. package/dist/base.command.js +33 -0
  3. package/dist/command.d.ts +21 -0
  4. package/dist/command.js +69 -0
  5. package/dist/commands/each.command.d.ts +17 -0
  6. package/dist/commands/each.command.js +115 -0
  7. package/dist/commands/info.command.d.ts +9 -0
  8. package/dist/commands/info.command.js +83 -0
  9. package/dist/commands/list.command.d.ts +22 -0
  10. package/dist/commands/list.command.js +177 -0
  11. package/dist/commands/run.command.d.ts +13 -0
  12. package/dist/commands/run.command.js +60 -0
  13. package/dist/filters/affected.js +3 -4
  14. package/dist/filters/filter.js +2 -1
  15. package/dist/filters/index.js +2 -1
  16. package/dist/index.d.ts +4 -9
  17. package/dist/index.js +13 -26
  18. package/dist/logger.d.ts +6 -23
  19. package/dist/logger.js +29 -119
  20. package/dist/main.js +19 -132
  21. package/dist/myr/commands/kill.command.d.ts +11 -0
  22. package/dist/myr/commands/kill.command.js +52 -0
  23. package/dist/myr/commands/list.command.d.ts +18 -0
  24. package/dist/myr/commands/list.command.js +127 -0
  25. package/dist/myr/commands/logs.command.d.ts +11 -0
  26. package/dist/myr/commands/logs.command.js +83 -0
  27. package/dist/myr/commands/spawn.command.d.ts +11 -0
  28. package/dist/myr/commands/spawn.command.js +45 -0
  29. package/dist/myr/commands/stop.command.d.ts +7 -0
  30. package/dist/myr/commands/stop.command.js +43 -0
  31. package/dist/myr/myr-client.d.ts +12 -5
  32. package/dist/myr/myr-client.js +106 -281
  33. package/dist/myr/myr.command.d.ts +8 -0
  34. package/dist/myr/myr.command.js +46 -0
  35. package/dist/myr/myr.process.js +3 -2
  36. package/dist/myr/watch.command.d.ts +13 -0
  37. package/dist/myr/watch.command.js +87 -0
  38. package/dist/pipeline.js +2 -1
  39. package/dist/plugin.d.ts +11 -0
  40. package/dist/plugin.js +40 -0
  41. package/dist/project.command.d.ts +13 -0
  42. package/dist/project.command.js +58 -0
  43. package/dist/task-logger.js +6 -5
  44. package/dist/utils/cli-list.js +2 -1
  45. package/dist/workspace.command.d.ts +12 -0
  46. package/dist/workspace.command.js +55 -0
  47. package/package.json +32 -22
  48. package/dist/commands/each.d.ts +0 -12
  49. package/dist/commands/each.js +0 -74
  50. package/dist/commands/info.d.ts +0 -5
  51. package/dist/commands/info.js +0 -42
  52. package/dist/commands/list.d.ts +0 -15
  53. package/dist/commands/list.js +0 -119
  54. package/dist/commands/run.d.ts +0 -9
  55. package/dist/commands/run.js +0 -43
  56. package/dist/myr/command.d.ts +0 -2
  57. package/dist/myr/command.js +0 -50
  58. package/dist/myr/commands/kill.d.ts +0 -5
  59. package/dist/myr/commands/kill.js +0 -34
  60. package/dist/myr/commands/list.d.ts +0 -10
  61. package/dist/myr/commands/list.js +0 -91
  62. package/dist/myr/commands/spawn.d.ts +0 -7
  63. package/dist/myr/commands/spawn.js +0 -39
  64. package/dist/myr/watch.d.ts +0 -8
  65. package/dist/myr/watch.js +0 -79
  66. package/dist/utils/deps-tree.d.ts +0 -2
  67. package/dist/utils/deps-tree.js +0 -51
  68. package/dist/wrapper.d.ts +0 -9
  69. package/dist/wrapper.js +0 -38
@@ -5,15 +5,25 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.MyrClient = void 0;
7
7
 
8
+ var _jillCore = require("@jujulego/jill-core");
9
+
8
10
  var _jillMyr = require("@jujulego/jill-myr");
9
11
 
12
+ var _repeater = require("@repeaterjs/repeater");
13
+
10
14
  var _child_process = require("child_process");
11
15
 
16
+ var _graphql = require("graphql");
17
+
12
18
  var _graphqlRequest = require("graphql-request");
13
19
 
20
+ var _graphqlWs = require("graphql-ws");
21
+
22
+ var _graphqlTag = _interopRequireDefault(require("graphql-tag"));
23
+
14
24
  var _path = _interopRequireDefault(require("path"));
15
25
 
16
- var _logger = require("../logger");
26
+ var _ws = _interopRequireDefault(require("ws"));
17
27
 
18
28
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
29
 
@@ -26,13 +36,19 @@ class MyrClient {
26
36
  constructor(project) {
27
37
  this.project = project;
28
38
 
29
- _defineProperty(this, "_logger", _logger.logger.child({
39
+ _defineProperty(this, "_logger", _jillCore.logger.child({
30
40
  context: MyrClient.name
31
41
  }));
32
42
 
33
43
  _defineProperty(this, "_endpoint", 'http://localhost:5001/graphql');
34
44
 
35
45
  _defineProperty(this, "_qclient", new _graphqlRequest.GraphQLClient(this._endpoint));
46
+
47
+ _defineProperty(this, "_sclient", (0, _graphqlWs.createClient)({
48
+ url: this._endpoint.replace(/^http/, 'ws'),
49
+ webSocketImpl: _ws.default,
50
+ lazy: true
51
+ }));
36
52
  } // Methods
37
53
 
38
54
 
@@ -50,6 +66,28 @@ class MyrClient {
50
66
  }
51
67
  }
52
68
 
69
+ _subscription(query, variables) {
70
+ return new _repeater.Repeater((push, stop) => {
71
+ this._sclient.subscribe({
72
+ query: (0, _graphql.print)(query),
73
+ variables
74
+ }, {
75
+ next(value) {
76
+ push(value.data).then();
77
+ },
78
+
79
+ error(error) {
80
+ stop(error);
81
+ },
82
+
83
+ complete() {
84
+ stop();
85
+ }
86
+
87
+ });
88
+ });
89
+ }
90
+
53
91
  start() {
54
92
  const child = (0, _child_process.fork)(_path.default.resolve(__dirname, './myr.process'), [], {
55
93
  cwd: this.project.root,
@@ -66,11 +104,11 @@ class MyrClient {
66
104
  ...meta
67
105
  } = JSON.parse(line);
68
106
 
69
- _logger.logger.log(level, message, meta);
107
+ _jillCore.logger.log(level, message, meta);
70
108
  }
71
109
  });
72
110
  child.stderr?.on('data', msg => {
73
- _logger.logger.error(msg.toString('utf-8'));
111
+ _jillCore.logger.error(msg.toString('utf-8'));
74
112
  }); // Start server
75
113
 
76
114
  return new Promise((resolve, reject) => {
@@ -88,58 +126,33 @@ class MyrClient {
88
126
  });
89
127
  }
90
128
 
129
+ async stop() {
130
+ try {
131
+ await this._qclient.request((0, _graphqlTag.default)`
132
+ mutation Shutdown {
133
+ shutdown
134
+ }
135
+ `);
136
+ return true;
137
+ } catch (error) {
138
+ if (error.code !== 'ECONNREFUSED') throw error;
139
+ return false;
140
+ }
141
+ }
142
+
91
143
  async tasks() {
92
144
  return await this._autoStart(async () => {
93
145
  const {
94
146
  tasks
95
- } = await this._qclient.request({
96
- "kind": "Document",
97
- "definitions": [{
98
- "kind": "OperationDefinition",
99
- "operation": "query",
100
- "name": {
101
- "kind": "Name",
102
- "value": "Tasks"
103
- },
104
- "variableDefinitions": [],
105
- "directives": [],
106
- "selectionSet": {
107
- "kind": "SelectionSet",
108
- "selections": [{
109
- "kind": "Field",
110
- "name": {
111
- "kind": "Name",
112
- "value": "tasks"
113
- },
114
- "arguments": [],
115
- "directives": [],
116
- "selectionSet": {
117
- "kind": "SelectionSet",
118
- "selections": [{
119
- "kind": "FragmentSpread",
120
- "name": {
121
- "kind": "Name",
122
- "value": "Task"
123
- },
124
- "directives": []
125
- }]
147
+ } = await this._qclient.request((0, _graphqlTag.default)`
148
+ query Tasks {
149
+ tasks {
150
+ ...Task
126
151
  }
127
- }]
128
- }
129
- }].concat(_jillMyr.TaskFragment.definitions).reduce((acc, definition) => definition.kind === 'FragmentDefinition' && acc.find(curDef => curDef.kind === 'FragmentDefinition' && curDef.name.value === definition.name.value) ? acc : acc.concat(definition), []),
130
- "loc": {
131
- "start": 0,
132
- "end": 119,
133
- "source": {
134
- "body": "\n query Tasks {\n tasks {\n ...Task\n }\n }\n\n \n ",
135
- "name": "GraphQL request",
136
- "locationOffset": {
137
- "line": 1,
138
- "column": 1
139
- }
140
152
  }
141
- }
142
- });
153
+
154
+ ${_jillMyr.TaskFragment}
155
+ `);
143
156
  return tasks;
144
157
  });
145
158
  }
@@ -148,159 +161,15 @@ class MyrClient {
148
161
  return await this._autoStart(async () => {
149
162
  const {
150
163
  spawn
151
- } = await this._qclient.request({
152
- "kind": "Document",
153
- "definitions": [{
154
- "kind": "OperationDefinition",
155
- "operation": "mutation",
156
- "name": {
157
- "kind": "Name",
158
- "value": "Spawn"
159
- },
160
- "variableDefinitions": [{
161
- "kind": "VariableDefinition",
162
- "variable": {
163
- "kind": "Variable",
164
- "name": {
165
- "kind": "Name",
166
- "value": "cwd"
167
- }
168
- },
169
- "type": {
170
- "kind": "NonNullType",
171
- "type": {
172
- "kind": "NamedType",
173
- "name": {
174
- "kind": "Name",
175
- "value": "String"
176
- }
164
+ } = await this._qclient.request((0, _graphqlTag.default)`
165
+ mutation Spawn($cwd: String!, $cmd: String!, $args: [String!]!) {
166
+ spawn(cwd: $cwd, cmd: $cmd, args: $args) {
167
+ ...Task
177
168
  }
178
- },
179
- "directives": []
180
- }, {
181
- "kind": "VariableDefinition",
182
- "variable": {
183
- "kind": "Variable",
184
- "name": {
185
- "kind": "Name",
186
- "value": "cmd"
187
- }
188
- },
189
- "type": {
190
- "kind": "NonNullType",
191
- "type": {
192
- "kind": "NamedType",
193
- "name": {
194
- "kind": "Name",
195
- "value": "String"
196
- }
197
- }
198
- },
199
- "directives": []
200
- }, {
201
- "kind": "VariableDefinition",
202
- "variable": {
203
- "kind": "Variable",
204
- "name": {
205
- "kind": "Name",
206
- "value": "args"
207
- }
208
- },
209
- "type": {
210
- "kind": "NonNullType",
211
- "type": {
212
- "kind": "ListType",
213
- "type": {
214
- "kind": "NonNullType",
215
- "type": {
216
- "kind": "NamedType",
217
- "name": {
218
- "kind": "Name",
219
- "value": "String"
220
- }
221
- }
222
- }
223
- }
224
- },
225
- "directives": []
226
- }],
227
- "directives": [],
228
- "selectionSet": {
229
- "kind": "SelectionSet",
230
- "selections": [{
231
- "kind": "Field",
232
- "name": {
233
- "kind": "Name",
234
- "value": "spawn"
235
- },
236
- "arguments": [{
237
- "kind": "Argument",
238
- "name": {
239
- "kind": "Name",
240
- "value": "cwd"
241
- },
242
- "value": {
243
- "kind": "Variable",
244
- "name": {
245
- "kind": "Name",
246
- "value": "cwd"
247
- }
248
- }
249
- }, {
250
- "kind": "Argument",
251
- "name": {
252
- "kind": "Name",
253
- "value": "cmd"
254
- },
255
- "value": {
256
- "kind": "Variable",
257
- "name": {
258
- "kind": "Name",
259
- "value": "cmd"
260
- }
261
- }
262
- }, {
263
- "kind": "Argument",
264
- "name": {
265
- "kind": "Name",
266
- "value": "args"
267
- },
268
- "value": {
269
- "kind": "Variable",
270
- "name": {
271
- "kind": "Name",
272
- "value": "args"
273
- }
274
- }
275
- }],
276
- "directives": [],
277
- "selectionSet": {
278
- "kind": "SelectionSet",
279
- "selections": [{
280
- "kind": "FragmentSpread",
281
- "name": {
282
- "kind": "Name",
283
- "value": "Task"
284
- },
285
- "directives": []
286
- }]
287
- }
288
- }]
289
- }
290
- }].concat(_jillMyr.TaskFragment.definitions).reduce((acc, definition) => definition.kind === 'FragmentDefinition' && acc.find(curDef => curDef.kind === 'FragmentDefinition' && curDef.name.value === definition.name.value) ? acc : acc.concat(definition), []),
291
- "loc": {
292
- "start": 0,
293
- "end": 206,
294
- "source": {
295
- "body": "\n mutation Spawn($cwd: String!, $cmd: String!, $args: [String!]!) {\n spawn(cwd: $cwd, cmd: $cmd, args: $args) {\n ...Task\n }\n }\n\n \n ",
296
- "name": "GraphQL request",
297
- "locationOffset": {
298
- "line": 1,
299
- "column": 1
300
- }
301
169
  }
302
- }
303
- }, {
170
+
171
+ ${_jillMyr.TaskFragment}
172
+ `, {
304
173
  cwd,
305
174
  cmd,
306
175
  args
@@ -313,91 +182,46 @@ class MyrClient {
313
182
  return await this.spawn(wks.cwd, await wks.project.packageManager(), [script, ...args]);
314
183
  }
315
184
 
185
+ async logs() {
186
+ try {
187
+ const res = await this._qclient.request((0, _graphqlTag.default)`
188
+ query Logs {
189
+ logs
190
+ }
191
+ `);
192
+ return res.logs;
193
+ } catch (error) {
194
+ if (error.code !== 'ECONNREFUSED') throw error;
195
+ return [];
196
+ }
197
+ }
198
+
199
+ async *logs$() {
200
+ try {
201
+ for await (const {
202
+ log
203
+ } of this._subscription((0, _graphqlTag.default)`subscription Logs { log }`, {})) {
204
+ yield log;
205
+ }
206
+ } catch (error) {
207
+ if (error.code !== 'ECONNREFUSED') throw error;
208
+ return;
209
+ }
210
+ }
211
+
316
212
  async kill(id) {
317
213
  return await this._autoStart(async () => {
318
214
  const {
319
215
  kill
320
- } = await this._qclient.request({
321
- "kind": "Document",
322
- "definitions": [{
323
- "kind": "OperationDefinition",
324
- "operation": "mutation",
325
- "name": {
326
- "kind": "Name",
327
- "value": "Kill"
328
- },
329
- "variableDefinitions": [{
330
- "kind": "VariableDefinition",
331
- "variable": {
332
- "kind": "Variable",
333
- "name": {
334
- "kind": "Name",
335
- "value": "id"
216
+ } = await this._qclient.request((0, _graphqlTag.default)`
217
+ mutation Kill($id: ID!) {
218
+ kill(id: $id) {
219
+ ...Task
336
220
  }
337
- },
338
- "type": {
339
- "kind": "NonNullType",
340
- "type": {
341
- "kind": "NamedType",
342
- "name": {
343
- "kind": "Name",
344
- "value": "ID"
345
- }
346
- }
347
- },
348
- "directives": []
349
- }],
350
- "directives": [],
351
- "selectionSet": {
352
- "kind": "SelectionSet",
353
- "selections": [{
354
- "kind": "Field",
355
- "name": {
356
- "kind": "Name",
357
- "value": "kill"
358
- },
359
- "arguments": [{
360
- "kind": "Argument",
361
- "name": {
362
- "kind": "Name",
363
- "value": "id"
364
- },
365
- "value": {
366
- "kind": "Variable",
367
- "name": {
368
- "kind": "Name",
369
- "value": "id"
370
- }
371
- }
372
- }],
373
- "directives": [],
374
- "selectionSet": {
375
- "kind": "SelectionSet",
376
- "selections": [{
377
- "kind": "FragmentSpread",
378
- "name": {
379
- "kind": "Name",
380
- "value": "Task"
381
- },
382
- "directives": []
383
- }]
384
- }
385
- }]
386
- }
387
- }].concat(_jillMyr.TaskFragment.definitions).reduce((acc, definition) => definition.kind === 'FragmentDefinition' && acc.find(curDef => curDef.kind === 'FragmentDefinition' && curDef.name.value === definition.name.value) ? acc : acc.concat(definition), []),
388
- "loc": {
389
- "start": 0,
390
- "end": 139,
391
- "source": {
392
- "body": "\n mutation Kill($id: ID!) {\n kill(id: $id) {\n ...Task\n }\n }\n\n \n ",
393
- "name": "GraphQL request",
394
- "locationOffset": {
395
- "line": 1,
396
- "column": 1
397
- }
398
221
  }
399
- }
400
- }, {
222
+
223
+ ${_jillMyr.TaskFragment}
224
+ `, {
401
225
  id
402
226
  });
403
227
  return kill;
@@ -406,4 +230,5 @@ class MyrClient {
406
230
 
407
231
  }
408
232
 
409
- exports.MyrClient = MyrClient;
233
+ exports.MyrClient = MyrClient;
234
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["myr/myr-client.ts"],"names":["MyrClient","constructor","project","logger","child","context","name","GraphQLClient","_endpoint","url","replace","webSocketImpl","WebSocket","lazy","_autoStart","fn","error","code","_logger","verbose","start","_subscription","query","variables","Repeater","push","stop","_sclient","subscribe","next","value","data","then","complete","path","resolve","__dirname","cwd","root","detached","stdio","stdout","on","msg","line","toString","split","level","message","meta","JSON","parse","log","stderr","Promise","reject","signal","Error","send","_qclient","request","tasks","TaskFragment","spawn","cmd","args","spawnScript","wks","script","packageManager","logs","res","logs$","kill","id"],"mappings":"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","sourcesContent":["import { logger, Project, Workspace } from '@jujulego/jill-core';\nimport { SpawnArgs, Task, TaskFragment } from '@jujulego/jill-myr';\nimport { Repeater } from '@repeaterjs/repeater';\nimport { fork } from 'child_process';\nimport { DocumentNode, print } from 'graphql';\nimport { GraphQLClient } from 'graphql-request';\nimport { createClient } from 'graphql-ws';\nimport gql from 'graphql-tag';\nimport path from 'path';\nimport WebSocket from 'ws';\n\n\n// Types\ntype ILog = Record<string, unknown> & {\n  // Attributes\n  level: string;\n  message: string;\n};\n\n// Class\nexport class MyrClient {\n  // Attributes\n  private readonly _logger = logger.child({ context: MyrClient.name });\n  private readonly _endpoint = 'http://localhost:5001/graphql';\n  private readonly _qclient = new GraphQLClient(this._endpoint);\n  private readonly _sclient = createClient({\n    url: this._endpoint.replace(/^http/, 'ws'),\n    webSocketImpl: WebSocket,\n    lazy: true\n  });\n\n  // Constructor\n  constructor(\n    readonly project: Project,\n  ) {}\n\n  // Methods\n  protected async _autoStart<T>(fn: () => Promise<T>): Promise<T> {\n    try {\n      return await fn();\n    } catch (error) {\n      if (error.code !== 'ECONNREFUSED') throw error;\n\n      // Start myr if connection impossible\n      this._logger.verbose('Unable to connect to myr server, trying to start it');\n      await this.start();\n\n      // Retry\n      return await fn();\n    }\n  }\n\n  protected _subscription<T>(query: DocumentNode, variables: Record<string, unknown>): Repeater<T> {\n    return new Repeater<T>((push, stop) => {\n      this._sclient.subscribe<T>({ query: print(query), variables }, {\n        next(value) {\n          push(value.data!).then();\n        },\n        error(error) {\n          stop(error);\n        },\n        complete() {\n          stop();\n        }\n      });\n    });\n  }\n\n  start(): Promise<void> {\n    const child = fork(path.resolve(__dirname, './myr.process'), [], {\n      cwd: this.project.root,\n      detached: true,\n      stdio: ['ignore', 'pipe', 'pipe', 'ipc'],\n    });\n\n    // Transmit logs to logger\n    child.stdout?.on('data', (msg: Buffer) => {\n      for (const line of msg.toString('utf-8').split('\\n')) {\n        if (!line) continue;\n\n        const { level, message, ...meta } = JSON.parse(line) as ILog;\n        logger.log(level, message, meta);\n      }\n    });\n\n    child.stderr?.on('data', (msg: Buffer) => {\n      logger.error(msg.toString('utf-8'));\n    });\n\n    // Start server\n    return new Promise<void>((resolve, reject) => {\n      child.on('message', (msg: 'started' | Error) => {\n        if (msg === 'started') {\n          resolve();\n        } else {\n          reject(msg);\n        }\n      });\n\n      child.on('close', (code, signal) => {\n        reject(new Error(`Myr process ended with code ${code} by signal ${signal}`));\n      });\n\n      child.send('start');\n    });\n  }\n\n  async stop(): Promise<boolean> {\n    try {\n      await this._qclient.request(gql`\n        mutation Shutdown {\n            shutdown\n        }\n    `);\n\n      return true;\n    } catch (error) {\n      if (error.code !== 'ECONNREFUSED') throw error;\n\n      return false;\n    }\n  }\n\n  async tasks(): Promise<Task[]> {\n    return await this._autoStart(async () => {\n      const { tasks } = await this._qclient.request<{ tasks: Task[] }>(gql`\n          query Tasks {\n              tasks {\n                  ...Task\n              }\n          }\n\n          ${TaskFragment}\n      `);\n\n      return tasks;\n    });\n  }\n\n  async spawn(cwd: string, cmd: string, args: string[] = []): Promise<Task> {\n    return await this._autoStart(async () => {\n      const { spawn } = await this._qclient.request<{ spawn:Task },SpawnArgs>(gql`\n          mutation Spawn($cwd: String!, $cmd: String!, $args: [String!]!) {\n              spawn(cwd: $cwd, cmd: $cmd, args: $args) {\n                  ...Task\n              }\n          }\n\n          ${TaskFragment}\n      `, { cwd, cmd, args });\n\n      return spawn;\n    });\n  }\n\n  async spawnScript(wks: Workspace, script: string, args: string[] = []): Promise<Task> {\n    return await this.spawn(wks.cwd, await wks.project.packageManager(), [script, ...args]);\n  }\n\n  async logs(): Promise<any[]> {\n    try {\n      const res = await this._qclient.request<{ logs: any[] }>(gql`\n          query Logs {\n              logs\n          }\n      `);\n\n      return res.logs;\n    } catch (error) {\n      if (error.code !== 'ECONNREFUSED') throw error;\n\n      return [];\n    }\n  }\n\n  async* logs$(): AsyncGenerator<any> {\n    try {\n      for await (const { log } of this._subscription<{ log: any }>(gql`subscription Logs { log }`, {})) {\n        yield log;\n      }\n    } catch (error) {\n      if (error.code !== 'ECONNREFUSED') throw error;\n\n      return;\n    }\n  }\n\n  async kill(id: string): Promise<Task | undefined> {\n    return await this._autoStart(async () => {\n      const { kill } = await this._qclient.request<{ kill: Task | undefined }>(gql`\n          mutation Kill($id: ID!) {\n              kill(id: $id) {\n                  ...Task\n              }\n          }\n\n          ${TaskFragment}\n      `, { id });\n\n      return kill;\n    });\n  }\n}"],"file":"myr/myr-client.js"}
@@ -0,0 +1,8 @@
1
+ import { Builder, Command } from '../command';
2
+ export declare class MyrCommand extends Command {
3
+ readonly name = "myr";
4
+ readonly description = "Interact with myr server";
5
+ readonly commands: readonly Command[];
6
+ protected define<T, U>(builder: Builder<T, U>): Builder<T, U>;
7
+ protected run(): number;
8
+ }
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.MyrCommand = void 0;
7
+
8
+ var _command = require("../command");
9
+
10
+ var _kill = require("./commands/kill.command");
11
+
12
+ var _list = require("./commands/list.command");
13
+
14
+ var _logs = require("./commands/logs.command");
15
+
16
+ var _spawn = require("./commands/spawn.command");
17
+
18
+ var _stop = require("./commands/stop.command");
19
+
20
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
21
+
22
+ // Command
23
+ class MyrCommand extends _command.Command {
24
+ constructor(...args) {
25
+ super(...args);
26
+
27
+ _defineProperty(this, "name", 'myr');
28
+
29
+ _defineProperty(this, "description", 'Interact with myr server');
30
+
31
+ _defineProperty(this, "commands", [new _kill.KillCommand(), new _list.ListCommand(), new _logs.LogsCommand(), new _spawn.SpawnCommand(), new _stop.StopCommand()]);
32
+ }
33
+
34
+ // Methods
35
+ define(builder) {
36
+ return yargs => this.commands.reduce((y, cmd) => cmd.setup(y), builder(yargs));
37
+ }
38
+
39
+ run() {
40
+ return 0;
41
+ }
42
+
43
+ }
44
+
45
+ exports.MyrCommand = MyrCommand;
46
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm15ci9teXIuY29tbWFuZC50cyJdLCJuYW1lcyI6WyJNeXJDb21tYW5kIiwiQ29tbWFuZCIsIktpbGxDb21tYW5kIiwiTGlzdENvbW1hbmQiLCJMb2dzQ29tbWFuZCIsIlNwYXduQ29tbWFuZCIsIlN0b3BDb21tYW5kIiwiZGVmaW5lIiwiYnVpbGRlciIsInlhcmdzIiwiY29tbWFuZHMiLCJyZWR1Y2UiLCJ5IiwiY21kIiwic2V0dXAiLCJydW4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7OztBQUVBO0FBQ08sTUFBTUEsVUFBTixTQUF5QkMsZ0JBQXpCLENBQWlDO0FBQUE7QUFBQTs7QUFBQSxrQ0FFdEIsS0FGc0I7O0FBQUEseUNBR2YsMEJBSGU7O0FBQUEsc0NBS0UsQ0FDdEMsSUFBSUMsaUJBQUosRUFEc0MsRUFFdEMsSUFBSUMsaUJBQUosRUFGc0MsRUFHdEMsSUFBSUMsaUJBQUosRUFIc0MsRUFJdEMsSUFBSUMsbUJBQUosRUFKc0MsRUFLdEMsSUFBSUMsaUJBQUosRUFMc0MsQ0FMRjtBQUFBOztBQWF0QztBQUNVQyxFQUFBQSxNQUFNLENBQU9DLE9BQVAsRUFBOEM7QUFDNUQsV0FBT0MsS0FBSyxJQUFJLEtBQUtDLFFBQUwsQ0FBY0MsTUFBZCxDQUFxQixDQUFDQyxDQUFELEVBQUlDLEdBQUosS0FBWUEsR0FBRyxDQUFDQyxLQUFKLENBQVVGLENBQVYsQ0FBakMsRUFBK0NKLE9BQU8sQ0FBQ0MsS0FBRCxDQUF0RCxDQUFoQjtBQUNEOztBQUVTTSxFQUFBQSxHQUFHLEdBQVc7QUFDdEIsV0FBTyxDQUFQO0FBQ0Q7O0FBcEJxQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJ1aWxkZXIsIENvbW1hbmQgfSBmcm9tICcuLi9jb21tYW5kJztcbmltcG9ydCB7IEtpbGxDb21tYW5kIH0gZnJvbSAnLi9jb21tYW5kcy9raWxsLmNvbW1hbmQnO1xuaW1wb3J0IHsgTGlzdENvbW1hbmQgfSBmcm9tICcuL2NvbW1hbmRzL2xpc3QuY29tbWFuZCc7XG5pbXBvcnQgeyBMb2dzQ29tbWFuZCB9IGZyb20gJy4vY29tbWFuZHMvbG9ncy5jb21tYW5kJztcbmltcG9ydCB7IFNwYXduQ29tbWFuZCB9IGZyb20gJy4vY29tbWFuZHMvc3Bhd24uY29tbWFuZCc7XG5pbXBvcnQgeyBTdG9wQ29tbWFuZCB9IGZyb20gJy4vY29tbWFuZHMvc3RvcC5jb21tYW5kJztcblxuLy8gQ29tbWFuZFxuZXhwb3J0IGNsYXNzIE15ckNvbW1hbmQgZXh0ZW5kcyBDb21tYW5kIHtcbiAgLy8gUHJvcGVydGllc1xuICByZWFkb25seSBuYW1lID0gJ215cic7XG4gIHJlYWRvbmx5IGRlc2NyaXB0aW9uID0gJ0ludGVyYWN0IHdpdGggbXlyIHNlcnZlcic7XG5cbiAgcmVhZG9ubHkgY29tbWFuZHM6IHJlYWRvbmx5IENvbW1hbmRbXSA9IFtcbiAgICBuZXcgS2lsbENvbW1hbmQoKSxcbiAgICBuZXcgTGlzdENvbW1hbmQoKSxcbiAgICBuZXcgTG9nc0NvbW1hbmQoKSxcbiAgICBuZXcgU3Bhd25Db21tYW5kKCksXG4gICAgbmV3IFN0b3BDb21tYW5kKCksXG4gIF07XG5cbiAgLy8gTWV0aG9kc1xuICBwcm90ZWN0ZWQgZGVmaW5lPFQsIFU+KGJ1aWxkZXI6IEJ1aWxkZXI8VCwgVT4pOiBCdWlsZGVyPFQsIFU+IHtcbiAgICByZXR1cm4geWFyZ3MgPT4gdGhpcy5jb21tYW5kcy5yZWR1Y2UoKHksIGNtZCkgPT4gY21kLnNldHVwKHkpLCBidWlsZGVyKHlhcmdzKSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgcnVuKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIDA7XG4gIH1cbn0iXSwiZmlsZSI6Im15ci9teXIuY29tbWFuZC5qcyJ9
@@ -26,7 +26,7 @@ _jillCore.logger.add(trans); // Start server when parent is ready
26
26
  process.once('message', async () => {
27
27
  try {
28
28
  // Start server
29
- const server = new _jillMyr.MyrServer();
29
+ const server = await _jillMyr.MyrServer.createServer();
30
30
  await server.start();
31
31
 
32
32
  _jillCore.logger.remove(trans);
@@ -39,4 +39,5 @@ process.once('message', async () => {
39
39
  });
40
40
  process.exit(1);
41
41
  }
42
- });
42
+ });
43
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm15ci9teXIucHJvY2Vzcy50cyJdLCJuYW1lcyI6WyJ0cmFucyIsIndpbnN0b24iLCJ0cmFuc3BvcnRzIiwiQ29uc29sZSIsImxldmVsIiwiZm9ybWF0IiwiY29tYmluZSIsInRpbWVzdGFtcCIsIkRhdGUiLCJ0b0xvY2FsZVN0cmluZyIsImVycm9ycyIsImpzb24iLCJjb25zb2xlV2FybkxldmVscyIsInN0ZGVyckxldmVscyIsImxvZ2dlciIsImFkZCIsInByb2Nlc3MiLCJvbmNlIiwic2VydmVyIiwiTXlyU2VydmVyIiwiY3JlYXRlU2VydmVyIiwic3RhcnQiLCJyZW1vdmUiLCJzZW5kIiwiZXJyb3IiLCJuYW1lIiwibWVzc2FnZSIsImV4aXQiXSwibWFwcGluZ3MiOiI7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVBO0FBQ0EsTUFBTUEsS0FBSyxHQUFHLElBQUlDLGlCQUFRQyxVQUFSLENBQW1CQyxPQUF2QixDQUErQjtBQUMzQ0MsRUFBQUEsS0FBSyxFQUFFLE9BRG9DO0FBRTNDQyxFQUFBQSxNQUFNLEVBQUVBLGdCQUFPQyxPQUFQLENBQ05ELGdCQUFPRSxTQUFQLENBQWlCO0FBQUVGLElBQUFBLE1BQU0sRUFBRSxNQUFNLElBQUlHLElBQUosR0FBV0MsY0FBWDtBQUFoQixHQUFqQixDQURNLEVBRU5KLGdCQUFPSyxNQUFQLEVBRk0sRUFHTkwsZ0JBQU9NLElBQVAsRUFITSxDQUZtQztBQU8zQ0MsRUFBQUEsaUJBQWlCLEVBQUUsRUFQd0I7QUFRM0NDLEVBQUFBLFlBQVksRUFBRTtBQVI2QixDQUEvQixDQUFkOztBQVVBQyxpQkFBT0MsR0FBUCxDQUFXZixLQUFYLEUsQ0FFQTs7O0FBQ0FnQixPQUFPLENBQUNDLElBQVIsQ0FBYSxTQUFiLEVBQXdCLFlBQVk7QUFDbEMsTUFBSTtBQUNGO0FBQ0EsVUFBTUMsTUFBTSxHQUFHLE1BQU1DLG1CQUFVQyxZQUFWLEVBQXJCO0FBQ0EsVUFBTUYsTUFBTSxDQUFDRyxLQUFQLEVBQU47O0FBRUFQLHFCQUFPUSxNQUFQLENBQWN0QixLQUFkOztBQUNBZ0IsSUFBQUEsT0FBTyxDQUFDTyxJQUFSLEdBQWUsU0FBZjtBQUNELEdBUEQsQ0FPRSxPQUFPQyxLQUFQLEVBQWM7QUFDZFIsSUFBQUEsT0FBTyxDQUFDTyxJQUFSLEdBQWU7QUFBRUUsTUFBQUEsSUFBSSxFQUFFRCxLQUFLLENBQUNDLElBQWQ7QUFBb0JDLE1BQUFBLE9BQU8sRUFBRUYsS0FBSyxDQUFDRTtBQUFuQyxLQUFmO0FBQ0FWLElBQUFBLE9BQU8sQ0FBQ1csSUFBUixDQUFhLENBQWI7QUFDRDtBQUNGLENBWkQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsb2dnZXIgfSBmcm9tICdAanVqdWxlZ28vamlsbC1jb3JlJztcbmltcG9ydCB7IE15clNlcnZlciB9IGZyb20gJ0BqdWp1bGVnby9qaWxsLW15cic7XG5pbXBvcnQgd2luc3RvbiwgeyBmb3JtYXQgfSBmcm9tICd3aW5zdG9uJztcblxuLy8gU2V0dXAgbG9nZ2VyXG5jb25zdCB0cmFucyA9IG5ldyB3aW5zdG9uLnRyYW5zcG9ydHMuQ29uc29sZSh7XG4gIGxldmVsOiAnZGVidWcnLFxuICBmb3JtYXQ6IGZvcm1hdC5jb21iaW5lKFxuICAgIGZvcm1hdC50aW1lc3RhbXAoeyBmb3JtYXQ6ICgpID0+IG5ldyBEYXRlKCkudG9Mb2NhbGVTdHJpbmcoKSB9KSxcbiAgICBmb3JtYXQuZXJyb3JzKCksXG4gICAgZm9ybWF0Lmpzb24oKVxuICApLFxuICBjb25zb2xlV2FybkxldmVsczogW10sXG4gIHN0ZGVyckxldmVsczogW11cbn0pO1xubG9nZ2VyLmFkZCh0cmFucyk7XG5cbi8vIFN0YXJ0IHNlcnZlciB3aGVuIHBhcmVudCBpcyByZWFkeVxucHJvY2Vzcy5vbmNlKCdtZXNzYWdlJywgYXN5bmMgKCkgPT4ge1xuICB0cnkge1xuICAgIC8vIFN0YXJ0IHNlcnZlclxuICAgIGNvbnN0IHNlcnZlciA9IGF3YWl0IE15clNlcnZlci5jcmVhdGVTZXJ2ZXIoKTtcbiAgICBhd2FpdCBzZXJ2ZXIuc3RhcnQoKTtcblxuICAgIGxvZ2dlci5yZW1vdmUodHJhbnMpO1xuICAgIHByb2Nlc3Muc2VuZD8uKCdzdGFydGVkJyk7XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgcHJvY2Vzcy5zZW5kPy4oeyBuYW1lOiBlcnJvci5uYW1lLCBtZXNzYWdlOiBlcnJvci5tZXNzYWdlIH0pO1xuICAgIHByb2Nlc3MuZXhpdCgxKTtcbiAgfVxufSk7Il0sImZpbGUiOiJteXIvbXlyLnByb2Nlc3MuanMifQ==
@@ -0,0 +1,13 @@
1
+ import { Arguments, Builder } from '../command';
2
+ import { WorkspaceArgs, WorkspaceCommand } from '../workspace.command';
3
+ export interface WatchArgs extends WorkspaceArgs {
4
+ script: string;
5
+ daemon: boolean;
6
+ }
7
+ export declare class WatchCommand extends WorkspaceCommand<WatchArgs> {
8
+ readonly name = "watch <script>";
9
+ readonly description = "Run script with watcher inside workspace and watch over deps";
10
+ private spawnDepsTree;
11
+ protected define<T, U>(builder: Builder<T, U>): Builder<T, U & WatchArgs>;
12
+ protected run(args: Arguments<WatchArgs>): Promise<number>;
13
+ }