@mzhub/promptc 0.1.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 (167) hide show
  1. package/README.md +224 -0
  2. package/dist/cli.d.ts +3 -0
  3. package/dist/cli.d.ts.map +1 -0
  4. package/dist/cli.js +111 -0
  5. package/dist/cli.js.map +1 -0
  6. package/dist/compiler/BootstrapFewShot.d.ts +13 -0
  7. package/dist/compiler/BootstrapFewShot.d.ts.map +1 -0
  8. package/dist/compiler/BootstrapFewShot.js +93 -0
  9. package/dist/compiler/BootstrapFewShot.js.map +1 -0
  10. package/dist/compiler/CandidatePool.d.ts +10 -0
  11. package/dist/compiler/CandidatePool.d.ts.map +1 -0
  12. package/dist/compiler/CandidatePool.js +29 -0
  13. package/dist/compiler/CandidatePool.js.map +1 -0
  14. package/dist/compiler/CompiledProgram.d.ts +43 -0
  15. package/dist/compiler/CompiledProgram.d.ts.map +1 -0
  16. package/dist/compiler/CompiledProgram.js +41 -0
  17. package/dist/compiler/CompiledProgram.js.map +1 -0
  18. package/dist/compiler/InstructionRewrite.d.ts +19 -0
  19. package/dist/compiler/InstructionRewrite.d.ts.map +1 -0
  20. package/dist/compiler/InstructionRewrite.js +117 -0
  21. package/dist/compiler/InstructionRewrite.js.map +1 -0
  22. package/dist/compiler/index.d.ts +8 -0
  23. package/dist/compiler/index.d.ts.map +1 -0
  24. package/dist/compiler/index.js +5 -0
  25. package/dist/compiler/index.js.map +1 -0
  26. package/dist/compiler/types.d.ts +41 -0
  27. package/dist/compiler/types.d.ts.map +1 -0
  28. package/dist/compiler/types.js +2 -0
  29. package/dist/compiler/types.js.map +1 -0
  30. package/dist/eval/exactMatch.d.ts +5 -0
  31. package/dist/eval/exactMatch.d.ts.map +1 -0
  32. package/dist/eval/exactMatch.js +58 -0
  33. package/dist/eval/exactMatch.js.map +1 -0
  34. package/dist/eval/index.d.ts +5 -0
  35. package/dist/eval/index.d.ts.map +1 -0
  36. package/dist/eval/index.js +3 -0
  37. package/dist/eval/index.js.map +1 -0
  38. package/dist/eval/llmJudge.d.ts +9 -0
  39. package/dist/eval/llmJudge.d.ts.map +1 -0
  40. package/dist/eval/llmJudge.js +33 -0
  41. package/dist/eval/llmJudge.js.map +1 -0
  42. package/dist/eval/types.d.ts +2 -0
  43. package/dist/eval/types.d.ts.map +1 -0
  44. package/dist/eval/types.js +2 -0
  45. package/dist/eval/types.js.map +1 -0
  46. package/dist/index.d.ts +14 -0
  47. package/dist/index.d.ts.map +1 -0
  48. package/dist/index.js +8 -0
  49. package/dist/index.js.map +1 -0
  50. package/dist/program/ChainOfThought.d.ts +6 -0
  51. package/dist/program/ChainOfThought.d.ts.map +1 -0
  52. package/dist/program/ChainOfThought.js +44 -0
  53. package/dist/program/ChainOfThought.js.map +1 -0
  54. package/dist/program/Predict.d.ts +6 -0
  55. package/dist/program/Predict.d.ts.map +1 -0
  56. package/dist/program/Predict.js +33 -0
  57. package/dist/program/Predict.js.map +1 -0
  58. package/dist/program/Program.d.ts +33 -0
  59. package/dist/program/Program.d.ts.map +1 -0
  60. package/dist/program/Program.js +28 -0
  61. package/dist/program/Program.js.map +1 -0
  62. package/dist/program/index.d.ts +5 -0
  63. package/dist/program/index.d.ts.map +1 -0
  64. package/dist/program/index.js +4 -0
  65. package/dist/program/index.js.map +1 -0
  66. package/dist/providers/anthropic.d.ts +10 -0
  67. package/dist/providers/anthropic.d.ts.map +1 -0
  68. package/dist/providers/anthropic.js +40 -0
  69. package/dist/providers/anthropic.js.map +1 -0
  70. package/dist/providers/cerebras.d.ts +10 -0
  71. package/dist/providers/cerebras.d.ts.map +1 -0
  72. package/dist/providers/cerebras.js +39 -0
  73. package/dist/providers/cerebras.js.map +1 -0
  74. package/dist/providers/google.d.ts +10 -0
  75. package/dist/providers/google.d.ts.map +1 -0
  76. package/dist/providers/google.js +42 -0
  77. package/dist/providers/google.js.map +1 -0
  78. package/dist/providers/groq.d.ts +10 -0
  79. package/dist/providers/groq.d.ts.map +1 -0
  80. package/dist/providers/groq.js +42 -0
  81. package/dist/providers/groq.js.map +1 -0
  82. package/dist/providers/index.d.ts +11 -0
  83. package/dist/providers/index.d.ts.map +1 -0
  84. package/dist/providers/index.js +31 -0
  85. package/dist/providers/index.js.map +1 -0
  86. package/dist/providers/ollama.d.ts +9 -0
  87. package/dist/providers/ollama.d.ts.map +1 -0
  88. package/dist/providers/ollama.js +39 -0
  89. package/dist/providers/ollama.js.map +1 -0
  90. package/dist/providers/openai.d.ts +10 -0
  91. package/dist/providers/openai.d.ts.map +1 -0
  92. package/dist/providers/openai.js +42 -0
  93. package/dist/providers/openai.js.map +1 -0
  94. package/dist/providers/types.d.ts +25 -0
  95. package/dist/providers/types.d.ts.map +1 -0
  96. package/dist/providers/types.js +2 -0
  97. package/dist/providers/types.js.map +1 -0
  98. package/dist/runtime/cache.d.ts +18 -0
  99. package/dist/runtime/cache.d.ts.map +1 -0
  100. package/dist/runtime/cache.js +45 -0
  101. package/dist/runtime/cache.js.map +1 -0
  102. package/dist/runtime/concurrency.d.ts +7 -0
  103. package/dist/runtime/concurrency.d.ts.map +1 -0
  104. package/dist/runtime/concurrency.js +14 -0
  105. package/dist/runtime/concurrency.js.map +1 -0
  106. package/dist/runtime/costTracker.d.ts +24 -0
  107. package/dist/runtime/costTracker.d.ts.map +1 -0
  108. package/dist/runtime/costTracker.js +37 -0
  109. package/dist/runtime/costTracker.js.map +1 -0
  110. package/dist/runtime/index.d.ts +9 -0
  111. package/dist/runtime/index.d.ts.map +1 -0
  112. package/dist/runtime/index.js +5 -0
  113. package/dist/runtime/index.js.map +1 -0
  114. package/dist/runtime/retry.d.ts +10 -0
  115. package/dist/runtime/retry.d.ts.map +1 -0
  116. package/dist/runtime/retry.js +39 -0
  117. package/dist/runtime/retry.js.map +1 -0
  118. package/dist/schema/defineSchema.d.ts +18 -0
  119. package/dist/schema/defineSchema.d.ts.map +1 -0
  120. package/dist/schema/defineSchema.js +27 -0
  121. package/dist/schema/defineSchema.js.map +1 -0
  122. package/dist/schema/index.d.ts +3 -0
  123. package/dist/schema/index.d.ts.map +1 -0
  124. package/dist/schema/index.js +2 -0
  125. package/dist/schema/index.js.map +1 -0
  126. package/examples/README.md +42 -0
  127. package/examples/load-compiled.ts +62 -0
  128. package/examples/multi-provider.ts +77 -0
  129. package/examples/name-extractor.ts +113 -0
  130. package/examples/qa-system.ts +98 -0
  131. package/package.json +62 -0
  132. package/src/cli.ts +122 -0
  133. package/src/compiler/BootstrapFewShot.ts +149 -0
  134. package/src/compiler/CandidatePool.ts +39 -0
  135. package/src/compiler/CompiledProgram.ts +112 -0
  136. package/src/compiler/InstructionRewrite.ts +200 -0
  137. package/src/compiler/index.ts +19 -0
  138. package/src/compiler/types.ts +46 -0
  139. package/src/eval/exactMatch.ts +65 -0
  140. package/src/eval/index.ts +4 -0
  141. package/src/eval/llmJudge.ts +45 -0
  142. package/src/eval/types.ts +4 -0
  143. package/src/index.ts +71 -0
  144. package/src/program/ChainOfThought.ts +59 -0
  145. package/src/program/Predict.ts +47 -0
  146. package/src/program/Program.ts +64 -0
  147. package/src/program/index.ts +4 -0
  148. package/src/providers/anthropic.ts +55 -0
  149. package/src/providers/cerebras.ts +53 -0
  150. package/src/providers/google.ts +57 -0
  151. package/src/providers/groq.ts +57 -0
  152. package/src/providers/index.ts +50 -0
  153. package/src/providers/ollama.ts +54 -0
  154. package/src/providers/openai.ts +57 -0
  155. package/src/providers/types.ts +27 -0
  156. package/src/runtime/cache.ts +65 -0
  157. package/src/runtime/concurrency.ts +21 -0
  158. package/src/runtime/costTracker.ts +58 -0
  159. package/src/runtime/index.ts +8 -0
  160. package/src/runtime/retry.ts +59 -0
  161. package/src/schema/defineSchema.ts +44 -0
  162. package/src/schema/index.ts +2 -0
  163. package/tests/candidatePool.test.ts +46 -0
  164. package/tests/evaluators.test.ts +69 -0
  165. package/tests/runtime.test.ts +106 -0
  166. package/tests/schema.test.ts +59 -0
  167. package/tsconfig.json +24 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anthropic.d.ts","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB,qBAAa,iBAAkB,YAAW,WAAW;IACnD,IAAI,SAAe;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAM5B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAmCpE"}
@@ -0,0 +1,40 @@
1
+ export class AnthropicProvider {
2
+ name = "anthropic";
3
+ defaultModel;
4
+ apiKey;
5
+ baseUrl;
6
+ constructor(config) {
7
+ this.apiKey = config.apiKey || process.env.ANTHROPIC_API_KEY || "";
8
+ this.baseUrl = config.baseUrl || "https://api.anthropic.com/v1";
9
+ this.defaultModel = config.defaultModel || "claude-3-5-sonnet-20241022";
10
+ }
11
+ async complete(params) {
12
+ const response = await fetch(`${this.baseUrl}/messages`, {
13
+ method: "POST",
14
+ headers: {
15
+ "Content-Type": "application/json",
16
+ "x-api-key": this.apiKey,
17
+ "anthropic-version": "2023-06-01",
18
+ },
19
+ body: JSON.stringify({
20
+ model: params.model || this.defaultModel,
21
+ max_tokens: params.maxTokens ?? 1024,
22
+ messages: [{ role: "user", content: params.prompt }],
23
+ }),
24
+ });
25
+ if (!response.ok) {
26
+ const error = await response.text();
27
+ throw new Error(`Anthropic API error: ${response.status} - ${error}`);
28
+ }
29
+ const data = (await response.json());
30
+ const textContent = data.content.find((c) => c.type === "text");
31
+ return {
32
+ content: textContent?.text || "",
33
+ usage: {
34
+ inputTokens: data.usage.input_tokens,
35
+ outputTokens: data.usage.output_tokens,
36
+ },
37
+ };
38
+ }
39
+ }
40
+ //# sourceMappingURL=anthropic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"anthropic.js","sourceRoot":"","sources":["../../src/providers/anthropic.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,iBAAiB;IAC5B,IAAI,GAAG,WAAW,CAAC;IACnB,YAAY,CAAS;IACb,MAAM,CAAS;IACf,OAAO,CAAS;IAExB,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,EAAE,CAAC;QACnE,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,8BAA8B,CAAC;QAChE,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,4BAA4B,CAAC;IAC1E,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,MAAwB;QACrC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,WAAW,EAAE;YACvD,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,WAAW,EAAE,IAAI,CAAC,MAAM;gBACxB,mBAAmB,EAAE,YAAY;aAClC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACnB,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY;gBACxC,UAAU,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI;gBACpC,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;aACrD,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,wBAAwB,QAAQ,CAAC,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACxE,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAGlC,CAAC;QAEF,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;QAEhE,OAAO;YACL,OAAO,EAAE,WAAW,EAAE,IAAI,IAAI,EAAE;YAChC,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;gBACpC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;aACvC;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,10 @@
1
+ import type { LLMProvider, CompletionParams, CompletionResult, ProviderConfig } from "./types.js";
2
+ export declare class CerebrasProvider implements LLMProvider {
3
+ name: string;
4
+ defaultModel: string;
5
+ private apiKey;
6
+ private baseUrl;
7
+ constructor(config: ProviderConfig);
8
+ complete(params: CompletionParams): Promise<CompletionResult>;
9
+ }
10
+ //# sourceMappingURL=cerebras.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cerebras.d.ts","sourceRoot":"","sources":["../../src/providers/cerebras.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB,qBAAa,gBAAiB,YAAW,WAAW;IAClD,IAAI,SAAc;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAM5B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAiCpE"}
@@ -0,0 +1,39 @@
1
+ export class CerebrasProvider {
2
+ name = "cerebras";
3
+ defaultModel;
4
+ apiKey;
5
+ baseUrl;
6
+ constructor(config) {
7
+ this.apiKey = config.apiKey || process.env.CEREBRAS_API_KEY || "";
8
+ this.baseUrl = config.baseUrl || "https://api.cerebras.ai/v1";
9
+ this.defaultModel = config.defaultModel || "llama3.1-8b";
10
+ }
11
+ async complete(params) {
12
+ const response = await fetch(`${this.baseUrl}/chat/completions`, {
13
+ method: "POST",
14
+ headers: {
15
+ "Content-Type": "application/json",
16
+ Authorization: `Bearer ${this.apiKey}`,
17
+ },
18
+ body: JSON.stringify({
19
+ model: params.model || this.defaultModel,
20
+ messages: [{ role: "user", content: params.prompt }],
21
+ temperature: params.temperature ?? 0.7,
22
+ max_tokens: params.maxTokens ?? 1024,
23
+ }),
24
+ });
25
+ if (!response.ok) {
26
+ const error = await response.text();
27
+ throw new Error(`Cerebras API error: ${response.status} - ${error}`);
28
+ }
29
+ const data = (await response.json());
30
+ return {
31
+ content: data.choices[0].message.content,
32
+ usage: {
33
+ inputTokens: data.usage.prompt_tokens,
34
+ outputTokens: data.usage.completion_tokens,
35
+ },
36
+ };
37
+ }
38
+ }
39
+ //# sourceMappingURL=cerebras.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cerebras.js","sourceRoot":"","sources":["../../src/providers/cerebras.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,gBAAgB;IAC3B,IAAI,GAAG,UAAU,CAAC;IAClB,YAAY,CAAS;IACb,MAAM,CAAS;IACf,OAAO,CAAS;IAExB,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,EAAE,CAAC;QAClE,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,4BAA4B,CAAC;QAC9D,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,aAAa,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,MAAwB;QACrC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,mBAAmB,EAAE;YAC/D,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,IAAI,CAAC,MAAM,EAAE;aACvC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACnB,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY;gBACxC,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;gBACpD,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,GAAG;gBACtC,UAAU,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI;aACrC,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,uBAAuB,QAAQ,CAAC,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACvE,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAGlC,CAAC;QAEF,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO;YACxC,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;gBACrC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,iBAAiB;aAC3C;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,10 @@
1
+ import type { LLMProvider, CompletionParams, CompletionResult, ProviderConfig } from "./types.js";
2
+ export declare class GoogleProvider implements LLMProvider {
3
+ name: string;
4
+ defaultModel: string;
5
+ private apiKey;
6
+ private baseUrl;
7
+ constructor(config: ProviderConfig);
8
+ complete(params: CompletionParams): Promise<CompletionResult>;
9
+ }
10
+ //# sourceMappingURL=google.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"google.d.ts","sourceRoot":"","sources":["../../src/providers/google.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB,qBAAa,cAAe,YAAW,WAAW;IAChD,IAAI,SAAY;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAO5B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAoCpE"}
@@ -0,0 +1,42 @@
1
+ export class GoogleProvider {
2
+ name = "google";
3
+ defaultModel;
4
+ apiKey;
5
+ baseUrl;
6
+ constructor(config) {
7
+ this.apiKey = config.apiKey || process.env.GOOGLE_API_KEY || "";
8
+ this.baseUrl =
9
+ config.baseUrl || "https://generativelanguage.googleapis.com/v1beta";
10
+ this.defaultModel = config.defaultModel || "gemini-2.0-flash";
11
+ }
12
+ async complete(params) {
13
+ const model = params.model || this.defaultModel;
14
+ const url = `${this.baseUrl}/models/${model}:generateContent?key=${this.apiKey}`;
15
+ const response = await fetch(url, {
16
+ method: "POST",
17
+ headers: {
18
+ "Content-Type": "application/json",
19
+ },
20
+ body: JSON.stringify({
21
+ contents: [{ parts: [{ text: params.prompt }] }],
22
+ generationConfig: {
23
+ temperature: params.temperature ?? 0.7,
24
+ maxOutputTokens: params.maxTokens ?? 1024,
25
+ },
26
+ }),
27
+ });
28
+ if (!response.ok) {
29
+ const error = await response.text();
30
+ throw new Error(`Google API error: ${response.status} - ${error}`);
31
+ }
32
+ const data = (await response.json());
33
+ return {
34
+ content: data.candidates[0]?.content?.parts[0]?.text || "",
35
+ usage: {
36
+ inputTokens: data.usageMetadata?.promptTokenCount || 0,
37
+ outputTokens: data.usageMetadata?.candidatesTokenCount || 0,
38
+ },
39
+ };
40
+ }
41
+ }
42
+ //# sourceMappingURL=google.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"google.js","sourceRoot":"","sources":["../../src/providers/google.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,cAAc;IACzB,IAAI,GAAG,QAAQ,CAAC;IAChB,YAAY,CAAS;IACb,MAAM,CAAS;IACf,OAAO,CAAS;IAExB,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC;QAChE,IAAI,CAAC,OAAO;YACV,MAAM,CAAC,OAAO,IAAI,kDAAkD,CAAC;QACvE,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,kBAAkB,CAAC;IAChE,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,MAAwB;QACrC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC;QAChD,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,OAAO,WAAW,KAAK,wBAAwB,IAAI,CAAC,MAAM,EAAE,CAAC;QAEjF,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,EAAE;YAChC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;aACnC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACnB,QAAQ,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;gBAChD,gBAAgB,EAAE;oBAChB,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,GAAG;oBACtC,eAAe,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI;iBAC1C;aACF,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,qBAAqB,QAAQ,CAAC,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACrE,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAGlC,CAAC;QAEF,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE;YAC1D,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI,CAAC,aAAa,EAAE,gBAAgB,IAAI,CAAC;gBACtD,YAAY,EAAE,IAAI,CAAC,aAAa,EAAE,oBAAoB,IAAI,CAAC;aAC5D;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,10 @@
1
+ import type { LLMProvider, CompletionParams, CompletionResult, ProviderConfig } from "./types.js";
2
+ export declare class GroqProvider implements LLMProvider {
3
+ name: string;
4
+ defaultModel: string;
5
+ private apiKey;
6
+ private baseUrl;
7
+ constructor(config: ProviderConfig);
8
+ complete(params: CompletionParams): Promise<CompletionResult>;
9
+ }
10
+ //# sourceMappingURL=groq.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"groq.d.ts","sourceRoot":"","sources":["../../src/providers/groq.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB,qBAAa,YAAa,YAAW,WAAW;IAC9C,IAAI,SAAU;IACd,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAM5B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAqCpE"}
@@ -0,0 +1,42 @@
1
+ export class GroqProvider {
2
+ name = "groq";
3
+ defaultModel;
4
+ apiKey;
5
+ baseUrl;
6
+ constructor(config) {
7
+ this.apiKey = config.apiKey || process.env.GROQ_API_KEY || "";
8
+ this.baseUrl = config.baseUrl || "https://api.groq.com/openai/v1";
9
+ this.defaultModel = config.defaultModel || "llama-3.3-70b-versatile";
10
+ }
11
+ async complete(params) {
12
+ const response = await fetch(`${this.baseUrl}/chat/completions`, {
13
+ method: "POST",
14
+ headers: {
15
+ "Content-Type": "application/json",
16
+ Authorization: `Bearer ${this.apiKey}`,
17
+ },
18
+ body: JSON.stringify({
19
+ model: params.model || this.defaultModel,
20
+ messages: [{ role: "user", content: params.prompt }],
21
+ temperature: params.temperature ?? 0.7,
22
+ max_tokens: params.maxTokens ?? 1024,
23
+ response_format: params.responseFormat === "json"
24
+ ? { type: "json_object" }
25
+ : undefined,
26
+ }),
27
+ });
28
+ if (!response.ok) {
29
+ const error = await response.text();
30
+ throw new Error(`Groq API error: ${response.status} - ${error}`);
31
+ }
32
+ const data = (await response.json());
33
+ return {
34
+ content: data.choices[0].message.content,
35
+ usage: {
36
+ inputTokens: data.usage.prompt_tokens,
37
+ outputTokens: data.usage.completion_tokens,
38
+ },
39
+ };
40
+ }
41
+ }
42
+ //# sourceMappingURL=groq.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"groq.js","sourceRoot":"","sources":["../../src/providers/groq.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,YAAY;IACvB,IAAI,GAAG,MAAM,CAAC;IACd,YAAY,CAAS;IACb,MAAM,CAAS;IACf,OAAO,CAAS;IAExB,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,EAAE,CAAC;QAC9D,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,gCAAgC,CAAC;QAClE,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,yBAAyB,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,MAAwB;QACrC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,mBAAmB,EAAE;YAC/D,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,IAAI,CAAC,MAAM,EAAE;aACvC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACnB,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY;gBACxC,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;gBACpD,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,GAAG;gBACtC,UAAU,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI;gBACpC,eAAe,EACb,MAAM,CAAC,cAAc,KAAK,MAAM;oBAC9B,CAAC,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE;oBACzB,CAAC,CAAC,SAAS;aAChB,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,mBAAmB,QAAQ,CAAC,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACnE,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAGlC,CAAC;QAEF,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO;YACxC,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;gBACrC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,iBAAiB;aAC3C;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import type { LLMProvider, ProviderConfig } from "./types.js";
2
+ export type ProviderName = "openai" | "anthropic" | "google" | "ollama" | "groq" | "cerebras";
3
+ export declare function createProvider(name: ProviderName, config?: ProviderConfig): LLMProvider;
4
+ export { OpenAIProvider } from "./openai.js";
5
+ export { AnthropicProvider } from "./anthropic.js";
6
+ export { GoogleProvider } from "./google.js";
7
+ export { OllamaProvider } from "./ollama.js";
8
+ export { GroqProvider } from "./groq.js";
9
+ export { CerebrasProvider } from "./cerebras.js";
10
+ export type { LLMProvider, CompletionParams, CompletionResult, ProviderConfig, } from "./types.js";
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAE9D,MAAM,MAAM,YAAY,GACpB,QAAQ,GACR,WAAW,GACX,QAAQ,GACR,QAAQ,GACR,MAAM,GACN,UAAU,CAAC;AAEf,wBAAgB,cAAc,CAC5B,IAAI,EAAE,YAAY,EAClB,MAAM,GAAE,cAAmB,GAC1B,WAAW,CAiBb;AAED,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,YAAY,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,GACf,MAAM,YAAY,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { OpenAIProvider } from "./openai.js";
2
+ import { AnthropicProvider } from "./anthropic.js";
3
+ import { GoogleProvider } from "./google.js";
4
+ import { OllamaProvider } from "./ollama.js";
5
+ import { GroqProvider } from "./groq.js";
6
+ import { CerebrasProvider } from "./cerebras.js";
7
+ export function createProvider(name, config = {}) {
8
+ switch (name) {
9
+ case "openai":
10
+ return new OpenAIProvider(config);
11
+ case "anthropic":
12
+ return new AnthropicProvider(config);
13
+ case "google":
14
+ return new GoogleProvider(config);
15
+ case "ollama":
16
+ return new OllamaProvider(config);
17
+ case "groq":
18
+ return new GroqProvider(config);
19
+ case "cerebras":
20
+ return new CerebrasProvider(config);
21
+ default:
22
+ throw new Error(`Unknown provider: ${name}`);
23
+ }
24
+ }
25
+ export { OpenAIProvider } from "./openai.js";
26
+ export { AnthropicProvider } from "./anthropic.js";
27
+ export { GoogleProvider } from "./google.js";
28
+ export { OllamaProvider } from "./ollama.js";
29
+ export { GroqProvider } from "./groq.js";
30
+ export { CerebrasProvider } from "./cerebras.js";
31
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAWjD,MAAM,UAAU,cAAc,CAC5B,IAAkB,EAClB,SAAyB,EAAE;IAE3B,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,QAAQ;YACX,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;QACpC,KAAK,WAAW;YACd,OAAO,IAAI,iBAAiB,CAAC,MAAM,CAAC,CAAC;QACvC,KAAK,QAAQ;YACX,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;QACpC,KAAK,QAAQ;YACX,OAAO,IAAI,cAAc,CAAC,MAAM,CAAC,CAAC;QACpC,KAAK,MAAM;YACT,OAAO,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;QAClC,KAAK,UAAU;YACb,OAAO,IAAI,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACtC;YACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAC;IACjD,CAAC;AACH,CAAC;AAED,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,9 @@
1
+ import type { LLMProvider, CompletionParams, CompletionResult, ProviderConfig } from "./types.js";
2
+ export declare class OllamaProvider implements LLMProvider {
3
+ name: string;
4
+ defaultModel: string;
5
+ private baseUrl;
6
+ constructor(config?: ProviderConfig);
7
+ complete(params: CompletionParams): Promise<CompletionResult>;
8
+ }
9
+ //# sourceMappingURL=ollama.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ollama.d.ts","sourceRoot":"","sources":["../../src/providers/ollama.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB,qBAAa,cAAe,YAAW,WAAW;IAChD,IAAI,SAAY;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,GAAE,cAAmB;IAKjC,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAoCpE"}
@@ -0,0 +1,39 @@
1
+ export class OllamaProvider {
2
+ name = "ollama";
3
+ defaultModel;
4
+ baseUrl;
5
+ constructor(config = {}) {
6
+ this.baseUrl = config.baseUrl || "http://localhost:11434";
7
+ this.defaultModel = config.defaultModel || "llama3.2";
8
+ }
9
+ async complete(params) {
10
+ const response = await fetch(`${this.baseUrl}/api/generate`, {
11
+ method: "POST",
12
+ headers: {
13
+ "Content-Type": "application/json",
14
+ },
15
+ body: JSON.stringify({
16
+ model: params.model || this.defaultModel,
17
+ prompt: params.prompt,
18
+ stream: false,
19
+ options: {
20
+ temperature: params.temperature ?? 0.7,
21
+ num_predict: params.maxTokens ?? 1024,
22
+ },
23
+ }),
24
+ });
25
+ if (!response.ok) {
26
+ const error = await response.text();
27
+ throw new Error(`Ollama API error: ${response.status} - ${error}`);
28
+ }
29
+ const data = (await response.json());
30
+ return {
31
+ content: data.response,
32
+ usage: {
33
+ inputTokens: data.prompt_eval_count || 0,
34
+ outputTokens: data.eval_count || 0,
35
+ },
36
+ };
37
+ }
38
+ }
39
+ //# sourceMappingURL=ollama.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ollama.js","sourceRoot":"","sources":["../../src/providers/ollama.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,cAAc;IACzB,IAAI,GAAG,QAAQ,CAAC;IAChB,YAAY,CAAS;IACb,OAAO,CAAS;IAExB,YAAY,SAAyB,EAAE;QACrC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,wBAAwB,CAAC;QAC1D,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,UAAU,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,MAAwB;QACrC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,eAAe,EAAE;YAC3D,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;aACnC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACnB,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY;gBACxC,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,MAAM,EAAE,KAAK;gBACb,OAAO,EAAE;oBACP,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,GAAG;oBACtC,WAAW,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI;iBACtC;aACF,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,qBAAqB,QAAQ,CAAC,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACrE,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAIlC,CAAC;QAEF,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI,CAAC,iBAAiB,IAAI,CAAC;gBACxC,YAAY,EAAE,IAAI,CAAC,UAAU,IAAI,CAAC;aACnC;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,10 @@
1
+ import type { LLMProvider, CompletionParams, CompletionResult, ProviderConfig } from "./types.js";
2
+ export declare class OpenAIProvider implements LLMProvider {
3
+ name: string;
4
+ defaultModel: string;
5
+ private apiKey;
6
+ private baseUrl;
7
+ constructor(config: ProviderConfig);
8
+ complete(params: CompletionParams): Promise<CompletionResult>;
9
+ }
10
+ //# sourceMappingURL=openai.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/providers/openai.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,WAAW,EACX,gBAAgB,EAChB,gBAAgB,EAChB,cAAc,EACf,MAAM,YAAY,CAAC;AAEpB,qBAAa,cAAe,YAAW,WAAW;IAChD,IAAI,SAAY;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,MAAM,EAAE,cAAc;IAM5B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;CAqCpE"}
@@ -0,0 +1,42 @@
1
+ export class OpenAIProvider {
2
+ name = "openai";
3
+ defaultModel;
4
+ apiKey;
5
+ baseUrl;
6
+ constructor(config) {
7
+ this.apiKey = config.apiKey || process.env.OPENAI_API_KEY || "";
8
+ this.baseUrl = config.baseUrl || "https://api.openai.com/v1";
9
+ this.defaultModel = config.defaultModel || "gpt-4o-mini";
10
+ }
11
+ async complete(params) {
12
+ const response = await fetch(`${this.baseUrl}/chat/completions`, {
13
+ method: "POST",
14
+ headers: {
15
+ "Content-Type": "application/json",
16
+ Authorization: `Bearer ${this.apiKey}`,
17
+ },
18
+ body: JSON.stringify({
19
+ model: params.model || this.defaultModel,
20
+ messages: [{ role: "user", content: params.prompt }],
21
+ temperature: params.temperature ?? 0.7,
22
+ max_tokens: params.maxTokens ?? 1024,
23
+ response_format: params.responseFormat === "json"
24
+ ? { type: "json_object" }
25
+ : undefined,
26
+ }),
27
+ });
28
+ if (!response.ok) {
29
+ const error = await response.text();
30
+ throw new Error(`OpenAI API error: ${response.status} - ${error}`);
31
+ }
32
+ const data = (await response.json());
33
+ return {
34
+ content: data.choices[0].message.content,
35
+ usage: {
36
+ inputTokens: data.usage.prompt_tokens,
37
+ outputTokens: data.usage.completion_tokens,
38
+ },
39
+ };
40
+ }
41
+ }
42
+ //# sourceMappingURL=openai.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/providers/openai.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,cAAc;IACzB,IAAI,GAAG,QAAQ,CAAC;IAChB,YAAY,CAAS;IACb,MAAM,CAAS;IACf,OAAO,CAAS;IAExB,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC;QAChE,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,2BAA2B,CAAC;QAC7D,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,aAAa,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,MAAwB;QACrC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,OAAO,mBAAmB,EAAE;YAC/D,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,IAAI,CAAC,MAAM,EAAE;aACvC;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACnB,KAAK,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY;gBACxC,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC;gBACpD,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,GAAG;gBACtC,UAAU,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI;gBACpC,eAAe,EACb,MAAM,CAAC,cAAc,KAAK,MAAM;oBAC9B,CAAC,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE;oBACzB,CAAC,CAAC,SAAS;aAChB,CAAC;SACH,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpC,MAAM,IAAI,KAAK,CAAC,qBAAqB,QAAQ,CAAC,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACrE,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAGlC,CAAC;QAEF,OAAO;YACL,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO;YACxC,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;gBACrC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,iBAAiB;aAC3C;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,25 @@
1
+ export interface CompletionParams {
2
+ prompt: string;
3
+ model?: string;
4
+ temperature?: number;
5
+ maxTokens?: number;
6
+ responseFormat?: "text" | "json";
7
+ }
8
+ export interface CompletionResult {
9
+ content: string;
10
+ usage: {
11
+ inputTokens: number;
12
+ outputTokens: number;
13
+ };
14
+ }
15
+ export interface LLMProvider {
16
+ name: string;
17
+ defaultModel: string;
18
+ complete(params: CompletionParams): Promise<CompletionResult>;
19
+ }
20
+ export interface ProviderConfig {
21
+ apiKey?: string;
22
+ baseUrl?: string;
23
+ defaultModel?: string;
24
+ }
25
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/providers/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE;QACL,WAAW,EAAE,MAAM,CAAC;QACpB,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC;CACH;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;CAC/D;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/providers/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,18 @@
1
+ export interface CacheOptions {
2
+ maxSize?: number;
3
+ ttlMs?: number;
4
+ }
5
+ export declare class PromptCache<T> {
6
+ private cache;
7
+ private maxSize;
8
+ private ttlMs;
9
+ constructor(options?: CacheOptions);
10
+ private makeKey;
11
+ get(prompt: string, input: unknown): T | undefined;
12
+ set(prompt: string, input: unknown, value: T): void;
13
+ has(prompt: string, input: unknown): boolean;
14
+ clear(): void;
15
+ get size(): number;
16
+ }
17
+ export declare function createCache<T>(options?: CacheOptions): PromptCache<T>;
18
+ //# sourceMappingURL=cache.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../src/runtime/cache.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAOD,qBAAa,WAAW,CAAC,CAAC;IACxB,OAAO,CAAC,KAAK,CAAoC;IACjD,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,KAAK,CAAS;gBAEV,OAAO,GAAE,YAAiB;IAKtC,OAAO,CAAC,OAAO;IAIf,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,CAAC,GAAG,SAAS;IAclD,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,GAAG,IAAI;IAWnD,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO;IAI5C,KAAK,IAAI,IAAI;IAIb,IAAI,IAAI,IAAI,MAAM,CAEjB;CACF;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,OAAO,GAAE,YAAiB,GAAG,WAAW,CAAC,CAAC,CAAC,CAEzE"}
@@ -0,0 +1,45 @@
1
+ export class PromptCache {
2
+ cache = new Map();
3
+ maxSize;
4
+ ttlMs;
5
+ constructor(options = {}) {
6
+ this.maxSize = options.maxSize ?? 1000;
7
+ this.ttlMs = options.ttlMs ?? 0;
8
+ }
9
+ makeKey(prompt, input) {
10
+ return `${prompt}::${JSON.stringify(input)}`;
11
+ }
12
+ get(prompt, input) {
13
+ const key = this.makeKey(prompt, input);
14
+ const entry = this.cache.get(key);
15
+ if (!entry)
16
+ return undefined;
17
+ if (this.ttlMs > 0 && Date.now() - entry.timestamp > this.ttlMs) {
18
+ this.cache.delete(key);
19
+ return undefined;
20
+ }
21
+ return entry.value;
22
+ }
23
+ set(prompt, input, value) {
24
+ const key = this.makeKey(prompt, input);
25
+ if (this.cache.size >= this.maxSize) {
26
+ const firstKey = this.cache.keys().next().value;
27
+ if (firstKey)
28
+ this.cache.delete(firstKey);
29
+ }
30
+ this.cache.set(key, { value, timestamp: Date.now() });
31
+ }
32
+ has(prompt, input) {
33
+ return this.get(prompt, input) !== undefined;
34
+ }
35
+ clear() {
36
+ this.cache.clear();
37
+ }
38
+ get size() {
39
+ return this.cache.size;
40
+ }
41
+ }
42
+ export function createCache(options = {}) {
43
+ return new PromptCache(options);
44
+ }
45
+ //# sourceMappingURL=cache.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/runtime/cache.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,WAAW;IACd,KAAK,GAAG,IAAI,GAAG,EAAyB,CAAC;IACzC,OAAO,CAAS;IAChB,KAAK,CAAS;IAEtB,YAAY,UAAwB,EAAE;QACpC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC;QACvC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC;IAClC,CAAC;IAEO,OAAO,CAAC,MAAc,EAAE,KAAc;QAC5C,OAAO,GAAG,MAAM,KAAK,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;IAC/C,CAAC;IAED,GAAG,CAAC,MAAc,EAAE,KAAc;QAChC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACxC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAElC,IAAI,CAAC,KAAK;YAAE,OAAO,SAAS,CAAC;QAE7B,IAAI,IAAI,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YAChE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,OAAO,KAAK,CAAC,KAAK,CAAC;IACrB,CAAC;IAED,GAAG,CAAC,MAAc,EAAE,KAAc,EAAE,KAAQ;QAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAExC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC;YAChD,IAAI,QAAQ;gBAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACxD,CAAC;IAED,GAAG,CAAC,MAAc,EAAE,KAAc;QAChC,OAAO,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,KAAK,SAAS,CAAC;IAC/C,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;IACzB,CAAC;CACF;AAED,MAAM,UAAU,WAAW,CAAI,UAAwB,EAAE;IACvD,OAAO,IAAI,WAAW,CAAI,OAAO,CAAC,CAAC;AACrC,CAAC"}
@@ -0,0 +1,7 @@
1
+ export interface ConcurrencyManager {
2
+ run<T>(fn: () => Promise<T>): Promise<T>;
3
+ get pending(): number;
4
+ get active(): number;
5
+ }
6
+ export declare function createConcurrencyManager(limit: number): ConcurrencyManager;
7
+ //# sourceMappingURL=concurrency.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"concurrency.d.ts","sourceRoot":"","sources":["../../src/runtime/concurrency.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,kBAAkB;IACjC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IACzC,IAAI,OAAO,IAAI,MAAM,CAAC;IACtB,IAAI,MAAM,IAAI,MAAM,CAAC;CACtB;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,MAAM,GAAG,kBAAkB,CAY1E"}
@@ -0,0 +1,14 @@
1
+ import pLimit from "p-limit";
2
+ export function createConcurrencyManager(limit) {
3
+ const limiter = pLimit(limit);
4
+ return {
5
+ run: (fn) => limiter(fn),
6
+ get pending() {
7
+ return limiter.pendingCount;
8
+ },
9
+ get active() {
10
+ return limiter.activeCount;
11
+ },
12
+ };
13
+ }
14
+ //# sourceMappingURL=concurrency.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"concurrency.js","sourceRoot":"","sources":["../../src/runtime/concurrency.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,SAAS,CAAC;AAQ7B,MAAM,UAAU,wBAAwB,CAAC,KAAa;IACpD,MAAM,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAE9B,OAAO;QACL,GAAG,EAAE,CAAI,EAAoB,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;QAC7C,IAAI,OAAO;YACT,OAAO,OAAO,CAAC,YAAY,CAAC;QAC9B,CAAC;QACD,IAAI,MAAM;YACR,OAAO,OAAO,CAAC,WAAW,CAAC;QAC7B,CAAC;KACF,CAAC;AACJ,CAAC"}
@@ -0,0 +1,24 @@
1
+ export interface TokenUsage {
2
+ inputTokens: number;
3
+ outputTokens: number;
4
+ }
5
+ export interface CostEstimate {
6
+ inputTokens: number;
7
+ outputTokens: number;
8
+ totalTokens: number;
9
+ estimatedCalls: number;
10
+ }
11
+ export declare class CostTracker {
12
+ private totalInputTokens;
13
+ private totalOutputTokens;
14
+ private callCount;
15
+ record(usage: TokenUsage): void;
16
+ get total(): TokenUsage & {
17
+ totalTokens: number;
18
+ calls: number;
19
+ };
20
+ exceedsBudget(maxTokens: number): boolean;
21
+ reset(): void;
22
+ }
23
+ export declare function estimateCost(candidateCount: number, testCaseCount: number, avgTokensPerCall?: number): CostEstimate;
24
+ //# sourceMappingURL=costTracker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"costTracker.d.ts","sourceRoot":"","sources":["../../src/runtime/costTracker.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,YAAY;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,iBAAiB,CAAK;IAC9B,OAAO,CAAC,SAAS,CAAK;IAEtB,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAM/B,IAAI,KAAK,IAAI,UAAU,GAAG;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAO/D;IAED,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO;IAIzC,KAAK,IAAI,IAAI;CAKd;AAED,wBAAgB,YAAY,CAC1B,cAAc,EAAE,MAAM,EACtB,aAAa,EAAE,MAAM,EACrB,gBAAgB,GAAE,MAAY,GAC7B,YAAY,CAUd"}
@@ -0,0 +1,37 @@
1
+ export class CostTracker {
2
+ totalInputTokens = 0;
3
+ totalOutputTokens = 0;
4
+ callCount = 0;
5
+ record(usage) {
6
+ this.totalInputTokens += usage.inputTokens;
7
+ this.totalOutputTokens += usage.outputTokens;
8
+ this.callCount++;
9
+ }
10
+ get total() {
11
+ return {
12
+ inputTokens: this.totalInputTokens,
13
+ outputTokens: this.totalOutputTokens,
14
+ totalTokens: this.totalInputTokens + this.totalOutputTokens,
15
+ calls: this.callCount,
16
+ };
17
+ }
18
+ exceedsBudget(maxTokens) {
19
+ return this.totalInputTokens + this.totalOutputTokens > maxTokens;
20
+ }
21
+ reset() {
22
+ this.totalInputTokens = 0;
23
+ this.totalOutputTokens = 0;
24
+ this.callCount = 0;
25
+ }
26
+ }
27
+ export function estimateCost(candidateCount, testCaseCount, avgTokensPerCall = 500) {
28
+ const estimatedCalls = candidateCount * testCaseCount;
29
+ const totalTokens = estimatedCalls * avgTokensPerCall;
30
+ return {
31
+ inputTokens: Math.round(totalTokens * 0.7),
32
+ outputTokens: Math.round(totalTokens * 0.3),
33
+ totalTokens,
34
+ estimatedCalls,
35
+ };
36
+ }
37
+ //# sourceMappingURL=costTracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"costTracker.js","sourceRoot":"","sources":["../../src/runtime/costTracker.ts"],"names":[],"mappings":"AAYA,MAAM,OAAO,WAAW;IACd,gBAAgB,GAAG,CAAC,CAAC;IACrB,iBAAiB,GAAG,CAAC,CAAC;IACtB,SAAS,GAAG,CAAC,CAAC;IAEtB,MAAM,CAAC,KAAiB;QACtB,IAAI,CAAC,gBAAgB,IAAI,KAAK,CAAC,WAAW,CAAC;QAC3C,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC,YAAY,CAAC;QAC7C,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,IAAI,KAAK;QACP,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,gBAAgB;YAClC,YAAY,EAAE,IAAI,CAAC,iBAAiB;YACpC,WAAW,EAAE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,iBAAiB;YAC3D,KAAK,EAAE,IAAI,CAAC,SAAS;SACtB,CAAC;IACJ,CAAC;IAED,aAAa,CAAC,SAAiB;QAC7B,OAAO,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;IACpE,CAAC;IAED,KAAK;QACH,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;CACF;AAED,MAAM,UAAU,YAAY,CAC1B,cAAsB,EACtB,aAAqB,EACrB,mBAA2B,GAAG;IAE9B,MAAM,cAAc,GAAG,cAAc,GAAG,aAAa,CAAC;IACtD,MAAM,WAAW,GAAG,cAAc,GAAG,gBAAgB,CAAC;IAEtD,OAAO;QACL,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC;QAC1C,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC;QAC3C,WAAW;QACX,cAAc;KACf,CAAC;AACJ,CAAC"}