@kontur.candy/tools 2.137.0 → 2.138.0

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/CHANGELOG.md CHANGED
@@ -1,3 +1,11 @@
1
+ <a name="2.138.0"></a>
2
+ # [2.138.0](https://git.skbkontur.ru/ke/candy-utils/compare/release/tools/v2.137.0...release/tools/v2.138.0) (2022-11-24)
3
+
4
+
5
+ ### Bug Fixes
6
+
7
+ * **Tools:** Исправлен путь для запуска build-server ([c722891](https://git.skbkontur.ru/ke/candy-utils/commit/c722891))
8
+
1
9
  <a name="2.137.0"></a>
2
10
  # [2.137.0](https://git.skbkontur.ru/ke/candy-utils/compare/release/tools/v2.136.0...release/tools/v2.137.0) (2022-11-24)
3
11
 
package/README.md CHANGED
@@ -293,6 +293,10 @@ Magic
293
293
 
294
294
  Одна или несколько GFV или GFV-масок для пересобрки.
295
295
 
296
+ * `--all-farm-dir (-a)`
297
+
298
+ Позволяет передать массив путей до всех фармов candy, чтобы открывать из всех них формы. Путь передавать относительно keforms.engine
299
+
296
300
  * `--no-client-override`
297
301
 
298
302
  Отключает перехват client.js. В этом случае не будет работать отображение логов сборки и ожидания сборки формы.
@@ -329,6 +333,10 @@ Magic
329
333
 
330
334
  Опция устарела. Оставлена для обратной совместимости.
331
335
 
336
+ * `--all-farm-dir (-a)`
337
+
338
+ Позволяет передать массив путей до всех фармов candy, чтобы открывать из всех них формы. Путь передавать относительно keforms.engine
339
+
332
340
  * `--nightly`
333
341
 
334
342
  Включает сборку форм на движке nightly.
@@ -33,10 +33,10 @@ class DefaultFileWriter {
33
33
 
34
34
  }
35
35
 
36
- async function generateForm(formSourcesPath, farmDirectory, hlFarmDirectoryPath, generator, parentLogger = (0, _StaticLogger.getLogger)(), generationOptions, fileWriter = new DefaultFileWriter()) {
36
+ async function generateForm(formSourcesPath, farmDirectory, hlDirPath, generator, parentLogger = (0, _StaticLogger.getLogger)(), generationOptions, fileWriter = new DefaultFileWriter()) {
37
37
  const logger = parentLogger.withPrefix(`GENERATE:${path.basename(formSourcesPath)}`);
38
38
  const action = (0, _ILogger.buildActionBegin)(logger, "Generation");
39
- const generatedContent = await generator.readSourcesAndProcessSugar(formSourcesPath, farmDirectory, hlFarmDirectoryPath, generationOptions);
39
+ const generatedContent = await generator.readSourcesAndProcessSugar(formSourcesPath, farmDirectory, hlDirPath, generationOptions);
40
40
  logger.log("Writing files");
41
41
  await writeGeneratedFiles(generatedContent, path.join(formSourcesPath, "form"), fileWriter);
42
42
  action.complete();
@@ -55,4 +55,4 @@ async function writeGeneratedFiles(candyFormContent, outputDirectory, fileWriter
55
55
 
56
56
  await fileWriter.writeBatch(fileBatch);
57
57
  }
58
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0Zvcm0vR2VuZXJhdGVGb3JtLnRzIl0sIm5hbWVzIjpbIkRlZmF1bHRGaWxlV3JpdGVyIiwid3JpdGVCYXRjaCIsImZpbGVCYXRjaCIsImZpbGVQYXRoIiwiT2JqZWN0Iiwia2V5cyIsImNvbnRlbnQiLCJ1bmRlZmluZWQiLCJwYXRoIiwicGFyc2UiLCJkaXIiLCJnZW5lcmF0ZUZvcm0iLCJmb3JtU291cmNlc1BhdGgiLCJmYXJtRGlyZWN0b3J5IiwiaGxGYXJtRGlyZWN0b3J5UGF0aCIsImdlbmVyYXRvciIsInBhcmVudExvZ2dlciIsImdlbmVyYXRpb25PcHRpb25zIiwiZmlsZVdyaXRlciIsImxvZ2dlciIsIndpdGhQcmVmaXgiLCJiYXNlbmFtZSIsImFjdGlvbiIsImdlbmVyYXRlZENvbnRlbnQiLCJyZWFkU291cmNlc0FuZFByb2Nlc3NTdWdhciIsImxvZyIsIndyaXRlR2VuZXJhdGVkRmlsZXMiLCJqb2luIiwiY29tcGxldGUiLCJjYW5keUZvcm1Db250ZW50Iiwib3V0cHV0RGlyZWN0b3J5Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBRUE7O0FBRUE7O0FBQ0E7O0FBQ0E7Ozs7OztBQWlEQSxNQUFNQSxpQkFBTixDQUErQztBQUNwQixRQUFWQyxVQUFVLENBQUNDLFNBQUQsRUFBbUU7QUFDdEYsU0FBSyxNQUFNQyxRQUFYLElBQXVCQyxNQUFNLENBQUNDLElBQVAsQ0FBWUgsU0FBWixDQUF2QixFQUErQztBQUMzQyxZQUFNSSxPQUFPLEdBQUdKLFNBQVMsQ0FBQ0MsUUFBRCxDQUF6Qjs7QUFDQSxVQUFJRyxPQUFPLElBQUlDLFNBQVgsSUFBd0JELE9BQU8sS0FBSyxFQUF4QyxFQUE0QztBQUN4QyxjQUFNLHdCQUFVRSxJQUFJLENBQUNDLEtBQUwsQ0FBV04sUUFBWCxFQUFxQk8sR0FBL0IsQ0FBTjtBQUNBLGNBQU0sNkJBQWVQLFFBQWYsRUFBeUJHLE9BQXpCLENBQU47QUFDSDtBQUNKO0FBQ0o7O0FBVDBDOztBQVl4QyxlQUFlSyxZQUFmLENBQ0hDLGVBREcsRUFFSEMsYUFGRyxFQUdIQyxtQkFIRyxFQUlIQyxTQUpHLEVBS0hDLFlBQXFCLEdBQUcsOEJBTHJCLEVBTUhDLGlCQU5HLEVBT0hDLFVBQXVCLEdBQUcsSUFBSWxCLGlCQUFKLEVBUHZCLEVBUVU7QUFDYixRQUFNbUIsTUFBTSxHQUFHSCxZQUFZLENBQUNJLFVBQWIsQ0FBeUIsWUFBV1osSUFBSSxDQUFDYSxRQUFMLENBQWNULGVBQWQsQ0FBK0IsRUFBbkUsQ0FBZjtBQUNBLFFBQU1VLE1BQU0sR0FBRywrQkFBaUJILE1BQWpCLEVBQXlCLFlBQXpCLENBQWY7QUFDQSxRQUFNSSxnQkFBZ0IsR0FBRyxNQUFNUixTQUFTLENBQUNTLDBCQUFWLENBQzNCWixlQUQyQixFQUUzQkMsYUFGMkIsRUFHM0JDLG1CQUgyQixFQUkzQkcsaUJBSjJCLENBQS9CO0FBTUFFLEVBQUFBLE1BQU0sQ0FBQ00sR0FBUCxDQUFXLGVBQVg7QUFDQSxRQUFNQyxtQkFBbUIsQ0FBQ0gsZ0JBQUQsRUFBbUJmLElBQUksQ0FBQ21CLElBQUwsQ0FBVWYsZUFBVixFQUEyQixNQUEzQixDQUFuQixFQUF1RE0sVUFBdkQsQ0FBekI7QUFDQUksRUFBQUEsTUFBTSxDQUFDTSxRQUFQO0FBQ0g7O0FBRUQsZUFBZUYsbUJBQWYsQ0FDSUcsZ0JBREosRUFFSUMsZUFGSixFQUdJWixVQUhKLEVBSWlCO0FBQ2IsUUFBTWhCLFNBQVMsR0FBRyxFQUFsQjs7QUFDQSxPQUFLLE1BQU1DLFFBQVgsSUFBdUJDLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZd0IsZ0JBQVosQ0FBdkIsRUFBc0Q7QUFDbEQsVUFBTXZCLE9BQU8sR0FBR3VCLGdCQUFnQixDQUFDMUIsUUFBRCxDQUFoQzs7QUFDQSxRQUFJRyxPQUFPLElBQUlDLFNBQVgsSUFBd0JELE9BQU8sS0FBSyxFQUF4QyxFQUE0QztBQUN4Q0osTUFBQUEsU0FBUyxDQUFDTSxJQUFJLENBQUNtQixJQUFMLENBQVVHLGVBQVYsRUFBMkIzQixRQUEzQixDQUFELENBQVQsR0FBa0RHLE9BQWxEO0FBQ0g7QUFDSjs7QUFDRCxRQUFNWSxVQUFVLENBQUNqQixVQUFYLENBQXNCQyxTQUF0QixDQUFOO0FBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwYXRoIGZyb20gXCJwYXRoXCI7XG5cbmltcG9ydCB7IGVuc3VyZURpciB9IGZyb20gXCJmcy1leHRyYVwiO1xuXG5pbXBvcnQgeyB3cml0ZUZpbGVBc3luYyB9IGZyb20gXCIuLi8uLi9Db21tb25zL0ZzVXRpbHNcIjtcbmltcG9ydCB7IGJ1aWxkQWN0aW9uQmVnaW4sIElMb2dnZXIgfSBmcm9tIFwiLi4vLi4vQ29tbW9ucy9Mb2dnaW5nL0lMb2dnZXJcIjtcbmltcG9ydCB7IGdldExvZ2dlciB9IGZyb20gXCIuLi8uLi9Db21tb25zL0xvZ2dpbmcvU3RhdGljTG9nZ2VyXCI7XG5pbXBvcnQgeyBGb3JtUmVzb3VyY2VzLCBGb3JtU291cmNlLCBTdWdhckNvbnRlbnQgfSBmcm9tIFwiLi4vUmVhZEZvcm1Tb3VyY2VcIjtcblxuZXhwb3J0IGludGVyZmFjZSBHZW5lcmF0ZWRGb3JtIHtcbiAgICBbcmVsYXRpdmVGaWxlTmFtZTogc3RyaW5nXTogQnVmZmVyIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsaXphdGlvbkRpY3Rpb25hcnlDb250ZW50IHtcbiAgICBbcmVsYXRpdmVGaWxlTmFtZTogc3RyaW5nXTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsaXphdGlvbkVudHJ5UG9pbnQge1xuICAgIGdldExvY2FsaXplZFN1Z2FyKHN1Z2FyRmlsZXM6IFN1Z2FyQ29udGVudCwgcmVzb3VyY2VzOiBGb3JtUmVzb3VyY2VzKTogUHJvbWlzZTxTdWdhckNvbnRlbnQ+O1xuICAgIGdldERpY3Rpb25hcnkoc3VnYXJGaWxlczogU3VnYXJDb250ZW50LCByZXNvdXJjZXM6IEZvcm1SZXNvdXJjZXMpOiBQcm9taXNlPExvY2FsaXphdGlvbkRpY3Rpb25hcnlDb250ZW50Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGb3JtR2VuZXJhdG9yIHtcbiAgICByZWFkU291cmNlcyhmb3JtU291cmNlc1BhdGg6IHN0cmluZywgZmFybURpcmVjdG9yeTogc3RyaW5nLCBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmcpOiBQcm9taXNlPEZvcm1Tb3VyY2U+O1xuICAgIGdldEFsbERlcGVuZGVuY2llcyhmb3JtU291cmNlc1BhdGg6IHN0cmluZywgZmFybURpcmVjdG9yeTogc3RyaW5nLCBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZ1tdPjtcbiAgICBnZXRBbGxEZXBlbmRlbmNpZXNIYXNoKFxuICAgICAgICBmb3JtU291cmNlc1BhdGg6IHN0cmluZyxcbiAgICAgICAgZmFybURpcmVjdG9yeTogc3RyaW5nLFxuICAgICAgICBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmdcbiAgICApOiBQcm9taXNlPHN0cmluZz47XG4gICAgc3VwcG9ydHNEZXBlbmRlbmNpZXNFeHRyYWN0aW9uKCk6IFByb21pc2U8Ym9vbGVhbj47XG4gICAgcHJvY2Vzc1N1Z2FyKFxuICAgICAgICBzdWdhckZpbGVzOiBTdWdhckNvbnRlbnQsXG4gICAgICAgIHJlc291cmNlczogRm9ybVJlc291cmNlcyxcbiAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnM/OiBHZW5lcmF0aW9uT3B0aW9uc1xuICAgICk6IFByb21pc2U8R2VuZXJhdGVkRm9ybT47XG4gICAgcmVhZFNvdXJjZXNBbmRQcm9jZXNzU3VnYXIoXG4gICAgICAgIGZvcm1Tb3VyY2VzUGF0aDogc3RyaW5nLFxuICAgICAgICBmYXJtRGlyZWN0b3J5OiBzdHJpbmcsXG4gICAgICAgIGhsRmFybURpcmVjdG9yeVBhdGg6IHN0cmluZyxcbiAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnM/OiBHZW5lcmF0aW9uT3B0aW9uc1xuICAgICk6IFByb21pc2U8R2VuZXJhdGVkRm9ybT47XG4gICAgZ2V0TG9jYWxpemVkU3VnYXIoc3VnYXJGaWxlczogU3VnYXJDb250ZW50LCByZXNvdXJjZXM6IEZvcm1SZXNvdXJjZXMpOiBQcm9taXNlPFN1Z2FyQ29udGVudD47XG4gICAgZ2V0RGljdGlvbmFyeShzdWdhckZpbGVzOiBTdWdhckNvbnRlbnQsIHJlc291cmNlczogRm9ybVJlc291cmNlcyk6IFByb21pc2U8TG9jYWxpemF0aW9uRGljdGlvbmFyeUNvbnRlbnQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdlbmVyYXRpb25PcHRpb25zIHtcbiAgICBza2lwQ29kZVJlZm9ybWF0dGluZzogYm9vbGVhbjtcbiAgICByZXNvdXJjZXNIYXNoOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUZpbGVXcml0ZXIge1xuICAgIHdyaXRlQmF0Y2goZmlsZUJhdGNoOiB7IFthYnNvbHV0ZUZpbGVOYW1lOiBzdHJpbmddOiBzdHJpbmcgfSk6IFByb21pc2U8dm9pZD47XG59XG5cbmNsYXNzIERlZmF1bHRGaWxlV3JpdGVyIGltcGxlbWVudHMgSUZpbGVXcml0ZXIge1xuICAgIHB1YmxpYyBhc3luYyB3cml0ZUJhdGNoKGZpbGVCYXRjaDogeyBbYWJzb2x1dGVGaWxlTmFtZTogc3RyaW5nXTogc3RyaW5nIH0pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgZm9yIChjb25zdCBmaWxlUGF0aCBvZiBPYmplY3Qua2V5cyhmaWxlQmF0Y2gpKSB7XG4gICAgICAgICAgICBjb25zdCBjb250ZW50ID0gZmlsZUJhdGNoW2ZpbGVQYXRoXTtcbiAgICAgICAgICAgIGlmIChjb250ZW50ICE9IHVuZGVmaW5lZCAmJiBjb250ZW50ICE9PSBcIlwiKSB7XG4gICAgICAgICAgICAgICAgYXdhaXQgZW5zdXJlRGlyKHBhdGgucGFyc2UoZmlsZVBhdGgpLmRpcik7XG4gICAgICAgICAgICAgICAgYXdhaXQgd3JpdGVGaWxlQXN5bmMoZmlsZVBhdGgsIGNvbnRlbnQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2VuZXJhdGVGb3JtKFxuICAgIGZvcm1Tb3VyY2VzUGF0aDogc3RyaW5nLFxuICAgIGZhcm1EaXJlY3Rvcnk6IHN0cmluZyxcbiAgICBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmcsXG4gICAgZ2VuZXJhdG9yOiBGb3JtR2VuZXJhdG9yLFxuICAgIHBhcmVudExvZ2dlcjogSUxvZ2dlciA9IGdldExvZ2dlcigpLFxuICAgIGdlbmVyYXRpb25PcHRpb25zPzogR2VuZXJhdGlvbk9wdGlvbnMsXG4gICAgZmlsZVdyaXRlcjogSUZpbGVXcml0ZXIgPSBuZXcgRGVmYXVsdEZpbGVXcml0ZXIoKVxuKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgbG9nZ2VyID0gcGFyZW50TG9nZ2VyLndpdGhQcmVmaXgoYEdFTkVSQVRFOiR7cGF0aC5iYXNlbmFtZShmb3JtU291cmNlc1BhdGgpfWApO1xuICAgIGNvbnN0IGFjdGlvbiA9IGJ1aWxkQWN0aW9uQmVnaW4obG9nZ2VyLCBcIkdlbmVyYXRpb25cIik7XG4gICAgY29uc3QgZ2VuZXJhdGVkQ29udGVudCA9IGF3YWl0IGdlbmVyYXRvci5yZWFkU291cmNlc0FuZFByb2Nlc3NTdWdhcihcbiAgICAgICAgZm9ybVNvdXJjZXNQYXRoLFxuICAgICAgICBmYXJtRGlyZWN0b3J5LFxuICAgICAgICBobEZhcm1EaXJlY3RvcnlQYXRoLFxuICAgICAgICBnZW5lcmF0aW9uT3B0aW9uc1xuICAgICk7XG4gICAgbG9nZ2VyLmxvZyhcIldyaXRpbmcgZmlsZXNcIik7XG4gICAgYXdhaXQgd3JpdGVHZW5lcmF0ZWRGaWxlcyhnZW5lcmF0ZWRDb250ZW50LCBwYXRoLmpvaW4oZm9ybVNvdXJjZXNQYXRoLCBcImZvcm1cIiksIGZpbGVXcml0ZXIpO1xuICAgIGFjdGlvbi5jb21wbGV0ZSgpO1xufVxuXG5hc3luYyBmdW5jdGlvbiB3cml0ZUdlbmVyYXRlZEZpbGVzKFxuICAgIGNhbmR5Rm9ybUNvbnRlbnQ6IEdlbmVyYXRlZEZvcm0sXG4gICAgb3V0cHV0RGlyZWN0b3J5OiBzdHJpbmcsXG4gICAgZmlsZVdyaXRlcjogSUZpbGVXcml0ZXJcbik6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGZpbGVCYXRjaCA9IHt9O1xuICAgIGZvciAoY29uc3QgZmlsZVBhdGggb2YgT2JqZWN0LmtleXMoY2FuZHlGb3JtQ29udGVudCkpIHtcbiAgICAgICAgY29uc3QgY29udGVudCA9IGNhbmR5Rm9ybUNvbnRlbnRbZmlsZVBhdGhdO1xuICAgICAgICBpZiAoY29udGVudCAhPSB1bmRlZmluZWQgJiYgY29udGVudCAhPT0gXCJcIikge1xuICAgICAgICAgICAgZmlsZUJhdGNoW3BhdGguam9pbihvdXRwdXREaXJlY3RvcnksIGZpbGVQYXRoKV0gPSBjb250ZW50O1xuICAgICAgICB9XG4gICAgfVxuICAgIGF3YWl0IGZpbGVXcml0ZXIud3JpdGVCYXRjaChmaWxlQmF0Y2gpO1xufVxuIl19
58
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0Zvcm0vR2VuZXJhdGVGb3JtLnRzIl0sIm5hbWVzIjpbIkRlZmF1bHRGaWxlV3JpdGVyIiwid3JpdGVCYXRjaCIsImZpbGVCYXRjaCIsImZpbGVQYXRoIiwiT2JqZWN0Iiwia2V5cyIsImNvbnRlbnQiLCJ1bmRlZmluZWQiLCJwYXRoIiwicGFyc2UiLCJkaXIiLCJnZW5lcmF0ZUZvcm0iLCJmb3JtU291cmNlc1BhdGgiLCJmYXJtRGlyZWN0b3J5IiwiaGxEaXJQYXRoIiwiZ2VuZXJhdG9yIiwicGFyZW50TG9nZ2VyIiwiZ2VuZXJhdGlvbk9wdGlvbnMiLCJmaWxlV3JpdGVyIiwibG9nZ2VyIiwid2l0aFByZWZpeCIsImJhc2VuYW1lIiwiYWN0aW9uIiwiZ2VuZXJhdGVkQ29udGVudCIsInJlYWRTb3VyY2VzQW5kUHJvY2Vzc1N1Z2FyIiwibG9nIiwid3JpdGVHZW5lcmF0ZWRGaWxlcyIsImpvaW4iLCJjb21wbGV0ZSIsImNhbmR5Rm9ybUNvbnRlbnQiLCJvdXRwdXREaXJlY3RvcnkiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFFQTs7QUFFQTs7QUFDQTs7QUFDQTs7Ozs7O0FBaURBLE1BQU1BLGlCQUFOLENBQStDO0FBQ3BCLFFBQVZDLFVBQVUsQ0FBQ0MsU0FBRCxFQUFtRTtBQUN0RixTQUFLLE1BQU1DLFFBQVgsSUFBdUJDLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZSCxTQUFaLENBQXZCLEVBQStDO0FBQzNDLFlBQU1JLE9BQU8sR0FBR0osU0FBUyxDQUFDQyxRQUFELENBQXpCOztBQUNBLFVBQUlHLE9BQU8sSUFBSUMsU0FBWCxJQUF3QkQsT0FBTyxLQUFLLEVBQXhDLEVBQTRDO0FBQ3hDLGNBQU0sd0JBQVVFLElBQUksQ0FBQ0MsS0FBTCxDQUFXTixRQUFYLEVBQXFCTyxHQUEvQixDQUFOO0FBQ0EsY0FBTSw2QkFBZVAsUUFBZixFQUF5QkcsT0FBekIsQ0FBTjtBQUNIO0FBQ0o7QUFDSjs7QUFUMEM7O0FBWXhDLGVBQWVLLFlBQWYsQ0FDSEMsZUFERyxFQUVIQyxhQUZHLEVBR0hDLFNBSEcsRUFJSEMsU0FKRyxFQUtIQyxZQUFxQixHQUFHLDhCQUxyQixFQU1IQyxpQkFORyxFQU9IQyxVQUF1QixHQUFHLElBQUlsQixpQkFBSixFQVB2QixFQVFVO0FBQ2IsUUFBTW1CLE1BQU0sR0FBR0gsWUFBWSxDQUFDSSxVQUFiLENBQXlCLFlBQVdaLElBQUksQ0FBQ2EsUUFBTCxDQUFjVCxlQUFkLENBQStCLEVBQW5FLENBQWY7QUFDQSxRQUFNVSxNQUFNLEdBQUcsK0JBQWlCSCxNQUFqQixFQUF5QixZQUF6QixDQUFmO0FBQ0EsUUFBTUksZ0JBQWdCLEdBQUcsTUFBTVIsU0FBUyxDQUFDUywwQkFBVixDQUMzQlosZUFEMkIsRUFFM0JDLGFBRjJCLEVBRzNCQyxTQUgyQixFQUkzQkcsaUJBSjJCLENBQS9CO0FBTUFFLEVBQUFBLE1BQU0sQ0FBQ00sR0FBUCxDQUFXLGVBQVg7QUFDQSxRQUFNQyxtQkFBbUIsQ0FBQ0gsZ0JBQUQsRUFBbUJmLElBQUksQ0FBQ21CLElBQUwsQ0FBVWYsZUFBVixFQUEyQixNQUEzQixDQUFuQixFQUF1RE0sVUFBdkQsQ0FBekI7QUFDQUksRUFBQUEsTUFBTSxDQUFDTSxRQUFQO0FBQ0g7O0FBRUQsZUFBZUYsbUJBQWYsQ0FDSUcsZ0JBREosRUFFSUMsZUFGSixFQUdJWixVQUhKLEVBSWlCO0FBQ2IsUUFBTWhCLFNBQVMsR0FBRyxFQUFsQjs7QUFDQSxPQUFLLE1BQU1DLFFBQVgsSUFBdUJDLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZd0IsZ0JBQVosQ0FBdkIsRUFBc0Q7QUFDbEQsVUFBTXZCLE9BQU8sR0FBR3VCLGdCQUFnQixDQUFDMUIsUUFBRCxDQUFoQzs7QUFDQSxRQUFJRyxPQUFPLElBQUlDLFNBQVgsSUFBd0JELE9BQU8sS0FBSyxFQUF4QyxFQUE0QztBQUN4Q0osTUFBQUEsU0FBUyxDQUFDTSxJQUFJLENBQUNtQixJQUFMLENBQVVHLGVBQVYsRUFBMkIzQixRQUEzQixDQUFELENBQVQsR0FBa0RHLE9BQWxEO0FBQ0g7QUFDSjs7QUFDRCxRQUFNWSxVQUFVLENBQUNqQixVQUFYLENBQXNCQyxTQUF0QixDQUFOO0FBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwYXRoIGZyb20gXCJwYXRoXCI7XG5cbmltcG9ydCB7IGVuc3VyZURpciB9IGZyb20gXCJmcy1leHRyYVwiO1xuXG5pbXBvcnQgeyB3cml0ZUZpbGVBc3luYyB9IGZyb20gXCIuLi8uLi9Db21tb25zL0ZzVXRpbHNcIjtcbmltcG9ydCB7IGJ1aWxkQWN0aW9uQmVnaW4sIElMb2dnZXIgfSBmcm9tIFwiLi4vLi4vQ29tbW9ucy9Mb2dnaW5nL0lMb2dnZXJcIjtcbmltcG9ydCB7IGdldExvZ2dlciB9IGZyb20gXCIuLi8uLi9Db21tb25zL0xvZ2dpbmcvU3RhdGljTG9nZ2VyXCI7XG5pbXBvcnQgeyBGb3JtUmVzb3VyY2VzLCBGb3JtU291cmNlLCBTdWdhckNvbnRlbnQgfSBmcm9tIFwiLi4vUmVhZEZvcm1Tb3VyY2VcIjtcblxuZXhwb3J0IGludGVyZmFjZSBHZW5lcmF0ZWRGb3JtIHtcbiAgICBbcmVsYXRpdmVGaWxlTmFtZTogc3RyaW5nXTogQnVmZmVyIHwgc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsaXphdGlvbkRpY3Rpb25hcnlDb250ZW50IHtcbiAgICBbcmVsYXRpdmVGaWxlTmFtZTogc3RyaW5nXTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsaXphdGlvbkVudHJ5UG9pbnQge1xuICAgIGdldExvY2FsaXplZFN1Z2FyKHN1Z2FyRmlsZXM6IFN1Z2FyQ29udGVudCwgcmVzb3VyY2VzOiBGb3JtUmVzb3VyY2VzKTogUHJvbWlzZTxTdWdhckNvbnRlbnQ+O1xuICAgIGdldERpY3Rpb25hcnkoc3VnYXJGaWxlczogU3VnYXJDb250ZW50LCByZXNvdXJjZXM6IEZvcm1SZXNvdXJjZXMpOiBQcm9taXNlPExvY2FsaXphdGlvbkRpY3Rpb25hcnlDb250ZW50Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGb3JtR2VuZXJhdG9yIHtcbiAgICByZWFkU291cmNlcyhmb3JtU291cmNlc1BhdGg6IHN0cmluZywgZmFybURpcmVjdG9yeTogc3RyaW5nLCBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmcpOiBQcm9taXNlPEZvcm1Tb3VyY2U+O1xuICAgIGdldEFsbERlcGVuZGVuY2llcyhmb3JtU291cmNlc1BhdGg6IHN0cmluZywgZmFybURpcmVjdG9yeTogc3RyaW5nLCBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZ1tdPjtcbiAgICBnZXRBbGxEZXBlbmRlbmNpZXNIYXNoKFxuICAgICAgICBmb3JtU291cmNlc1BhdGg6IHN0cmluZyxcbiAgICAgICAgZmFybURpcmVjdG9yeTogc3RyaW5nLFxuICAgICAgICBobEZhcm1EaXJlY3RvcnlQYXRoOiBzdHJpbmdcbiAgICApOiBQcm9taXNlPHN0cmluZz47XG4gICAgc3VwcG9ydHNEZXBlbmRlbmNpZXNFeHRyYWN0aW9uKCk6IFByb21pc2U8Ym9vbGVhbj47XG4gICAgcHJvY2Vzc1N1Z2FyKFxuICAgICAgICBzdWdhckZpbGVzOiBTdWdhckNvbnRlbnQsXG4gICAgICAgIHJlc291cmNlczogRm9ybVJlc291cmNlcyxcbiAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnM/OiBHZW5lcmF0aW9uT3B0aW9uc1xuICAgICk6IFByb21pc2U8R2VuZXJhdGVkRm9ybT47XG4gICAgcmVhZFNvdXJjZXNBbmRQcm9jZXNzU3VnYXIoXG4gICAgICAgIGZvcm1Tb3VyY2VzUGF0aDogc3RyaW5nLFxuICAgICAgICBmYXJtRGlyZWN0b3J5OiBzdHJpbmcsXG4gICAgICAgIGhsRmFybURpcmVjdG9yeVBhdGg6IHN0cmluZyxcbiAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnM/OiBHZW5lcmF0aW9uT3B0aW9uc1xuICAgICk6IFByb21pc2U8R2VuZXJhdGVkRm9ybT47XG4gICAgZ2V0TG9jYWxpemVkU3VnYXIoc3VnYXJGaWxlczogU3VnYXJDb250ZW50LCByZXNvdXJjZXM6IEZvcm1SZXNvdXJjZXMpOiBQcm9taXNlPFN1Z2FyQ29udGVudD47XG4gICAgZ2V0RGljdGlvbmFyeShzdWdhckZpbGVzOiBTdWdhckNvbnRlbnQsIHJlc291cmNlczogRm9ybVJlc291cmNlcyk6IFByb21pc2U8TG9jYWxpemF0aW9uRGljdGlvbmFyeUNvbnRlbnQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdlbmVyYXRpb25PcHRpb25zIHtcbiAgICBza2lwQ29kZVJlZm9ybWF0dGluZzogYm9vbGVhbjtcbiAgICByZXNvdXJjZXNIYXNoOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUZpbGVXcml0ZXIge1xuICAgIHdyaXRlQmF0Y2goZmlsZUJhdGNoOiB7IFthYnNvbHV0ZUZpbGVOYW1lOiBzdHJpbmddOiBzdHJpbmcgfSk6IFByb21pc2U8dm9pZD47XG59XG5cbmNsYXNzIERlZmF1bHRGaWxlV3JpdGVyIGltcGxlbWVudHMgSUZpbGVXcml0ZXIge1xuICAgIHB1YmxpYyBhc3luYyB3cml0ZUJhdGNoKGZpbGVCYXRjaDogeyBbYWJzb2x1dGVGaWxlTmFtZTogc3RyaW5nXTogc3RyaW5nIH0pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAgICAgZm9yIChjb25zdCBmaWxlUGF0aCBvZiBPYmplY3Qua2V5cyhmaWxlQmF0Y2gpKSB7XG4gICAgICAgICAgICBjb25zdCBjb250ZW50ID0gZmlsZUJhdGNoW2ZpbGVQYXRoXTtcbiAgICAgICAgICAgIGlmIChjb250ZW50ICE9IHVuZGVmaW5lZCAmJiBjb250ZW50ICE9PSBcIlwiKSB7XG4gICAgICAgICAgICAgICAgYXdhaXQgZW5zdXJlRGlyKHBhdGgucGFyc2UoZmlsZVBhdGgpLmRpcik7XG4gICAgICAgICAgICAgICAgYXdhaXQgd3JpdGVGaWxlQXN5bmMoZmlsZVBhdGgsIGNvbnRlbnQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2VuZXJhdGVGb3JtKFxuICAgIGZvcm1Tb3VyY2VzUGF0aDogc3RyaW5nLFxuICAgIGZhcm1EaXJlY3Rvcnk6IHN0cmluZyxcbiAgICBobERpclBhdGg6IHN0cmluZyxcbiAgICBnZW5lcmF0b3I6IEZvcm1HZW5lcmF0b3IsXG4gICAgcGFyZW50TG9nZ2VyOiBJTG9nZ2VyID0gZ2V0TG9nZ2VyKCksXG4gICAgZ2VuZXJhdGlvbk9wdGlvbnM/OiBHZW5lcmF0aW9uT3B0aW9ucyxcbiAgICBmaWxlV3JpdGVyOiBJRmlsZVdyaXRlciA9IG5ldyBEZWZhdWx0RmlsZVdyaXRlcigpXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBsb2dnZXIgPSBwYXJlbnRMb2dnZXIud2l0aFByZWZpeChgR0VORVJBVEU6JHtwYXRoLmJhc2VuYW1lKGZvcm1Tb3VyY2VzUGF0aCl9YCk7XG4gICAgY29uc3QgYWN0aW9uID0gYnVpbGRBY3Rpb25CZWdpbihsb2dnZXIsIFwiR2VuZXJhdGlvblwiKTtcbiAgICBjb25zdCBnZW5lcmF0ZWRDb250ZW50ID0gYXdhaXQgZ2VuZXJhdG9yLnJlYWRTb3VyY2VzQW5kUHJvY2Vzc1N1Z2FyKFxuICAgICAgICBmb3JtU291cmNlc1BhdGgsXG4gICAgICAgIGZhcm1EaXJlY3RvcnksXG4gICAgICAgIGhsRGlyUGF0aCxcbiAgICAgICAgZ2VuZXJhdGlvbk9wdGlvbnNcbiAgICApO1xuICAgIGxvZ2dlci5sb2coXCJXcml0aW5nIGZpbGVzXCIpO1xuICAgIGF3YWl0IHdyaXRlR2VuZXJhdGVkRmlsZXMoZ2VuZXJhdGVkQ29udGVudCwgcGF0aC5qb2luKGZvcm1Tb3VyY2VzUGF0aCwgXCJmb3JtXCIpLCBmaWxlV3JpdGVyKTtcbiAgICBhY3Rpb24uY29tcGxldGUoKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gd3JpdGVHZW5lcmF0ZWRGaWxlcyhcbiAgICBjYW5keUZvcm1Db250ZW50OiBHZW5lcmF0ZWRGb3JtLFxuICAgIG91dHB1dERpcmVjdG9yeTogc3RyaW5nLFxuICAgIGZpbGVXcml0ZXI6IElGaWxlV3JpdGVyXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBmaWxlQmF0Y2ggPSB7fTtcbiAgICBmb3IgKGNvbnN0IGZpbGVQYXRoIG9mIE9iamVjdC5rZXlzKGNhbmR5Rm9ybUNvbnRlbnQpKSB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSBjYW5keUZvcm1Db250ZW50W2ZpbGVQYXRoXTtcbiAgICAgICAgaWYgKGNvbnRlbnQgIT0gdW5kZWZpbmVkICYmIGNvbnRlbnQgIT09IFwiXCIpIHtcbiAgICAgICAgICAgIGZpbGVCYXRjaFtwYXRoLmpvaW4ob3V0cHV0RGlyZWN0b3J5LCBmaWxlUGF0aCldID0gY29udGVudDtcbiAgICAgICAgfVxuICAgIH1cbiAgICBhd2FpdCBmaWxlV3JpdGVyLndyaXRlQmF0Y2goZmlsZUJhdGNoKTtcbn1cbiJdfQ==
@@ -98,7 +98,7 @@ class GeneratorAsyncProxy {
98
98
 
99
99
  if (this.useGeneratorRestarting) {
100
100
  if (this.maxRequestNumber % 10 === 0) {
101
- console.log("Restaring generator");
101
+ console.log("Restarting generator");
102
102
  this.generatorProcess.kill();
103
103
  this.generatorProcess = undefined;
104
104
  this.generatorProcess = this.forkReadSourcesAndProcessSugarWorker();
@@ -206,4 +206,4 @@ function createAsyncGenerator(pathToGeneratorRootDir, purgeCache, useGeneratorRe
206
206
 
207
207
  return result;
208
208
  }
209
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../src/BuildTasks/Generator/GeneratorWorker/CreateAsyncGenerator.ts"],"names":["GeneratorAsyncProxy","constructor","pathToGeneratorRootDir","purgeCache","useGeneratorRestarting","logger","generatorSourcesImporter","generatorProcess","maxRequestNumber","processSugarDeferredMap","Map","GeneratorSourcesImporter","getLocalizedSugar","sugarFiles","resources","localizationEntryPoint","importLocalization","undefined","Error","getDictionary","readSources","formSourcesPath","farmDirectory","hlFarmDirectoryPath","importReadSources","formSource","getAllDependencies","importGetAllDependencies","supportsDependenciesExtraction","getAllDependenciesHash","importGetAllDependenciesHash","readSourcesAndProcessSugar","generationOptions","currentRequestNumber","promise","Promise","resolve","reject","set","forkReadSourcesAndProcessSugarWorker","console","log","kill","send","result","delete","processSugar","forkProcessSugarWorker","processSugarWorker","cwd","__dirname","on","response","currentDeferred","get","requestNumber","type","errorText","formContent","generatedForm","key","formContentItem","Buffer","from","payload","encoding","error","generatorsCache","createAsyncGenerator"],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport { ChildProcess, fork } from \"child_process\";\n\nimport { ILogger } from \"../../../Commons/Logging/ILogger\";\nimport { getLogger } from \"../../../Commons/Logging/StaticLogger\";\nimport {\n    FormGenerator,\n    GeneratedForm,\n    GenerationOptions,\n    LocalizationDictionaryContent,\n} from \"../../Form/GenerateForm\";\nimport { FormResources, FormSource, SugarContent } from \"../../ReadFormSource\";\nimport { iterateEntries } from \"../../../../../Common/IterableUtils\";\n\nimport { GeneratorSourcesImporter } from \"./GeneratorRequireUtils\";\nimport { CallResponse } from \"./ProcessSugarWorker\";\n\ninterface ProcessSugarDeferred {\n    resolve: (result: GeneratedForm) => void;\n    reject: (error: unknown) => void;\n}\n\nclass GeneratorAsyncProxy implements FormGenerator {\n    private readonly pathToGeneratorRootDir: string;\n    private readonly generatorSourcesImporter: GeneratorSourcesImporter;\n    private readonly purgeCache: boolean;\n    private readonly useGeneratorRestarting: boolean;\n    private generatorProcess?: ChildProcess;\n    private maxRequestNumber = 0;\n    private readonly processSugarDeferredMap: Map<number, ProcessSugarDeferred> = new Map();\n\n    public constructor(\n        pathToGeneratorRootDir: string,\n        purgeCache: boolean,\n        useGeneratorRestarting: boolean,\n        logger: ILogger = getLogger()\n    ) {\n        this.useGeneratorRestarting = useGeneratorRestarting;\n        this.pathToGeneratorRootDir = pathToGeneratorRootDir;\n        this.purgeCache = purgeCache;\n        this.generatorSourcesImporter = new GeneratorSourcesImporter(purgeCache);\n    }\n\n    public async getLocalizedSugar(sugarFiles: SugarContent, resources: FormResources): Promise<SugarContent> {\n        const localizationEntryPoint = await this.generatorSourcesImporter.importLocalization(\n            this.pathToGeneratorRootDir\n        );\n        if (localizationEntryPoint == undefined) {\n            throw new Error(\"Данная версия генератора не поддерживает локализацию.\");\n        }\n        return localizationEntryPoint.getLocalizedSugar(sugarFiles, resources);\n    }\n\n    public async getDictionary(\n        sugarFiles: SugarContent,\n        resources: FormResources\n    ): Promise<LocalizationDictionaryContent> {\n        const localizationEntryPoint = await this.generatorSourcesImporter.importLocalization(\n            this.pathToGeneratorRootDir\n        );\n        if (localizationEntryPoint == undefined) {\n            throw new Error(\"Данная версия генератора не поддерживает локализацию.\");\n        }\n        return localizationEntryPoint.getDictionary(sugarFiles, resources);\n    }\n\n    public async readSources(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string\n    ): Promise<FormSource> {\n        const readSources: FormGenerator[\"readSources\"] = await this.generatorSourcesImporter.importReadSources(\n            this.pathToGeneratorRootDir\n        );\n        const formSource = await readSources(formSourcesPath, farmDirectory, hlFarmDirectoryPath);\n\n        return formSource;\n    }\n\n    public async getAllDependencies(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string\n    ): Promise<string[]> {\n        const getAllDependencies = await this.generatorSourcesImporter.importGetAllDependencies(\n            this.pathToGeneratorRootDir\n        );\n        if (getAllDependencies == undefined) {\n            throw new Error(\"This version of generator does not support dependencies extraction\");\n        }\n        const formSource = await getAllDependencies(formSourcesPath, farmDirectory, hlFarmDirectoryPath);\n        return formSource;\n    }\n\n    public async supportsDependenciesExtraction(): Promise<boolean> {\n        const getAllDependenciesHash = await this.generatorSourcesImporter.importGetAllDependenciesHash(\n            this.pathToGeneratorRootDir\n        );\n        return getAllDependenciesHash != undefined;\n    }\n\n    public async getAllDependenciesHash(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string\n    ): Promise<string> {\n        const getAllDependenciesHash = await this.generatorSourcesImporter.importGetAllDependenciesHash(\n            this.pathToGeneratorRootDir\n        );\n        if (getAllDependenciesHash == undefined) {\n            throw new Error(\"This version of generator does not support dependencies extraction\");\n        }\n        const formSource = await getAllDependenciesHash(formSourcesPath, farmDirectory, hlFarmDirectoryPath);\n        return formSource;\n    }\n\n    public async readSourcesAndProcessSugar(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string,\n        generationOptions?: GenerationOptions\n    ): Promise<GeneratedForm> {\n        this.maxRequestNumber++;\n        const currentRequestNumber = this.maxRequestNumber;\n        const promise = new Promise<GeneratedForm>((resolve, reject) => {\n            this.processSugarDeferredMap.set(currentRequestNumber, {\n                resolve: resolve,\n                reject: reject,\n            });\n        });\n\n        if (!this.generatorProcess) {\n            this.generatorProcess = this.forkReadSourcesAndProcessSugarWorker();\n        }\n        if (this.useGeneratorRestarting) {\n            if (this.maxRequestNumber % 10 === 0) {\n                console.log(\"Restaring generator\");\n                this.generatorProcess.kill();\n                this.generatorProcess = undefined;\n                this.generatorProcess = this.forkReadSourcesAndProcessSugarWorker();\n                console.log(\"Restarted generator\");\n            }\n        }\n\n        this.generatorProcess.send([\n            this.pathToGeneratorRootDir,\n            formSourcesPath,\n            farmDirectory,\n            hlFarmDirectoryPath,\n            generationOptions,\n            this.purgeCache,\n            currentRequestNumber,\n        ]);\n\n        const result = await promise;\n        this.processSugarDeferredMap.delete(currentRequestNumber);\n        return result;\n    }\n\n    public async processSugar(\n        sugarFiles: SugarContent,\n        resources: FormResources,\n        generationOptions?: GenerationOptions\n    ): Promise<GeneratedForm> {\n        this.maxRequestNumber++;\n        const currentRequestNumber = this.maxRequestNumber;\n        const promise = new Promise<GeneratedForm>((resolve, reject) => {\n            this.processSugarDeferredMap.set(currentRequestNumber, {\n                resolve: resolve,\n                reject: reject,\n            });\n        });\n\n        if (!this.generatorProcess) {\n            this.generatorProcess = this.forkProcessSugarWorker();\n        }\n\n        this.generatorProcess.send([\n            this.pathToGeneratorRootDir,\n            sugarFiles,\n            resources,\n            generationOptions,\n            this.purgeCache,\n            currentRequestNumber,\n        ]);\n\n        const result = await promise;\n        this.processSugarDeferredMap.delete(currentRequestNumber);\n        return result;\n    }\n\n    private forkProcessSugarWorker(): ChildProcess {\n        const processSugarWorker = fork(\"./ProcessSugarWorker\", [], {\n            cwd: __dirname,\n        });\n\n        processSugarWorker.on(\"message\", (response: CallResponse) => {\n            const currentDeferred = this.processSugarDeferredMap.get(response.requestNumber);\n            if (currentDeferred == undefined) {\n                return;\n            }\n            if (response.type === \"Error\") {\n                currentDeferred.reject(new Error(response.errorText));\n            } else {\n                const formContent = response.generatedForm;\n                const result: GeneratedForm = {};\n\n                for (const [key, formContentItem] of iterateEntries(formContent)) {\n                    result[key] =\n                        typeof formContentItem === \"string\"\n                            ? formContentItem\n                            : Buffer.from(formContentItem.payload, formContentItem.encoding);\n                }\n\n                currentDeferred.resolve(result);\n            }\n        });\n\n        processSugarWorker.on(\"error\", error => {\n            throw error;\n        });\n\n        return processSugarWorker;\n    }\n\n    private forkReadSourcesAndProcessSugarWorker(): ChildProcess {\n        const processSugarWorker = fork(\"./ReadSourcesAndProcessSugarWorker\", [], {\n            cwd: __dirname,\n        });\n\n        processSugarWorker.on(\"message\", (response: CallResponse) => {\n            const currentDeferred = this.processSugarDeferredMap.get(response.requestNumber);\n            if (currentDeferred == undefined) {\n                return;\n            }\n            if (response.type === \"Error\") {\n                currentDeferred.reject(new Error(response.errorText));\n            } else {\n                const formContent = response.generatedForm;\n                const result: GeneratedForm = {};\n\n                for (const [key, formContentItem] of iterateEntries(formContent)) {\n                    result[key] =\n                        typeof formContentItem === \"string\"\n                            ? formContentItem\n                            : Buffer.from(formContentItem.payload, formContentItem.encoding);\n                }\n\n                currentDeferred.resolve(result);\n            }\n        });\n\n        processSugarWorker.on(\"error\", error => {\n            throw error;\n        });\n\n        return processSugarWorker;\n    }\n}\n\nconst generatorsCache: Map<string, GeneratorAsyncProxy> = new Map();\n\nexport function createAsyncGenerator(\n    pathToGeneratorRootDir: string,\n    purgeCache: boolean,\n    useGeneratorRestarting: boolean\n): FormGenerator {\n    let result = generatorsCache.get(pathToGeneratorRootDir);\n    if (result == undefined) {\n        result = new GeneratorAsyncProxy(pathToGeneratorRootDir, purgeCache, useGeneratorRestarting);\n        generatorsCache.set(pathToGeneratorRootDir, result);\n    }\n    return result;\n}\n"]}
209
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../src/BuildTasks/Generator/GeneratorWorker/CreateAsyncGenerator.ts"],"names":["GeneratorAsyncProxy","constructor","pathToGeneratorRootDir","purgeCache","useGeneratorRestarting","logger","generatorSourcesImporter","generatorProcess","maxRequestNumber","processSugarDeferredMap","Map","GeneratorSourcesImporter","getLocalizedSugar","sugarFiles","resources","localizationEntryPoint","importLocalization","undefined","Error","getDictionary","readSources","formSourcesPath","farmDirectory","hlFarmDirectoryPath","importReadSources","formSource","getAllDependencies","importGetAllDependencies","supportsDependenciesExtraction","getAllDependenciesHash","importGetAllDependenciesHash","readSourcesAndProcessSugar","generationOptions","currentRequestNumber","promise","Promise","resolve","reject","set","forkReadSourcesAndProcessSugarWorker","console","log","kill","send","result","delete","processSugar","forkProcessSugarWorker","processSugarWorker","cwd","__dirname","on","response","currentDeferred","get","requestNumber","type","errorText","formContent","generatedForm","key","formContentItem","Buffer","from","payload","encoding","error","generatorsCache","createAsyncGenerator"],"mappings":"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","sourcesContent":["/* eslint-disable no-console */\nimport { ChildProcess, fork } from \"child_process\";\n\nimport { ILogger } from \"../../../Commons/Logging/ILogger\";\nimport { getLogger } from \"../../../Commons/Logging/StaticLogger\";\nimport {\n    FormGenerator,\n    GeneratedForm,\n    GenerationOptions,\n    LocalizationDictionaryContent,\n} from \"../../Form/GenerateForm\";\nimport { FormResources, FormSource, SugarContent } from \"../../ReadFormSource\";\nimport { iterateEntries } from \"../../../../../Common/IterableUtils\";\n\nimport { GeneratorSourcesImporter } from \"./GeneratorRequireUtils\";\nimport { CallResponse } from \"./ProcessSugarWorker\";\n\ninterface ProcessSugarDeferred {\n    resolve: (result: GeneratedForm) => void;\n    reject: (error: unknown) => void;\n}\n\nclass GeneratorAsyncProxy implements FormGenerator {\n    private readonly pathToGeneratorRootDir: string;\n    private readonly generatorSourcesImporter: GeneratorSourcesImporter;\n    private readonly purgeCache: boolean;\n    private readonly useGeneratorRestarting: boolean;\n    private generatorProcess?: ChildProcess;\n    private maxRequestNumber = 0;\n    private readonly processSugarDeferredMap: Map<number, ProcessSugarDeferred> = new Map();\n\n    public constructor(\n        pathToGeneratorRootDir: string,\n        purgeCache: boolean,\n        useGeneratorRestarting: boolean,\n        logger: ILogger = getLogger()\n    ) {\n        this.useGeneratorRestarting = useGeneratorRestarting;\n        this.pathToGeneratorRootDir = pathToGeneratorRootDir;\n        this.purgeCache = purgeCache;\n        this.generatorSourcesImporter = new GeneratorSourcesImporter(purgeCache);\n    }\n\n    public async getLocalizedSugar(sugarFiles: SugarContent, resources: FormResources): Promise<SugarContent> {\n        const localizationEntryPoint = await this.generatorSourcesImporter.importLocalization(\n            this.pathToGeneratorRootDir\n        );\n        if (localizationEntryPoint == undefined) {\n            throw new Error(\"Данная версия генератора не поддерживает локализацию.\");\n        }\n        return localizationEntryPoint.getLocalizedSugar(sugarFiles, resources);\n    }\n\n    public async getDictionary(\n        sugarFiles: SugarContent,\n        resources: FormResources\n    ): Promise<LocalizationDictionaryContent> {\n        const localizationEntryPoint = await this.generatorSourcesImporter.importLocalization(\n            this.pathToGeneratorRootDir\n        );\n        if (localizationEntryPoint == undefined) {\n            throw new Error(\"Данная версия генератора не поддерживает локализацию.\");\n        }\n        return localizationEntryPoint.getDictionary(sugarFiles, resources);\n    }\n\n    public async readSources(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string\n    ): Promise<FormSource> {\n        const readSources: FormGenerator[\"readSources\"] = await this.generatorSourcesImporter.importReadSources(\n            this.pathToGeneratorRootDir\n        );\n        const formSource = await readSources(formSourcesPath, farmDirectory, hlFarmDirectoryPath);\n\n        return formSource;\n    }\n\n    public async getAllDependencies(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string\n    ): Promise<string[]> {\n        const getAllDependencies = await this.generatorSourcesImporter.importGetAllDependencies(\n            this.pathToGeneratorRootDir\n        );\n        if (getAllDependencies == undefined) {\n            throw new Error(\"This version of generator does not support dependencies extraction\");\n        }\n        const formSource = await getAllDependencies(formSourcesPath, farmDirectory, hlFarmDirectoryPath);\n        return formSource;\n    }\n\n    public async supportsDependenciesExtraction(): Promise<boolean> {\n        const getAllDependenciesHash = await this.generatorSourcesImporter.importGetAllDependenciesHash(\n            this.pathToGeneratorRootDir\n        );\n        return getAllDependenciesHash != undefined;\n    }\n\n    public async getAllDependenciesHash(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string\n    ): Promise<string> {\n        const getAllDependenciesHash = await this.generatorSourcesImporter.importGetAllDependenciesHash(\n            this.pathToGeneratorRootDir\n        );\n        if (getAllDependenciesHash == undefined) {\n            throw new Error(\"This version of generator does not support dependencies extraction\");\n        }\n        const formSource = await getAllDependenciesHash(formSourcesPath, farmDirectory, hlFarmDirectoryPath);\n        return formSource;\n    }\n\n    public async readSourcesAndProcessSugar(\n        formSourcesPath: string,\n        farmDirectory: string,\n        hlFarmDirectoryPath: string,\n        generationOptions?: GenerationOptions\n    ): Promise<GeneratedForm> {\n        this.maxRequestNumber++;\n        const currentRequestNumber = this.maxRequestNumber;\n        const promise = new Promise<GeneratedForm>((resolve, reject) => {\n            this.processSugarDeferredMap.set(currentRequestNumber, {\n                resolve: resolve,\n                reject: reject,\n            });\n        });\n\n        if (!this.generatorProcess) {\n            this.generatorProcess = this.forkReadSourcesAndProcessSugarWorker();\n        }\n        if (this.useGeneratorRestarting) {\n            if (this.maxRequestNumber % 10 === 0) {\n                console.log(\"Restarting generator\");\n                this.generatorProcess.kill();\n                this.generatorProcess = undefined;\n                this.generatorProcess = this.forkReadSourcesAndProcessSugarWorker();\n                console.log(\"Restarted generator\");\n            }\n        }\n\n        this.generatorProcess.send([\n            this.pathToGeneratorRootDir,\n            formSourcesPath,\n            farmDirectory,\n            hlFarmDirectoryPath,\n            generationOptions,\n            this.purgeCache,\n            currentRequestNumber,\n        ]);\n\n        const result = await promise;\n        this.processSugarDeferredMap.delete(currentRequestNumber);\n        return result;\n    }\n\n    public async processSugar(\n        sugarFiles: SugarContent,\n        resources: FormResources,\n        generationOptions?: GenerationOptions\n    ): Promise<GeneratedForm> {\n        this.maxRequestNumber++;\n        const currentRequestNumber = this.maxRequestNumber;\n        const promise = new Promise<GeneratedForm>((resolve, reject) => {\n            this.processSugarDeferredMap.set(currentRequestNumber, {\n                resolve: resolve,\n                reject: reject,\n            });\n        });\n\n        if (!this.generatorProcess) {\n            this.generatorProcess = this.forkProcessSugarWorker();\n        }\n\n        this.generatorProcess.send([\n            this.pathToGeneratorRootDir,\n            sugarFiles,\n            resources,\n            generationOptions,\n            this.purgeCache,\n            currentRequestNumber,\n        ]);\n\n        const result = await promise;\n        this.processSugarDeferredMap.delete(currentRequestNumber);\n        return result;\n    }\n\n    private forkProcessSugarWorker(): ChildProcess {\n        const processSugarWorker = fork(\"./ProcessSugarWorker\", [], {\n            cwd: __dirname,\n        });\n\n        processSugarWorker.on(\"message\", (response: CallResponse) => {\n            const currentDeferred = this.processSugarDeferredMap.get(response.requestNumber);\n            if (currentDeferred == undefined) {\n                return;\n            }\n            if (response.type === \"Error\") {\n                currentDeferred.reject(new Error(response.errorText));\n            } else {\n                const formContent = response.generatedForm;\n                const result: GeneratedForm = {};\n\n                for (const [key, formContentItem] of iterateEntries(formContent)) {\n                    result[key] =\n                        typeof formContentItem === \"string\"\n                            ? formContentItem\n                            : Buffer.from(formContentItem.payload, formContentItem.encoding);\n                }\n\n                currentDeferred.resolve(result);\n            }\n        });\n\n        processSugarWorker.on(\"error\", error => {\n            throw error;\n        });\n\n        return processSugarWorker;\n    }\n\n    private forkReadSourcesAndProcessSugarWorker(): ChildProcess {\n        const processSugarWorker = fork(\"./ReadSourcesAndProcessSugarWorker\", [], {\n            cwd: __dirname,\n        });\n\n        processSugarWorker.on(\"message\", (response: CallResponse) => {\n            const currentDeferred = this.processSugarDeferredMap.get(response.requestNumber);\n            if (currentDeferred == undefined) {\n                return;\n            }\n            if (response.type === \"Error\") {\n                currentDeferred.reject(new Error(response.errorText));\n            } else {\n                const formContent = response.generatedForm;\n                const result: GeneratedForm = {};\n\n                for (const [key, formContentItem] of iterateEntries(formContent)) {\n                    result[key] =\n                        typeof formContentItem === \"string\"\n                            ? formContentItem\n                            : Buffer.from(formContentItem.payload, formContentItem.encoding);\n                }\n\n                currentDeferred.resolve(result);\n            }\n        });\n\n        processSugarWorker.on(\"error\", error => {\n            throw error;\n        });\n\n        return processSugarWorker;\n    }\n}\n\nconst generatorsCache: Map<string, GeneratorAsyncProxy> = new Map();\n\nexport function createAsyncGenerator(\n    pathToGeneratorRootDir: string,\n    purgeCache: boolean,\n    useGeneratorRestarting: boolean\n): FormGenerator {\n    let result = generatorsCache.get(pathToGeneratorRootDir);\n    if (result == undefined) {\n        result = new GeneratorAsyncProxy(pathToGeneratorRootDir, purgeCache, useGeneratorRestarting);\n        generatorsCache.set(pathToGeneratorRootDir, result);\n    }\n    return result;\n}\n"]}
@@ -19,6 +19,18 @@ const buildServerCommandDefinition = (0, _CommandBasedOptionsParser.commandDefin
19
19
  defaultOption: true,
20
20
  multiple: true,
21
21
  description: "Опция устарела. Оставлена для обратной совместимости."
22
+ }, {
23
+ alias: "a",
24
+ name: "all-farm-dir",
25
+ defaultValue: {
26
+ allFarmsDir: []
27
+ },
28
+ parse: input => ({
29
+ allFarmsDir: input
30
+ }),
31
+ defaultOption: false,
32
+ multiple: true,
33
+ description: "Позволяет передать массив путей до всех фармов candy, чтобы открывать из всех них формы. Путь передавать относительно keforms.engine"
22
34
  }, {
23
35
  name: "nightly",
24
36
  defaultValue: {
@@ -66,6 +78,18 @@ const devBuildServerCommandDefinition = (0, _CommandBasedOptionsParser.commandDe
66
78
  defaultOption: true,
67
79
  multiple: true,
68
80
  description: "Одна или несколько GFV или GFV-масок для пересобрки."
81
+ }, {
82
+ alias: "a",
83
+ name: "all-farm-dir",
84
+ defaultValue: {
85
+ allFarmsDir: []
86
+ },
87
+ parse: input => ({
88
+ allFarmsDir: input
89
+ }),
90
+ defaultOption: false,
91
+ multiple: true,
92
+ description: "Позволяет передать массив путей до всех фармов candy, чтобы открывать из всех них формы. Путь передавать относительно keforms.engine"
69
93
  }, {
70
94
  name: "no-client-override",
71
95
  defaultValue: {
@@ -91,4 +115,4 @@ const devBuildServerCommandDefinition = (0, _CommandBasedOptionsParser.commandDe
91
115
  description: "Magic"
92
116
  });
93
117
  exports.devBuildServerCommandDefinition = devBuildServerCommandDefinition;
94
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/CLICommands/BuildServer/BuildServerServerOptions.ts"],"names":["buildServerCommandDefinition","alias","name","defaultValue","parse","input","defaultOption","multiple","description","nightly","doesNotRequireValue","disableClientOverride","skipGeneratedCodeReformatting","debugOnlyOptionDefinition","devModeOption","logVerbosityOption","devBuildServerCommandDefinition","formGlobs"],"mappings":"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","sourcesContent":["import { commandDefinition, optionsDefinition } from \"../../Commons/Options/CommandBasedOptionsParser\";\nimport { BuildDebugOnlyOption, debugOnlyOptionDefinition } from \"../CommonOptions/BuildDebugOnlyOption\";\nimport { CommonOptions } from \"../CommonOptions/CommonOptions\";\nimport { devModeOption, logVerbosityOption } from \"../CommonOptions/CommonOptionDefintions\";\n\nexport interface BuildServerOptions extends CommonOptions, BuildDebugOnlyOption {\n    disableClientOverride: boolean;\n    skipGeneratedCodeReformatting: boolean;\n    nightly: boolean;\n}\n\nexport interface DevBuildServerOptions extends CommonOptions, BuildDebugOnlyOption {\n    formGlobs: string[];\n    disableClientOverride: boolean;\n    skipGeneratedCodeReformatting: boolean;\n}\n\nexport const buildServerCommandDefinition = commandDefinition<\"build-server\", BuildServerOptions>(\n    \"build-server\",\n    \"build-server\",\n    optionsDefinition(\n        {\n            alias: \"g\",\n            name: \"gfvs\",\n            defaultValue: {},\n            parse: (input: string[]) => ({}),\n            defaultOption: true,\n            multiple: true,\n            description: \"Опция устарела. Оставлена для обратной совместимости.\",\n        },\n        {\n            name: \"nightly\",\n            defaultValue: { nightly: false },\n            parse: input => ({ nightly: input }),\n            doesNotRequireValue: true,\n            description: \"Включает сборку форм на движке nightly.\",\n        },\n        {\n            name: \"no-client-override\",\n            defaultValue: { disableClientOverride: false },\n            parse: input => ({ disableClientOverride: input }),\n            doesNotRequireValue: true,\n            description:\n                \"Отключает перехват client.js. В этом случае не будет работать отображение логов сборки и ожидания сборки формы.\",\n        },\n        {\n            name: \"reformat\",\n            alias: \"r\",\n            doesNotRequireValue: true,\n            defaultValue: { skipGeneratedCodeReformatting: true },\n            parse: (input: boolean) => ({ skipGeneratedCodeReformatting: !input }),\n            description:\n                \"Включает форматирование генерируемого кода. Работает, только если версия генератора поддерживает эту опцию. Используется для отладки и просмотра сгенерированных форм в отдадчике. (default: false)\",\n        },\n        debugOnlyOptionDefinition,\n        devModeOption,\n        logVerbosityOption\n    ),\n    {\n        description: \"Magic\",\n    }\n);\n\nexport const devBuildServerCommandDefinition = commandDefinition<\"dev-build-server\", DevBuildServerOptions>(\n    \"dev-build-server\",\n    \"dev-build-server\",\n    optionsDefinition(\n        {\n            alias: \"g\",\n            name: \"gfvs\",\n            defaultValue: { formGlobs: [\"*\"] },\n            parse: (input: string[]) => ({ formGlobs: input }),\n            defaultOption: true,\n            multiple: true,\n            description: \"Одна или несколько GFV или GFV-масок для пересобрки.\",\n        },\n        {\n            name: \"no-client-override\",\n            defaultValue: { disableClientOverride: false },\n            parse: input => ({ disableClientOverride: input }),\n            doesNotRequireValue: true,\n            description:\n                \"Отключает перехват client.js. В этом случае не будет работать отображение логов сборки и ожидания сборки формы.\",\n        },\n        {\n            name: \"reformat\",\n            alias: \"r\",\n            doesNotRequireValue: true,\n            defaultValue: { skipGeneratedCodeReformatting: true },\n            parse: (input: boolean) => ({ skipGeneratedCodeReformatting: !input }),\n            description:\n                \"Включает форматирование генерируемого кода. Работает, только если версия генератора поддерживает эту опцию. Используется для отладки и просмотра сгенерированных форм в отдадчике. (default: false)\",\n        },\n        debugOnlyOptionDefinition,\n        devModeOption,\n        logVerbosityOption\n    ),\n    {\n        description: \"Magic\",\n    }\n);\n"]}
118
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/CLICommands/BuildServer/BuildServerServerOptions.ts"],"names":["buildServerCommandDefinition","alias","name","defaultValue","parse","input","defaultOption","multiple","description","allFarmsDir","nightly","doesNotRequireValue","disableClientOverride","skipGeneratedCodeReformatting","debugOnlyOptionDefinition","devModeOption","logVerbosityOption","devBuildServerCommandDefinition","formGlobs"],"mappings":";;;;;;;AAAA;;AACA;;AAEA;;AAgBO,MAAMA,4BAA4B,GAAG,kDACxC,cADwC,EAExC,cAFwC,EAGxC,kDACI;AACIC,EAAAA,KAAK,EAAE,GADX;AAEIC,EAAAA,IAAI,EAAE,MAFV;AAGIC,EAAAA,YAAY,EAAE,EAHlB;AAIIC,EAAAA,KAAK,EAAGC,KAAD,KAAsB,EAAtB,CAJX;AAKIC,EAAAA,aAAa,EAAE,IALnB;AAMIC,EAAAA,QAAQ,EAAE,IANd;AAOIC,EAAAA,WAAW,EAAE;AAPjB,CADJ,EAUI;AACIP,EAAAA,KAAK,EAAE,GADX;AAEIC,EAAAA,IAAI,EAAE,cAFV;AAGIC,EAAAA,YAAY,EAAE;AAAEM,IAAAA,WAAW,EAAE;AAAf,GAHlB;AAIIL,EAAAA,KAAK,EAAGC,KAAD,KAAsB;AAAEI,IAAAA,WAAW,EAAEJ;AAAf,GAAtB,CAJX;AAKIC,EAAAA,aAAa,EAAE,KALnB;AAMIC,EAAAA,QAAQ,EAAE,IANd;AAOIC,EAAAA,WAAW,EACP;AARR,CAVJ,EAoBI;AACIN,EAAAA,IAAI,EAAE,SADV;AAEIC,EAAAA,YAAY,EAAE;AAAEO,IAAAA,OAAO,EAAE;AAAX,GAFlB;AAGIN,EAAAA,KAAK,EAAEC,KAAK,KAAK;AAAEK,IAAAA,OAAO,EAAEL;AAAX,GAAL,CAHhB;AAIIM,EAAAA,mBAAmB,EAAE,IAJzB;AAKIH,EAAAA,WAAW,EAAE;AALjB,CApBJ,EA2BI;AACIN,EAAAA,IAAI,EAAE,oBADV;AAEIC,EAAAA,YAAY,EAAE;AAAES,IAAAA,qBAAqB,EAAE;AAAzB,GAFlB;AAGIR,EAAAA,KAAK,EAAEC,KAAK,KAAK;AAAEO,IAAAA,qBAAqB,EAAEP;AAAzB,GAAL,CAHhB;AAIIM,EAAAA,mBAAmB,EAAE,IAJzB;AAKIH,EAAAA,WAAW,EACP;AANR,CA3BJ,EAmCI;AACIN,EAAAA,IAAI,EAAE,UADV;AAEID,EAAAA,KAAK,EAAE,GAFX;AAGIU,EAAAA,mBAAmB,EAAE,IAHzB;AAIIR,EAAAA,YAAY,EAAE;AAAEU,IAAAA,6BAA6B,EAAE;AAAjC,GAJlB;AAKIT,EAAAA,KAAK,EAAGC,KAAD,KAAqB;AAAEQ,IAAAA,6BAA6B,EAAE,CAACR;AAAlC,GAArB,CALX;AAMIG,EAAAA,WAAW,EACP;AAPR,CAnCJ,EA4CIM,+CA5CJ,EA6CIC,qCA7CJ,EA8CIC,0CA9CJ,CAHwC,EAmDxC;AACIR,EAAAA,WAAW,EAAE;AADjB,CAnDwC,CAArC;;AAwDA,MAAMS,+BAA+B,GAAG,kDAC3C,kBAD2C,EAE3C,kBAF2C,EAG3C,kDACI;AACIhB,EAAAA,KAAK,EAAE,GADX;AAEIC,EAAAA,IAAI,EAAE,MAFV;AAGIC,EAAAA,YAAY,EAAE;AAAEe,IAAAA,SAAS,EAAE,CAAC,GAAD;AAAb,GAHlB;AAIId,EAAAA,KAAK,EAAGC,KAAD,KAAsB;AAAEa,IAAAA,SAAS,EAAEb;AAAb,GAAtB,CAJX;AAKIC,EAAAA,aAAa,EAAE,IALnB;AAMIC,EAAAA,QAAQ,EAAE,IANd;AAOIC,EAAAA,WAAW,EAAE;AAPjB,CADJ,EAUI;AACIP,EAAAA,KAAK,EAAE,GADX;AAEIC,EAAAA,IAAI,EAAE,cAFV;AAGIC,EAAAA,YAAY,EAAE;AAAEM,IAAAA,WAAW,EAAE;AAAf,GAHlB;AAIIL,EAAAA,KAAK,EAAGC,KAAD,KAAsB;AAAEI,IAAAA,WAAW,EAAEJ;AAAf,GAAtB,CAJX;AAKIC,EAAAA,aAAa,EAAE,KALnB;AAMIC,EAAAA,QAAQ,EAAE,IANd;AAOIC,EAAAA,WAAW,EACP;AARR,CAVJ,EAoBI;AACIN,EAAAA,IAAI,EAAE,oBADV;AAEIC,EAAAA,YAAY,EAAE;AAAES,IAAAA,qBAAqB,EAAE;AAAzB,GAFlB;AAGIR,EAAAA,KAAK,EAAEC,KAAK,KAAK;AAAEO,IAAAA,qBAAqB,EAAEP;AAAzB,GAAL,CAHhB;AAIIM,EAAAA,mBAAmB,EAAE,IAJzB;AAKIH,EAAAA,WAAW,EACP;AANR,CApBJ,EA4BI;AACIN,EAAAA,IAAI,EAAE,UADV;AAEID,EAAAA,KAAK,EAAE,GAFX;AAGIU,EAAAA,mBAAmB,EAAE,IAHzB;AAIIR,EAAAA,YAAY,EAAE;AAAEU,IAAAA,6BAA6B,EAAE;AAAjC,GAJlB;AAKIT,EAAAA,KAAK,EAAGC,KAAD,KAAqB;AAAEQ,IAAAA,6BAA6B,EAAE,CAACR;AAAlC,GAArB,CALX;AAMIG,EAAAA,WAAW,EACP;AAPR,CA5BJ,EAqCIM,+CArCJ,EAsCIC,qCAtCJ,EAuCIC,0CAvCJ,CAH2C,EA4C3C;AACIR,EAAAA,WAAW,EAAE;AADjB,CA5C2C,CAAxC","sourcesContent":["import { commandDefinition, optionsDefinition } from \"../../Commons/Options/CommandBasedOptionsParser\";\nimport { BuildDebugOnlyOption, debugOnlyOptionDefinition } from \"../CommonOptions/BuildDebugOnlyOption\";\nimport { CommonOptions } from \"../CommonOptions/CommonOptions\";\nimport { devModeOption, logVerbosityOption } from \"../CommonOptions/CommonOptionDefintions\";\n\nexport interface BuildServerOptions extends CommonOptions, BuildDebugOnlyOption {\n    disableClientOverride: boolean;\n    skipGeneratedCodeReformatting: boolean;\n    nightly: boolean;\n    allFarmsDir: string[] | [];\n}\n\nexport interface DevBuildServerOptions extends CommonOptions, BuildDebugOnlyOption {\n    formGlobs: string[];\n    disableClientOverride: boolean;\n    skipGeneratedCodeReformatting: boolean;\n    allFarmsDir: string[] | [];\n}\n\nexport const buildServerCommandDefinition = commandDefinition<\"build-server\", BuildServerOptions>(\n    \"build-server\",\n    \"build-server\",\n    optionsDefinition(\n        {\n            alias: \"g\",\n            name: \"gfvs\",\n            defaultValue: {},\n            parse: (input: string[]) => ({}),\n            defaultOption: true,\n            multiple: true,\n            description: \"Опция устарела. Оставлена для обратной совместимости.\",\n        },\n        {\n            alias: \"a\",\n            name: \"all-farm-dir\",\n            defaultValue: { allFarmsDir: [] },\n            parse: (input: string[]) => ({ allFarmsDir: input }),\n            defaultOption: false,\n            multiple: true,\n            description:\n                \"Позволяет передать массив путей до всех фармов candy, чтобы открывать из всех них формы. Путь передавать относительно keforms.engine\",\n        },\n        {\n            name: \"nightly\",\n            defaultValue: { nightly: false },\n            parse: input => ({ nightly: input }),\n            doesNotRequireValue: true,\n            description: \"Включает сборку форм на движке nightly.\",\n        },\n        {\n            name: \"no-client-override\",\n            defaultValue: { disableClientOverride: false },\n            parse: input => ({ disableClientOverride: input }),\n            doesNotRequireValue: true,\n            description:\n                \"Отключает перехват client.js. В этом случае не будет работать отображение логов сборки и ожидания сборки формы.\",\n        },\n        {\n            name: \"reformat\",\n            alias: \"r\",\n            doesNotRequireValue: true,\n            defaultValue: { skipGeneratedCodeReformatting: true },\n            parse: (input: boolean) => ({ skipGeneratedCodeReformatting: !input }),\n            description:\n                \"Включает форматирование генерируемого кода. Работает, только если версия генератора поддерживает эту опцию. Используется для отладки и просмотра сгенерированных форм в отдадчике. (default: false)\",\n        },\n        debugOnlyOptionDefinition,\n        devModeOption,\n        logVerbosityOption\n    ),\n    {\n        description: \"Magic\",\n    }\n);\n\nexport const devBuildServerCommandDefinition = commandDefinition<\"dev-build-server\", DevBuildServerOptions>(\n    \"dev-build-server\",\n    \"dev-build-server\",\n    optionsDefinition(\n        {\n            alias: \"g\",\n            name: \"gfvs\",\n            defaultValue: { formGlobs: [\"*\"] },\n            parse: (input: string[]) => ({ formGlobs: input }),\n            defaultOption: true,\n            multiple: true,\n            description: \"Одна или несколько GFV или GFV-масок для пересобрки.\",\n        },\n        {\n            alias: \"a\",\n            name: \"all-farm-dir\",\n            defaultValue: { allFarmsDir: [] },\n            parse: (input: string[]) => ({ allFarmsDir: input }),\n            defaultOption: false,\n            multiple: true,\n            description:\n                \"Позволяет передать массив путей до всех фармов candy, чтобы открывать из всех них формы. Путь передавать относительно keforms.engine\",\n        },\n        {\n            name: \"no-client-override\",\n            defaultValue: { disableClientOverride: false },\n            parse: input => ({ disableClientOverride: input }),\n            doesNotRequireValue: true,\n            description:\n                \"Отключает перехват client.js. В этом случае не будет работать отображение логов сборки и ожидания сборки формы.\",\n        },\n        {\n            name: \"reformat\",\n            alias: \"r\",\n            doesNotRequireValue: true,\n            defaultValue: { skipGeneratedCodeReformatting: true },\n            parse: (input: boolean) => ({ skipGeneratedCodeReformatting: !input }),\n            description:\n                \"Включает форматирование генерируемого кода. Работает, только если версия генератора поддерживает эту опцию. Используется для отладки и просмотра сгенерированных форм в отдадчике. (default: false)\",\n        },\n        debugOnlyOptionDefinition,\n        devModeOption,\n        logVerbosityOption\n    ),\n    {\n        description: \"Magic\",\n    }\n);\n"]}