@kontur.candy/tools 2.131.0 → 2.133.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.
@@ -122,7 +122,7 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
122
122
  copiedEngines.add((0, _EngineSource.getEngineSourceKey)(fi.engineSource));
123
123
  }
124
124
  });
125
- }, async fi => fi, async fi => fi.engineSource != undefined ? (0, _EngineSource.getEngineSourceKey)(fi.engineSource) : "NullEngine").attach(async fi => _Observe.Observe.files(fi.formSourcesPath, "../../controls/**/*", "schemas/**/*", "sugar/**/*", "controls/**/*", "autocalc/**/*", "helpers/**/*", "validations/**/*", "localization/**/*")).transform(async fi => {
125
+ }, async fi => fi, async fi => fi.engineSource != undefined ? (0, _EngineSource.getEngineSourceKey)(fi.engineSource) : "NullEngine").attach(async fi => _Observe.Observe.files(fi.formSourcesPath, "../../controls/**/*", "../../xsltTemplates/**/*", "../../jsHelpers/**/*", "schemas/**/*", "sugar/**/*", "controls/**/*", "autocalc/**/*", "helpers/**/*", "validations/**/*", "localization/**/*")).transform(async fi => {
126
126
  let dependenciesHash;
127
127
 
128
128
  if (fi.mode !== _ResolveFormInfo.FormBuildMode.NormalBuild) {
@@ -200,7 +200,11 @@ async function runBuildForms(context, options, farmDirectory, resourcesDirectory
200
200
  } else {
201
201
  return new _SingleValueProducer.SingleValueProducer("");
202
202
  }
203
- }).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "schemas"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("SCHEMAS"), x, _path.default.join(resourcesDirectory, "schemas")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "converters"), "*").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("CONVERTERS"), x, _path.default.join(resourcesDirectory, "converters")))).attach(async fi => _Observe.Observe.file(_path.default.join(fi.formSourcesPath, "presentations.json")).do(x => _FSTask.FSTask.copyFile((0, _StaticLogger.getLogger)().withPrefix("PRESENTATIONS"), x, _path.default.join(resourcesDirectory, "presentations", `${gfv}.presentations.json`)))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "normalize"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("NORMALIZE"), x, _path.default.join(resourcesDirectory, "normalize")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "patch"), "*.xslt").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("PATCH"), x, _path.default.join(resourcesDirectory, "patch")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "map"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("MAP"), x, _path.default.join(resourcesDirectory, "map")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "unmap"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("UNMAP"), x, _path.default.join(resourcesDirectory, "unmap")))).do(async fi => {
203
+ }).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "schemas"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("SCHEMAS"), x, _path.default.join(resourcesDirectory, "schemas")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "converters"), "*").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("CONVERTERS"), x, _path.default.join(resourcesDirectory, "converters")))).attach(async fi => {
204
+ const modifier = content => content.replace(/<x:include href="[./]+/g, '<x:include href="');
205
+
206
+ return _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "converters"), "*").do(x => _FSTask.FSTask.modifyFilesContent((0, _StaticLogger.getLogger)().withPrefix("FIX-XSLT-INCLUDE"), x, _path.default.join(resourcesDirectory, "converters"), "**/*.xslt", modifier));
207
+ }).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "..", "..", "xsltTemplates"), "*").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("XSLT-TEMPLATES"), x, _path.default.join(resourcesDirectory, "converters", "xsltTemplates")))).attach(async fi => _Observe.Observe.file(_path.default.join(fi.formSourcesPath, "presentations.json")).do(x => _FSTask.FSTask.copyFile((0, _StaticLogger.getLogger)().withPrefix("PRESENTATIONS"), x, _path.default.join(resourcesDirectory, "presentations", `${gfv}.presentations.json`)))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "normalize"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("NORMALIZE"), x, _path.default.join(resourcesDirectory, "normalize")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "patch"), "*.xslt").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("PATCH"), x, _path.default.join(resourcesDirectory, "patch")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "map"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("MAP"), x, _path.default.join(resourcesDirectory, "map")))).attach(async fi => _Observe.Observe.files(_path.default.join(fi.formSourcesPath, "unmap"), "*.xml").do(x => _FSTask.FSTask.copyRecursively((0, _StaticLogger.getLogger)().withPrefix("UNMAP"), x, _path.default.join(resourcesDirectory, "unmap")))).do(async fi => {
204
208
  if (buildOptions.watch) {
205
209
  _nodeNotifier.default.notify({
206
210
  title: `${fi.formName}: сборка завершена`,
@@ -258,4 +262,4 @@ async function cleanTargetDirectory(resourcesDirectory, logger) {
258
262
  await (0, _fsExtra.emptyDir)(resourcesDirectory);
259
263
  logger.log("Resource directory clean");
260
264
  }
261
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/CLICommands/BuildForms/RunBuildForms.ts"],"names":["getGeneratorVersion","generatorSource","type","version","Error","runBuildForms","context","options","farmDirectory","resourcesDirectory","engineDirectory","candyModulesDirectory","hlFarmDirectoryPath","buildOptions","pickListsChain","Observe","files","path","join","do","x","FSTask","copyRecursively","logger","withPrefix","formGlobs","FormGlobs","validateGlobs","resolveSpecifiers","staticResourcesForProductionChain","__dirname","resourcesNuSpecChain","copyByMasks","copiedEngines","Set","buildCache","BuildCache","buildCacheMode","buildFormsChain","directory","splitToParallelChains","gfv","formDirPath","warning","value","file","transform","formJsonFile","upgradeFormJson","useLastStableVersion","usePrereleaseVersion","fi","mode","FormBuildMode","NormalBuild","generatorVersion","undefined","engineVersion","engineSource","attach","SingleValueProducer","NullFormGenerator","useVersionFromCache","y","generator","has","add","formSourcesPath","dependenciesHash","supportsDependenciesExtraction","getAllDependenciesHash","exists","log","skipCodeReformatting","skipGeneratedCodeReformatting","resourcesHash","extract","buildCacheOptions","depsHash","formName","themes","CopyLegacyPrebuiltResources","copyFile","watch","notifier","notify","title","message","clean","cleanTargetDirectory","stopObserve1","observe","stopObserve2","stopObserve3","stopObserve4","waitForExit","startDate","Date","now","currentValue","console","chalk","greenBright","totalTime"],"mappings":"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","sourcesContent":["import path from \"path\";\n\nimport chalk from \"chalk\";\nimport { emptyDir, pathExists } from \"fs-extra\";\nimport notifier from \"node-notifier\";\n\nimport { engineFactory } from \"../../BuildTasks/Engine/AcquireFormEngine\";\nimport { getEngineSourceKey } from \"../../BuildTasks/Engine/EngineSource\";\nimport { compileForm } from \"../../BuildTasks/Form/CompileForm\";\nimport { generateForm } from \"../../BuildTasks/Form/GenerateForm\";\nimport { NullFormGenerator } from \"../../BuildTasks/Form/NullFormGenerator\";\nimport { writeFLangNormalizationFiles } from \"../../BuildTasks/Form/WriteFLangNormalizationFiles\";\nimport { FSTask } from \"../../BuildTasks/FSTask\";\nimport {\n    generatorFactory,\n    GeneratorSource,\n    getGeneratorSourceKey,\n} from \"../../BuildTasks/Generator/AcquireFormGenerator\";\nimport { resolveEngineVersion, resolveGeneratorVersion } from \"../../BuildTasks/PublishedVersionUtils\";\nimport { FormBuildMode, resolveFormInfo } from \"../../BuildTasks/ResolveFormInfo\";\nimport { writeFormMeta } from \"../../BuildTasks/WriteFormMeta\";\nimport { ConsoleApplicationContext } from \"../../Commons/ConsoleApplication/ConsoleApplicationContext\";\nimport { FormGlobs } from \"../../Commons/FormGlobsUtils\";\nimport { ILogger } from \"../../Commons/Logging/ILogger\";\nimport { getLogger } from \"../../Commons/Logging/StaticLogger\";\nimport { Observe } from \"../../Commons/TasksCore/Observe\";\nimport { SingleValueProducer } from \"../../Commons/TasksCore/SingleValueProducer\";\nimport { printTime } from \"../../Commons/TimingUtils\";\nimport { BuildCache } from \"../../FormWebpackConfiguration/CacheAssetsPlugin\";\nimport { reject } from \"../../../../Common/TypingUtils\";\nimport { writeAttachmentPathFiles } from \"../../BuildTasks/Form/WriteAttachmentPathFiles\";\n\nimport { BuildFormsOptions } from \"./BuildFormsOptions\";\n\nfunction getGeneratorVersion(generatorSource: GeneratorSource): string {\n    if (generatorSource.type === \"PublishedGenerator\") {\n        return generatorSource.version;\n    } else {\n        throw new Error(\"InvalidProgramState\");\n    }\n}\n\nexport async function runBuildForms(\n    context: ConsoleApplicationContext,\n    options: BuildFormsOptions,\n    farmDirectory: string,\n    resourcesDirectory: string,\n    engineDirectory: string,\n    candyModulesDirectory: string,\n    hlFarmDirectoryPath: string\n): Promise<void> {\n    const buildOptions = options;\n\n    const pickListsChain = Observe.files(path.join(farmDirectory, \"picklists\"), \"*.json\").do(x =>\n        FSTask.copyRecursively(context.logger.withPrefix(\"PICKLISTS\"), x, path.join(resourcesDirectory, \"picklists\"))\n    );\n\n    const formGlobs = await FormGlobs.validateGlobs(\n        await FormGlobs.resolveSpecifiers(buildOptions.formGlobs, farmDirectory),\n        farmDirectory\n    );\n\n    const staticResourcesForProductionChain = Observe.files(\n        path.join(__dirname, \"..\", \"..\", \"StaticFilesForProductionResourcesDir\"),\n        \"*.js\",\n        \"*.js.map\"\n    ).do(x =>\n        FSTask.copyRecursively(getLogger().withPrefix(\"STATICS\"), x, path.join(resourcesDirectory, \"public\", \"scripts\"))\n    );\n\n    const resourcesNuSpecChain = Observe.files(path.join(farmDirectory), \"*.nuspec\").do(x =>\n        FSTask.copyByMasks(getLogger().withPrefix(\"NUSPEC\"), x, [\"*.nuspec\"], path.join(resourcesDirectory))\n    );\n\n    const copiedEngines = new Set<string>();\n\n    const buildCache = new BuildCache(farmDirectory, options.buildCacheMode);\n    const buildFormsChain = Observe.directory(path.join(farmDirectory, \"forms\"), formGlobs).splitToParallelChains(\n        x => x,\n        x => x,\n        async gfv => {\n            const formDirPath = path.join(farmDirectory, \"forms\", gfv);\n\n            if (!(await pathExists(path.join(formDirPath, \"form.json\")))) {\n                context.logger.warning(\n                    `Form ${gfv} does not have form.json file. To include this form to build process restart build`\n                );\n                return Observe.value({});\n            }\n\n            return Observe.file(path.join(formDirPath, \"form.json\"))\n                .transform(formJsonFile =>\n                    resolveFormInfo(\n                        formJsonFile,\n                        formDirPath,\n                        engineDirectory,\n                        context.logger.withPrefix(`FORM:${gfv}`),\n                        options.upgradeFormJson,\n                        options.useLastStableVersion,\n                        options.usePrereleaseVersion\n                    )\n                )\n                .transform(async fi => {\n                    if (fi.mode === FormBuildMode.NormalBuild) {\n                        if (fi.generatorVersion == undefined) {\n                            throw new Error(\"generatorVersion is no defined\");\n                        }\n                        if (fi.engineVersion == undefined) {\n                            throw new Error(\"engineVersion is no defined\");\n                        }\n                        return {\n                            ...fi,\n                            generatorSource: await resolveGeneratorVersion(\n                                fi.generatorVersion,\n                                context.logger.withPrefix(gfv)\n                            ),\n                            engineSource: await resolveEngineVersion(fi.engineVersion, context.logger.withPrefix(gfv)),\n                        };\n                    } else {\n                        return {\n                            ...fi,\n                            generatorSource: undefined,\n                            engineSource: undefined,\n                        };\n                    }\n                })\n                .attach(\n                    async fi => {\n                        if (fi.generatorSource == undefined) {\n                            return new SingleValueProducer(new NullFormGenerator());\n                        } else {\n                            return generatorFactory(\n                                fi.generatorSource,\n                                candyModulesDirectory,\n                                options.useVersionFromCache\n                            );\n                        }\n                    },\n                    async (fi, y) => ({ ...fi, generator: y }),\n                    async fi =>\n                        fi.generatorSource != undefined\n                            ? getGeneratorSourceKey(fi.generatorSource)\n                            : \"NullFormGenerator\"\n                )\n                .attach(\n                    async fi => {\n                        if (fi.engineSource === undefined) {\n                            return new SingleValueProducer(\"NullEngine\");\n                        }\n                        return engineFactory(fi.engineSource, candyModulesDirectory, options.useVersionFromCache).do(\n                            async x => {\n                                if (!copiedEngines.has(getEngineSourceKey(fi.engineSource))) {\n                                    await FSTask.copyRecursively(\n                                        getLogger().withPrefix(\"ENGINE\"),\n                                        x,\n                                        path.join(resourcesDirectory, \"public\")\n                                    );\n                                    copiedEngines.add(getEngineSourceKey(fi.engineSource));\n                                }\n                            }\n                        );\n                    },\n                    async fi => fi,\n                    async fi => (fi.engineSource != undefined ? getEngineSourceKey(fi.engineSource) : \"NullEngine\")\n                )\n                .attach(async fi =>\n                    Observe.files(\n                        fi.formSourcesPath,\n                        \"../../controls/**/*\",\n                        \"schemas/**/*\",\n                        \"sugar/**/*\",\n                        \"controls/**/*\",\n                        \"autocalc/**/*\",\n                        \"helpers/**/*\",\n                        \"validations/**/*\",\n                        \"localization/**/*\"\n                    )\n                )\n                .transform(async fi => {\n                    let dependenciesHash: undefined | string;\n                    if (fi.mode !== FormBuildMode.NormalBuild) {\n                        return {\n                            ...fi,\n                            dependenciesHash: undefined,\n                        };\n                    }\n                    if (await fi.generator.supportsDependenciesExtraction()) {\n                        dependenciesHash = await fi.generator.getAllDependenciesHash(\n                            formDirPath,\n                            farmDirectory,\n                            hlFarmDirectoryPath\n                        );\n                    }\n                    return {\n                        ...fi,\n                        dependenciesHash: dependenciesHash,\n                    };\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return undefined;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`GENERATE:${gfv}`).log(\"Skipped due build cache exits\");\n                            return undefined;\n                        }\n                    }\n                    return generateForm(\n                        fi.formSourcesPath,\n                        farmDirectory,\n                        hlFarmDirectoryPath,\n                        fi.generator,\n                        undefined,\n                        {\n                            skipCodeReformatting: options.skipGeneratedCodeReformatting,\n                            resourcesHash: fi.dependenciesHash ?? \"UndefinedResourcesHash\",\n                        }\n                    );\n                })\n                .attach(async fi => Observe.files(path.join(formDirPath, \"form\"), \"**/*\"))\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`COMPILE:${gfv}`).log(\"Skipped due build cache exists\");\n                            await buildCache.extract(fi.generatorSource, gfv, fi.dependenciesHash, resourcesDirectory);\n                            return;\n                        }\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await compileForm(\n                        fi.formName,\n                        fi.themes,\n                        farmDirectory,\n                        resourcesDirectory,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supporter\"\n                            ),\n                        false,\n                        undefined,\n                        buildCacheOptions\n                    );\n                    await writeFormMeta(\n                        resourcesDirectory,\n                        gfv,\n                        fi.engineSource,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supporter\"\n                            ),\n                        fi.themes,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await writeFLangNormalizationFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                    await writeAttachmentPathFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .attach(async fi => {\n                    if (fi.mode === FormBuildMode.CopyLegacyPrebuiltResources) {\n                        return Observe.files(path.join(fi.formSourcesPath, \"legacy-prebuilt\"), \"*\").do(x =>\n                            FSTask.copyRecursively(\n                                getLogger().withPrefix(\"LEGACY-PREBUILT\"),\n                                x,\n                                path.join(resourcesDirectory)\n                            )\n                        );\n                    } else {\n                        return new SingleValueProducer(\"\");\n                    }\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"schemas\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"SCHEMAS\"),\n                            x,\n                            path.join(resourcesDirectory, \"schemas\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"CONVERTERS\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.file(path.join(fi.formSourcesPath, \"presentations.json\")).do(x =>\n                        FSTask.copyFile(\n                            getLogger().withPrefix(\"PRESENTATIONS\"),\n                            x,\n                            path.join(resourcesDirectory, \"presentations\", `${gfv}.presentations.json`)\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"normalize\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"NORMALIZE\"),\n                            x,\n                            path.join(resourcesDirectory, \"normalize\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"patch\"), \"*.xslt\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"PATCH\"),\n                            x,\n                            path.join(resourcesDirectory, \"patch\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"map\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(getLogger().withPrefix(\"MAP\"), x, path.join(resourcesDirectory, \"map\"))\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"unmap\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"UNMAP\"),\n                            x,\n                            path.join(resourcesDirectory, \"unmap\")\n                        )\n                    )\n                )\n                .do(async fi => {\n                    if (buildOptions.watch) {\n                        notifier.notify({\n                            title: `${fi.formName}: сборка завершена`,\n                            message: `Engine: ${\n                                fi.engineSource == undefined\n                                    ? \"[NoEngine]\"\n                                    : fi.engineSource.type === \"LocalEngineSources\"\n                                    ? \"local\"\n                                    : fi.engineSource.version\n                            }`,\n                        });\n                    }\n                });\n        }\n    );\n\n    if (buildOptions.watch) {\n        if (options.clean) {\n            await cleanTargetDirectory(resourcesDirectory, context.logger);\n        }\n        const stopObserve1 = await pickListsChain.observe();\n        const stopObserve2 = await buildFormsChain.observe();\n        const stopObserve3 = await staticResourcesForProductionChain.observe();\n        const stopObserve4 = await resourcesNuSpecChain.observe();\n        await context.waitForExit();\n        if (stopObserve3 != undefined) {\n            await stopObserve3();\n        }\n        if (stopObserve4 != undefined) {\n            await stopObserve4();\n        }\n        await stopObserve2();\n        await stopObserve1();\n    } else {\n        const startDate = Date.now();\n        try {\n            if (options.clean) {\n                await cleanTargetDirectory(resourcesDirectory, context.logger);\n            }\n            await pickListsChain.currentValue;\n            await staticResourcesForProductionChain.currentValue;\n            await resourcesNuSpecChain.currentValue;\n            await buildFormsChain.currentValue;\n            // eslint-disable-next-line no-console\n            console.log(chalk.greenBright(\"Build success\"));\n        } finally {\n            const totalTime = Date.now() - startDate;\n            // eslint-disable-next-line no-console\n            console.log(`Total time: ${printTime(totalTime)}`);\n        }\n    }\n}\n\nasync function cleanTargetDirectory(resourcesDirectory: string, logger: ILogger): Promise<void> {\n    logger.log(\"Cleaning resource directory. \" + resourcesDirectory);\n    await emptyDir(resourcesDirectory);\n    logger.log(\"Resource directory clean\");\n}\n"]}
265
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/CLICommands/BuildForms/RunBuildForms.ts"],"names":["getGeneratorVersion","generatorSource","type","version","Error","runBuildForms","context","options","farmDirectory","resourcesDirectory","engineDirectory","candyModulesDirectory","hlFarmDirectoryPath","buildOptions","pickListsChain","Observe","files","path","join","do","x","FSTask","copyRecursively","logger","withPrefix","formGlobs","FormGlobs","validateGlobs","resolveSpecifiers","staticResourcesForProductionChain","__dirname","resourcesNuSpecChain","copyByMasks","copiedEngines","Set","buildCache","BuildCache","buildCacheMode","buildFormsChain","directory","splitToParallelChains","gfv","formDirPath","warning","value","file","transform","formJsonFile","upgradeFormJson","useLastStableVersion","usePrereleaseVersion","fi","mode","FormBuildMode","NormalBuild","generatorVersion","undefined","engineVersion","engineSource","attach","SingleValueProducer","NullFormGenerator","useVersionFromCache","y","generator","has","add","formSourcesPath","dependenciesHash","supportsDependenciesExtraction","getAllDependenciesHash","exists","log","skipCodeReformatting","skipGeneratedCodeReformatting","resourcesHash","extract","buildCacheOptions","depsHash","formName","themes","CopyLegacyPrebuiltResources","modifier","content","replace","modifyFilesContent","copyFile","watch","notifier","notify","title","message","clean","cleanTargetDirectory","stopObserve1","observe","stopObserve2","stopObserve3","stopObserve4","waitForExit","startDate","Date","now","currentValue","console","chalk","greenBright","totalTime"],"mappings":";;;;;;;;;AAAA;;AAEA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAKA;;AACA;;AACA;;AAEA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAIA,SAASA,mBAAT,CAA6BC,eAA7B,EAAuE;AACnE,MAAIA,eAAe,CAACC,IAAhB,KAAyB,oBAA7B,EAAmD;AAC/C,WAAOD,eAAe,CAACE,OAAvB;AACH,GAFD,MAEO;AACH,UAAM,IAAIC,KAAJ,CAAU,qBAAV,CAAN;AACH;AACJ;;AAEM,eAAeC,aAAf,CACHC,OADG,EAEHC,OAFG,EAGHC,aAHG,EAIHC,kBAJG,EAKHC,eALG,EAMHC,qBANG,EAOHC,mBAPG,EAQU;AACb,QAAMC,YAAY,GAAGN,OAArB;;AAEA,QAAMO,cAAc,GAAGC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUV,aAAV,EAAyB,WAAzB,CAAd,EAAqD,QAArD,EAA+DW,EAA/D,CAAkEC,CAAC,IACtFC,eAAOC,eAAP,CAAuBhB,OAAO,CAACiB,MAAR,CAAeC,UAAf,CAA0B,WAA1B,CAAvB,EAA+DJ,CAA/D,EAAkEH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,WAA9B,CAAlE,CADmB,CAAvB;;AAIA,QAAMgB,SAAS,GAAG,MAAMC,0BAAUC,aAAV,CACpB,MAAMD,0BAAUE,iBAAV,CAA4Bf,YAAY,CAACY,SAAzC,EAAoDjB,aAApD,CADc,EAEpBA,aAFoB,CAAxB;;AAKA,QAAMqB,iCAAiC,GAAGd,iBAAQC,KAAR,CACtCC,cAAKC,IAAL,CAAUY,SAAV,EAAqB,IAArB,EAA2B,IAA3B,EAAiC,sCAAjC,CADsC,EAEtC,MAFsC,EAGtC,UAHsC,EAIxCX,EAJwC,CAIrCC,CAAC,IACFC,eAAOC,eAAP,CAAuB,+BAAYE,UAAZ,CAAuB,SAAvB,CAAvB,EAA0DJ,CAA1D,EAA6DH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,QAA9B,EAAwC,SAAxC,CAA7D,CALsC,CAA1C;;AAQA,QAAMsB,oBAAoB,GAAGhB,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUV,aAAV,CAAd,EAAwC,UAAxC,EAAoDW,EAApD,CAAuDC,CAAC,IACjFC,eAAOW,WAAP,CAAmB,+BAAYR,UAAZ,CAAuB,QAAvB,CAAnB,EAAqDJ,CAArD,EAAwD,CAAC,UAAD,CAAxD,EAAsEH,cAAKC,IAAL,CAAUT,kBAAV,CAAtE,CADyB,CAA7B;;AAIA,QAAMwB,aAAa,GAAG,IAAIC,GAAJ,EAAtB;AAEA,QAAMC,UAAU,GAAG,IAAIC,6BAAJ,CAAe5B,aAAf,EAA8BD,OAAO,CAAC8B,cAAtC,CAAnB;;AACA,QAAMC,eAAe,GAAGvB,iBAAQwB,SAAR,CAAkBtB,cAAKC,IAAL,CAAUV,aAAV,EAAyB,OAAzB,CAAlB,EAAqDiB,SAArD,EAAgEe,qBAAhE,CACpBpB,CAAC,IAAIA,CADe,EAEpBA,CAAC,IAAIA,CAFe,EAGpB,MAAMqB,GAAN,IAAa;AACT,UAAMC,WAAW,GAAGzB,cAAKC,IAAL,CAAUV,aAAV,EAAyB,OAAzB,EAAkCiC,GAAlC,CAApB;;AAEA,QAAI,EAAE,MAAM,yBAAWxB,cAAKC,IAAL,CAAUwB,WAAV,EAAuB,WAAvB,CAAX,CAAR,CAAJ,EAA8D;AAC1DpC,MAAAA,OAAO,CAACiB,MAAR,CAAeoB,OAAf,CACK,QAAOF,GAAI,oFADhB;AAGA,aAAO1B,iBAAQ6B,KAAR,CAAc,EAAd,CAAP;AACH;;AAED,WAAO7B,iBAAQ8B,IAAR,CAAa5B,cAAKC,IAAL,CAAUwB,WAAV,EAAuB,WAAvB,CAAb,EACFI,SADE,CACQC,YAAY,IACnB,sCACIA,YADJ,EAEIL,WAFJ,EAGIhC,eAHJ,EAIIJ,OAAO,CAACiB,MAAR,CAAeC,UAAf,CAA2B,QAAOiB,GAAI,EAAtC,CAJJ,EAKIlC,OAAO,CAACyC,eALZ,EAMIzC,OAAO,CAAC0C,oBANZ,EAOI1C,OAAO,CAAC2C,oBAPZ,CAFD,EAYFJ,SAZE,CAYQ,MAAMK,EAAN,IAAY;AACnB,UAAIA,EAAE,CAACC,IAAH,KAAYC,+BAAcC,WAA9B,EAA2C;AACvC,YAAIH,EAAE,CAACI,gBAAH,IAAuBC,SAA3B,EAAsC;AAClC,gBAAM,IAAIpD,KAAJ,CAAU,gCAAV,CAAN;AACH;;AACD,YAAI+C,EAAE,CAACM,aAAH,IAAoBD,SAAxB,EAAmC;AAC/B,gBAAM,IAAIpD,KAAJ,CAAU,6BAAV,CAAN;AACH;;AACD,eAAO,EACH,GAAG+C,EADA;AAEHlD,UAAAA,eAAe,EAAE,MAAM,oDACnBkD,EAAE,CAACI,gBADgB,EAEnBjD,OAAO,CAACiB,MAAR,CAAeC,UAAf,CAA0BiB,GAA1B,CAFmB,CAFpB;AAMHiB,UAAAA,YAAY,EAAE,MAAM,iDAAqBP,EAAE,CAACM,aAAxB,EAAuCnD,OAAO,CAACiB,MAAR,CAAeC,UAAf,CAA0BiB,GAA1B,CAAvC;AANjB,SAAP;AAQH,OAfD,MAeO;AACH,eAAO,EACH,GAAGU,EADA;AAEHlD,UAAAA,eAAe,EAAEuD,SAFd;AAGHE,UAAAA,YAAY,EAAEF;AAHX,SAAP;AAKH;AACJ,KAnCE,EAoCFG,MApCE,CAqCC,MAAMR,EAAN,IAAY;AACR,UAAIA,EAAE,CAAClD,eAAH,IAAsBuD,SAA1B,EAAqC;AACjC,eAAO,IAAII,wCAAJ,CAAwB,IAAIC,oCAAJ,EAAxB,CAAP;AACH,OAFD,MAEO;AACH,eAAO,4CACHV,EAAE,CAAClD,eADA,EAEHU,qBAFG,EAGHJ,OAAO,CAACuD,mBAHL,CAAP;AAKH;AACJ,KA/CF,EAgDC,OAAOX,EAAP,EAAWY,CAAX,MAAkB,EAAE,GAAGZ,EAAL;AAASa,MAAAA,SAAS,EAAED;AAApB,KAAlB,CAhDD,EAiDC,MAAMZ,EAAN,IACIA,EAAE,CAAClD,eAAH,IAAsBuD,SAAtB,GACM,iDAAsBL,EAAE,CAAClD,eAAzB,CADN,GAEM,mBApDX,EAsDF0D,MAtDE,CAuDC,MAAMR,EAAN,IAAY;AACR,UAAIA,EAAE,CAACO,YAAH,KAAoBF,SAAxB,EAAmC;AAC/B,eAAO,IAAII,wCAAJ,CAAwB,YAAxB,CAAP;AACH;;AACD,aAAO,sCAAcT,EAAE,CAACO,YAAjB,EAA+B/C,qBAA/B,EAAsDJ,OAAO,CAACuD,mBAA9D,EAAmF3C,EAAnF,CACH,MAAMC,CAAN,IAAW;AACP,YAAI,CAACa,aAAa,CAACgC,GAAd,CAAkB,sCAAmBd,EAAE,CAACO,YAAtB,CAAlB,CAAL,EAA6D;AACzD,gBAAMrC,eAAOC,eAAP,CACF,+BAAYE,UAAZ,CAAuB,QAAvB,CADE,EAEFJ,CAFE,EAGFH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,QAA9B,CAHE,CAAN;AAKAwB,UAAAA,aAAa,CAACiC,GAAd,CAAkB,sCAAmBf,EAAE,CAACO,YAAtB,CAAlB;AACH;AACJ,OAVE,CAAP;AAYH,KAvEF,EAwEC,MAAMP,EAAN,IAAYA,EAxEb,EAyEC,MAAMA,EAAN,IAAaA,EAAE,CAACO,YAAH,IAAmBF,SAAnB,GAA+B,sCAAmBL,EAAE,CAACO,YAAtB,CAA/B,GAAqE,YAzEnF,EA2EFC,MA3EE,CA2EK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CACImC,EAAE,CAACgB,eADP,EAEI,qBAFJ,EAGI,0BAHJ,EAII,sBAJJ,EAKI,cALJ,EAMI,YANJ,EAOI,eAPJ,EAQI,eARJ,EASI,cATJ,EAUI,kBAVJ,EAWI,mBAXJ,CA5ED,EA0FFrB,SA1FE,CA0FQ,MAAMK,EAAN,IAAY;AACnB,UAAIiB,gBAAJ;;AACA,UAAIjB,EAAE,CAACC,IAAH,KAAYC,+BAAcC,WAA9B,EAA2C;AACvC,eAAO,EACH,GAAGH,EADA;AAEHiB,UAAAA,gBAAgB,EAAEZ;AAFf,SAAP;AAIH;;AACD,UAAI,MAAML,EAAE,CAACa,SAAH,CAAaK,8BAAb,EAAV,EAAyD;AACrDD,QAAAA,gBAAgB,GAAG,MAAMjB,EAAE,CAACa,SAAH,CAAaM,sBAAb,CACrB5B,WADqB,EAErBlC,aAFqB,EAGrBI,mBAHqB,CAAzB;AAKH;;AACD,aAAO,EACH,GAAGuC,EADA;AAEHiB,QAAAA,gBAAgB,EAAEA;AAFf,OAAP;AAIH,KA7GE,EA8GFjD,EA9GE,CA8GC,MAAMgC,EAAN,IAAY;AAAA;;AACZ,UAAIA,EAAE,CAAClD,eAAH,IAAsBuD,SAA1B,EAAqC;AACjC,eAAOA,SAAP;AACH;;AACD,UAAIL,EAAE,CAACiB,gBAAH,IAAuBZ,SAA3B,EAAsC;AAClC,YAAI,MAAMrB,UAAU,CAACoC,MAAX,CAAkBpB,EAAE,CAAClD,eAArB,EAAsCwC,GAAtC,EAA2CU,EAAE,CAACiB,gBAA9C,CAAV,EAA2E;AACvE9D,UAAAA,OAAO,CAACiB,MAAR,CAAeC,UAAf,CAA2B,YAAWiB,GAAI,EAA1C,EAA6C+B,GAA7C,CAAiD,+BAAjD;AACA,iBAAOhB,SAAP;AACH;AACJ;;AACD,aAAO,gCACHL,EAAE,CAACgB,eADA,EAEH3D,aAFG,EAGHI,mBAHG,EAIHuC,EAAE,CAACa,SAJA,EAKHR,SALG,EAMH;AACIiB,QAAAA,oBAAoB,EAAElE,OAAO,CAACmE,6BADlC;AAEIC,QAAAA,aAAa,0BAAExB,EAAE,CAACiB,gBAAL,uEAAyB;AAF1C,OANG,CAAP;AAWH,KAnIE,EAoIFT,MApIE,CAoIK,MAAMR,EAAN,IAAYpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUwB,WAAV,EAAuB,MAAvB,CAAd,EAA8C,MAA9C,CApIjB,EAqIFvB,EArIE,CAqIC,MAAMgC,EAAN,IAAY;AAAA;;AACZ,UAAIA,EAAE,CAAClD,eAAH,IAAsBuD,SAA1B,EAAqC;AACjC;AACH;;AACD,UAAIL,EAAE,CAACiB,gBAAH,IAAuBZ,SAA3B,EAAsC;AAClC,YAAI,MAAMrB,UAAU,CAACoC,MAAX,CAAkBpB,EAAE,CAAClD,eAArB,EAAsCwC,GAAtC,EAA2CU,EAAE,CAACiB,gBAA9C,CAAV,EAA2E;AACvE9D,UAAAA,OAAO,CAACiB,MAAR,CAAeC,UAAf,CAA2B,WAAUiB,GAAI,EAAzC,EAA4C+B,GAA5C,CAAgD,gCAAhD;AACA,gBAAMrC,UAAU,CAACyC,OAAX,CAAmBzB,EAAE,CAAClD,eAAtB,EAAuCwC,GAAvC,EAA4CU,EAAE,CAACiB,gBAA/C,EAAiE3D,kBAAjE,CAAN;AACA;AACH;AACJ;;AACD,YAAMoE,iBAAiB,GACnB1B,EAAE,CAACiB,gBAAH,IAAuBZ,SAAvB,GACM;AACIsB,QAAAA,QAAQ,EAAE3B,EAAE,CAACiB,gBADjB;AAEIb,QAAAA,gBAAgB,EAAEvD,mBAAmB,CAACmD,EAAE,CAAClD,eAAJ,CAFzC;AAGIwC,QAAAA,GAAG,EAAEA,GAHT;AAIIW,QAAAA,IAAI,EAAE7C,OAAO,CAAC8B,cAJlB;AAKI7B,QAAAA,aAAa,EAAEA;AALnB,OADN,GAQMgD,SATV;AAUA,YAAM,8BACFL,EAAE,CAAC4B,QADD,EAEF5B,EAAE,CAAC6B,MAFD,EAGFxE,aAHE,EAIFC,kBAJE,2BAKF0C,EAAE,CAACiB,gBALD,yEAME,yBACI,4FADJ,CANF,EASF,KATE,EAUFZ,SAVE,EAWFqB,iBAXE,CAAN;AAaA,YAAM,kCACFpE,kBADE,EAEFgC,GAFE,EAGFU,EAAE,CAACO,YAHD,2BAIFP,EAAE,CAACiB,gBAJD,yEAKE,yBACI,4FADJ,CALF,EAQFjB,EAAE,CAAC6B,MARD,EASF7C,UATE,EAUF0C,iBAVE,CAAN;AAYH,KAnLE,EAoLF1D,EApLE,CAoLC,MAAMgC,EAAN,IAAY;AACZ,UAAIA,EAAE,CAAClD,eAAH,IAAsBuD,SAA1B,EAAqC;AACjC;AACH;;AACD,YAAMqB,iBAAiB,GACnB1B,EAAE,CAACiB,gBAAH,IAAuBZ,SAAvB,GACM;AACIsB,QAAAA,QAAQ,EAAE3B,EAAE,CAACiB,gBADjB;AAEIb,QAAAA,gBAAgB,EAAEvD,mBAAmB,CAACmD,EAAE,CAAClD,eAAJ,CAFzC;AAGIwC,QAAAA,GAAG,EAAEA,GAHT;AAIIW,QAAAA,IAAI,EAAE7C,OAAO,CAAC8B,cAJlB;AAKI7B,QAAAA,aAAa,EAAEA;AALnB,OADN,GAQMgD,SATV;AAUA,YAAM,gEACFL,EAAE,CAAC4B,QADD,EAEFvE,aAFE,EAGFC,kBAHE,EAIF+C,SAJE,EAKFrB,UALE,EAMF0C,iBANE,CAAN;AAQA,YAAM,wDACF1B,EAAE,CAAC4B,QADD,EAEFvE,aAFE,EAGFC,kBAHE,EAIF+C,SAJE,EAKFrB,UALE,EAMF0C,iBANE,CAAN;AAQH,KAlNE,EAmNFlB,MAnNE,CAmNK,MAAMR,EAAN,IAAY;AAChB,UAAIA,EAAE,CAACC,IAAH,KAAYC,+BAAc4B,2BAA9B,EAA2D;AACvD,eAAOlE,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,iBAA9B,CAAd,EAAgE,GAAhE,EAAqEhD,EAArE,CAAwEC,CAAC,IAC5EC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,iBAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,CAHJ,CADG,CAAP;AAOH,OARD,MAQO;AACH,eAAO,IAAImD,wCAAJ,CAAwB,EAAxB,CAAP;AACH;AACJ,KA/NE,EAgOFD,MAhOE,CAgOK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,SAA9B,CAAd,EAAwD,OAAxD,EAAiEhD,EAAjE,CAAoEC,CAAC,IACjEC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,SAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,SAA9B,CAHJ,CADJ,CAjOD,EAyOFkD,MAzOE,CAyOK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,YAA9B,CAAd,EAA2D,GAA3D,EAAgEhD,EAAhE,CAAmEC,CAAC,IAChEC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,YAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,YAA9B,CAHJ,CADJ,CA1OD,EAkPFkD,MAlPE,CAkPK,MAAMR,EAAN,IAAY;AAChB,YAAM+B,QAAQ,GAAIC,OAAD,IACbA,OAAO,CAACC,OAAR,CAAgB,yBAAhB,EAA2C,mBAA3C,CADJ;;AAEA,aAAOrE,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,YAA9B,CAAd,EAA2D,GAA3D,EAAgEhD,EAAhE,CAAmEC,CAAC,IACvEC,eAAOgE,kBAAP,CACI,+BAAY7D,UAAZ,CAAuB,kBAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,YAA9B,CAHJ,EAII,WAJJ,EAKIyE,QALJ,CADG,CAAP;AASH,KA9PE,EA+PFvB,MA/PE,CA+PK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,IAA9B,EAAoC,IAApC,EAA0C,eAA1C,CAAd,EAA0E,GAA1E,EAA+EhD,EAA/E,CAAkFC,CAAC,IAC/EC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,gBAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,YAA9B,EAA4C,eAA5C,CAHJ,CADJ,CAhQD,EAwQFkD,MAxQE,CAwQK,MAAMR,EAAN,IACJpC,iBAAQ8B,IAAR,CAAa5B,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,oBAA9B,CAAb,EAAkEhD,EAAlE,CAAqEC,CAAC,IAClEC,eAAOiE,QAAP,CACI,+BAAY9D,UAAZ,CAAuB,eAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,eAA9B,EAAgD,GAAEgC,GAAI,qBAAtD,CAHJ,CADJ,CAzQD,EAiRFkB,MAjRE,CAiRK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,WAA9B,CAAd,EAA0D,OAA1D,EAAmEhD,EAAnE,CAAsEC,CAAC,IACnEC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,WAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,WAA9B,CAHJ,CADJ,CAlRD,EA0RFkD,MA1RE,CA0RK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,OAA9B,CAAd,EAAsD,QAAtD,EAAgEhD,EAAhE,CAAmEC,CAAC,IAChEC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,OAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,OAA9B,CAHJ,CADJ,CA3RD,EAmSFkD,MAnSE,CAmSK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,KAA9B,CAAd,EAAoD,OAApD,EAA6DhD,EAA7D,CAAgEC,CAAC,IAC7DC,eAAOC,eAAP,CAAuB,+BAAYE,UAAZ,CAAuB,KAAvB,CAAvB,EAAsDJ,CAAtD,EAAyDH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,KAA9B,CAAzD,CADJ,CApSD,EAwSFkD,MAxSE,CAwSK,MAAMR,EAAN,IACJpC,iBAAQC,KAAR,CAAcC,cAAKC,IAAL,CAAUiC,EAAE,CAACgB,eAAb,EAA8B,OAA9B,CAAd,EAAsD,OAAtD,EAA+DhD,EAA/D,CAAkEC,CAAC,IAC/DC,eAAOC,eAAP,CACI,+BAAYE,UAAZ,CAAuB,OAAvB,CADJ,EAEIJ,CAFJ,EAGIH,cAAKC,IAAL,CAAUT,kBAAV,EAA8B,OAA9B,CAHJ,CADJ,CAzSD,EAiTFU,EAjTE,CAiTC,MAAMgC,EAAN,IAAY;AACZ,UAAItC,YAAY,CAAC0E,KAAjB,EAAwB;AACpBC,8BAASC,MAAT,CAAgB;AACZC,UAAAA,KAAK,EAAG,GAAEvC,EAAE,CAAC4B,QAAS,oBADV;AAEZY,UAAAA,OAAO,EAAG,WACNxC,EAAE,CAACO,YAAH,IAAmBF,SAAnB,GACM,YADN,GAEML,EAAE,CAACO,YAAH,CAAgBxD,IAAhB,KAAyB,oBAAzB,GACA,OADA,GAEAiD,EAAE,CAACO,YAAH,CAAgBvD,OACzB;AARW,SAAhB;AAUH;AACJ,KA9TE,CAAP;AA+TH,GA5UmB,CAAxB;;AA+UA,MAAIU,YAAY,CAAC0E,KAAjB,EAAwB;AACpB,QAAIhF,OAAO,CAACqF,KAAZ,EAAmB;AACf,YAAMC,oBAAoB,CAACpF,kBAAD,EAAqBH,OAAO,CAACiB,MAA7B,CAA1B;AACH;;AACD,UAAMuE,YAAY,GAAG,MAAMhF,cAAc,CAACiF,OAAf,EAA3B;AACA,UAAMC,YAAY,GAAG,MAAM1D,eAAe,CAACyD,OAAhB,EAA3B;AACA,UAAME,YAAY,GAAG,MAAMpE,iCAAiC,CAACkE,OAAlC,EAA3B;AACA,UAAMG,YAAY,GAAG,MAAMnE,oBAAoB,CAACgE,OAArB,EAA3B;AACA,UAAMzF,OAAO,CAAC6F,WAAR,EAAN;;AACA,QAAIF,YAAY,IAAIzC,SAApB,EAA+B;AAC3B,YAAMyC,YAAY,EAAlB;AACH;;AACD,QAAIC,YAAY,IAAI1C,SAApB,EAA+B;AAC3B,YAAM0C,YAAY,EAAlB;AACH;;AACD,UAAMF,YAAY,EAAlB;AACA,UAAMF,YAAY,EAAlB;AACH,GAjBD,MAiBO;AACH,UAAMM,SAAS,GAAGC,IAAI,CAACC,GAAL,EAAlB;;AACA,QAAI;AACA,UAAI/F,OAAO,CAACqF,KAAZ,EAAmB;AACf,cAAMC,oBAAoB,CAACpF,kBAAD,EAAqBH,OAAO,CAACiB,MAA7B,CAA1B;AACH;;AACD,YAAMT,cAAc,CAACyF,YAArB;AACA,YAAM1E,iCAAiC,CAAC0E,YAAxC;AACA,YAAMxE,oBAAoB,CAACwE,YAA3B;AACA,YAAMjE,eAAe,CAACiE,YAAtB,CAPA,CAQA;;AACAC,MAAAA,OAAO,CAAChC,GAAR,CAAYiC,eAAMC,WAAN,CAAkB,eAAlB,CAAZ;AACH,KAVD,SAUU;AACN,YAAMC,SAAS,GAAGN,IAAI,CAACC,GAAL,KAAaF,SAA/B,CADM,CAEN;;AACAI,MAAAA,OAAO,CAAChC,GAAR,CAAa,eAAc,4BAAUmC,SAAV,CAAqB,EAAhD;AACH;AACJ;AACJ;;AAED,eAAed,oBAAf,CAAoCpF,kBAApC,EAAgEc,MAAhE,EAAgG;AAC5FA,EAAAA,MAAM,CAACiD,GAAP,CAAW,kCAAkC/D,kBAA7C;AACA,QAAM,uBAASA,kBAAT,CAAN;AACAc,EAAAA,MAAM,CAACiD,GAAP,CAAW,0BAAX;AACH","sourcesContent":["import path from \"path\";\n\nimport chalk from \"chalk\";\nimport { emptyDir, pathExists } from \"fs-extra\";\nimport notifier from \"node-notifier\";\n\nimport { engineFactory } from \"../../BuildTasks/Engine/AcquireFormEngine\";\nimport { getEngineSourceKey } from \"../../BuildTasks/Engine/EngineSource\";\nimport { compileForm } from \"../../BuildTasks/Form/CompileForm\";\nimport { generateForm } from \"../../BuildTasks/Form/GenerateForm\";\nimport { NullFormGenerator } from \"../../BuildTasks/Form/NullFormGenerator\";\nimport { writeFLangNormalizationFiles } from \"../../BuildTasks/Form/WriteFLangNormalizationFiles\";\nimport { FSTask } from \"../../BuildTasks/FSTask\";\nimport {\n    generatorFactory,\n    GeneratorSource,\n    getGeneratorSourceKey,\n} from \"../../BuildTasks/Generator/AcquireFormGenerator\";\nimport { resolveEngineVersion, resolveGeneratorVersion } from \"../../BuildTasks/PublishedVersionUtils\";\nimport { FormBuildMode, resolveFormInfo } from \"../../BuildTasks/ResolveFormInfo\";\nimport { writeFormMeta } from \"../../BuildTasks/WriteFormMeta\";\nimport { ConsoleApplicationContext } from \"../../Commons/ConsoleApplication/ConsoleApplicationContext\";\nimport { FormGlobs } from \"../../Commons/FormGlobsUtils\";\nimport { ILogger } from \"../../Commons/Logging/ILogger\";\nimport { getLogger } from \"../../Commons/Logging/StaticLogger\";\nimport { Observe } from \"../../Commons/TasksCore/Observe\";\nimport { SingleValueProducer } from \"../../Commons/TasksCore/SingleValueProducer\";\nimport { printTime } from \"../../Commons/TimingUtils\";\nimport { BuildCache } from \"../../FormWebpackConfiguration/CacheAssetsPlugin\";\nimport { reject } from \"../../../../Common/TypingUtils\";\nimport { writeAttachmentPathFiles } from \"../../BuildTasks/Form/WriteAttachmentPathFiles\";\n\nimport { BuildFormsOptions } from \"./BuildFormsOptions\";\n\nfunction getGeneratorVersion(generatorSource: GeneratorSource): string {\n    if (generatorSource.type === \"PublishedGenerator\") {\n        return generatorSource.version;\n    } else {\n        throw new Error(\"InvalidProgramState\");\n    }\n}\n\nexport async function runBuildForms(\n    context: ConsoleApplicationContext,\n    options: BuildFormsOptions,\n    farmDirectory: string,\n    resourcesDirectory: string,\n    engineDirectory: string,\n    candyModulesDirectory: string,\n    hlFarmDirectoryPath: string\n): Promise<void> {\n    const buildOptions = options;\n\n    const pickListsChain = Observe.files(path.join(farmDirectory, \"picklists\"), \"*.json\").do(x =>\n        FSTask.copyRecursively(context.logger.withPrefix(\"PICKLISTS\"), x, path.join(resourcesDirectory, \"picklists\"))\n    );\n\n    const formGlobs = await FormGlobs.validateGlobs(\n        await FormGlobs.resolveSpecifiers(buildOptions.formGlobs, farmDirectory),\n        farmDirectory\n    );\n\n    const staticResourcesForProductionChain = Observe.files(\n        path.join(__dirname, \"..\", \"..\", \"StaticFilesForProductionResourcesDir\"),\n        \"*.js\",\n        \"*.js.map\"\n    ).do(x =>\n        FSTask.copyRecursively(getLogger().withPrefix(\"STATICS\"), x, path.join(resourcesDirectory, \"public\", \"scripts\"))\n    );\n\n    const resourcesNuSpecChain = Observe.files(path.join(farmDirectory), \"*.nuspec\").do(x =>\n        FSTask.copyByMasks(getLogger().withPrefix(\"NUSPEC\"), x, [\"*.nuspec\"], path.join(resourcesDirectory))\n    );\n\n    const copiedEngines = new Set<string>();\n\n    const buildCache = new BuildCache(farmDirectory, options.buildCacheMode);\n    const buildFormsChain = Observe.directory(path.join(farmDirectory, \"forms\"), formGlobs).splitToParallelChains(\n        x => x,\n        x => x,\n        async gfv => {\n            const formDirPath = path.join(farmDirectory, \"forms\", gfv);\n\n            if (!(await pathExists(path.join(formDirPath, \"form.json\")))) {\n                context.logger.warning(\n                    `Form ${gfv} does not have form.json file. To include this form to build process restart build`\n                );\n                return Observe.value({});\n            }\n\n            return Observe.file(path.join(formDirPath, \"form.json\"))\n                .transform(formJsonFile =>\n                    resolveFormInfo(\n                        formJsonFile,\n                        formDirPath,\n                        engineDirectory,\n                        context.logger.withPrefix(`FORM:${gfv}`),\n                        options.upgradeFormJson,\n                        options.useLastStableVersion,\n                        options.usePrereleaseVersion\n                    )\n                )\n                .transform(async fi => {\n                    if (fi.mode === FormBuildMode.NormalBuild) {\n                        if (fi.generatorVersion == undefined) {\n                            throw new Error(\"generatorVersion is no defined\");\n                        }\n                        if (fi.engineVersion == undefined) {\n                            throw new Error(\"engineVersion is no defined\");\n                        }\n                        return {\n                            ...fi,\n                            generatorSource: await resolveGeneratorVersion(\n                                fi.generatorVersion,\n                                context.logger.withPrefix(gfv)\n                            ),\n                            engineSource: await resolveEngineVersion(fi.engineVersion, context.logger.withPrefix(gfv)),\n                        };\n                    } else {\n                        return {\n                            ...fi,\n                            generatorSource: undefined,\n                            engineSource: undefined,\n                        };\n                    }\n                })\n                .attach(\n                    async fi => {\n                        if (fi.generatorSource == undefined) {\n                            return new SingleValueProducer(new NullFormGenerator());\n                        } else {\n                            return generatorFactory(\n                                fi.generatorSource,\n                                candyModulesDirectory,\n                                options.useVersionFromCache\n                            );\n                        }\n                    },\n                    async (fi, y) => ({ ...fi, generator: y }),\n                    async fi =>\n                        fi.generatorSource != undefined\n                            ? getGeneratorSourceKey(fi.generatorSource)\n                            : \"NullFormGenerator\"\n                )\n                .attach(\n                    async fi => {\n                        if (fi.engineSource === undefined) {\n                            return new SingleValueProducer(\"NullEngine\");\n                        }\n                        return engineFactory(fi.engineSource, candyModulesDirectory, options.useVersionFromCache).do(\n                            async x => {\n                                if (!copiedEngines.has(getEngineSourceKey(fi.engineSource))) {\n                                    await FSTask.copyRecursively(\n                                        getLogger().withPrefix(\"ENGINE\"),\n                                        x,\n                                        path.join(resourcesDirectory, \"public\")\n                                    );\n                                    copiedEngines.add(getEngineSourceKey(fi.engineSource));\n                                }\n                            }\n                        );\n                    },\n                    async fi => fi,\n                    async fi => (fi.engineSource != undefined ? getEngineSourceKey(fi.engineSource) : \"NullEngine\")\n                )\n                .attach(async fi =>\n                    Observe.files(\n                        fi.formSourcesPath,\n                        \"../../controls/**/*\",\n                        \"../../xsltTemplates/**/*\",\n                        \"../../jsHelpers/**/*\",\n                        \"schemas/**/*\",\n                        \"sugar/**/*\",\n                        \"controls/**/*\",\n                        \"autocalc/**/*\",\n                        \"helpers/**/*\",\n                        \"validations/**/*\",\n                        \"localization/**/*\"\n                    )\n                )\n                .transform(async fi => {\n                    let dependenciesHash: undefined | string;\n                    if (fi.mode !== FormBuildMode.NormalBuild) {\n                        return {\n                            ...fi,\n                            dependenciesHash: undefined,\n                        };\n                    }\n                    if (await fi.generator.supportsDependenciesExtraction()) {\n                        dependenciesHash = await fi.generator.getAllDependenciesHash(\n                            formDirPath,\n                            farmDirectory,\n                            hlFarmDirectoryPath\n                        );\n                    }\n                    return {\n                        ...fi,\n                        dependenciesHash: dependenciesHash,\n                    };\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return undefined;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`GENERATE:${gfv}`).log(\"Skipped due build cache exits\");\n                            return undefined;\n                        }\n                    }\n                    return generateForm(\n                        fi.formSourcesPath,\n                        farmDirectory,\n                        hlFarmDirectoryPath,\n                        fi.generator,\n                        undefined,\n                        {\n                            skipCodeReformatting: options.skipGeneratedCodeReformatting,\n                            resourcesHash: fi.dependenciesHash ?? \"UndefinedResourcesHash\",\n                        }\n                    );\n                })\n                .attach(async fi => Observe.files(path.join(formDirPath, \"form\"), \"**/*\"))\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    if (fi.dependenciesHash != undefined) {\n                        if (await buildCache.exists(fi.generatorSource, gfv, fi.dependenciesHash)) {\n                            context.logger.withPrefix(`COMPILE:${gfv}`).log(\"Skipped due build cache exists\");\n                            await buildCache.extract(fi.generatorSource, gfv, fi.dependenciesHash, resourcesDirectory);\n                            return;\n                        }\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await compileForm(\n                        fi.formName,\n                        fi.themes,\n                        farmDirectory,\n                        resourcesDirectory,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supporter\"\n                            ),\n                        false,\n                        undefined,\n                        buildCacheOptions\n                    );\n                    await writeFormMeta(\n                        resourcesDirectory,\n                        gfv,\n                        fi.engineSource,\n                        fi.dependenciesHash ??\n                            reject(\n                                \"This version of generator is not supported due to dependencies extraction is not supporter\"\n                            ),\n                        fi.themes,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .do(async fi => {\n                    if (fi.generatorSource == undefined) {\n                        return;\n                    }\n                    const buildCacheOptions =\n                        fi.dependenciesHash != undefined\n                            ? {\n                                  depsHash: fi.dependenciesHash,\n                                  generatorVersion: getGeneratorVersion(fi.generatorSource),\n                                  gfv: gfv,\n                                  mode: options.buildCacheMode,\n                                  farmDirectory: farmDirectory,\n                              }\n                            : undefined;\n                    await writeFLangNormalizationFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                    await writeAttachmentPathFiles(\n                        fi.formName,\n                        farmDirectory,\n                        resourcesDirectory,\n                        undefined,\n                        buildCache,\n                        buildCacheOptions\n                    );\n                })\n                .attach(async fi => {\n                    if (fi.mode === FormBuildMode.CopyLegacyPrebuiltResources) {\n                        return Observe.files(path.join(fi.formSourcesPath, \"legacy-prebuilt\"), \"*\").do(x =>\n                            FSTask.copyRecursively(\n                                getLogger().withPrefix(\"LEGACY-PREBUILT\"),\n                                x,\n                                path.join(resourcesDirectory)\n                            )\n                        );\n                    } else {\n                        return new SingleValueProducer(\"\");\n                    }\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"schemas\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"SCHEMAS\"),\n                            x,\n                            path.join(resourcesDirectory, \"schemas\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"CONVERTERS\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\")\n                        )\n                    )\n                )\n                .attach(async fi => {\n                    const modifier = (content: string): string =>\n                        content.replace(/<x:include href=\"[./]+/g, '<x:include href=\"');\n                    return Observe.files(path.join(fi.formSourcesPath, \"converters\"), \"*\").do(x =>\n                        FSTask.modifyFilesContent(\n                            getLogger().withPrefix(\"FIX-XSLT-INCLUDE\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\"),\n                            \"**/*.xslt\",\n                            modifier\n                        )\n                    );\n                })\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"..\", \"..\", \"xsltTemplates\"), \"*\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"XSLT-TEMPLATES\"),\n                            x,\n                            path.join(resourcesDirectory, \"converters\", \"xsltTemplates\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.file(path.join(fi.formSourcesPath, \"presentations.json\")).do(x =>\n                        FSTask.copyFile(\n                            getLogger().withPrefix(\"PRESENTATIONS\"),\n                            x,\n                            path.join(resourcesDirectory, \"presentations\", `${gfv}.presentations.json`)\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"normalize\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"NORMALIZE\"),\n                            x,\n                            path.join(resourcesDirectory, \"normalize\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"patch\"), \"*.xslt\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"PATCH\"),\n                            x,\n                            path.join(resourcesDirectory, \"patch\")\n                        )\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"map\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(getLogger().withPrefix(\"MAP\"), x, path.join(resourcesDirectory, \"map\"))\n                    )\n                )\n                .attach(async fi =>\n                    Observe.files(path.join(fi.formSourcesPath, \"unmap\"), \"*.xml\").do(x =>\n                        FSTask.copyRecursively(\n                            getLogger().withPrefix(\"UNMAP\"),\n                            x,\n                            path.join(resourcesDirectory, \"unmap\")\n                        )\n                    )\n                )\n                .do(async fi => {\n                    if (buildOptions.watch) {\n                        notifier.notify({\n                            title: `${fi.formName}: сборка завершена`,\n                            message: `Engine: ${\n                                fi.engineSource == undefined\n                                    ? \"[NoEngine]\"\n                                    : fi.engineSource.type === \"LocalEngineSources\"\n                                    ? \"local\"\n                                    : fi.engineSource.version\n                            }`,\n                        });\n                    }\n                });\n        }\n    );\n\n    if (buildOptions.watch) {\n        if (options.clean) {\n            await cleanTargetDirectory(resourcesDirectory, context.logger);\n        }\n        const stopObserve1 = await pickListsChain.observe();\n        const stopObserve2 = await buildFormsChain.observe();\n        const stopObserve3 = await staticResourcesForProductionChain.observe();\n        const stopObserve4 = await resourcesNuSpecChain.observe();\n        await context.waitForExit();\n        if (stopObserve3 != undefined) {\n            await stopObserve3();\n        }\n        if (stopObserve4 != undefined) {\n            await stopObserve4();\n        }\n        await stopObserve2();\n        await stopObserve1();\n    } else {\n        const startDate = Date.now();\n        try {\n            if (options.clean) {\n                await cleanTargetDirectory(resourcesDirectory, context.logger);\n            }\n            await pickListsChain.currentValue;\n            await staticResourcesForProductionChain.currentValue;\n            await resourcesNuSpecChain.currentValue;\n            await buildFormsChain.currentValue;\n            // eslint-disable-next-line no-console\n            console.log(chalk.greenBright(\"Build success\"));\n        } finally {\n            const totalTime = Date.now() - startDate;\n            // eslint-disable-next-line no-console\n            console.log(`Total time: ${printTime(totalTime)}`);\n        }\n    }\n}\n\nasync function cleanTargetDirectory(resourcesDirectory: string, logger: ILogger): Promise<void> {\n    logger.log(\"Cleaning resource directory. \" + resourcesDirectory);\n    await emptyDir(resourcesDirectory);\n    logger.log(\"Resource directory clean\");\n}\n"]}
@@ -82,7 +82,7 @@ async function removeTemporaryWebpackConfigFiles(farmDirectory, logger) {
82
82
  context.logger.verbose(`Verbose level: ${options.options.logVerbosity}`);
83
83
  const farmDirectory = process.cwd();
84
84
  await removeTemporaryWebpackConfigFiles(farmDirectory, context.logger);
85
- const farmConfig = (0, _ReadFarmConfig.readFarmConfig)(process.cwd());
85
+ const farmConfig = (0, _ReadFarmConfig.readFarmConfig)(farmDirectory);
86
86
 
87
87
  if (farmConfig.engineDirectory == undefined) {
88
88
  throw new Error("EngineDirectory is not specified");
@@ -130,4 +130,4 @@ async function removeTemporaryWebpackConfigFiles(farmDirectory, logger) {
130
130
  await (0, _RunInitForm.runInitForm)(context, options.options, farmDirectory);
131
131
  }
132
132
  });
133
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/CandyCLI.ts"],"names":["config","fatal","remoteInspectFlagToDisableDebuggerInChildProcess","debugArgIdx","process","execArgv","indexOf","splice","debugArg2Idx","removeTemporaryWebpackConfigFiles","farmDirectory","logger","files","oldTempFileNames","filter","x","endsWith","length","log","fileName","path","join","argv","context","options","setConsoleLoggingVerbosity","logVerbosity","verbose","cwd","farmConfig","engineDirectory","undefined","Error","resourcesDirectory","resolve","candyModulesDirectory","type","hlFarmDirectoryPath"],"mappings":"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","sourcesContent":["import \"core-js/stable\";\nimport \"regenerator-runtime/runtime\";\nimport \"core-js/features/array/flat\";\nimport \"core-js/proposals/iterator-helpers\";\nimport \"reflect-metadata\";\n\nimport path from \"path\";\n\nimport { readdir, unlink } from \"fs-extra\";\nimport { config } from \"shelljs\";\n\nimport { runConsoleApplication } from \"./Commons/ConsoleApplication/ConsoleApplication\";\nimport { ILogger } from \"./Commons/Logging/ILogger\";\nimport { setLogger } from \"./Commons/Logging/StaticLogger\";\nimport { runBuildForms } from \"./CLICommands/BuildForms/RunBuildForms\";\nimport { runBuildServer, runDevBuildServer } from \"./CLICommands/BuildServer/RunBuildServer\";\nimport { runDevBuild } from \"./CLICommands/DevBuild/RunDevBuild\";\nimport { runFormStats } from \"./CLICommands/FormStats/RunFormStats\";\nimport { runInitForm } from \"./CLICommands/InitForm/RunInitForm\";\nimport { runLocalization } from \"./CLICommands/Localization/RunLocalization\";\nimport { runUpgradeForm } from \"./CLICommands/UpgradeForm/RunUpgradeForm\";\nimport { parseOptions } from \"./Options/CandyToolOptions\";\nimport { readFarmConfig } from \"./ReadFarmConfig\";\nimport { getCurrentVersion } from \"./SelfUpdate\";\n\nconfig.fatal = true;\n\nfunction remoteInspectFlagToDisableDebuggerInChildProcess(): void {\n    const debugArgIdx = process.execArgv.indexOf(\"--inspect-brk\");\n    if (debugArgIdx !== -1) {\n        process.execArgv.splice(debugArgIdx, 1);\n    }\n    const debugArg2Idx = process.execArgv.indexOf(\"--inspect\");\n    if (debugArg2Idx !== -1) {\n        process.execArgv.splice(debugArg2Idx, 1);\n    }\n}\n\nasync function removeTemporaryWebpackConfigFiles(farmDirectory: string, logger: ILogger): Promise<void> {\n    const files = await readdir(farmDirectory);\n    const oldTempFileNames = files.filter(x => x.endsWith(\".candy-tmp.webpack.config.js\"));\n    if (oldTempFileNames.length > 0) {\n        logger.log(\"Removing old webpack.config.js files\");\n        for (const fileName of oldTempFileNames) {\n            await unlink(path.join(farmDirectory, fileName));\n        }\n        logger.log(\"Removed old webpack.config.js files\");\n    }\n}\n\nrunConsoleApplication(async (argv, context) => {\n    remoteInspectFlagToDisableDebuggerInChildProcess();\n\n    context.logger.log(\"@kontur.candy/tools: \" + (await getCurrentVersion()));\n    const options = parseOptions(argv);\n    context.setConsoleLoggingVerbosity(options.options.logVerbosity);\n    setLogger(context.logger);\n    context.logger.verbose(`Verbose level: ${options.options.logVerbosity}`);\n\n    const farmDirectory = process.cwd();\n    await removeTemporaryWebpackConfigFiles(farmDirectory, context.logger);\n    const farmConfig = readFarmConfig(process.cwd());\n\n    if (farmConfig.engineDirectory == undefined) {\n        throw new Error(\"EngineDirectory is not specified\");\n    }\n    if (farmConfig.resourcesDirectory == undefined) {\n        throw new Error(\"ResourcesDirectory is not specified\");\n    }\n\n    const engineDirectory = path.resolve(farmConfig.engineDirectory);\n    const resourcesDirectory = path.resolve(farmConfig.resourcesDirectory);\n    const candyModulesDirectory = path.resolve(farmDirectory, \"..\", \".candy_modules\");\n\n    if (options.type === \"build-server\") {\n        await runBuildServer(\n            context,\n            options.options,\n            engineDirectory,\n            farmDirectory,\n            resourcesDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"dev-build-server\") {\n        await runDevBuildServer(\n            context,\n            options.options,\n            engineDirectory,\n            farmDirectory,\n            resourcesDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"build\") {\n        await runBuildForms(\n            context,\n            options.options,\n            farmDirectory,\n            resourcesDirectory,\n            engineDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"dev-build\") {\n        await runDevBuild(\n            context,\n            options.options,\n            engineDirectory,\n            resourcesDirectory,\n            farmDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"form-stats\") {\n        await runFormStats(context, options.options, farmDirectory);\n    }\n    if (options.type === \"upgrade\") {\n        await runUpgradeForm(context, options.options, resourcesDirectory, farmDirectory);\n    }\n    if (options.type === \"localize\") {\n        await runLocalization(\n            context,\n            options.options,\n            farmDirectory,\n            engineDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n    if (options.type === \"init-form\") {\n        await runInitForm(context, options.options, farmDirectory);\n    }\n});\n"]}
133
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/CandyCLI.ts"],"names":["config","fatal","remoteInspectFlagToDisableDebuggerInChildProcess","debugArgIdx","process","execArgv","indexOf","splice","debugArg2Idx","removeTemporaryWebpackConfigFiles","farmDirectory","logger","files","oldTempFileNames","filter","x","endsWith","length","log","fileName","path","join","argv","context","options","setConsoleLoggingVerbosity","logVerbosity","verbose","cwd","farmConfig","engineDirectory","undefined","Error","resourcesDirectory","resolve","candyModulesDirectory","type","hlFarmDirectoryPath"],"mappings":"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","sourcesContent":["import \"core-js/stable\";\nimport \"regenerator-runtime/runtime\";\nimport \"core-js/features/array/flat\";\nimport \"core-js/proposals/iterator-helpers\";\nimport \"reflect-metadata\";\n\nimport path from \"path\";\n\nimport { readdir, unlink } from \"fs-extra\";\nimport { config } from \"shelljs\";\n\nimport { runConsoleApplication } from \"./Commons/ConsoleApplication/ConsoleApplication\";\nimport { ILogger } from \"./Commons/Logging/ILogger\";\nimport { setLogger } from \"./Commons/Logging/StaticLogger\";\nimport { runBuildForms } from \"./CLICommands/BuildForms/RunBuildForms\";\nimport { runBuildServer, runDevBuildServer } from \"./CLICommands/BuildServer/RunBuildServer\";\nimport { runDevBuild } from \"./CLICommands/DevBuild/RunDevBuild\";\nimport { runFormStats } from \"./CLICommands/FormStats/RunFormStats\";\nimport { runInitForm } from \"./CLICommands/InitForm/RunInitForm\";\nimport { runLocalization } from \"./CLICommands/Localization/RunLocalization\";\nimport { runUpgradeForm } from \"./CLICommands/UpgradeForm/RunUpgradeForm\";\nimport { parseOptions } from \"./Options/CandyToolOptions\";\nimport { readFarmConfig } from \"./ReadFarmConfig\";\nimport { getCurrentVersion } from \"./SelfUpdate\";\n\nconfig.fatal = true;\n\nfunction remoteInspectFlagToDisableDebuggerInChildProcess(): void {\n    const debugArgIdx = process.execArgv.indexOf(\"--inspect-brk\");\n    if (debugArgIdx !== -1) {\n        process.execArgv.splice(debugArgIdx, 1);\n    }\n    const debugArg2Idx = process.execArgv.indexOf(\"--inspect\");\n    if (debugArg2Idx !== -1) {\n        process.execArgv.splice(debugArg2Idx, 1);\n    }\n}\n\nasync function removeTemporaryWebpackConfigFiles(farmDirectory: string, logger: ILogger): Promise<void> {\n    const files = await readdir(farmDirectory);\n    const oldTempFileNames = files.filter(x => x.endsWith(\".candy-tmp.webpack.config.js\"));\n    if (oldTempFileNames.length > 0) {\n        logger.log(\"Removing old webpack.config.js files\");\n        for (const fileName of oldTempFileNames) {\n            await unlink(path.join(farmDirectory, fileName));\n        }\n        logger.log(\"Removed old webpack.config.js files\");\n    }\n}\n\nrunConsoleApplication(async (argv, context) => {\n    remoteInspectFlagToDisableDebuggerInChildProcess();\n\n    context.logger.log(\"@kontur.candy/tools: \" + (await getCurrentVersion()));\n    const options = parseOptions(argv);\n    context.setConsoleLoggingVerbosity(options.options.logVerbosity);\n    setLogger(context.logger);\n    context.logger.verbose(`Verbose level: ${options.options.logVerbosity}`);\n\n    const farmDirectory = process.cwd();\n    await removeTemporaryWebpackConfigFiles(farmDirectory, context.logger);\n    const farmConfig = readFarmConfig(farmDirectory);\n\n    if (farmConfig.engineDirectory == undefined) {\n        throw new Error(\"EngineDirectory is not specified\");\n    }\n    if (farmConfig.resourcesDirectory == undefined) {\n        throw new Error(\"ResourcesDirectory is not specified\");\n    }\n\n    const engineDirectory = path.resolve(farmConfig.engineDirectory);\n    const resourcesDirectory = path.resolve(farmConfig.resourcesDirectory);\n    const candyModulesDirectory = path.resolve(farmDirectory, \"..\", \".candy_modules\");\n\n    if (options.type === \"build-server\") {\n        await runBuildServer(\n            context,\n            options.options,\n            engineDirectory,\n            farmDirectory,\n            resourcesDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"dev-build-server\") {\n        await runDevBuildServer(\n            context,\n            options.options,\n            engineDirectory,\n            farmDirectory,\n            resourcesDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"build\") {\n        await runBuildForms(\n            context,\n            options.options,\n            farmDirectory,\n            resourcesDirectory,\n            engineDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"dev-build\") {\n        await runDevBuild(\n            context,\n            options.options,\n            engineDirectory,\n            resourcesDirectory,\n            farmDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n\n    if (options.type === \"form-stats\") {\n        await runFormStats(context, options.options, farmDirectory);\n    }\n    if (options.type === \"upgrade\") {\n        await runUpgradeForm(context, options.options, resourcesDirectory, farmDirectory);\n    }\n    if (options.type === \"localize\") {\n        await runLocalization(\n            context,\n            options.options,\n            farmDirectory,\n            engineDirectory,\n            candyModulesDirectory,\n            farmConfig.hlFarmDirectoryPath\n        );\n    }\n    if (options.type === \"init-form\") {\n        await runInitForm(context, options.options, farmDirectory);\n    }\n});\n"]}
@@ -132,6 +132,7 @@ class BuildCache {
132
132
  content = { ...content,
133
133
  [fileName]: fileContent
134
134
  };
135
+ await (0, _fsExtra.ensureDir)(path.dirname(cacheFilePath));
135
136
  await (0, _fsExtra.writeFile)(cacheFilePath, JSON.stringify(content), "utf-8");
136
137
  }
137
138
 
@@ -140,15 +141,10 @@ class BuildCache {
140
141
  return undefined;
141
142
  }
142
143
 
143
- const cachedFilePath = await this.existsFileCacheOrDownload(options.gfv, options.generatorVersion, options.depsHash);
144
-
145
- if (cachedFilePath != undefined) {
146
- new CacheAssetsPlugin({
147
- cacheFile: cachedFilePath
148
- });
149
- }
150
-
151
- return undefined;
144
+ const cachedFilePath = this.getCacheFilePath(options.gfv, options.generatorVersion, options.depsHash);
145
+ return new CacheAssetsPlugin({
146
+ cacheFile: cachedFilePath
147
+ });
152
148
  }
153
149
 
154
150
  getCacheFilePath(gfv, generatorVersion, depsHash) {
@@ -194,4 +190,4 @@ class BuildCache {
194
190
  }
195
191
 
196
192
  exports.BuildCache = BuildCache;
197
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/FormWebpackConfiguration/CacheAssetsPlugin.ts"],"names":["singleLimit","CacheAssetsPlugin","constructor","options","apply","compiler","hooks","emit","tapPromise","compilation","cacheItems","assetName","Object","keys","assets","source","Buffer","type","base64content","toString","updateFile","filePath","path","resolve","cacheFile","content","JSON","parse","dirname","stringify","BuildCache","farmDirectory","mode","logger","withPrefix","extract","generatorSource","gfv","depsHash","resourcesDirectory","Error","getCacheFilePath","version","assetPath","contentElement","join","from","exists","BuildCacheMode","Disabled","ForceUpdate","cachedFilePath","existsFileCacheOrDownload","undefined","setContent","fileName","fileContent","cacheFilePath","createWebpackPlugin","ReadOnly","generatorVersion","log","response","basename","status","buffer","error","e"],"mappings":"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","sourcesContent":["import * as path from \"path\";\n\nimport { ensureDir, pathExists, readFile, writeFile } from \"fs-extra\";\nimport md5 from \"md5\";\nimport pLimit from \"p-limit\";\nimport webpack from \"webpack\";\nimport fetch from \"node-fetch\";\n\nimport { GeneratorSource } from \"../BuildTasks/Generator/AcquireFormGenerator\";\nimport { BuildCacheMode } from \"../CLICommands/BuildForms/BuildCacheMode\";\nimport { reject } from \"../../../Common/TypingUtils\";\nimport { ILogger } from \"../Commons/Logging/ILogger\";\nimport { getLogger } from \"../Commons/Logging/StaticLogger\";\n\ninterface CacheAssetsPluginOptions {\n    cacheFile: string;\n}\n\nexport interface FormBuildCacheOptions {\n    farmDirectory: string;\n    mode: BuildCacheMode;\n    generatorVersion: string;\n    gfv: string;\n    depsHash: string;\n}\n\nconst singleLimit = pLimit(1);\n\ninterface BuildResultsSerialized {\n    [path: string]: string | { type: \"Buffer\"; base64content: string };\n}\n\nexport class CacheAssetsPlugin {\n    private readonly options: CacheAssetsPluginOptions;\n\n    public constructor(options: CacheAssetsPluginOptions) {\n        this.options = options;\n    }\n\n    public async apply(compiler: webpack.Compiler): Promise<void> {\n        compiler.hooks.emit.tapPromise(\"CacheAssetsPlugin\", compilation =>\n            singleLimit(async () => {\n                const cacheItems: BuildResultsSerialized = {};\n                // tslint:disable-next-line no-unsafe-any\n                for (const assetName of Object.keys(compilation.assets)) {\n                    // tslint:disable-next-line no-unsafe-any\n                    const source: string | Buffer = compilation.assets[assetName]?.source() ?? reject();\n                    if (source instanceof Buffer) {\n                        cacheItems[assetName] = { type: \"Buffer\", base64content: source.toString(\"base64\") };\n                    } else {\n                        cacheItems[assetName] = source;\n                    }\n                }\n                await this.updateFile(cacheItems);\n            })\n        );\n    }\n\n    private async updateFile(cacheItems: BuildResultsSerialized): Promise<void> {\n        const filePath = path.resolve(this.options.cacheFile);\n        let content: BuildResultsSerialized = (await pathExists(filePath))\n            ? // tslint:disable-next-line no-unsafe-any\n              JSON.parse(await readFile(filePath, \"utf-8\"))\n            : {};\n        content = {\n            ...content,\n            ...cacheItems,\n        };\n        await ensureDir(path.dirname(filePath));\n        await writeFile(filePath, JSON.stringify(content), \"utf-8\");\n    }\n}\n\nexport class BuildCache {\n    private readonly farmDirectory: string;\n    private readonly mode: BuildCacheMode;\n    private readonly logger: ILogger;\n\n    public constructor(farmDirectory: string, mode: BuildCacheMode) {\n        this.farmDirectory = farmDirectory;\n        this.mode = mode;\n        this.logger = getLogger().withPrefix(\"BUILD_CACHE\");\n    }\n\n    public async extract(\n        generatorSource: GeneratorSource,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string\n    ): Promise<void> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        // tslint:disable-next-line no-unsafe-any\n        const content: BuildResultsSerialized = JSON.parse(\n            await readFile(this.getCacheFilePath(gfv, generatorSource.version, depsHash), \"utf-8\")\n        );\n        for (const assetPath of Object.keys(content)) {\n            const contentElement = content[assetPath] ?? reject();\n            const filePath = path.join(resourcesDirectory, assetPath);\n            await ensureDir(path.dirname(filePath));\n            if (typeof contentElement === \"string\") {\n                await writeFile(filePath, contentElement, \"utf8\");\n            } else {\n                await writeFile(filePath, Buffer.from(contentElement.base64content, \"base64\"));\n            }\n        }\n    }\n\n    public async exists(generatorSource: GeneratorSource, gfv: string, depsHash: string): Promise<boolean> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        if (this.mode === BuildCacheMode.Disabled || this.mode === BuildCacheMode.ForceUpdate) {\n            return false;\n        }\n        const cachedFilePath = await this.existsFileCacheOrDownload(gfv, generatorSource.version, depsHash);\n        return cachedFilePath != undefined;\n    }\n\n    public async setContent(\n        generatorSource: string,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string,\n        fileName: string,\n        fileContent: string\n    ): Promise<void> {\n        const cacheFilePath = this.getCacheFilePath(gfv, generatorSource, depsHash);\n        if (!(await pathExists(cacheFilePath))) {\n            return;\n        }\n        // tslint:disable-next-line no-unsafe-any\n        let content: BuildResultsSerialized = JSON.parse(await readFile(cacheFilePath, \"utf-8\"));\n        content = {\n            ...content,\n            [fileName]: fileContent,\n        };\n        await writeFile(cacheFilePath, JSON.stringify(content), \"utf-8\");\n    }\n\n    public async createWebpackPlugin(options: FormBuildCacheOptions): Promise<CacheAssetsPlugin | undefined> {\n        if (options.mode === BuildCacheMode.Disabled || options.mode === BuildCacheMode.ReadOnly) {\n            return undefined;\n        }\n        const cachedFilePath = await this.existsFileCacheOrDownload(\n            options.gfv,\n            options.generatorVersion,\n            options.depsHash\n        );\n        if (cachedFilePath != undefined) {\n            new CacheAssetsPlugin({\n                cacheFile: cachedFilePath,\n            });\n        }\n        return undefined;\n    }\n\n    private getCacheFilePath(gfv: string, generatorVersion: string, depsHash: string): string {\n        const fileName = `${md5(gfv)}-${md5(generatorVersion)}-${depsHash}.zip`;\n        return path.join(this.farmDirectory, \".build-cache\", \"compile\", fileName);\n    }\n\n    private async existsFileCacheOrDownload(\n        gfv: string,\n        generatorVersion: string,\n        depsHash: string\n    ): Promise<string | undefined> {\n        const filePath = this.getCacheFilePath(gfv, generatorVersion, depsHash);\n        this.logger.log(`Start search file in local ${filePath}`);\n        await ensureDir(path.dirname(filePath));\n        if (await pathExists(filePath)) {\n            this.logger.log(`Found file in local directory`);\n            return filePath;\n        } else {\n            try {\n                this.logger.log(\"The cache file was not found in the local directory Im looking for it in drive\");\n                const response = await fetch(`https://api.kontur.ru/drive/v1/public/${path.basename(filePath)}`);\n                this.logger.log(`Drive response status code: ${response.status.toString()}`);\n                if (response.status === 200) {\n                    await writeFile(filePath, await response.buffer(), \"utf-8\");\n                    return filePath;\n                } else {\n                    if (response.status === 404) {\n                        this.logger.error(\"The cache file not found in drive storage\");\n                    } else {\n                        this.logger.error(\n                            `Drive storage send ${response.status} status code, I don't process it in any way`\n                        );\n                    }\n                    return undefined;\n                }\n            } catch (e) {\n                this.logger.error(\"Drive storage responded with an error\");\n                this.logger.error(\"The build will continue without a cache\");\n                this.logger.error(e);\n                return undefined;\n            }\n        }\n    }\n}\n"]}
193
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/FormWebpackConfiguration/CacheAssetsPlugin.ts"],"names":["singleLimit","CacheAssetsPlugin","constructor","options","apply","compiler","hooks","emit","tapPromise","compilation","cacheItems","assetName","Object","keys","assets","source","Buffer","type","base64content","toString","updateFile","filePath","path","resolve","cacheFile","content","JSON","parse","dirname","stringify","BuildCache","farmDirectory","mode","logger","withPrefix","extract","generatorSource","gfv","depsHash","resourcesDirectory","Error","getCacheFilePath","version","assetPath","contentElement","join","from","exists","BuildCacheMode","Disabled","ForceUpdate","cachedFilePath","existsFileCacheOrDownload","undefined","setContent","fileName","fileContent","cacheFilePath","createWebpackPlugin","ReadOnly","generatorVersion","log","response","basename","status","buffer","error","e"],"mappings":"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","sourcesContent":["import * as path from \"path\";\n\nimport { ensureDir, pathExists, readFile, writeFile } from \"fs-extra\";\nimport md5 from \"md5\";\nimport pLimit from \"p-limit\";\nimport webpack from \"webpack\";\nimport fetch from \"node-fetch\";\n\nimport { GeneratorSource } from \"../BuildTasks/Generator/AcquireFormGenerator\";\nimport { BuildCacheMode } from \"../CLICommands/BuildForms/BuildCacheMode\";\nimport { reject } from \"../../../Common/TypingUtils\";\nimport { ILogger } from \"../Commons/Logging/ILogger\";\nimport { getLogger } from \"../Commons/Logging/StaticLogger\";\n\ninterface CacheAssetsPluginOptions {\n    cacheFile: string;\n}\n\nexport interface FormBuildCacheOptions {\n    farmDirectory: string;\n    mode: BuildCacheMode;\n    generatorVersion: string;\n    gfv: string;\n    depsHash: string;\n}\n\nconst singleLimit = pLimit(1);\n\ninterface BuildResultsSerialized {\n    [path: string]: string | { type: \"Buffer\"; base64content: string };\n}\n\nexport class CacheAssetsPlugin {\n    private readonly options: CacheAssetsPluginOptions;\n\n    public constructor(options: CacheAssetsPluginOptions) {\n        this.options = options;\n    }\n\n    public async apply(compiler: webpack.Compiler): Promise<void> {\n        compiler.hooks.emit.tapPromise(\"CacheAssetsPlugin\", compilation =>\n            singleLimit(async () => {\n                const cacheItems: BuildResultsSerialized = {};\n                // tslint:disable-next-line no-unsafe-any\n                for (const assetName of Object.keys(compilation.assets)) {\n                    // tslint:disable-next-line no-unsafe-any\n                    const source: string | Buffer = compilation.assets[assetName]?.source() ?? reject();\n                    if (source instanceof Buffer) {\n                        cacheItems[assetName] = { type: \"Buffer\", base64content: source.toString(\"base64\") };\n                    } else {\n                        cacheItems[assetName] = source;\n                    }\n                }\n                await this.updateFile(cacheItems);\n            })\n        );\n    }\n\n    private async updateFile(cacheItems: BuildResultsSerialized): Promise<void> {\n        const filePath = path.resolve(this.options.cacheFile);\n        let content: BuildResultsSerialized = (await pathExists(filePath))\n            ? // tslint:disable-next-line no-unsafe-any\n              JSON.parse(await readFile(filePath, \"utf-8\"))\n            : {};\n        content = {\n            ...content,\n            ...cacheItems,\n        };\n        await ensureDir(path.dirname(filePath));\n        await writeFile(filePath, JSON.stringify(content), \"utf-8\");\n    }\n}\n\nexport class BuildCache {\n    private readonly farmDirectory: string;\n    private readonly mode: BuildCacheMode;\n    private readonly logger: ILogger;\n\n    public constructor(farmDirectory: string, mode: BuildCacheMode) {\n        this.farmDirectory = farmDirectory;\n        this.mode = mode;\n        this.logger = getLogger().withPrefix(\"BUILD_CACHE\");\n    }\n\n    public async extract(\n        generatorSource: GeneratorSource,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string\n    ): Promise<void> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        // tslint:disable-next-line no-unsafe-any\n        const content: BuildResultsSerialized = JSON.parse(\n            await readFile(this.getCacheFilePath(gfv, generatorSource.version, depsHash), \"utf-8\")\n        );\n        for (const assetPath of Object.keys(content)) {\n            const contentElement = content[assetPath] ?? reject();\n            const filePath = path.join(resourcesDirectory, assetPath);\n            await ensureDir(path.dirname(filePath));\n            if (typeof contentElement === \"string\") {\n                await writeFile(filePath, contentElement, \"utf8\");\n            } else {\n                await writeFile(filePath, Buffer.from(contentElement.base64content, \"base64\"));\n            }\n        }\n    }\n\n    public async exists(generatorSource: GeneratorSource, gfv: string, depsHash: string): Promise<boolean> {\n        if (generatorSource.type === \"GeneratorSources\") {\n            throw new Error(\"Local generator does not supports caching\");\n        }\n        if (this.mode === BuildCacheMode.Disabled || this.mode === BuildCacheMode.ForceUpdate) {\n            return false;\n        }\n        const cachedFilePath = await this.existsFileCacheOrDownload(gfv, generatorSource.version, depsHash);\n        return cachedFilePath != undefined;\n    }\n\n    public async setContent(\n        generatorSource: string,\n        gfv: string,\n        depsHash: string,\n        resourcesDirectory: string,\n        fileName: string,\n        fileContent: string\n    ): Promise<void> {\n        const cacheFilePath = this.getCacheFilePath(gfv, generatorSource, depsHash);\n        if (!(await pathExists(cacheFilePath))) {\n            return;\n        }\n        // tslint:disable-next-line no-unsafe-any\n        let content: BuildResultsSerialized = JSON.parse(await readFile(cacheFilePath, \"utf-8\"));\n        content = {\n            ...content,\n            [fileName]: fileContent,\n        };\n        await ensureDir(path.dirname(cacheFilePath));\n        await writeFile(cacheFilePath, JSON.stringify(content), \"utf-8\");\n    }\n\n    public async createWebpackPlugin(options: FormBuildCacheOptions): Promise<CacheAssetsPlugin | undefined> {\n        if (options.mode === BuildCacheMode.Disabled || options.mode === BuildCacheMode.ReadOnly) {\n            return undefined;\n        }\n        const cachedFilePath = this.getCacheFilePath(options.gfv, options.generatorVersion, options.depsHash);\n        return new CacheAssetsPlugin({\n            cacheFile: cachedFilePath,\n        });\n    }\n\n    private getCacheFilePath(gfv: string, generatorVersion: string, depsHash: string): string {\n        const fileName = `${md5(gfv)}-${md5(generatorVersion)}-${depsHash}.zip`;\n        return path.join(this.farmDirectory, \".build-cache\", \"compile\", fileName);\n    }\n\n    private async existsFileCacheOrDownload(\n        gfv: string,\n        generatorVersion: string,\n        depsHash: string\n    ): Promise<string | undefined> {\n        const filePath = this.getCacheFilePath(gfv, generatorVersion, depsHash);\n        this.logger.log(`Start search file in local ${filePath}`);\n        await ensureDir(path.dirname(filePath));\n        if (await pathExists(filePath)) {\n            this.logger.log(`Found file in local directory`);\n            return filePath;\n        } else {\n            try {\n                this.logger.log(\"The cache file was not found in the local directory Im looking for it in drive\");\n                const response = await fetch(`https://api.kontur.ru/drive/v1/public/${path.basename(filePath)}`);\n                this.logger.log(`Drive response status code: ${response.status.toString()}`);\n                if (response.status === 200) {\n                    await writeFile(filePath, await response.buffer(), \"utf-8\");\n                    return filePath;\n                } else {\n                    if (response.status === 404) {\n                        this.logger.error(\"The cache file not found in drive storage\");\n                    } else {\n                        this.logger.error(\n                            `Drive storage send ${response.status} status code, I don't process it in any way`\n                        );\n                    }\n                    return undefined;\n                }\n            } catch (e) {\n                this.logger.error(\"Drive storage responded with an error\");\n                this.logger.error(\"The build will continue without a cache\");\n                this.logger.error(e);\n                return undefined;\n            }\n        }\n    }\n}\n"]}