@promptbook/google 0.92.0-9 → 0.92.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.
Files changed (206) hide show
  1. package/README.md +1 -5
  2. package/esm/index.es.js +41 -30
  3. package/esm/index.es.js.map +1 -1
  4. package/esm/typings/src/_packages/browser.index.d.ts +2 -0
  5. package/esm/typings/src/_packages/core.index.d.ts +26 -14
  6. package/esm/typings/src/_packages/types.index.d.ts +6 -2
  7. package/esm/typings/src/collection/PipelineCollection.d.ts +0 -2
  8. package/esm/typings/src/collection/SimplePipelineCollection.d.ts +1 -1
  9. package/esm/typings/src/commands/FOREACH/ForeachJson.d.ts +6 -6
  10. package/esm/typings/src/commands/FOREACH/foreachCommandParser.d.ts +0 -2
  11. package/esm/typings/src/commands/FORMFACTOR/formfactorCommandParser.d.ts +1 -1
  12. package/esm/typings/src/commands/_BOILERPLATE/boilerplateCommandParser.d.ts +1 -1
  13. package/esm/typings/src/commands/_common/types/CommandParser.d.ts +36 -28
  14. package/esm/typings/src/config.d.ts +41 -11
  15. package/esm/typings/src/constants.d.ts +43 -2
  16. package/esm/typings/src/conversion/parsePipeline.d.ts +2 -2
  17. package/esm/typings/src/errors/0-BoilerplateError.d.ts +2 -2
  18. package/esm/typings/src/errors/CollectionError.d.ts +1 -1
  19. package/esm/typings/src/executables/$provideExecutablesForNode.d.ts +1 -1
  20. package/esm/typings/src/executables/apps/locateLibreoffice.d.ts +2 -1
  21. package/esm/typings/src/executables/apps/locatePandoc.d.ts +2 -1
  22. package/esm/typings/src/executables/locateApp.d.ts +2 -2
  23. package/esm/typings/src/executables/platforms/locateAppOnLinux.d.ts +2 -1
  24. package/esm/typings/src/executables/platforms/locateAppOnMacOs.d.ts +2 -1
  25. package/esm/typings/src/executables/platforms/locateAppOnWindows.d.ts +2 -1
  26. package/esm/typings/src/execution/AbstractTaskResult.d.ts +1 -1
  27. package/esm/typings/src/execution/CommonToolsOptions.d.ts +3 -3
  28. package/esm/typings/src/execution/ExecutionTask.d.ts +19 -1
  29. package/esm/typings/src/execution/LlmExecutionToolsConstructor.d.ts +2 -1
  30. package/esm/typings/src/execution/PipelineExecutorResult.d.ts +4 -2
  31. package/esm/typings/src/execution/PromptbookFetch.d.ts +1 -1
  32. package/esm/typings/src/execution/ScriptExecutionTools.d.ts +1 -1
  33. package/esm/typings/src/execution/createPipelineExecutor/$OngoingTaskResult.d.ts +12 -9
  34. package/esm/typings/src/execution/createPipelineExecutor/10-executePipeline.d.ts +13 -10
  35. package/esm/typings/src/execution/createPipelineExecutor/20-executeTask.d.ts +12 -9
  36. package/esm/typings/src/execution/createPipelineExecutor/30-executeFormatSubvalues.d.ts +15 -3
  37. package/esm/typings/src/execution/createPipelineExecutor/40-executeAttempts.d.ts +21 -15
  38. package/esm/typings/src/execution/createPipelineExecutor/computeCosineSimilarity.d.ts +13 -0
  39. package/esm/typings/src/execution/createPipelineExecutor/filterJustOutputParameters.d.ts +7 -6
  40. package/esm/typings/src/execution/createPipelineExecutor/getContextForTask.d.ts +5 -1
  41. package/esm/typings/src/execution/createPipelineExecutor/getExamplesForTask.d.ts +1 -1
  42. package/esm/typings/src/execution/createPipelineExecutor/getKnowledgeForTask.d.ts +12 -9
  43. package/esm/typings/src/execution/createPipelineExecutor/getReservedParametersForTask.d.ts +18 -5
  44. package/esm/typings/src/execution/createPipelineExecutor/knowledgePiecesToString.d.ts +9 -0
  45. package/esm/typings/src/execution/execution-report/ExecutionReportJson.d.ts +1 -1
  46. package/esm/typings/src/execution/execution-report/ExecutionReportString.d.ts +1 -1
  47. package/esm/typings/src/execution/translation/automatic-translate/automatic-translators/LindatAutomaticTranslator.d.ts +4 -4
  48. package/esm/typings/src/execution/utils/checkExpectations.d.ts +3 -3
  49. package/esm/typings/src/execution/utils/uncertainNumber.d.ts +3 -2
  50. package/esm/typings/src/execution/utils/usageToWorktime.d.ts +1 -1
  51. package/esm/typings/src/formats/_common/{FormatDefinition.d.ts → FormatParser.d.ts} +8 -6
  52. package/esm/typings/src/formats/_common/FormatSubvalueParser.d.ts +66 -0
  53. package/esm/typings/src/formats/csv/CsvFormatParser.d.ts +17 -0
  54. package/esm/typings/src/formats/csv/CsvSettings.d.ts +2 -2
  55. package/esm/typings/src/formats/csv/utils/csvParse.d.ts +12 -0
  56. package/esm/typings/src/formats/csv/utils/isValidCsvString.d.ts +1 -1
  57. package/esm/typings/src/formats/index.d.ts +2 -2
  58. package/esm/typings/src/formats/json/JsonFormatParser.d.ts +19 -0
  59. package/esm/typings/src/formats/json/utils/isValidJsonString.d.ts +1 -1
  60. package/esm/typings/src/formats/json/utils/jsonParse.d.ts +0 -3
  61. package/esm/typings/src/formats/text/{TextFormatDefinition.d.ts → TextFormatParser.d.ts} +7 -7
  62. package/esm/typings/src/formats/xml/XmlFormatParser.d.ts +19 -0
  63. package/esm/typings/src/formats/xml/utils/isValidXmlString.d.ts +1 -1
  64. package/esm/typings/src/formfactors/_boilerplate/BoilerplateFormfactorDefinition.d.ts +3 -2
  65. package/esm/typings/src/formfactors/_common/AbstractFormfactorDefinition.d.ts +16 -7
  66. package/esm/typings/src/formfactors/_common/FormfactorDefinition.d.ts +3 -1
  67. package/esm/typings/src/formfactors/_common/string_formfactor_name.d.ts +2 -1
  68. package/esm/typings/src/formfactors/chatbot/ChatbotFormfactorDefinition.d.ts +2 -2
  69. package/esm/typings/src/formfactors/completion/CompletionFormfactorDefinition.d.ts +29 -0
  70. package/esm/typings/src/formfactors/generator/GeneratorFormfactorDefinition.d.ts +2 -1
  71. package/esm/typings/src/formfactors/generic/GenericFormfactorDefinition.d.ts +2 -2
  72. package/esm/typings/src/formfactors/index.d.ts +33 -8
  73. package/esm/typings/src/formfactors/matcher/MatcherFormfactorDefinition.d.ts +4 -2
  74. package/esm/typings/src/formfactors/sheets/SheetsFormfactorDefinition.d.ts +3 -2
  75. package/esm/typings/src/formfactors/translator/TranslatorFormfactorDefinition.d.ts +3 -2
  76. package/esm/typings/src/high-level-abstractions/index.d.ts +2 -2
  77. package/esm/typings/src/llm-providers/_common/register/$llmToolsMetadataRegister.d.ts +3 -3
  78. package/esm/typings/src/llm-providers/_common/register/$llmToolsRegister.d.ts +3 -3
  79. package/esm/typings/src/llm-providers/_common/register/$provideLlmToolsConfigurationFromEnv.d.ts +4 -4
  80. package/esm/typings/src/llm-providers/_common/register/$provideLlmToolsForTestingAndScriptsAndPlayground.d.ts +4 -3
  81. package/esm/typings/src/llm-providers/_common/register/$provideLlmToolsFromEnv.d.ts +18 -5
  82. package/esm/typings/src/llm-providers/_common/register/LlmToolsConfiguration.d.ts +11 -4
  83. package/esm/typings/src/llm-providers/_common/register/LlmToolsMetadata.d.ts +21 -42
  84. package/esm/typings/src/llm-providers/_common/register/LlmToolsOptions.d.ts +9 -2
  85. package/esm/typings/src/llm-providers/_common/register/createLlmToolsFromConfiguration.d.ts +13 -4
  86. package/esm/typings/src/llm-providers/_common/utils/cache/CacheItem.d.ts +10 -5
  87. package/esm/typings/src/llm-providers/_common/utils/cache/CacheLlmToolsOptions.d.ts +11 -3
  88. package/esm/typings/src/llm-providers/_common/utils/cache/cacheLlmTools.d.ts +3 -3
  89. package/esm/typings/src/llm-providers/_common/utils/count-total-usage/limitTotalUsage.d.ts +5 -5
  90. package/esm/typings/src/llm-providers/anthropic-claude/AnthropicClaudeExecutionTools.d.ts +6 -0
  91. package/esm/typings/src/llm-providers/anthropic-claude/anthropic-claude-models.d.ts +1 -1
  92. package/esm/typings/src/llm-providers/azure-openai/AzureOpenAiExecutionTools.d.ts +1 -1
  93. package/esm/typings/src/llm-providers/azure-openai/AzureOpenAiExecutionToolsOptions.d.ts +4 -4
  94. package/esm/typings/src/llm-providers/deepseek/deepseek-models.d.ts +1 -1
  95. package/esm/typings/src/llm-providers/google/google-models.d.ts +1 -1
  96. package/esm/typings/src/llm-providers/openai/OpenAiAssistantExecutionTools.d.ts +1 -1
  97. package/esm/typings/src/llm-providers/openai/openai-models.d.ts +1 -1
  98. package/esm/typings/src/llm-providers/openai/register-configuration.d.ts +2 -2
  99. package/esm/typings/src/llm-providers/openai/register-constructor.d.ts +2 -2
  100. package/esm/typings/src/migrations/migratePipeline.d.ts +9 -0
  101. package/esm/typings/src/other/templates/getBookTemplates.d.ts +2 -2
  102. package/esm/typings/src/pipeline/PipelineInterface/PipelineInterface.d.ts +3 -3
  103. package/esm/typings/src/pipeline/PipelineInterface/constants.d.ts +1 -1
  104. package/esm/typings/src/pipeline/PipelineInterface/getPipelineInterface.d.ts +1 -1
  105. package/esm/typings/src/pipeline/PipelineInterface/isPipelineImplementingInterface.d.ts +5 -4
  106. package/esm/typings/src/pipeline/PipelineInterface/isPipelineInterfacesEqual.d.ts +1 -1
  107. package/esm/typings/src/pipeline/PipelineJson/CommonTaskJson.d.ts +10 -7
  108. package/esm/typings/src/pipeline/PipelineJson/ParameterJson.d.ts +1 -1
  109. package/esm/typings/src/pipeline/PipelineJson/PipelineJson.d.ts +3 -2
  110. package/esm/typings/src/pipeline/PipelineString.d.ts +3 -1
  111. package/esm/typings/src/pipeline/book-notation.d.ts +2 -2
  112. package/esm/typings/src/postprocessing/utils/extractBlock.d.ts +1 -1
  113. package/esm/typings/src/postprocessing/utils/extractJsonBlock.d.ts +2 -2
  114. package/esm/typings/src/prepare/prepareTasks.d.ts +8 -5
  115. package/esm/typings/src/remote-server/openapi.d.ts +1 -1
  116. package/esm/typings/src/remote-server/socket-types/listModels/PromptbookServer_ListModels_Response.d.ts +1 -1
  117. package/esm/typings/src/remote-server/startRemoteServer.d.ts +1 -1
  118. package/esm/typings/src/remote-server/types/RemoteServerOptions.d.ts +7 -6
  119. package/esm/typings/src/scrapers/_boilerplate/BoilerplateScraper.d.ts +3 -3
  120. package/esm/typings/src/scrapers/_boilerplate/createBoilerplateScraper.d.ts +1 -1
  121. package/esm/typings/src/scrapers/_boilerplate/register-metadata.d.ts +1 -1
  122. package/esm/typings/src/scrapers/_common/Converter.d.ts +3 -1
  123. package/esm/typings/src/scrapers/_common/Scraper.d.ts +4 -3
  124. package/esm/typings/src/scrapers/_common/ScraperIntermediateSource.d.ts +4 -2
  125. package/esm/typings/src/scrapers/_common/prepareKnowledgePieces.d.ts +2 -2
  126. package/esm/typings/src/scrapers/_common/register/$provideFilesystemForNode.d.ts +2 -1
  127. package/esm/typings/src/scrapers/_common/register/$provideScrapersForBrowser.d.ts +6 -3
  128. package/esm/typings/src/scrapers/_common/register/$provideScrapersForNode.d.ts +3 -5
  129. package/esm/typings/src/scrapers/_common/register/$scrapersMetadataRegister.d.ts +3 -3
  130. package/esm/typings/src/scrapers/_common/register/$scrapersRegister.d.ts +3 -2
  131. package/esm/typings/src/scrapers/_common/register/ScraperAndConverterMetadata.d.ts +8 -5
  132. package/esm/typings/src/scrapers/_common/register/ScraperConstructor.d.ts +2 -1
  133. package/esm/typings/src/scrapers/_common/utils/getScraperIntermediateSource.d.ts +6 -5
  134. package/esm/typings/src/scrapers/_common/utils/makeKnowledgeSourceHandler.d.ts +3 -1
  135. package/esm/typings/src/scrapers/document/createDocumentScraper.d.ts +1 -1
  136. package/esm/typings/src/scrapers/document-legacy/createLegacyDocumentScraper.d.ts +2 -1
  137. package/esm/typings/src/scrapers/markdown/createMarkdownScraper.d.ts +4 -1
  138. package/esm/typings/src/scrapers/markitdown/MarkitdownScraper.d.ts +1 -1
  139. package/esm/typings/src/scrapers/pdf/createPdfScraper.d.ts +2 -1
  140. package/esm/typings/src/scrapers/website/createWebsiteScraper.d.ts +3 -4
  141. package/esm/typings/src/scripting/javascript/JavascriptExecutionTools.d.ts +1 -1
  142. package/esm/typings/src/scripting/javascript/postprocessing-functions.d.ts +5 -1
  143. package/esm/typings/src/scripting/javascript/utils/preserve.d.ts +1 -1
  144. package/esm/typings/src/storage/_common/PromptbookStorage.d.ts +1 -1
  145. package/esm/typings/src/storage/file-cache-storage/FileCacheStorage.d.ts +12 -5
  146. package/esm/typings/src/storage/file-cache-storage/FileCacheStorageOptions.d.ts +4 -2
  147. package/esm/typings/src/storage/file-cache-storage/utils/nameToSubfolderPath.d.ts +2 -1
  148. package/esm/typings/src/storage/local-storage/getIndexedDbStorage.d.ts +11 -0
  149. package/esm/typings/src/storage/local-storage/utils/IndexedDbStorageOptions.d.ts +14 -0
  150. package/esm/typings/src/storage/local-storage/utils/makePromptbookStorageFromIndexedDb.d.ts +8 -0
  151. package/esm/typings/src/storage/local-storage/utils/makePromptbookStorageFromWebStorage.d.ts +2 -1
  152. package/esm/typings/src/types/IntermediateFilesStrategy.d.ts +2 -1
  153. package/esm/typings/src/types/ModelRequirements.d.ts +2 -2
  154. package/esm/typings/src/types/ModelVariant.d.ts +5 -5
  155. package/esm/typings/src/types/typeAliases.d.ts +22 -19
  156. package/esm/typings/src/utils/$Register.d.ts +8 -7
  157. package/esm/typings/src/utils/editable/edit-pipeline-string/addPipelineCommand.d.ts +2 -2
  158. package/esm/typings/src/utils/editable/edit-pipeline-string/deflatePipeline.d.ts +4 -1
  159. package/esm/typings/src/utils/editable/utils/isFlatPipeline.d.ts +2 -1
  160. package/esm/typings/src/utils/editable/utils/stringifyPipelineJson.d.ts +1 -1
  161. package/esm/typings/src/utils/environment/$getGlobalScope.d.ts +2 -1
  162. package/esm/typings/src/utils/expectation-counters/index.d.ts +1 -1
  163. package/esm/typings/src/utils/markdown/extractAllBlocksFromMarkdown.d.ts +2 -2
  164. package/esm/typings/src/utils/markdown/extractAllListItemsFromMarkdown.d.ts +1 -1
  165. package/esm/typings/src/utils/markdown/extractOneBlockFromMarkdown.d.ts +2 -2
  166. package/esm/typings/src/utils/normalization/nameToUriPart.d.ts +4 -4
  167. package/esm/typings/src/utils/normalization/nameToUriParts.d.ts +4 -4
  168. package/esm/typings/src/utils/normalization/normalize-to-kebab-case.d.ts +3 -3
  169. package/esm/typings/src/utils/normalization/normalizeTo_SCREAMING_CASE.d.ts +3 -3
  170. package/esm/typings/src/utils/normalization/normalizeTo_camelCase.d.ts +4 -4
  171. package/esm/typings/src/utils/normalization/normalizeTo_snake_case.d.ts +3 -3
  172. package/esm/typings/src/utils/normalization/removeDiacritics.d.ts +3 -3
  173. package/esm/typings/src/utils/normalization/searchKeywords.d.ts +4 -1
  174. package/esm/typings/src/utils/normalization/titleToName.d.ts +4 -4
  175. package/esm/typings/src/utils/organization/TODO_USE.d.ts +1 -1
  176. package/esm/typings/src/utils/organization/empty_object.d.ts +2 -2
  177. package/esm/typings/src/utils/organization/just.d.ts +1 -1
  178. package/esm/typings/src/utils/organization/just_empty_object.d.ts +4 -4
  179. package/esm/typings/src/utils/organization/keepUnused.d.ts +1 -1
  180. package/esm/typings/src/utils/parameters/mapAvailableToExpectedParameters.d.ts +7 -7
  181. package/esm/typings/src/utils/removeQuotes.d.ts +2 -2
  182. package/esm/typings/src/utils/serialization/clonePipeline.d.ts +4 -3
  183. package/esm/typings/src/utils/serialization/deepClone.d.ts +5 -1
  184. package/esm/typings/src/utils/trimCodeBlock.d.ts +1 -1
  185. package/esm/typings/src/utils/trimEndOfCodeBlock.d.ts +1 -1
  186. package/esm/typings/src/utils/unwrapResult.d.ts +2 -2
  187. package/esm/typings/src/utils/validators/javascriptName/isValidJavascriptName.d.ts +3 -3
  188. package/esm/typings/src/utils/validators/parameterName/validateParameterName.d.ts +5 -4
  189. package/esm/typings/src/utils/validators/semanticVersion/isValidPromptbookVersion.d.ts +1 -1
  190. package/esm/typings/src/utils/validators/semanticVersion/isValidSemanticVersion.d.ts +1 -1
  191. package/esm/typings/src/utils/validators/url/isHostnameOnPrivateNetwork.d.ts +1 -1
  192. package/esm/typings/src/utils/validators/url/isUrlOnPrivateNetwork.d.ts +1 -1
  193. package/esm/typings/src/utils/validators/url/isValidPipelineUrl.d.ts +1 -1
  194. package/esm/typings/src/utils/validators/url/isValidUrl.d.ts +1 -1
  195. package/esm/typings/src/version.d.ts +2 -1
  196. package/esm/typings/src/wizzard/wizzard.d.ts +1 -1
  197. package/package.json +14 -2
  198. package/umd/index.umd.js +41 -30
  199. package/umd/index.umd.js.map +1 -1
  200. package/esm/typings/src/formats/_common/FormatSubvalueDefinition.d.ts +0 -31
  201. package/esm/typings/src/formats/csv/CsvFormatDefinition.d.ts +0 -17
  202. package/esm/typings/src/formats/json/JsonFormatDefinition.d.ts +0 -19
  203. package/esm/typings/src/formats/xml/XmlFormatDefinition.d.ts +0 -19
  204. /package/esm/typings/src/llm-providers/{multiple → _multiple}/MultipleLlmExecutionTools.d.ts +0 -0
  205. /package/esm/typings/src/llm-providers/{multiple → _multiple}/joinLlmExecutionTools.d.ts +0 -0
  206. /package/esm/typings/src/llm-providers/{multiple → _multiple}/playground/playground.d.ts +0 -0
@@ -1,27 +1,27 @@
1
1
  import type { string_parameter_name } from '../../types/typeAliases';
2
2
  import type { TODO_string } from '../../utils/organization/TODO_string';
3
3
  /**
4
- * @@@
4
+ * Information for the FOREACH command, describing how to iterate over a parameter's subvalues in a pipeline task.
5
5
  */
6
6
  export type ForeachJson = {
7
7
  /**
8
- * @@@
8
+ * The name of the format to use for parsing the parameter (e.g., 'CSV').
9
9
  */
10
10
  readonly formatName: TODO_string;
11
11
  /**
12
- * @@@
12
+ * The name of the subformat to use (e.g., CSV Rows).
13
13
  */
14
14
  readonly subformatName: TODO_string;
15
15
  /**
16
- * @@@
16
+ * The name of the parameter to iterate over.
17
17
  */
18
18
  readonly parameterName: string_parameter_name;
19
19
  /**
20
- * @@@
20
+ * The names of the subparameters (e.g., name of the CSV rows)
21
21
  */
22
22
  readonly inputSubparameterNames: Array<string_parameter_name>;
23
23
  /**
24
- * @@@
24
+ * The name of the subparameters (e.g., name of the CSV rows)
25
25
  */
26
26
  readonly outputSubparameterName: string_parameter_name;
27
27
  };
@@ -3,8 +3,6 @@ import type { ForeachCommand } from './ForeachCommand';
3
3
  /**
4
4
  * Parses the foreach command
5
5
  *
6
- * Note: @@@ This command is used as foreach for new commands - it should NOT be used in any `.book` file
7
- *
8
6
  * @see `documentationUrl` for more details
9
7
  * @public exported from `@promptbook/editable`
10
8
  */
@@ -3,7 +3,7 @@ import type { FormfactorCommand } from './FormfactorCommand';
3
3
  /**
4
4
  * Parses the formfactor command
5
5
  *
6
- * Note: @@@ This command is used as formfactor for new commands - it should NOT be used in any `.book` file
6
+ * Note: This command is used as a formfactor for new commands and defines the app type format - it should NOT be used in any `.book` file
7
7
  *
8
8
  * @see `documentationUrl` for more details
9
9
  * @public exported from `@promptbook/editable`
@@ -3,7 +3,7 @@ import type { BoilerplateCommand } from './BoilerplateCommand';
3
3
  /**
4
4
  * Parses the boilerplate command
5
5
  *
6
- * Note: @@@ This command is used as boilerplate for new commands - it should NOT be used in any `.book` file
6
+ * Note: @@ This command is used as boilerplate for new commands - it should NOT be used in any `.book` file
7
7
  *
8
8
  * @see `documentationUrl` for more details
9
9
  * @private within the commands folder
@@ -8,7 +8,8 @@ import type { string_SCREAMING_CASE } from '../../../utils/normalization/normali
8
8
  import type { ___and___ } from '../../../utils/organization/___and___';
9
9
  import type { CommandUsagePlace } from './CommandUsagePlaces';
10
10
  /**
11
- * @@@
11
+ * Base type for all command objects.
12
+ * Requires a `type` property which is a SCREAMING_CASE string.
12
13
  *
13
14
  * @private just abstract helper for command parsers
14
15
  */
@@ -16,47 +17,48 @@ export type CommandBase = {
16
17
  type: string_name & string_SCREAMING_CASE;
17
18
  };
18
19
  /**
19
- * @@@
20
+ * Represents a parser for a specific command used within a Promptbook pipeline.
21
+ * It can parse commands used in the pipeline head, tasks, or both.
20
22
  *
21
23
  * @public exported from `@promptbook/editable`
22
24
  */
23
25
  export type CommandParser<TCommand extends CommandBase> = PipelineHeadCommandParser<TCommand> | PipelineTaskCommandParser<TCommand> | PipelineBothCommandParser<TCommand>;
24
26
  /**
25
- * @@@
27
+ * Common properties shared by all command parsers.
26
28
  *
27
29
  * @private just abstract the common properties of the command parsers
28
30
  */
29
31
  export type CommonCommandParser<TCommand extends CommandBase> = {
30
32
  /**
31
- * @@@
33
+ * The unique SCREAMING_CASE name of the command (e.g., 'MODEL', 'PARAMETER').
32
34
  */
33
35
  readonly name: string_name & string_SCREAMING_CASE;
34
36
  /**
35
- * @@@
37
+ * Indicates if the command can be used in the pipeline's head section.
36
38
  */
37
39
  readonly isUsedInPipelineHead: boolean;
38
40
  /**
39
- * @@@
41
+ * Indicates if the command can be used within a pipeline task.
40
42
  */
41
43
  readonly isUsedInPipelineTask: boolean;
42
44
  /**
43
- * @@@
45
+ * Optional alternative names (aliases) for the command, also in SCREAMING_CASE.
44
46
  */
45
47
  readonly aliasNames?: ReadonlyArray<string_name & string_SCREAMING_CASE>;
46
48
  /**
47
- * @@@
49
+ * Optional list of deprecated names for the command, used for backward compatibility.
48
50
  */
49
51
  readonly deprecatedNames?: ReadonlyArray<string_name & string_SCREAMING_CASE>;
50
52
  /**
51
- * @@@
53
+ * A brief description of the command's purpose, supporting simple Markdown.
52
54
  */
53
55
  readonly description: string_markdown_text;
54
56
  /**
55
- * @@@
57
+ * A URL pointing to the command's documentation.
56
58
  */
57
59
  readonly documentationUrl: string_promptbook_documentation_url;
58
60
  /**
59
- * @@@
61
+ * Examples demonstrating the usage of the command in Markdown format.
60
62
  */
61
63
  readonly examples: ReadonlyArray<string_markdown_text>;
62
64
  /**
@@ -72,23 +74,23 @@ export type CommonCommandParser<TCommand extends CommandBase> = {
72
74
  stringify(command: TCommand): string_markdown_text;
73
75
  };
74
76
  /**
75
- * @@@
77
+ * Represents a command parser that can be used in both the pipeline head and tasks.
76
78
  *
77
79
  * @public exported from `@promptbook/editable`
78
80
  */
79
81
  export type PipelineBothCommandParser<TCommand extends CommandBase> = ___and___ & Omit<PipelineHeadCommandParser<TCommand>, 'isUsedInPipelineTask'> & Omit<PipelineTaskCommandParser<TCommand>, 'isUsedInPipelineHead'>;
80
82
  /**
81
- * @@@
83
+ * Represents a command parser specifically for the pipeline head section.
82
84
  *
83
85
  * @public exported from `@promptbook/editable`
84
86
  */
85
87
  export type PipelineHeadCommandParser<TCommand extends CommandBase> = CommonCommandParser<TCommand> & {
86
88
  /**
87
- * @@@
89
+ * Always true for pipeline head commands.
88
90
  */
89
91
  readonly isUsedInPipelineHead: true;
90
92
  /**
91
- * @@@
93
+ * Always false for pipeline head commands.
92
94
  */
93
95
  readonly isUsedInPipelineTask: false;
94
96
  /**
@@ -106,17 +108,17 @@ export type PipelineHeadCommandParser<TCommand extends CommandBase> = CommonComm
106
108
  takeFromPipelineJson(pipelineJson: PipelineJson): ReadonlyArray<TCommand>;
107
109
  };
108
110
  /**
109
- * @@@
111
+ * Represents a command parser specifically for pipeline tasks.
110
112
  *
111
113
  * @public exported from `@promptbook/editable`
112
114
  */
113
115
  export type PipelineTaskCommandParser<TCommand extends CommandBase> = CommonCommandParser<TCommand> & {
114
116
  /**
115
- * @@@
117
+ * Always false for pipeline task commands.
116
118
  */
117
119
  readonly isUsedInPipelineHead: false;
118
120
  /**
119
- * @@@
121
+ * Always true for pipeline task commands.
120
122
  */
121
123
  readonly isUsedInPipelineTask: true;
122
124
  /**
@@ -133,58 +135,64 @@ export type PipelineTaskCommandParser<TCommand extends CommandBase> = CommonComm
133
135
  takeFromTaskJson($taskJson: $TaskJson): ReadonlyArray<TCommand>;
134
136
  };
135
137
  /**
136
- * @@@
138
+ * Represents a mutable TaskJson object, used internally by command parsers during application.
137
139
  *
138
- * Note: `$` is used to indicate that purpose of this type is to mutate the given object
140
+ * Note: `$` prefix indicates the object is intended for mutation.
139
141
  *
140
142
  * @private internal helper for command parsers
141
143
  */
142
144
  export type $TaskJson = {
145
+ /**
146
+ * Flag indicating if the section type (e.g., `SIMPLE_TEMPLATE`) has been set for this task.
147
+ */
143
148
  isSectionTypeSet: boolean;
149
+ /**
150
+ * Flag indicating if this object represents a task (as opposed to other sections like parameters).
151
+ */
144
152
  isTask: boolean;
145
153
  } & Partial<WritableDeep<TaskJson>>;
146
154
  /**
147
- * @@@
155
+ * Represents a mutable PipelineJson object, used internally by command parsers during application.
148
156
  *
149
- * Note: `$` is used to indicate that purpose of this type is to mutate the given object
157
+ * Note: `$` prefix indicates the object is intended for mutation.
150
158
  *
151
159
  * @private internal helper for command parsers
152
160
  */
153
161
  export type $PipelineJson = WritableDeep<SetOptional<PipelineJson, 'formfactorName'>>;
154
162
  /**
155
- * @@@
163
+ * Input object provided to the `parse` method of a CommandParser.
156
164
  */
157
165
  export type CommandParserInput = {
158
166
  /**
159
- * @@@
167
+ * Specifies where the command is being used (pipeline head or task).
160
168
  *
161
169
  * @example 'PIPELINE_HEAD'
162
170
  * @example 'PIPELINE_TASK'
163
171
  */
164
172
  readonly usagePlace: CommandUsagePlace;
165
173
  /**
166
- * @@@
174
+ * The raw, unprocessed line containing the command and its arguments.
167
175
  *
168
176
  * @example 'promptbook version 0.62.0'
169
177
  * @example 'FOREACH Text Line `{customers}` -> `{customer}`'
170
178
  */
171
179
  readonly raw: string_markdown_text;
172
180
  /**
173
- * @@@
181
+ * The arguments part of the raw command line, after the command name.
174
182
  *
175
183
  * @example '0.62.0'
176
184
  * @example 'List Line `{customers}` -> `{customer}`'
177
185
  */
178
186
  readonly rawArgs: string_markdown_text;
179
187
  /**
180
- * @@@
188
+ * The normalized, SCREAMING_CASE representation of the command and its core arguments.
181
189
  *
182
190
  * @example 'PROMPTBOOK_ENGINE_VERSION_0_62_0'
183
191
  * @example 'FOREACH_LIST_LINE_CUSTOMERS_CUSTOMER'
184
192
  */
185
193
  readonly normalized: string_name & string_SCREAMING_CASE;
186
194
  /**
187
- * @@@
195
+ * An array of arguments extracted from the line where the command is used.
188
196
  *
189
197
  * @example [ '0.62.0' ]
190
198
  * @example [ 'List', 'Line', '{customers}', '', '{customer}' ]
@@ -68,6 +68,28 @@ export declare const DEFAULT_BOOK_OUTPUT_PARAMETER_NAME = "result";
68
68
  * @public exported from `@promptbook/core`
69
69
  */
70
70
  export declare const DEFAULT_MAX_FILE_SIZE: number;
71
+ /**
72
+ * Threshold value that determines when a dataset is considered "big"
73
+ * and may require special handling or optimizations
74
+ *
75
+ * For example, when error occurs in one item of the big dataset, it will not fail the whole pipeline
76
+ *
77
+ * @public exported from `@promptbook/core`
78
+ */
79
+ export declare const BIG_DATASET_TRESHOLD = 50;
80
+ /**
81
+ * Placeholder text used to represent a placeholder value of failed operation
82
+ *
83
+ * @public exported from `@promptbook/core`
84
+ */
85
+ export declare const FAILED_VALUE_PLACEHOLDER = "!?";
86
+ /**
87
+ * Placeholder text used to represent operations or values that are still in progress
88
+ * or awaiting completion in UI displays and logging
89
+ *
90
+ * @public exported from `@promptbook/core`
91
+ */
92
+ export declare const PENDING_VALUE_PLACEHOLDER = "\u2026";
71
93
  /**
72
94
  * Warning message for the generated sections and files files
73
95
  *
@@ -156,15 +178,15 @@ export declare const DEFAULT_MAX_PARALLEL_COUNT = 5;
156
178
  */
157
179
  export declare const DEFAULT_MAX_EXECUTION_ATTEMPTS = 10;
158
180
  /**
159
- * @@@
160
- * TODO: [🐝][main] !!3 Use
181
+ * The maximum depth to which knowledge sources will be scraped when building a knowledge base.
182
+ * This prevents infinite recursion and limits resource usage.
161
183
  *
162
184
  * @public exported from `@promptbook/core`
163
185
  */
164
186
  export declare const DEFAULT_MAX_KNOWLEDGE_SOURCES_SCRAPING_DEPTH = 3;
165
187
  /**
166
- * @@@
167
- * TODO: [🐝][main] !!3 Use
188
+ * The maximum total number of knowledge sources that will be scraped in a single operation.
189
+ * This acts as a global limit to avoid excessive resource consumption.
168
190
  *
169
191
  * @public exported from `@promptbook/core`
170
192
  */
@@ -234,27 +256,27 @@ export declare const MOMENT_ARG_THRESHOLDS: {
234
256
  */
235
257
  export declare const DEFAULT_REMOTE_SERVER_URL: string_promptbook_server_url;
236
258
  /**
237
- * @@@
259
+ * Default settings for parsing and generating CSV files in Promptbook.
238
260
  *
239
261
  * @public exported from `@promptbook/core`
240
262
  */
241
263
  export declare const DEFAULT_CSV_SETTINGS: CsvSettings;
242
264
  /**
243
- * @@@
265
+ * Controls whether verbose logging is enabled by default throughout the application.
244
266
  *
245
267
  * @public exported from `@promptbook/core`
246
268
  */
247
269
  export declare let DEFAULT_IS_VERBOSE: boolean;
248
270
  /**
249
- * @@@
271
+ * Enables or disables verbose logging globally at runtime.
250
272
  *
251
- * Note: This is experimental feature
273
+ * Note: This is an experimental feature.
252
274
  *
253
275
  * @public exported from `@promptbook/core`
254
276
  */
255
277
  export declare function SET_IS_VERBOSE(isVerbose: boolean): void;
256
278
  /**
257
- * @@@
279
+ * Controls whether auto-installation of dependencies is enabled by default.
258
280
  *
259
281
  * @public exported from `@promptbook/core`
260
282
  */
@@ -266,13 +288,21 @@ export declare const DEFAULT_IS_AUTO_INSTALLED = false;
266
288
  */
267
289
  export declare const DEFAULT_GET_PIPELINE_COLLECTION_FUNCTION_NAME = "getPipelineCollection";
268
290
  /**
269
- * @@@
291
+ * Default rate limits (requests per minute)
292
+ *
293
+ * Note: Adjust based on the provider tier you are have
294
+ *
295
+ * @public exported from `@promptbook/core`
296
+ */
297
+ export declare const DEFAULT_MAX_REQUESTS_PER_MINUTE = 60;
298
+ /**
299
+ * Indicates whether pipeline logic validation is enabled. When true, the pipeline logic is checked for consistency.
270
300
  *
271
301
  * @private within the repository
272
302
  */
273
303
  export declare const IS_PIPELINE_LOGIC_VALIDATED: boolean;
274
304
  /**
275
- * @@@
305
+ * Indicates whether cost-prevention is enabled. When true, real API keys are prevented from being used in tests.
276
306
  *
277
307
  * @private within the repository
278
308
  */
@@ -1,5 +1,40 @@
1
1
  import type { PipelineJson } from './pipeline/PipelineJson/PipelineJson';
2
2
  import type { ExportJsonOptions } from './utils/serialization/exportJson';
3
+ /**
4
+ * How is the model provider trusted?
5
+ *
6
+ * @public exported from `@promptbook/core`
7
+ */
8
+ export declare const MODEL_TRUST_LEVELS: {
9
+ readonly FULL: "Model is running on the local machine, training data and model weights are known, data are ethically sourced";
10
+ readonly OPEN: "Model is open source, training data and model weights are known";
11
+ readonly PARTIALLY_OPEN: "Model is open source, but training data and model weights are not (fully) known";
12
+ readonly CLOSED_LOCAL: "Model can be run locally, but it is not open source";
13
+ readonly CLOSED_FREE: "Model is behind API gateway but free to use";
14
+ readonly CLOSED_BUSINESS: "Model is behind API gateway and paid but has good SLA, TOS, privacy policy and in general is a good to use in business applications";
15
+ readonly CLOSED: "Model is behind API gateway and paid";
16
+ readonly UNTRUSTED: "Model has questions about the training data and ethics, but it is not known if it is a problem or not";
17
+ readonly VURNABLE: "Model has some known serious vulnerabilities, leaks, ethical problems, etc.";
18
+ };
19
+ /**
20
+ * How is the model provider important?
21
+ *
22
+ * @public exported from `@promptbook/core`
23
+ */
24
+ export declare const MODEL_ORDERS: {
25
+ /**
26
+ * Top-tier models, e.g. OpenAI, Anthropic,...
27
+ */
28
+ readonly TOP_TIER: 333;
29
+ /**
30
+ * Mid-tier models, e.g. Llama, Mistral, etc.
31
+ */
32
+ readonly NORMAL: 100;
33
+ /**
34
+ * Low-tier models, e.g. Phi, Tiny, etc.
35
+ */
36
+ readonly LOW_TIER: 0;
37
+ };
3
38
  /**
4
39
  * Order of keys in the pipeline JSON
5
40
  *
@@ -13,13 +48,19 @@ export declare const ORDER_OF_PIPELINE_JSON: ExportJsonOptions<PipelineJson>['or
13
48
  */
14
49
  export declare const REPLACING_NONCE = "ptbkauk42kV2dzao34faw7FudQUHYPtW";
15
50
  /**
16
- * @@@
51
+ * Nonce which is used as string which is not occurring in normal text
52
+ *
53
+ * @private within the repository
54
+ */
55
+ export declare const SALT_NONCE = "ptbkghhewbvruets21t54et5";
56
+ /**
57
+ * Placeholder value indicating a parameter is missing its value.
17
58
  *
18
59
  * @private within the repository
19
60
  */
20
61
  export declare const RESERVED_PARAMETER_MISSING_VALUE: string;
21
62
  /**
22
- * @@@
63
+ * Placeholder value indicating a parameter is restricted and cannot be used directly.
23
64
  *
24
65
  * @private within the repository
25
66
  */
@@ -4,7 +4,7 @@ import type { PipelineString } from '../pipeline/PipelineString';
4
4
  * Compile pipeline from string (markdown) format to JSON format synchronously
5
5
  *
6
6
  * Note: There are 3 similar functions:
7
- * - `compilePipeline` **(preferred)** - which propperly compiles the promptbook and use embedding for external knowledge
7
+ * - `compilePipeline` **(preferred)** - which properly compiles the promptbook and uses embedding for external knowledge
8
8
  * - `parsePipeline` - use only if you need to compile promptbook synchronously and it contains NO external knowledge
9
9
  * - `preparePipeline` - just one step in the compilation process
10
10
  *
@@ -24,7 +24,7 @@ export declare function parsePipeline(pipelineString: PipelineString): PipelineJ
24
24
  * TODO: Use spaceTrim more effectively
25
25
  * TODO: [🧠] Parameter flags - isInput, isOutput, isInternal
26
26
  * TODO: [🥞] Not optimal parsing because `splitMarkdownIntoSections` is executed twice with same string, once through `flattenMarkdown` and second directly here
27
- * TODO: [♈] Probbably move expectations from tasks to parameters
27
+ * TODO: [♈] Probably move expectations from tasks to parameters
28
28
  * TODO: [🛠] Actions, instruments (and maybe knowledge) => Functions and tools
29
29
  * TODO: [🍙] Make some standard order of json properties
30
30
  */
@@ -1,5 +1,5 @@
1
1
  /**
2
- * This error indicates @@@
2
+ * This error indicates @@
3
3
  *
4
4
  * @public exported from `@promptbook/core`
5
5
  */
@@ -8,5 +8,5 @@ export declare class BoilerplateError extends Error {
8
8
  constructor(message: string);
9
9
  }
10
10
  /**
11
- * TODO: @@@ Do not forget to add the error into `0-index.ts` ERRORS
11
+ * TODO: @@ Do not forget to add the error into `0-index.ts` ERRORS
12
12
  */
@@ -1,5 +1,5 @@
1
1
  /**
2
- * This error indicates that the pipeline collection cannot be propperly loaded
2
+ * This error indicates that the pipeline collection cannot be properly loaded
3
3
  *
4
4
  * @public exported from `@promptbook/core`
5
5
  */
@@ -1,7 +1,7 @@
1
1
  import type { Executables } from '../execution/Executables';
2
2
  import type { PrepareAndScrapeOptions } from '../prepare/PrepareAndScrapeOptions';
3
3
  /**
4
- * @@@
4
+ * Provides paths to required executables (i.e. as Pandoc and LibreOffice) for Node.js environments.
5
5
  *
6
6
  * @public exported from `@promptbook/node`
7
7
  */
@@ -1,6 +1,7 @@
1
1
  import type { string_executable_path } from '../../types/typeAliases';
2
2
  /**
3
- * @@@
3
+ * Locates the LibreOffice executable on the current system by searching platform-specific paths.
4
+ * Returns the path to the executable if found, or null otherwise.
4
5
  *
5
6
  * @private within the repository
6
7
  */
@@ -1,6 +1,7 @@
1
1
  import type { string_executable_path } from '../../types/typeAliases';
2
2
  /**
3
- * @@@
3
+ * Locates the Pandoc executable on the current system by searching platform-specific paths.
4
+ * Returns the path to the executable if found, or null otherwise.
4
5
  *
5
6
  * @private within the repository
6
7
  */
@@ -3,7 +3,7 @@ import type { string_executable_path } from '../types/typeAliases';
3
3
  /**
4
4
  * Options for locating any application
5
5
  */
6
- export interface LocateAppOptions {
6
+ export type LocateAppOptions = {
7
7
  /**
8
8
  * Name of the application
9
9
  */
@@ -20,7 +20,7 @@ export interface LocateAppOptions {
20
20
  * Name of the application on macOS
21
21
  */
22
22
  macOsName?: string;
23
- }
23
+ };
24
24
  /**
25
25
  * Locates an application on the system
26
26
  *
@@ -1,7 +1,8 @@
1
1
  import type { string_executable_path } from '../../types/typeAliases';
2
2
  import type { LocateAppOptions } from '../locateApp';
3
3
  /**
4
- * @@@
4
+ * Attempts to locate the specified application on a Linux system using the 'which' command.
5
+ * Returns the path to the executable if found, or null otherwise.
5
6
  *
6
7
  * @private within the repository
7
8
  */
@@ -1,7 +1,8 @@
1
1
  import type { string_executable_path } from '../../types/typeAliases';
2
2
  import type { LocateAppOptions } from '../locateApp';
3
3
  /**
4
- * @@@
4
+ * Attempts to locate the specified application on a macOS system by checking standard application paths and using mdfind.
5
+ * Returns the path to the executable if found, or null otherwise.
5
6
  *
6
7
  * @private within the repository
7
8
  */
@@ -1,7 +1,8 @@
1
1
  import type { string_executable_path } from '../../types/typeAliases';
2
2
  import type { LocateAppOptions } from '../locateApp';
3
3
  /**
4
- * @@@
4
+ * Attempts to locate the specified application on a Windows system by searching common installation directories.
5
+ * Returns the path to the executable if found, or null otherwise.
5
6
  *
6
7
  * @private within the repository
7
8
  */
@@ -1,7 +1,7 @@
1
1
  import { ReadonlyDeep } from 'type-fest';
2
2
  import type { ErrorJson } from '../errors/utils/ErrorJson';
3
3
  /**
4
- * @@@
4
+ * Represents the result of execution of a task in a pipeline
5
5
  *
6
6
  * Note: [🚉] This is fully serializable as JSON
7
7
  */
@@ -1,6 +1,6 @@
1
1
  import type { string_user_id } from '../types/typeAliases';
2
2
  /**
3
- * @@@
3
+ * Common options shared across various execution tools.
4
4
  *
5
5
  * Note: Keep it public to allow people to make their own execution tools
6
6
  */
@@ -17,8 +17,8 @@ export type CommonToolsOptions = {
17
17
  */
18
18
  readonly isVerbose?: boolean;
19
19
  /**
20
- * Maximum number of requests per minute
21
- */
20
+ * Maximum number of requests per minute
21
+ */
22
22
  readonly maxRequestsPerMinute?: number;
23
23
  };
24
24
  /**
@@ -2,6 +2,7 @@ import type { Observable } from 'rxjs';
2
2
  import { PartialDeep } from 'type-fest';
3
3
  import type { task_id } from '../types/typeAliases';
4
4
  import type { string_SCREAMING_CASE } from '../utils/normalization/normalizeTo_SCREAMING_CASE';
5
+ import type { string_promptbook_version } from '../version';
5
6
  import type { AbstractTaskResult } from './AbstractTaskResult';
6
7
  import type { PipelineExecutorResult } from './PipelineExecutorResult';
7
8
  /**
@@ -12,12 +13,21 @@ type CreateTaskOptions<TTaskResult extends AbstractTaskResult> = {
12
13
  * The type of task to create
13
14
  */
14
15
  readonly taskType: AbstractTask<TTaskResult>['taskType'];
16
+ /**
17
+ * Human-readable title of the task - used for displaying in the UI
18
+ */
19
+ readonly title: AbstractTask<TTaskResult>['title'];
15
20
  /**
16
21
  * Callback that processes the task and updates the ongoing result
17
22
  * @param ongoingResult The partial result of the task processing
18
23
  * @returns The final task result
19
24
  */
20
- taskProcessCallback(updateOngoingResult: (newOngoingResult: PartialDeep<TTaskResult>) => void): Promise<TTaskResult>;
25
+ taskProcessCallback(updateOngoingResult: (newOngoingResult: PartialDeep<TTaskResult> & {
26
+ /**
27
+ * Optional update of the task title
28
+ */
29
+ readonly title?: AbstractTask<TTaskResult>['title'];
30
+ }) => void): Promise<TTaskResult>;
21
31
  };
22
32
  /**
23
33
  * Helper to create a new task
@@ -52,10 +62,18 @@ export type AbstractTask<TTaskResult extends AbstractTaskResult> = {
52
62
  * Type of the task
53
63
  */
54
64
  readonly taskType: string_SCREAMING_CASE;
65
+ /**
66
+ * Version of the promptbook used to run the task
67
+ */
68
+ readonly promptbookVersion: string_promptbook_version;
55
69
  /**
56
70
  * Unique identifier for the task
57
71
  */
58
72
  readonly taskId: task_id;
73
+ /**
74
+ * Human-readable title of the task - used for displaying in the UI
75
+ */
76
+ readonly title: string;
59
77
  /**
60
78
  * Status of the task
61
79
  */
@@ -2,7 +2,8 @@ import type { Registered } from '../utils/$Register';
2
2
  import type { TODO_any } from '../utils/organization/TODO_any';
3
3
  import type { LlmExecutionTools } from './LlmExecutionTools';
4
4
  /**
5
- * @@@
5
+ * Type representing a constructor for LLM execution tools, which are used to interact with language models.
6
+ * Combines registration metadata with a factory function for creating LLM tool instances.
6
7
  */
7
8
  export type LlmExecutionToolsConstructor = Registered & ((options: TODO_any) => LlmExecutionTools);
8
9
  /**
@@ -5,7 +5,7 @@ import type { AbstractTaskResult } from './AbstractTaskResult';
5
5
  import type { ExecutionReportJson } from './execution-report/ExecutionReportJson';
6
6
  import type { Usage } from './Usage';
7
7
  /**
8
- * @@@
8
+ * The result of executing a pipeline
9
9
  *
10
10
  * Note: [🚉] This is fully serializable as JSON
11
11
  */
@@ -22,8 +22,10 @@ export type PipelineExecutorResult = AbstractTaskResult & {
22
22
  readonly usage: ReadonlyDeep<Usage>;
23
23
  /**
24
24
  * The report of the execution with all details
25
+ *
26
+ * Note: If the execution fails unexpectedly, this will be `null`
25
27
  */
26
- readonly executionReport: ReadonlyDeep<ExecutionReportJson>;
28
+ readonly executionReport: ReadonlyDeep<ExecutionReportJson> | null;
27
29
  /**
28
30
  * The prepared pipeline that was used for the execution
29
31
  *