@promptbook/openai 0.61.0-12 → 0.61.0-14

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 (125) hide show
  1. package/esm/index.es.js +31 -13
  2. package/esm/index.es.js.map +1 -1
  3. package/esm/typings/src/_packages/execute-javascript.index.d.ts +1 -1
  4. package/esm/typings/src/_packages/types.index.d.ts +6 -3
  5. package/esm/typings/src/_packages/utils.index.d.ts +1 -1
  6. package/esm/typings/src/commands/MODEL/ModelCommand.d.ts +2 -2
  7. package/esm/typings/src/config.d.ts +5 -1
  8. package/esm/typings/src/conversion/utils/stringifyPipelineJson.d.ts +13 -0
  9. package/esm/typings/src/conversion/validation/_importPipeline.d.ts +10 -1
  10. package/esm/typings/src/conversion/validation/validatePipeline.d.ts +1 -1
  11. package/esm/typings/src/errors/LimitReachedError.d.ts +7 -0
  12. package/esm/typings/src/execution/LlmExecutionTools.d.ts +7 -7
  13. package/esm/typings/src/execution/PipelineExecutor.d.ts +1 -1
  14. package/esm/typings/src/execution/PromptResult.d.ts +14 -56
  15. package/esm/typings/src/execution/PromptResultUsage.d.ts +26 -0
  16. package/esm/typings/src/execution/UncertainNumber.d.ts +18 -0
  17. package/esm/typings/src/execution/utils/addUsage.d.ts +58 -2
  18. package/esm/typings/src/execution/utils/computeUsageCounts.d.ts +1 -1
  19. package/esm/typings/src/execution/utils/uncertainNumber.d.ts +1 -1
  20. package/esm/typings/src/execution/utils/usageToWorktime.d.ts +2 -2
  21. package/esm/typings/src/llm-providers/_common/createLlmToolsFromEnv.d.ts +10 -2
  22. package/esm/typings/src/llm-providers/_common/getLlmToolsForTestingAndScriptsAndPlayground.d.ts +2 -1
  23. package/esm/typings/src/llm-providers/_common/utils/count-total-cost/LlmExecutionToolsWithTotalCost.d.ts +1 -1
  24. package/esm/typings/src/llm-providers/_common/utils/count-total-cost/limitTotalCost.d.ts +32 -0
  25. package/esm/typings/src/llm-providers/anthropic-claude/AnthropicClaudeExecutionTools.d.ts +2 -2
  26. package/esm/typings/src/llm-providers/azure-openai/AzureOpenAiExecutionTools.d.ts +4 -4
  27. package/esm/typings/src/llm-providers/mocked/MockedEchoLlmExecutionTools.d.ts +4 -4
  28. package/esm/typings/src/llm-providers/mocked/MockedFackedLlmExecutionTools.d.ts +6 -6
  29. package/esm/typings/src/llm-providers/multiple/MultipleLlmExecutionTools.d.ts +9 -7
  30. package/esm/typings/src/llm-providers/openai/OpenAiExecutionTools.d.ts +6 -6
  31. package/esm/typings/src/llm-providers/openai/computeOpenaiUsage.d.ts +1 -1
  32. package/esm/typings/src/llm-providers/remote/RemoteLlmExecutionTools.d.ts +9 -7
  33. package/esm/typings/src/scripting/javascript/utils/unknownToString.d.ts +2 -1
  34. package/esm/typings/src/types/ModelRequirements.d.ts +53 -14
  35. package/esm/typings/src/types/ModelVariant.d.ts +14 -0
  36. package/esm/typings/src/types/PipelineJson/PersonaJson.d.ts +2 -4
  37. package/esm/typings/src/types/PipelineJson/PreparationJson.d.ts +1 -1
  38. package/esm/typings/src/types/Prompt.d.ts +45 -1
  39. package/esm/typings/src/types/typeAliases.d.ts +11 -0
  40. package/esm/typings/src/utils/deepClone.d.ts +9 -0
  41. package/esm/typings/src/utils/deepFreeze.d.ts +13 -0
  42. package/esm/typings/src/utils/normalization/parseKeywords.d.ts +2 -1
  43. package/{umd/typings/src/utils/organization/TODO.d.ts → esm/typings/src/utils/organization/TODO_any.d.ts} +1 -1
  44. package/esm/typings/src/utils/organization/TODO_object.d.ts +6 -0
  45. package/esm/typings/src/utils/organization/TODO_unknown.d.ts +6 -0
  46. package/esm/typings/src/utils/organization/just.d.ts +4 -1
  47. package/esm/typings/src/utils/organization/keepUnused.d.ts +16 -0
  48. package/esm/typings/src/utils/organization/really_any.d.ts +1 -1
  49. package/esm/typings/src/utils/organization/really_unknown.d.ts +6 -0
  50. package/esm/typings/src/utils/validators/email/isValidEmail.d.ts +2 -1
  51. package/esm/typings/src/utils/validators/filePath/isValidFilePath.d.ts +2 -1
  52. package/esm/typings/src/utils/validators/javascriptName/isValidJavascriptName.d.ts +2 -1
  53. package/esm/typings/src/utils/validators/semanticVersion/isValidPromptbookVersion.d.ts +2 -1
  54. package/esm/typings/src/utils/validators/semanticVersion/isValidSemanticVersion.d.ts +2 -1
  55. package/esm/typings/src/utils/validators/url/isValidPipelineUrl.d.ts +2 -1
  56. package/esm/typings/src/utils/validators/url/isValidUrl.d.ts +2 -1
  57. package/esm/typings/src/utils/validators/uuid/isValidUuid.d.ts +2 -1
  58. package/esm/typings/src/version.d.ts +0 -3
  59. package/package.json +2 -2
  60. package/umd/index.umd.js +31 -13
  61. package/umd/index.umd.js.map +1 -1
  62. package/umd/typings/src/_packages/execute-javascript.index.d.ts +1 -1
  63. package/umd/typings/src/_packages/types.index.d.ts +6 -3
  64. package/umd/typings/src/_packages/utils.index.d.ts +1 -1
  65. package/umd/typings/src/commands/MODEL/ModelCommand.d.ts +2 -2
  66. package/umd/typings/src/config.d.ts +5 -1
  67. package/umd/typings/src/conversion/utils/stringifyPipelineJson.d.ts +13 -0
  68. package/umd/typings/src/conversion/validation/_importPipeline.d.ts +10 -1
  69. package/umd/typings/src/conversion/validation/validatePipeline.d.ts +1 -1
  70. package/umd/typings/src/errors/LimitReachedError.d.ts +7 -0
  71. package/umd/typings/src/execution/LlmExecutionTools.d.ts +7 -7
  72. package/umd/typings/src/execution/PipelineExecutor.d.ts +1 -1
  73. package/umd/typings/src/execution/PromptResult.d.ts +14 -56
  74. package/umd/typings/src/execution/PromptResultUsage.d.ts +26 -0
  75. package/umd/typings/src/execution/UncertainNumber.d.ts +18 -0
  76. package/umd/typings/src/execution/utils/addUsage.d.ts +58 -2
  77. package/umd/typings/src/execution/utils/computeUsageCounts.d.ts +1 -1
  78. package/umd/typings/src/execution/utils/uncertainNumber.d.ts +1 -1
  79. package/umd/typings/src/execution/utils/usageToWorktime.d.ts +2 -2
  80. package/umd/typings/src/llm-providers/_common/createLlmToolsFromEnv.d.ts +10 -2
  81. package/umd/typings/src/llm-providers/_common/getLlmToolsForTestingAndScriptsAndPlayground.d.ts +2 -1
  82. package/umd/typings/src/llm-providers/_common/utils/count-total-cost/LlmExecutionToolsWithTotalCost.d.ts +1 -1
  83. package/umd/typings/src/llm-providers/_common/utils/count-total-cost/limitTotalCost.d.ts +32 -0
  84. package/umd/typings/src/llm-providers/anthropic-claude/AnthropicClaudeExecutionTools.d.ts +2 -2
  85. package/umd/typings/src/llm-providers/azure-openai/AzureOpenAiExecutionTools.d.ts +4 -4
  86. package/umd/typings/src/llm-providers/mocked/MockedEchoLlmExecutionTools.d.ts +4 -4
  87. package/umd/typings/src/llm-providers/mocked/MockedFackedLlmExecutionTools.d.ts +6 -6
  88. package/umd/typings/src/llm-providers/multiple/MultipleLlmExecutionTools.d.ts +9 -7
  89. package/umd/typings/src/llm-providers/openai/OpenAiExecutionTools.d.ts +6 -6
  90. package/umd/typings/src/llm-providers/openai/computeOpenaiUsage.d.ts +1 -1
  91. package/umd/typings/src/llm-providers/remote/RemoteLlmExecutionTools.d.ts +9 -7
  92. package/umd/typings/src/scripting/javascript/utils/unknownToString.d.ts +2 -1
  93. package/umd/typings/src/types/ModelRequirements.d.ts +53 -14
  94. package/umd/typings/src/types/ModelVariant.d.ts +14 -0
  95. package/umd/typings/src/types/PipelineJson/PersonaJson.d.ts +2 -4
  96. package/umd/typings/src/types/PipelineJson/PreparationJson.d.ts +1 -1
  97. package/umd/typings/src/types/Prompt.d.ts +45 -1
  98. package/umd/typings/src/types/typeAliases.d.ts +11 -0
  99. package/umd/typings/src/utils/deepClone.d.ts +9 -0
  100. package/umd/typings/src/utils/deepFreeze.d.ts +13 -0
  101. package/umd/typings/src/utils/normalization/parseKeywords.d.ts +2 -1
  102. package/{esm/typings/src/utils/organization/TODO.d.ts → umd/typings/src/utils/organization/TODO_any.d.ts} +1 -1
  103. package/umd/typings/src/utils/organization/TODO_object.d.ts +6 -0
  104. package/umd/typings/src/utils/organization/TODO_unknown.d.ts +6 -0
  105. package/umd/typings/src/utils/organization/just.d.ts +4 -1
  106. package/umd/typings/src/utils/organization/keepUnused.d.ts +16 -0
  107. package/umd/typings/src/utils/organization/really_any.d.ts +1 -1
  108. package/umd/typings/src/utils/organization/really_unknown.d.ts +6 -0
  109. package/umd/typings/src/utils/validators/email/isValidEmail.d.ts +2 -1
  110. package/umd/typings/src/utils/validators/filePath/isValidFilePath.d.ts +2 -1
  111. package/umd/typings/src/utils/validators/javascriptName/isValidJavascriptName.d.ts +2 -1
  112. package/umd/typings/src/utils/validators/semanticVersion/isValidPromptbookVersion.d.ts +2 -1
  113. package/umd/typings/src/utils/validators/semanticVersion/isValidSemanticVersion.d.ts +2 -1
  114. package/umd/typings/src/utils/validators/url/isValidPipelineUrl.d.ts +2 -1
  115. package/umd/typings/src/utils/validators/url/isValidUrl.d.ts +2 -1
  116. package/umd/typings/src/utils/validators/uuid/isValidUuid.d.ts +2 -1
  117. package/umd/typings/src/version.d.ts +0 -3
  118. package/esm/typings/src/utils/organization/keepImported.d.ts +0 -12
  119. package/esm/typings/src/utils/organization/notUsing.d.ts +0 -12
  120. package/umd/typings/src/utils/organization/keepImported.d.ts +0 -12
  121. package/umd/typings/src/utils/organization/notUsing.d.ts +0 -12
  122. /package/esm/typings/src/{execution/addPromptResultUsage.test.d.ts → conversion/utils/stringifyPipelineJson.test.d.ts} +0 -0
  123. /package/esm/typings/src/{utils/postprocessing → postprocessing/utils}/extractBlock.d.ts +0 -0
  124. /package/umd/typings/src/{execution/addPromptResultUsage.test.d.ts → conversion/utils/stringifyPipelineJson.test.d.ts} +0 -0
  125. /package/umd/typings/src/{utils/postprocessing → postprocessing/utils}/extractBlock.d.ts +0 -0
@@ -1,9 +1,11 @@
1
1
  import type { AvailableModel } from '../../execution/LlmExecutionTools';
2
2
  import type { LlmExecutionTools } from '../../execution/LlmExecutionTools';
3
- import type { PromptChatResult } from '../../execution/PromptResult';
4
- import type { PromptCompletionResult } from '../../execution/PromptResult';
5
- import type { PromptEmbeddingResult } from '../../execution/PromptResult';
6
- import type { Prompt } from '../../types/Prompt';
3
+ import type { ChatPromptResult } from '../../execution/PromptResult';
4
+ import type { CompletionPromptResult } from '../../execution/PromptResult';
5
+ import type { EmbeddingPromptResult } from '../../execution/PromptResult';
6
+ import type { ChatPrompt } from '../../types/Prompt';
7
+ import type { CompletionPrompt } from '../../types/Prompt';
8
+ import type { EmbeddingPrompt } from '../../types/Prompt';
7
9
  import type { string_markdown } from '../../types/typeAliases';
8
10
  import type { string_markdown_text } from '../../types/typeAliases';
9
11
  import type { string_title } from '../../types/typeAliases';
@@ -28,15 +30,15 @@ export declare class RemoteLlmExecutionTools implements LlmExecutionTools {
28
30
  /**
29
31
  * Calls remote proxy server to use a chat model
30
32
  */
31
- callChatModel(prompt: Prompt): Promise<PromptChatResult>;
33
+ callChatModel(prompt: ChatPrompt): Promise<ChatPromptResult>;
32
34
  /**
33
35
  * Calls remote proxy server to use a completion model
34
36
  */
35
- callCompletionModel(prompt: Prompt): Promise<PromptCompletionResult>;
37
+ callCompletionModel(prompt: CompletionPrompt): Promise<CompletionPromptResult>;
36
38
  /**
37
39
  * Calls remote proxy server to use a embedding model
38
40
  */
39
- callEmbeddingModel(prompt: Prompt): Promise<PromptEmbeddingResult>;
41
+ callEmbeddingModel(prompt: EmbeddingPrompt): Promise<EmbeddingPromptResult>;
40
42
  /**
41
43
  * Calls remote proxy server to use both completion or chat model
42
44
  */
@@ -1,7 +1,8 @@
1
+ import type { really_unknown } from '../../../utils/organization/really_unknown';
1
2
  /**
2
3
  * Converts anything to string that can be used for debugging and logging
3
4
  *
4
5
  * @param value String value for logging
5
6
  * @private Internal util
6
7
  */
7
- export declare function unknownToString(value: unknown): string;
8
+ export declare function unknownToString(value: really_unknown): string;
@@ -1,28 +1,67 @@
1
+ import type { ModelVariant } from './ModelVariant';
1
2
  import type { number_model_temperature } from './typeAliases';
2
3
  import type { number_seed } from './typeAliases';
3
4
  import type { string_model_name } from './typeAliases';
4
5
  import type { string_system_message } from './typeAliases';
5
- export declare const MODEL_VARIANTS: readonly ["COMPLETION", "CHAT", "EMBEDDING"];
6
6
  /**
7
- * Model variant describes the very general type of the model
7
+ * Abstract way to specify the LLM.
8
+ * It does not specify the LLM with concrete version itself, only the requirements for the LLM.
8
9
  *
9
- * There are two variants:
10
- * - **COMPLETION** - model that takes prompt and writes the rest of the text
11
- * - **CHAT** - model that takes prompt and previous messages and returns response
10
+ * Note: This is fully serializable as JSON
11
+ * @see https://github.com/webgptorg/promptbook#model-requirements
12
12
  */
13
- export type ModelVariant = typeof MODEL_VARIANTS[number];
13
+ export type ModelRequirements = CompletionModelRequirements | ChatModelRequirements | EmbeddingModelRequirements;
14
14
  /**
15
- * Abstract way to specify the LLM. It does not specify the LLM with concrete version itself, only the requirements for the LLM.
15
+ * Model requirements for the completion variant
16
16
  *
17
- * @see https://github.com/webgptorg/promptbook#model-requirements
17
+ * Note: This is fully serializable as JSON
18
+ */
19
+ export type CompletionModelRequirements = CommonModelRequirements & {
20
+ /**
21
+ * Completion model variant
22
+ */
23
+ modelVariant: 'COMPLETION';
24
+ };
25
+ /**
26
+ * Model requirements for the chat variant
27
+ *
28
+ * Note: This is fully serializable as JSON
18
29
  */
19
- export type ModelRequirements = {
30
+ export type ChatModelRequirements = CommonModelRequirements & {
31
+ /**
32
+ * Chat model variant
33
+ */
34
+ modelVariant: 'CHAT';
35
+ /**
36
+ * System message to be used in the model
37
+ */
38
+ readonly systemMessage?: string_system_message;
39
+ };
40
+ /**
41
+ * Model requirements for the embedding variant
42
+ *
43
+ * Note: This is fully serializable as JSON
44
+ */
45
+ export type EmbeddingModelRequirements = CommonModelRequirements & {
46
+ /**
47
+ * Embedding model variant
48
+ */
49
+ modelVariant: 'EMBEDDING';
50
+ };
51
+ /**
52
+ * Common properties for all model requirements variants
53
+ *
54
+ * Note: This is fully serializable as JSON
55
+ */
56
+ export type CommonModelRequirements = {
20
57
  /**
21
58
  * Model variant describes the very general type of the model
22
59
  *
23
- * There are two variants:
60
+ * There are 3 variants:
24
61
  * - **COMPLETION** - model that takes prompt and writes the rest of the text
25
62
  * - **CHAT** - model that takes prompt and previous messages and returns response
63
+ * - **EMBEDDING** - model that takes prompt and returns embedding
64
+ * <- [🤖]
26
65
  */
27
66
  readonly modelVariant: ModelVariant;
28
67
  /**
@@ -34,10 +73,6 @@ export type ModelRequirements = {
34
73
  * @example 'gpt-4', 'gpt-4-32k-0314', 'gpt-3.5-turbo-instruct',...
35
74
  */
36
75
  readonly modelName?: string_model_name;
37
- /**
38
- * System message to be used in the model
39
- */
40
- readonly systemMessage?: string_system_message;
41
76
  /**
42
77
  * The temperature of the model
43
78
  *
@@ -50,10 +85,13 @@ export type ModelRequirements = {
50
85
  readonly seed?: number_seed;
51
86
  /**
52
87
  * Maximum number of tokens that can be generated by the model
88
+ *
89
+ * Note: [🌾]
53
90
  */
54
91
  readonly maxTokens?: number;
55
92
  };
56
93
  /**
94
+ * TODO: [🔼] !!!! Export all from `@promptbook/types`
57
95
  * TODO: [🧠][🈁] `seed` should maybe be somewhere else (not in `ModelRequirements`) (simmilar that `user` identification is not here)
58
96
  * TODO: [🧠][💱] Add more model options: `stop_token`, `logit_bias`, `logprobs` (`top_logprobs`), `top_k`, `top_p`, `presence_penalty`, `frequency_penalty`, `bestOf`, `logitBias`, `logitBiasType`,...
59
97
  * [💱] Probbably keep using just `temperature` in Promptbook (not `top_k` and `top_p`)
@@ -61,4 +99,5 @@ export type ModelRequirements = {
61
99
  * TODO: Maybe figure out better word than "variant"
62
100
  * TODO: Add here more requirement options like max context size, max tokens, etc.
63
101
  * TODO: [💕][🧠] Just selecting gpt3 or gpt4 level of model
102
+ * TODO: [🧄] Replace all "github.com/webgptorg/promptbook#xxx" with "ptbk.io/xxx"
64
103
  */
@@ -0,0 +1,14 @@
1
+ /**
2
+ * @@@
3
+ *
4
+ * @private for `ModelVariant` and `modelCommandParser`
5
+ */
6
+ export declare const MODEL_VARIANTS: readonly ["COMPLETION", "CHAT", "EMBEDDING"];
7
+ /**
8
+ * Model variant describes the very general type of the model
9
+ *
10
+ * There are two variants:
11
+ * - **COMPLETION** - model that takes prompt and writes the rest of the text
12
+ * - **CHAT** - model that takes prompt and previous messages and returns response
13
+ */
14
+ export type ModelVariant = typeof MODEL_VARIANTS[number];
@@ -1,4 +1,4 @@
1
- import type { ModelRequirements } from '../ModelRequirements';
1
+ import type { ChatModelRequirements } from '../ModelRequirements';
2
2
  import type { number_id } from '../typeAliases';
3
3
  import type { string_name } from '../typeAliases';
4
4
  import type { string_persona_description } from '../typeAliases';
@@ -30,9 +30,7 @@ export type PersonaPreparedJson = PersonaJson & {
30
30
  *
31
31
  * Note: The model must be CHAT variant to be usable through persona
32
32
  */
33
- readonly modelRequirements: ModelRequirements & {
34
- readonly modelVariant: 'CHAT';
35
- };
33
+ readonly modelRequirements: ChatModelRequirements;
36
34
  /**
37
35
  * List of preparation ids that were used to prepare this persona
38
36
  */
@@ -1,4 +1,4 @@
1
- import type { PromptResultUsage } from '../../execution/PromptResult';
1
+ import type { PromptResultUsage } from '../../execution/PromptResultUsage';
2
2
  import type { string_promptbook_version } from '../../version';
3
3
  import type { number_id } from '../typeAliases';
4
4
  export type PreparationJson = {
@@ -1,5 +1,8 @@
1
1
  import type { ExpectFormatCommand } from '../commands/EXPECT/ExpectFormatCommand';
2
2
  import type { PostprocessingFunction } from '../scripting/javascript/JavascriptExecutionToolsOptions';
3
+ import type { ChatModelRequirements } from './ModelRequirements';
4
+ import type { CompletionModelRequirements } from './ModelRequirements';
5
+ import type { EmbeddingModelRequirements } from './ModelRequirements';
3
6
  import type { ModelRequirements } from './ModelRequirements';
4
7
  import type { Expectations } from './PipelineJson/Expectations';
5
8
  import type { string_parameter_name } from './typeAliases';
@@ -13,7 +16,46 @@ import type { string_title } from './typeAliases';
13
16
  * Note: [🛫] This is NOT fully serializable as JSON, it contains functions which are not serializable
14
17
  * @see https://github.com/webgptorg/promptbook#prompt
15
18
  */
16
- export type Prompt = {
19
+ export type Prompt = CompletionPrompt | ChatPrompt | EmbeddingPrompt;
20
+ /**
21
+ * Completion prompt
22
+ *
23
+ * Note: [🛫] This is NOT fully serializable as JSON, it contains functions which are not serializable
24
+ */
25
+ export type CompletionPrompt = CommonPrompt & {
26
+ /**
27
+ * Requirements for completion model
28
+ */
29
+ modelRequirements: CompletionModelRequirements;
30
+ };
31
+ /**
32
+ * Chat prompt
33
+ *
34
+ * Note: [🛫] This is NOT fully serializable as JSON, it contains functions which are not serializable
35
+ */
36
+ export type ChatPrompt = CommonPrompt & {
37
+ /**
38
+ * Requirements for chat model
39
+ */
40
+ modelRequirements: ChatModelRequirements;
41
+ };
42
+ /**
43
+ * Embedding prompt
44
+ *
45
+ * Note: [🛫] This is NOT fully serializable as JSON, it contains functions which are not serializable
46
+ */
47
+ export type EmbeddingPrompt = CommonPrompt & {
48
+ /**
49
+ * Requirements for chat model
50
+ */
51
+ modelRequirements: EmbeddingModelRequirements;
52
+ };
53
+ /**
54
+ * Common properties for all prompt results
55
+ *
56
+ * Note: This is fully serializable as JSON
57
+ */
58
+ export type CommonPrompt = {
17
59
  /**
18
60
  * The title of the prompt
19
61
  *
@@ -63,6 +105,8 @@ export type Prompt = {
63
105
  readonly parameters: Record<string_parameter_name, string_parameter_value>;
64
106
  };
65
107
  /**
108
+ * TODO: [🔼] !!!! Export all from `@promptbook/types`
109
+ * TODO: [🧄] Replace all "github.com/webgptorg/promptbook#xxx" with "ptbk.io/xxx"
66
110
  * TODO: [✔] Check ModelRequirements in runtime
67
111
  * TODO: [🏳] Add options for translation - maybe create `TranslationPrompt`
68
112
  */
@@ -196,6 +196,17 @@ export type string_script = string;
196
196
  * For example `console.info("Hello World!")`
197
197
  */
198
198
  export type string_javascript = string;
199
+ /**
200
+ * Semantic helper for JSON strings
201
+ *
202
+ * Note: TType is a type of the JSON object inside the string
203
+ *
204
+ * For example `{"foo": "bar"}`
205
+ */
206
+ export type string_json<TType> = string & {
207
+ _type: 'string_json';
208
+ scheme: TType;
209
+ };
199
210
  /**
200
211
  * Semantic helper
201
212
  *
@@ -0,0 +1,9 @@
1
+ import type { WritableDeep } from 'type-fest';
2
+ /**
3
+ * @@@
4
+ */
5
+ export declare function deepClone<TObject>(objectValue: TObject): WritableDeep<TObject>;
6
+ /**
7
+ * TODO: [🔼] Export from `@promptbook/utils`
8
+ * TODO: [🧠] Is there a way how to meaningfully test this utility
9
+ */
@@ -0,0 +1,13 @@
1
+ import type { ReadonlyDeep } from 'type-fest';
2
+ /**
3
+ * @@@
4
+ *
5
+ * @returns The same object as the input, but deeply frozen
6
+ *
7
+ * Note: This function mutates the object
8
+ */
9
+ export declare function deepFreeze<TObject>(objectValue: TObject): ReadonlyDeep<TObject>;
10
+ /**
11
+ * TODO: [🔼] Export from `@promptbook/utils`
12
+ * TODO: [🧠] Is there a way how to meaningfully test this utility
13
+ */
@@ -1,3 +1,4 @@
1
+ import type { really_unknown } from '../organization/really_unknown';
1
2
  import type { IKeywords } from './IKeywords';
2
3
  /**
3
4
  * Parses keywords from any object and recursively walks through
@@ -7,7 +8,7 @@ import type { IKeywords } from './IKeywords';
7
8
  * @param input of any kind
8
9
  * @returns {Set} of keywords without diacritics in lowercase
9
10
  */
10
- export declare function parseKeywords(input: unknown): IKeywords;
11
+ export declare function parseKeywords(input: really_unknown): IKeywords;
11
12
  /**
12
13
  * Note: Not using spread in input param because of keeping second parameter for options
13
14
  * TODO: [🌺] Use some intermediate util splitWords
@@ -3,4 +3,4 @@
3
3
  *
4
4
  * @private within the repository
5
5
  */
6
- export type TODO = any;
6
+ export type TODO_any = any;
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Organizational helper to better mark the place where the type is missing
3
+ *
4
+ * @private within the repository
5
+ */
6
+ export type TODO_object = object;
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Organizational helper to better mark the place where the type is missing
3
+ *
4
+ * @private within the repository
5
+ */
6
+ export type TODO_unknown = unknown;
@@ -2,7 +2,10 @@
2
2
  * Returns the same value that is passed as argument.
3
3
  * No side effects.
4
4
  *
5
- * Note: It can be usefull for leveling indentation
5
+ * Note: It can be usefull for:
6
+ *
7
+ * 1) Leveling indentation
8
+ * 2) Putting always-true or always-false conditions without getting eslint errors
6
9
  *
7
10
  * @param value any values
8
11
  * @returns the same values
@@ -0,0 +1,16 @@
1
+ import type { really_any } from './really_any';
2
+ /**
3
+ * Just says that the variable is not used but should be kept
4
+ * No side effects.
5
+ *
6
+ * Note: It can be usefull for:
7
+ *
8
+ * 1) Suppressing eager optimization of unused imports
9
+ * 2) Suppressing eslint errors of unused variables in the tests
10
+ * 3) Keeping the type of the variable for type testing
11
+ *
12
+ * @param value any values
13
+ * @returns void
14
+ * @private within the repository
15
+ */
16
+ export declare function keepUnused<TTypeToKeep1 = really_any, TTypeToKeep2 = really_any, TTypeToKeep3 = really_any>(...valuesToKeep: Array<really_any>): void;
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Organizational helper to mark a place where to really use any
2
+ * Organizational helper to mark a place where to really use `any`
3
3
  *
4
4
  * @private within the repository
5
5
  */
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Organizational helper to mark a place where to really use `unknown`
3
+ *
4
+ * @private within the repository
5
+ */
6
+ export type really_unknown = unknown;
@@ -1,5 +1,6 @@
1
1
  import type { string_email } from '../../../types/typeAliases';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Checks if value is valid email
4
5
  */
5
- export declare function isValidEmail(email: unknown): email is string_email;
6
+ export declare function isValidEmail(email: really_unknown): email is string_email;
@@ -1,7 +1,8 @@
1
1
  import type { string_file_path } from '../../../types/typeAliases';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Tests if given string is valid URL.
4
5
  *
5
6
  * Note: This does not check if the file exists only if the path is valid
6
7
  */
7
- export declare function isValidFilePath(filePath: unknown): filePath is string_file_path;
8
+ export declare function isValidFilePath(filePath: really_unknown): filePath is string_file_path;
@@ -1,2 +1,3 @@
1
1
  import type { string_javascript_name } from '../../../types/typeAliases';
2
- export declare function isValidJavascriptName(javascriptName: unknown): javascriptName is string_javascript_name;
2
+ import type { really_unknown } from '../../organization/really_unknown';
3
+ export declare function isValidJavascriptName(javascriptName: really_unknown): javascriptName is string_javascript_name;
@@ -1,4 +1,5 @@
1
1
  import type { string_promptbook_version } from '../../../version';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Tests if given string is valid promptbook version
4
5
  * It looks into list of known promptbook versions.
@@ -9,4 +10,4 @@ import type { string_promptbook_version } from '../../../version';
9
10
  * - `isValidSemanticVersion` which tests any semantic version
10
11
  * - `isValidPromptbookVersion` *(this one)* which tests just Promptbook versions
11
12
  */
12
- export declare function isValidPromptbookVersion(version: unknown): version is string_promptbook_version;
13
+ export declare function isValidPromptbookVersion(version: really_unknown): version is string_promptbook_version;
@@ -1,4 +1,5 @@
1
1
  import type { string_semantic_version } from '../../../types/typeAliases';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Tests if given string is valid semantic version
4
5
  *
@@ -6,4 +7,4 @@ import type { string_semantic_version } from '../../../types/typeAliases';
6
7
  * - `isValidSemanticVersion` which tests any semantic version
7
8
  * - `isValidPromptbookVersion` *(this one)* which tests just Promptbook versions
8
9
  */
9
- export declare function isValidSemanticVersion(version: unknown): version is string_semantic_version;
10
+ export declare function isValidSemanticVersion(version: really_unknown): version is string_semantic_version;
@@ -1,4 +1,5 @@
1
1
  import type { string_pipeline_url } from '../../../types/typeAliases';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Tests if given string is valid pipeline URL URL.
4
5
  *
@@ -6,7 +7,7 @@ import type { string_pipeline_url } from '../../../types/typeAliases';
6
7
  * - `isValidUrl` which tests any URL
7
8
  * - `isValidPipelineUrl` *(this one)* which tests just pipeline URL
8
9
  */
9
- export declare function isValidPipelineUrl(url: unknown): url is string_pipeline_url;
10
+ export declare function isValidPipelineUrl(url: really_unknown): url is string_pipeline_url;
10
11
  /**
11
12
  * TODO: [🐠] Maybe more info why the URL is invalid
12
13
  */
@@ -1,4 +1,5 @@
1
1
  import type { string_url } from '../../../types/typeAliases';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Tests if given string is valid URL.
4
5
  *
@@ -7,4 +8,4 @@ import type { string_url } from '../../../types/typeAliases';
7
8
  * - `isValidUrl` which tests any URL
8
9
  * - `isValidPipelineUrl` *(this one)* which tests just promptbook URL
9
10
  */
10
- export declare function isValidUrl(url: unknown): url is string_url;
11
+ export declare function isValidUrl(url: really_unknown): url is string_url;
@@ -1,5 +1,6 @@
1
1
  import type { string_uuid } from '../../../types/typeAliases';
2
+ import type { really_unknown } from '../../organization/really_unknown';
2
3
  /**
3
4
  * Checks if value is valid uuid
4
5
  */
5
- export declare function isValidUuid(value: unknown): value is string_uuid;
6
+ export declare function isValidUuid(value: really_unknown): value is string_uuid;
@@ -4,6 +4,3 @@ import type { string_semantic_version } from './types/typeAliases';
4
4
  */
5
5
  export declare const PROMPTBOOK_VERSION: string_promptbook_version;
6
6
  export type string_promptbook_version = string_semantic_version;
7
- /**
8
- * TODO: [🔼] !!! Export via `@promptbook/code`
9
- */
@@ -1,12 +0,0 @@
1
- import type { really_any } from './really_any';
2
- /**
3
- * Just says that the variable is not used but should be kept
4
- * No side effects.
5
- *
6
- * Note: It can be usefull suppressing eager optimization of unused imports
7
- *
8
- * @param value any values
9
- * @returns void
10
- * @private within the repository
11
- */
12
- export declare function keepImported(...value: Array<really_any>): void;
@@ -1,12 +0,0 @@
1
- import type { really_any } from './really_any';
2
- /**
3
- * Just says that the variable is not used
4
- * No side effects.
5
- *
6
- * Note: It can be usefull suppressing eslint errors of unused variables in the tests
7
- *
8
- * @param value any values
9
- * @returns void
10
- * @private within the repository
11
- */
12
- export declare function notUsing(...value: Array<really_any>): void;
@@ -1,12 +0,0 @@
1
- import type { really_any } from './really_any';
2
- /**
3
- * Just says that the variable is not used but should be kept
4
- * No side effects.
5
- *
6
- * Note: It can be usefull suppressing eager optimization of unused imports
7
- *
8
- * @param value any values
9
- * @returns void
10
- * @private within the repository
11
- */
12
- export declare function keepImported(...value: Array<really_any>): void;
@@ -1,12 +0,0 @@
1
- import type { really_any } from './really_any';
2
- /**
3
- * Just says that the variable is not used
4
- * No side effects.
5
- *
6
- * Note: It can be usefull suppressing eslint errors of unused variables in the tests
7
- *
8
- * @param value any values
9
- * @returns void
10
- * @private within the repository
11
- */
12
- export declare function notUsing(...value: Array<really_any>): void;