node-llama-cpp 3.0.0-beta.2 → 3.0.0-beta.21

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 (641) hide show
  1. package/README.md +14 -11
  2. package/dist/ChatWrapper.d.ts +2 -15
  3. package/dist/ChatWrapper.js +28 -33
  4. package/dist/ChatWrapper.js.map +1 -1
  5. package/dist/apiDocsOverrides.d.ts +1 -0
  6. package/dist/apiDocsOverrides.js +5 -0
  7. package/dist/apiDocsOverrides.js.map +1 -0
  8. package/dist/{utils/getBin.d.ts → bindings/AddonTypes.d.ts} +54 -7
  9. package/dist/bindings/AddonTypes.js +2 -0
  10. package/dist/bindings/AddonTypes.js.map +1 -0
  11. package/dist/bindings/Llama.d.ts +47 -0
  12. package/dist/bindings/Llama.js +343 -0
  13. package/dist/bindings/Llama.js.map +1 -0
  14. package/dist/bindings/consts.d.ts +2 -0
  15. package/dist/bindings/consts.js +11 -0
  16. package/dist/bindings/consts.js.map +1 -0
  17. package/dist/bindings/getLlama.d.ts +145 -0
  18. package/dist/bindings/getLlama.js +389 -0
  19. package/dist/bindings/getLlama.js.map +1 -0
  20. package/dist/bindings/types.d.ts +55 -0
  21. package/dist/bindings/types.js +77 -0
  22. package/dist/bindings/types.js.map +1 -0
  23. package/dist/bindings/utils/MemoryOrchestrator.d.ts +21 -0
  24. package/dist/bindings/utils/MemoryOrchestrator.js +49 -0
  25. package/dist/bindings/utils/MemoryOrchestrator.js.map +1 -0
  26. package/dist/bindings/utils/NoBinaryFoundError.d.ts +2 -0
  27. package/dist/bindings/utils/NoBinaryFoundError.js +7 -0
  28. package/dist/bindings/utils/NoBinaryFoundError.js.map +1 -0
  29. package/dist/bindings/utils/asyncEvery.d.ts +5 -0
  30. package/dist/bindings/utils/asyncEvery.js +15 -0
  31. package/dist/bindings/utils/asyncEvery.js.map +1 -0
  32. package/dist/bindings/utils/asyncSome.d.ts +5 -0
  33. package/dist/bindings/utils/asyncSome.js +27 -0
  34. package/dist/bindings/utils/asyncSome.js.map +1 -0
  35. package/dist/{utils → bindings/utils}/binariesGithubRelease.js +1 -1
  36. package/dist/bindings/utils/binariesGithubRelease.js.map +1 -0
  37. package/dist/bindings/utils/clearAllLocalBuilds.d.ts +1 -0
  38. package/dist/bindings/utils/clearAllLocalBuilds.js +47 -0
  39. package/dist/bindings/utils/clearAllLocalBuilds.js.map +1 -0
  40. package/dist/bindings/utils/cloneLlamaCppRepo.d.ts +11 -0
  41. package/dist/bindings/utils/cloneLlamaCppRepo.js +166 -0
  42. package/dist/bindings/utils/cloneLlamaCppRepo.js.map +1 -0
  43. package/dist/bindings/utils/compileLLamaCpp.d.ts +15 -0
  44. package/dist/bindings/utils/compileLLamaCpp.js +221 -0
  45. package/dist/bindings/utils/compileLLamaCpp.js.map +1 -0
  46. package/dist/bindings/utils/detectAvailableComputeLayers.d.ts +14 -0
  47. package/dist/bindings/utils/detectAvailableComputeLayers.js +304 -0
  48. package/dist/bindings/utils/detectAvailableComputeLayers.js.map +1 -0
  49. package/dist/bindings/utils/detectGlibc.d.ts +4 -0
  50. package/dist/bindings/utils/detectGlibc.js +46 -0
  51. package/dist/bindings/utils/detectGlibc.js.map +1 -0
  52. package/dist/bindings/utils/getBestComputeLayersAvailable.d.ts +9 -0
  53. package/dist/bindings/utils/getBestComputeLayersAvailable.js +29 -0
  54. package/dist/bindings/utils/getBestComputeLayersAvailable.js.map +1 -0
  55. package/dist/bindings/utils/getBuildFolderNameForBuildOptions.d.ts +5 -0
  56. package/dist/bindings/utils/getBuildFolderNameForBuildOptions.js +93 -0
  57. package/dist/bindings/utils/getBuildFolderNameForBuildOptions.js.map +1 -0
  58. package/dist/bindings/utils/getCanUsePrebuiltBinaries.d.ts +1 -0
  59. package/dist/bindings/utils/getCanUsePrebuiltBinaries.js +8 -0
  60. package/dist/bindings/utils/getCanUsePrebuiltBinaries.js.map +1 -0
  61. package/dist/bindings/utils/getExampleUsageCodeOfGetLlama.d.ts +2 -0
  62. package/dist/bindings/utils/getExampleUsageCodeOfGetLlama.js +21 -0
  63. package/dist/bindings/utils/getExampleUsageCodeOfGetLlama.js.map +1 -0
  64. package/dist/bindings/utils/getGpuTypesToUseForOption.d.ts +11 -0
  65. package/dist/bindings/utils/getGpuTypesToUseForOption.js +30 -0
  66. package/dist/bindings/utils/getGpuTypesToUseForOption.js.map +1 -0
  67. package/dist/bindings/utils/getLinuxDistroInfo.d.ts +9 -0
  68. package/dist/bindings/utils/getLinuxDistroInfo.js +46 -0
  69. package/dist/bindings/utils/getLinuxDistroInfo.js.map +1 -0
  70. package/dist/bindings/utils/getLlamaWithoutBackend.d.ts +5 -0
  71. package/dist/bindings/utils/getLlamaWithoutBackend.js +27 -0
  72. package/dist/bindings/utils/getLlamaWithoutBackend.js.map +1 -0
  73. package/dist/bindings/utils/getPlatform.d.ts +2 -0
  74. package/dist/bindings/utils/getPlatform.js +15 -0
  75. package/dist/bindings/utils/getPlatform.js.map +1 -0
  76. package/dist/bindings/utils/getPlatformInfo.d.ts +5 -0
  77. package/dist/bindings/utils/getPlatformInfo.js +28 -0
  78. package/dist/bindings/utils/getPlatformInfo.js.map +1 -0
  79. package/dist/bindings/utils/hasBuildingFromSourceDependenciesInstalled.d.ts +3 -0
  80. package/dist/bindings/utils/hasBuildingFromSourceDependenciesInstalled.js +27 -0
  81. package/dist/bindings/utils/hasBuildingFromSourceDependenciesInstalled.js.map +1 -0
  82. package/dist/bindings/utils/hasFileInPath.d.ts +2 -0
  83. package/dist/bindings/utils/hasFileInPath.js +34 -0
  84. package/dist/bindings/utils/hasFileInPath.js.map +1 -0
  85. package/dist/bindings/utils/lastBuildInfo.d.ts +6 -0
  86. package/dist/bindings/utils/lastBuildInfo.js +17 -0
  87. package/dist/bindings/utils/lastBuildInfo.js.map +1 -0
  88. package/dist/bindings/utils/logBinaryUsageExampleToConsole.d.ts +2 -0
  89. package/dist/bindings/utils/logBinaryUsageExampleToConsole.js +22 -0
  90. package/dist/bindings/utils/logBinaryUsageExampleToConsole.js.map +1 -0
  91. package/dist/bindings/utils/logDistroInstallInstruction.d.ts +14 -0
  92. package/dist/bindings/utils/logDistroInstallInstruction.js +48 -0
  93. package/dist/bindings/utils/logDistroInstallInstruction.js.map +1 -0
  94. package/dist/bindings/utils/resolveCustomCmakeOptions.d.ts +1 -0
  95. package/dist/bindings/utils/resolveCustomCmakeOptions.js +45 -0
  96. package/dist/bindings/utils/resolveCustomCmakeOptions.js.map +1 -0
  97. package/dist/bindings/utils/testBindingBinary.d.ts +1 -0
  98. package/dist/bindings/utils/testBindingBinary.js +98 -0
  99. package/dist/bindings/utils/testBindingBinary.js.map +1 -0
  100. package/dist/bindings/utils/testCmakeBinary.d.ts +5 -0
  101. package/dist/bindings/utils/testCmakeBinary.js +32 -0
  102. package/dist/bindings/utils/testCmakeBinary.js.map +1 -0
  103. package/dist/chatWrappers/AlpacaChatWrapper.d.ts +2 -1
  104. package/dist/chatWrappers/AlpacaChatWrapper.js +9 -2
  105. package/dist/chatWrappers/AlpacaChatWrapper.js.map +1 -1
  106. package/dist/chatWrappers/ChatMLChatWrapper.d.ts +5 -0
  107. package/dist/chatWrappers/ChatMLChatWrapper.js +13 -11
  108. package/dist/chatWrappers/ChatMLChatWrapper.js.map +1 -1
  109. package/dist/chatWrappers/FalconChatWrapper.d.ts +2 -1
  110. package/dist/chatWrappers/FalconChatWrapper.js +28 -11
  111. package/dist/chatWrappers/FalconChatWrapper.js.map +1 -1
  112. package/dist/chatWrappers/FunctionaryChatWrapper.js +86 -73
  113. package/dist/chatWrappers/FunctionaryChatWrapper.js.map +1 -1
  114. package/dist/chatWrappers/{LlamaChatWrapper.d.ts → GemmaChatWrapper.d.ts} +6 -1
  115. package/dist/chatWrappers/GemmaChatWrapper.js +88 -0
  116. package/dist/chatWrappers/GemmaChatWrapper.js.map +1 -0
  117. package/dist/chatWrappers/GeneralChatWrapper.d.ts +2 -1
  118. package/dist/chatWrappers/GeneralChatWrapper.js +35 -12
  119. package/dist/chatWrappers/GeneralChatWrapper.js.map +1 -1
  120. package/dist/chatWrappers/Llama2ChatWrapper.d.ts +20 -0
  121. package/dist/chatWrappers/{LlamaChatWrapper.js → Llama2ChatWrapper.js} +29 -11
  122. package/dist/chatWrappers/Llama2ChatWrapper.js.map +1 -0
  123. package/dist/chatWrappers/Llama3ChatWrapper.d.ts +31 -0
  124. package/dist/chatWrappers/Llama3ChatWrapper.js +129 -0
  125. package/dist/chatWrappers/Llama3ChatWrapper.js.map +1 -0
  126. package/dist/chatWrappers/generic/JinjaTemplateChatWrapper.d.ts +73 -0
  127. package/dist/chatWrappers/generic/JinjaTemplateChatWrapper.js +359 -0
  128. package/dist/chatWrappers/generic/JinjaTemplateChatWrapper.js.map +1 -0
  129. package/dist/chatWrappers/generic/TemplateChatWrapper.d.ts +64 -0
  130. package/dist/chatWrappers/generic/TemplateChatWrapper.js +200 -0
  131. package/dist/chatWrappers/generic/TemplateChatWrapper.js.map +1 -0
  132. package/dist/chatWrappers/generic/utils/chatHistoryFunctionCallMessageTemplate.d.ts +33 -0
  133. package/dist/chatWrappers/generic/utils/chatHistoryFunctionCallMessageTemplate.js +45 -0
  134. package/dist/chatWrappers/generic/utils/chatHistoryFunctionCallMessageTemplate.js.map +1 -0
  135. package/dist/chatWrappers/utils/ChatModelFunctionsDocumentationGenerator.d.ts +42 -0
  136. package/dist/chatWrappers/utils/ChatModelFunctionsDocumentationGenerator.js +82 -0
  137. package/dist/chatWrappers/utils/ChatModelFunctionsDocumentationGenerator.js.map +1 -0
  138. package/dist/chatWrappers/utils/isJinjaTemplateEquivalentToSpecializedChatWrapper.d.ts +4 -0
  139. package/dist/chatWrappers/utils/isJinjaTemplateEquivalentToSpecializedChatWrapper.js +206 -0
  140. package/dist/chatWrappers/utils/isJinjaTemplateEquivalentToSpecializedChatWrapper.js.map +1 -0
  141. package/dist/chatWrappers/utils/resolveChatWrapper.d.ts +69 -0
  142. package/dist/chatWrappers/utils/resolveChatWrapper.js +214 -0
  143. package/dist/chatWrappers/utils/resolveChatWrapper.js.map +1 -0
  144. package/dist/cli/cli.js +21 -7
  145. package/dist/cli/cli.js.map +1 -1
  146. package/dist/cli/commands/BuildCommand.d.ts +6 -4
  147. package/dist/cli/commands/BuildCommand.js +103 -41
  148. package/dist/cli/commands/BuildCommand.js.map +1 -1
  149. package/dist/cli/commands/ChatCommand.d.ts +18 -6
  150. package/dist/cli/commands/ChatCommand.js +298 -142
  151. package/dist/cli/commands/ChatCommand.js.map +1 -1
  152. package/dist/cli/commands/ClearCommand.d.ts +1 -1
  153. package/dist/cli/commands/ClearCommand.js +11 -12
  154. package/dist/cli/commands/ClearCommand.js.map +1 -1
  155. package/dist/cli/commands/CompleteCommand.d.ts +29 -0
  156. package/dist/cli/commands/CompleteCommand.js +365 -0
  157. package/dist/cli/commands/CompleteCommand.js.map +1 -0
  158. package/dist/cli/commands/DebugCommand.d.ts +7 -0
  159. package/dist/cli/commands/DebugCommand.js +54 -0
  160. package/dist/cli/commands/DebugCommand.js.map +1 -0
  161. package/dist/cli/commands/DownloadCommand.d.ts +6 -4
  162. package/dist/cli/commands/DownloadCommand.js +120 -69
  163. package/dist/cli/commands/DownloadCommand.js.map +1 -1
  164. package/dist/cli/commands/InfillCommand.d.ts +31 -0
  165. package/dist/cli/commands/InfillCommand.js +401 -0
  166. package/dist/cli/commands/InfillCommand.js.map +1 -0
  167. package/dist/cli/commands/InitCommand.d.ts +11 -0
  168. package/dist/cli/commands/InitCommand.js +195 -0
  169. package/dist/cli/commands/InitCommand.js.map +1 -0
  170. package/dist/cli/commands/OnPostInstallCommand.js +9 -10
  171. package/dist/cli/commands/OnPostInstallCommand.js.map +1 -1
  172. package/dist/cli/commands/PullCommand.d.ts +12 -0
  173. package/dist/cli/commands/PullCommand.js +117 -0
  174. package/dist/cli/commands/PullCommand.js.map +1 -0
  175. package/dist/cli/commands/inspect/InspectCommand.d.ts +4 -0
  176. package/dist/cli/commands/inspect/InspectCommand.js +19 -0
  177. package/dist/cli/commands/inspect/InspectCommand.js.map +1 -0
  178. package/dist/cli/commands/inspect/commands/InspectGgufCommand.d.ts +12 -0
  179. package/dist/cli/commands/inspect/commands/InspectGgufCommand.js +136 -0
  180. package/dist/cli/commands/inspect/commands/InspectGgufCommand.js.map +1 -0
  181. package/dist/cli/commands/inspect/commands/InspectGpuCommand.d.ts +4 -0
  182. package/dist/cli/commands/inspect/commands/InspectGpuCommand.js +138 -0
  183. package/dist/cli/commands/inspect/commands/InspectGpuCommand.js.map +1 -0
  184. package/dist/cli/commands/inspect/commands/InspectMeasureCommand.d.ts +17 -0
  185. package/dist/cli/commands/inspect/commands/InspectMeasureCommand.js +613 -0
  186. package/dist/cli/commands/inspect/commands/InspectMeasureCommand.js.map +1 -0
  187. package/dist/cli/projectTemplates.d.ts +7 -0
  188. package/dist/cli/projectTemplates.js +10 -0
  189. package/dist/cli/projectTemplates.js.map +1 -0
  190. package/dist/cli/recommendedModels.d.ts +2 -0
  191. package/dist/cli/recommendedModels.js +342 -0
  192. package/dist/cli/recommendedModels.js.map +1 -0
  193. package/dist/cli/startCreateCli.d.ts +2 -0
  194. package/dist/cli/startCreateCli.js +26 -0
  195. package/dist/cli/startCreateCli.js.map +1 -0
  196. package/dist/cli/utils/ConsoleInteraction.d.ts +23 -0
  197. package/dist/cli/utils/ConsoleInteraction.js +122 -0
  198. package/dist/cli/utils/ConsoleInteraction.js.map +1 -0
  199. package/dist/cli/utils/ConsoleTable.d.ts +23 -0
  200. package/dist/cli/utils/ConsoleTable.js +86 -0
  201. package/dist/cli/utils/ConsoleTable.js.map +1 -0
  202. package/dist/cli/utils/basicChooseFromListConsoleInteraction.d.ts +13 -0
  203. package/dist/cli/utils/basicChooseFromListConsoleInteraction.js +111 -0
  204. package/dist/cli/utils/basicChooseFromListConsoleInteraction.js.map +1 -0
  205. package/dist/cli/utils/consolePromptQuestion.d.ts +6 -0
  206. package/dist/cli/utils/consolePromptQuestion.js +82 -0
  207. package/dist/cli/utils/consolePromptQuestion.js.map +1 -0
  208. package/dist/cli/utils/getReadablePath.d.ts +1 -0
  209. package/dist/cli/utils/getReadablePath.js +14 -0
  210. package/dist/cli/utils/getReadablePath.js.map +1 -0
  211. package/dist/cli/utils/interactivelyAskForModel.d.ts +7 -0
  212. package/dist/cli/utils/interactivelyAskForModel.js +451 -0
  213. package/dist/cli/utils/interactivelyAskForModel.js.map +1 -0
  214. package/dist/cli/utils/logUsedGpuTypeOption.d.ts +2 -0
  215. package/dist/cli/utils/logUsedGpuTypeOption.js +9 -0
  216. package/dist/cli/utils/logUsedGpuTypeOption.js.map +1 -0
  217. package/dist/cli/utils/printCommonInfoLines.d.ts +9 -0
  218. package/dist/cli/utils/printCommonInfoLines.js +71 -0
  219. package/dist/cli/utils/printCommonInfoLines.js.map +1 -0
  220. package/dist/cli/utils/printInfoLine.d.ts +12 -0
  221. package/dist/cli/utils/printInfoLine.js +54 -0
  222. package/dist/cli/utils/printInfoLine.js.map +1 -0
  223. package/dist/cli/utils/projectTemplates.d.ts +19 -0
  224. package/dist/cli/utils/projectTemplates.js +47 -0
  225. package/dist/cli/utils/projectTemplates.js.map +1 -0
  226. package/dist/cli/utils/resolveCommandGgufPath.d.ts +4 -0
  227. package/dist/cli/utils/resolveCommandGgufPath.js +71 -0
  228. package/dist/cli/utils/resolveCommandGgufPath.js.map +1 -0
  229. package/dist/cli/utils/resolveHeaderFlag.d.ts +1 -0
  230. package/dist/cli/utils/resolveHeaderFlag.js +21 -0
  231. package/dist/cli/utils/resolveHeaderFlag.js.map +1 -0
  232. package/dist/cli/utils/resolveModelRecommendationFileOptions.d.ts +19 -0
  233. package/dist/cli/utils/resolveModelRecommendationFileOptions.js +7 -0
  234. package/dist/cli/utils/resolveModelRecommendationFileOptions.js.map +1 -0
  235. package/dist/cli/utils/splitAnsiToLines.d.ts +1 -0
  236. package/dist/cli/utils/splitAnsiToLines.js +32 -0
  237. package/dist/cli/utils/splitAnsiToLines.js.map +1 -0
  238. package/dist/cli/utils/withCliCommandDescriptionDocsUrl.d.ts +2 -0
  239. package/dist/cli/utils/withCliCommandDescriptionDocsUrl.js +23 -0
  240. package/dist/cli/utils/withCliCommandDescriptionDocsUrl.js.map +1 -0
  241. package/dist/commands.d.ts +1 -0
  242. package/dist/commands.js +3 -0
  243. package/dist/commands.js.map +1 -1
  244. package/dist/config.d.ts +38 -5
  245. package/dist/config.js +61 -16
  246. package/dist/config.js.map +1 -1
  247. package/dist/consts.d.ts +3 -0
  248. package/dist/consts.js +10 -0
  249. package/dist/consts.js.map +1 -0
  250. package/dist/{llamaEvaluator → evaluator}/LlamaChat/LlamaChat.d.ts +37 -35
  251. package/dist/{llamaEvaluator → evaluator}/LlamaChat/LlamaChat.js +298 -221
  252. package/dist/evaluator/LlamaChat/LlamaChat.js.map +1 -0
  253. package/dist/{llamaEvaluator → evaluator}/LlamaChat/utils/FunctionCallGrammar.d.ts +2 -1
  254. package/dist/{llamaEvaluator → evaluator}/LlamaChat/utils/FunctionCallGrammar.js +5 -3
  255. package/dist/evaluator/LlamaChat/utils/FunctionCallGrammar.js.map +1 -0
  256. package/dist/{llamaEvaluator → evaluator}/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.js +18 -0
  257. package/dist/evaluator/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.js.map +1 -0
  258. package/dist/{llamaEvaluator → evaluator}/LlamaChatSession/LlamaChatSession.d.ts +40 -3
  259. package/dist/{llamaEvaluator → evaluator}/LlamaChatSession/LlamaChatSession.js +28 -7
  260. package/dist/evaluator/LlamaChatSession/LlamaChatSession.js.map +1 -0
  261. package/dist/{llamaEvaluator → evaluator}/LlamaChatSession/utils/defineChatSessionFunction.d.ts +3 -0
  262. package/dist/{llamaEvaluator → evaluator}/LlamaChatSession/utils/defineChatSessionFunction.js +3 -0
  263. package/dist/evaluator/LlamaChatSession/utils/defineChatSessionFunction.js.map +1 -0
  264. package/dist/evaluator/LlamaCompletion.d.ts +155 -0
  265. package/dist/evaluator/LlamaCompletion.js +405 -0
  266. package/dist/evaluator/LlamaCompletion.js.map +1 -0
  267. package/dist/{llamaEvaluator → evaluator}/LlamaContext/LlamaContext.d.ts +41 -20
  268. package/dist/{llamaEvaluator → evaluator}/LlamaContext/LlamaContext.js +271 -81
  269. package/dist/evaluator/LlamaContext/LlamaContext.js.map +1 -0
  270. package/dist/evaluator/LlamaContext/types.d.ts +140 -0
  271. package/dist/evaluator/LlamaContext/types.js.map +1 -0
  272. package/dist/evaluator/LlamaContext/utils/batchItemsPrioritizationStrategies/firstInFirstOutStrategy.js.map +1 -0
  273. package/dist/evaluator/LlamaContext/utils/batchItemsPrioritizationStrategies/maximumParallelismStrategy.js.map +1 -0
  274. package/dist/evaluator/LlamaContext/utils/resolveBatchItemsPrioritizationStrategy.d.ts +2 -0
  275. package/dist/{llamaEvaluator/LlamaContext/utils/resolveBatchItemsPrioritizingStrategy.js → evaluator/LlamaContext/utils/resolveBatchItemsPrioritizationStrategy.js} +4 -4
  276. package/dist/evaluator/LlamaContext/utils/resolveBatchItemsPrioritizationStrategy.js.map +1 -0
  277. package/dist/evaluator/LlamaEmbeddingContext.d.ts +51 -0
  278. package/dist/evaluator/LlamaEmbeddingContext.js +73 -0
  279. package/dist/evaluator/LlamaEmbeddingContext.js.map +1 -0
  280. package/dist/{llamaEvaluator → evaluator}/LlamaGrammar.d.ts +8 -5
  281. package/dist/{llamaEvaluator → evaluator}/LlamaGrammar.js +13 -10
  282. package/dist/evaluator/LlamaGrammar.js.map +1 -0
  283. package/dist/{llamaEvaluator → evaluator}/LlamaGrammarEvaluationState.js +4 -4
  284. package/dist/evaluator/LlamaGrammarEvaluationState.js.map +1 -0
  285. package/dist/{llamaEvaluator → evaluator}/LlamaJsonSchemaGrammar.d.ts +2 -1
  286. package/dist/{llamaEvaluator → evaluator}/LlamaJsonSchemaGrammar.js +3 -3
  287. package/dist/evaluator/LlamaJsonSchemaGrammar.js.map +1 -0
  288. package/dist/evaluator/LlamaModel.d.ts +230 -0
  289. package/dist/evaluator/LlamaModel.js +597 -0
  290. package/dist/evaluator/LlamaModel.js.map +1 -0
  291. package/dist/evaluator/TokenBias.d.ts +22 -0
  292. package/dist/evaluator/TokenBias.js +33 -0
  293. package/dist/evaluator/TokenBias.js.map +1 -0
  294. package/dist/evaluator/TokenMeter.d.ts +54 -0
  295. package/dist/evaluator/TokenMeter.js +86 -0
  296. package/dist/evaluator/TokenMeter.js.map +1 -0
  297. package/dist/gguf/consts.d.ts +3 -0
  298. package/dist/gguf/consts.js +8 -0
  299. package/dist/gguf/consts.js.map +1 -0
  300. package/dist/gguf/errors/InvalidGgufMagicError.d.ts +3 -0
  301. package/dist/gguf/errors/InvalidGgufMagicError.js +6 -0
  302. package/dist/gguf/errors/InvalidGgufMagicError.js.map +1 -0
  303. package/dist/gguf/errors/UnsupportedGgufValueTypeError.d.ts +4 -0
  304. package/dist/gguf/errors/UnsupportedGgufValueTypeError.js +9 -0
  305. package/dist/gguf/errors/UnsupportedGgufValueTypeError.js.map +1 -0
  306. package/dist/gguf/fileReaders/GgufFileReader.d.ts +33 -0
  307. package/dist/gguf/fileReaders/GgufFileReader.js +76 -0
  308. package/dist/gguf/fileReaders/GgufFileReader.js.map +1 -0
  309. package/dist/gguf/fileReaders/GgufFsFileReader.d.ts +17 -0
  310. package/dist/gguf/fileReaders/GgufFsFileReader.js +45 -0
  311. package/dist/gguf/fileReaders/GgufFsFileReader.js.map +1 -0
  312. package/dist/gguf/fileReaders/GgufNetworkFetchFileReader.d.ts +22 -0
  313. package/dist/gguf/fileReaders/GgufNetworkFetchFileReader.js +63 -0
  314. package/dist/gguf/fileReaders/GgufNetworkFetchFileReader.js.map +1 -0
  315. package/dist/gguf/insights/GgufInsights.d.ts +42 -0
  316. package/dist/gguf/insights/GgufInsights.js +361 -0
  317. package/dist/gguf/insights/GgufInsights.js.map +1 -0
  318. package/dist/gguf/insights/GgufInsightsConfigurationResolver.d.ts +87 -0
  319. package/dist/gguf/insights/GgufInsightsConfigurationResolver.js +136 -0
  320. package/dist/gguf/insights/GgufInsightsConfigurationResolver.js.map +1 -0
  321. package/dist/gguf/insights/utils/resolveContextContextSizeOption.d.ts +18 -0
  322. package/dist/gguf/insights/utils/resolveContextContextSizeOption.js +76 -0
  323. package/dist/gguf/insights/utils/resolveContextContextSizeOption.js.map +1 -0
  324. package/dist/gguf/insights/utils/resolveModelGpuLayersOption.d.ts +14 -0
  325. package/dist/gguf/insights/utils/resolveModelGpuLayersOption.js +177 -0
  326. package/dist/gguf/insights/utils/resolveModelGpuLayersOption.js.map +1 -0
  327. package/dist/gguf/insights/utils/scoreLevels.d.ts +5 -0
  328. package/dist/gguf/insights/utils/scoreLevels.js +16 -0
  329. package/dist/gguf/insights/utils/scoreLevels.js.map +1 -0
  330. package/dist/gguf/parser/GgufV2Parser.d.ts +19 -0
  331. package/dist/gguf/parser/GgufV2Parser.js +115 -0
  332. package/dist/gguf/parser/GgufV2Parser.js.map +1 -0
  333. package/dist/gguf/parser/GgufV3Parser.d.ts +3 -0
  334. package/dist/gguf/parser/GgufV3Parser.js +4 -0
  335. package/dist/gguf/parser/GgufV3Parser.js.map +1 -0
  336. package/dist/gguf/parser/parseGguf.d.ts +8 -0
  337. package/dist/gguf/parser/parseGguf.js +63 -0
  338. package/dist/gguf/parser/parseGguf.js.map +1 -0
  339. package/dist/gguf/readGgufFileInfo.d.ts +33 -0
  340. package/dist/gguf/readGgufFileInfo.js +66 -0
  341. package/dist/gguf/readGgufFileInfo.js.map +1 -0
  342. package/dist/gguf/types/GgufFileInfoTypes.d.ts +84 -0
  343. package/dist/gguf/types/GgufFileInfoTypes.js +18 -0
  344. package/dist/gguf/types/GgufFileInfoTypes.js.map +1 -0
  345. package/dist/gguf/types/GgufMetadataTypes.d.ts +334 -0
  346. package/dist/gguf/types/GgufMetadataTypes.js +86 -0
  347. package/dist/gguf/types/GgufMetadataTypes.js.map +1 -0
  348. package/dist/gguf/types/GgufTensorInfoTypes.d.ts +37 -0
  349. package/dist/gguf/types/GgufTensorInfoTypes.js +33 -0
  350. package/dist/gguf/types/GgufTensorInfoTypes.js.map +1 -0
  351. package/dist/gguf/utils/GgufReadOffset.d.ts +6 -0
  352. package/dist/gguf/utils/GgufReadOffset.js +18 -0
  353. package/dist/gguf/utils/GgufReadOffset.js.map +1 -0
  354. package/dist/gguf/utils/convertMetadataKeyValueRecordToNestedObject.d.ts +5 -0
  355. package/dist/gguf/utils/convertMetadataKeyValueRecordToNestedObject.js +38 -0
  356. package/dist/gguf/utils/convertMetadataKeyValueRecordToNestedObject.js.map +1 -0
  357. package/dist/gguf/utils/getGgufFileTypeName.d.ts +4 -0
  358. package/dist/gguf/utils/getGgufFileTypeName.js +13 -0
  359. package/dist/gguf/utils/getGgufFileTypeName.js.map +1 -0
  360. package/dist/gguf/utils/getGgufMetadataArchitectureData.d.ts +3 -0
  361. package/dist/gguf/utils/getGgufMetadataArchitectureData.js +4 -0
  362. package/dist/gguf/utils/getGgufMetadataArchitectureData.js.map +1 -0
  363. package/dist/gguf/utils/normalizeGgufDownloadUrl.d.ts +1 -0
  364. package/dist/gguf/utils/normalizeGgufDownloadUrl.js +16 -0
  365. package/dist/gguf/utils/normalizeGgufDownloadUrl.js.map +1 -0
  366. package/dist/gguf/utils/resolveBinarySplitGgufPartUrls.d.ts +2 -0
  367. package/dist/gguf/utils/resolveBinarySplitGgufPartUrls.js +39 -0
  368. package/dist/gguf/utils/resolveBinarySplitGgufPartUrls.js.map +1 -0
  369. package/dist/gguf/utils/resolveSplitGgufParts.d.ts +7 -0
  370. package/dist/gguf/utils/resolveSplitGgufParts.js +55 -0
  371. package/dist/gguf/utils/resolveSplitGgufParts.js.map +1 -0
  372. package/dist/index.d.ts +37 -17
  373. package/dist/index.js +33 -14
  374. package/dist/index.js.map +1 -1
  375. package/dist/state.d.ts +4 -0
  376. package/dist/state.js +14 -0
  377. package/dist/state.js.map +1 -1
  378. package/dist/types.d.ts +53 -2
  379. package/dist/types.js.map +1 -1
  380. package/dist/utils/DisposeGuard.d.ts +13 -0
  381. package/dist/utils/DisposeGuard.js +120 -0
  382. package/dist/utils/DisposeGuard.js.map +1 -0
  383. package/dist/utils/InsufficientMemoryError.d.ts +3 -0
  384. package/dist/utils/InsufficientMemoryError.js +6 -0
  385. package/dist/utils/InsufficientMemoryError.js.map +1 -0
  386. package/dist/utils/LlamaText.d.ts +50 -25
  387. package/dist/utils/LlamaText.js +367 -155
  388. package/dist/utils/LlamaText.js.map +1 -1
  389. package/dist/utils/StopGenerationDetector.d.ts +1 -1
  390. package/dist/utils/StopGenerationDetector.js +23 -18
  391. package/dist/utils/StopGenerationDetector.js.map +1 -1
  392. package/dist/utils/TokenStreamRegulator.d.ts +8 -4
  393. package/dist/utils/TokenStreamRegulator.js +78 -8
  394. package/dist/utils/TokenStreamRegulator.js.map +1 -1
  395. package/dist/utils/UnsupportedError.d.ts +2 -0
  396. package/dist/utils/UnsupportedError.js +7 -0
  397. package/dist/utils/UnsupportedError.js.map +1 -0
  398. package/dist/utils/cmake.js +38 -20
  399. package/dist/utils/cmake.js.map +1 -1
  400. package/dist/utils/createModelDownloader.d.ts +102 -0
  401. package/dist/utils/createModelDownloader.js +226 -0
  402. package/dist/utils/createModelDownloader.js.map +1 -0
  403. package/dist/utils/findBestOption.d.ts +4 -0
  404. package/dist/utils/findBestOption.js +15 -0
  405. package/dist/utils/findBestOption.js.map +1 -0
  406. package/dist/utils/findCharacterRemovalCountToFitChatHistoryInContext.js +18 -8
  407. package/dist/utils/findCharacterRemovalCountToFitChatHistoryInContext.js.map +1 -1
  408. package/dist/utils/gbnfJson/getGbnfGrammarForGbnfJsonSchema.d.ts +5 -0
  409. package/dist/utils/gbnfJson/getGbnfGrammarForGbnfJsonSchema.js +11 -0
  410. package/dist/utils/gbnfJson/getGbnfGrammarForGbnfJsonSchema.js.map +1 -0
  411. package/dist/utils/gbnfJson/terminals/GbnfArray.d.ts +3 -1
  412. package/dist/utils/gbnfJson/terminals/GbnfArray.js +10 -5
  413. package/dist/utils/gbnfJson/terminals/GbnfArray.js.map +1 -1
  414. package/dist/utils/gbnfJson/terminals/GbnfBoolean.d.ts +1 -1
  415. package/dist/utils/gbnfJson/terminals/GbnfBoolean.js.map +1 -1
  416. package/dist/utils/gbnfJson/terminals/GbnfBooleanValue.js.map +1 -1
  417. package/dist/utils/gbnfJson/terminals/GbnfGrammar.js.map +1 -1
  418. package/dist/utils/gbnfJson/terminals/GbnfNull.d.ts +1 -1
  419. package/dist/utils/gbnfJson/terminals/GbnfNull.js.map +1 -1
  420. package/dist/utils/gbnfJson/terminals/GbnfNumber.d.ts +1 -1
  421. package/dist/utils/gbnfJson/terminals/GbnfNumber.js.map +1 -1
  422. package/dist/utils/gbnfJson/terminals/GbnfNumberValue.js.map +1 -1
  423. package/dist/utils/gbnfJson/terminals/GbnfObjectMap.d.ts +3 -1
  424. package/dist/utils/gbnfJson/terminals/GbnfObjectMap.js +9 -4
  425. package/dist/utils/gbnfJson/terminals/GbnfObjectMap.js.map +1 -1
  426. package/dist/utils/gbnfJson/terminals/GbnfOr.js.map +1 -1
  427. package/dist/utils/gbnfJson/terminals/GbnfRepetition.d.ts +9 -0
  428. package/dist/utils/gbnfJson/terminals/GbnfRepetition.js +37 -0
  429. package/dist/utils/gbnfJson/terminals/GbnfRepetition.js.map +1 -0
  430. package/dist/utils/gbnfJson/terminals/GbnfString.d.ts +1 -1
  431. package/dist/utils/gbnfJson/terminals/GbnfString.js +23 -5
  432. package/dist/utils/gbnfJson/terminals/GbnfString.js.map +1 -1
  433. package/dist/utils/gbnfJson/terminals/GbnfStringValue.js.map +1 -1
  434. package/dist/utils/gbnfJson/terminals/GbnfVerbatimText.js.map +1 -1
  435. package/dist/utils/gbnfJson/terminals/GbnfWhitespace.d.ts +7 -4
  436. package/dist/utils/gbnfJson/terminals/GbnfWhitespace.js +37 -9
  437. package/dist/utils/gbnfJson/terminals/GbnfWhitespace.js.map +1 -1
  438. package/dist/utils/gbnfJson/terminals/gbnfConsts.d.ts +5 -4
  439. package/dist/utils/gbnfJson/terminals/gbnfConsts.js +14 -3
  440. package/dist/utils/gbnfJson/terminals/gbnfConsts.js.map +1 -1
  441. package/dist/utils/gbnfJson/utils/GbnfJsonScopeState.d.ts +10 -0
  442. package/dist/utils/gbnfJson/utils/GbnfJsonScopeState.js +15 -0
  443. package/dist/utils/gbnfJson/utils/GbnfJsonScopeState.js.map +1 -0
  444. package/dist/utils/gbnfJson/utils/getGbnfJsonTerminalForGbnfJsonSchema.d.ts +2 -1
  445. package/dist/utils/gbnfJson/utils/getGbnfJsonTerminalForGbnfJsonSchema.js +6 -5
  446. package/dist/utils/gbnfJson/utils/getGbnfJsonTerminalForGbnfJsonSchema.js.map +1 -1
  447. package/dist/utils/getBuildDefaults.d.ts +1 -2
  448. package/dist/utils/getBuildDefaults.js +2 -3
  449. package/dist/utils/getBuildDefaults.js.map +1 -1
  450. package/dist/utils/getConsoleLogPrefix.d.ts +1 -0
  451. package/dist/utils/getConsoleLogPrefix.js +10 -0
  452. package/dist/utils/getConsoleLogPrefix.js.map +1 -0
  453. package/dist/utils/getGrammarsFolder.d.ts +2 -1
  454. package/dist/utils/getGrammarsFolder.js +8 -7
  455. package/dist/utils/getGrammarsFolder.js.map +1 -1
  456. package/dist/utils/getModuleVersion.d.ts +1 -0
  457. package/dist/utils/getModuleVersion.js +13 -0
  458. package/dist/utils/getModuleVersion.js.map +1 -0
  459. package/dist/utils/getQueuedTokensBeforeStopTrigger.d.ts +6 -0
  460. package/dist/utils/getQueuedTokensBeforeStopTrigger.js +22 -0
  461. package/dist/utils/getQueuedTokensBeforeStopTrigger.js.map +1 -0
  462. package/dist/utils/getReadableContextSize.d.ts +1 -0
  463. package/dist/utils/getReadableContextSize.js +7 -0
  464. package/dist/utils/getReadableContextSize.js.map +1 -0
  465. package/dist/utils/getTypeScriptTypeStringForGbnfJsonSchema.js +15 -11
  466. package/dist/utils/getTypeScriptTypeStringForGbnfJsonSchema.js.map +1 -1
  467. package/dist/utils/gitReleaseBundles.js +73 -5
  468. package/dist/utils/gitReleaseBundles.js.map +1 -1
  469. package/dist/utils/hashString.d.ts +1 -0
  470. package/dist/utils/hashString.js +8 -0
  471. package/dist/utils/hashString.js.map +1 -0
  472. package/dist/utils/isLockfileActive.d.ts +4 -0
  473. package/dist/utils/isLockfileActive.js +12 -0
  474. package/dist/utils/isLockfileActive.js.map +1 -0
  475. package/dist/utils/isToken.d.ts +2 -0
  476. package/dist/utils/isToken.js +4 -0
  477. package/dist/utils/isToken.js.map +1 -0
  478. package/dist/utils/isUrl.d.ts +1 -0
  479. package/dist/utils/isUrl.js +15 -0
  480. package/dist/utils/isUrl.js.map +1 -0
  481. package/dist/utils/mergeUnionTypes.d.ts +10 -0
  482. package/dist/utils/mergeUnionTypes.js +2 -0
  483. package/dist/utils/mergeUnionTypes.js.map +1 -0
  484. package/dist/utils/parseModelFileName.d.ts +1 -0
  485. package/dist/utils/parseModelFileName.js +6 -1
  486. package/dist/utils/parseModelFileName.js.map +1 -1
  487. package/dist/utils/parseTextTemplate.d.ts +66 -0
  488. package/dist/utils/parseTextTemplate.js +116 -0
  489. package/dist/utils/parseTextTemplate.js.map +1 -0
  490. package/dist/utils/prettyPrintObject.d.ts +10 -0
  491. package/dist/utils/prettyPrintObject.js +84 -0
  492. package/dist/utils/prettyPrintObject.js.map +1 -0
  493. package/dist/utils/removeNullFields.d.ts +2 -1
  494. package/dist/utils/removeNullFields.js +8 -0
  495. package/dist/utils/removeNullFields.js.map +1 -1
  496. package/dist/utils/resolveGithubRelease.d.ts +2 -0
  497. package/dist/utils/resolveGithubRelease.js +36 -0
  498. package/dist/utils/resolveGithubRelease.js.map +1 -0
  499. package/dist/utils/runtime.d.ts +4 -0
  500. package/dist/utils/runtime.js +8 -0
  501. package/dist/utils/runtime.js.map +1 -0
  502. package/dist/utils/spawnCommand.d.ts +11 -1
  503. package/dist/utils/spawnCommand.js +56 -6
  504. package/dist/utils/spawnCommand.js.map +1 -1
  505. package/dist/utils/tokenizeInput.d.ts +3 -0
  506. package/dist/utils/tokenizeInput.js +12 -0
  507. package/dist/utils/tokenizeInput.js.map +1 -0
  508. package/dist/utils/utilTypes.d.ts +3 -0
  509. package/dist/utils/utilTypes.js +2 -0
  510. package/dist/utils/utilTypes.js.map +1 -0
  511. package/dist/utils/waitForLockfileRelease.d.ts +5 -0
  512. package/dist/utils/waitForLockfileRelease.js +20 -0
  513. package/dist/utils/waitForLockfileRelease.js.map +1 -0
  514. package/dist/utils/withLockfile.d.ts +7 -0
  515. package/dist/utils/withLockfile.js +44 -0
  516. package/dist/utils/withLockfile.js.map +1 -0
  517. package/dist/utils/withOra.d.ts +2 -0
  518. package/dist/utils/withOra.js +22 -6
  519. package/dist/utils/withOra.js.map +1 -1
  520. package/dist/utils/withProgressLog.d.ts +23 -0
  521. package/dist/utils/withProgressLog.js +211 -0
  522. package/dist/utils/withProgressLog.js.map +1 -0
  523. package/dist/utils/withStatusLogs.d.ts +2 -1
  524. package/dist/utils/withStatusLogs.js +12 -9
  525. package/dist/utils/withStatusLogs.js.map +1 -1
  526. package/llama/.clang-format +1 -2
  527. package/llama/CMakeLists.txt +115 -4
  528. package/llama/addon.cpp +1318 -99
  529. package/llama/binariesGithubRelease.json +1 -1
  530. package/llama/gitRelease.bundle +0 -0
  531. package/llama/gpuInfo/cuda-gpu-info.cu +120 -0
  532. package/llama/gpuInfo/cuda-gpu-info.h +10 -0
  533. package/llama/gpuInfo/metal-gpu-info.h +8 -0
  534. package/llama/gpuInfo/metal-gpu-info.mm +30 -0
  535. package/llama/gpuInfo/vulkan-gpu-info.cpp +83 -0
  536. package/llama/gpuInfo/vulkan-gpu-info.h +9 -0
  537. package/llama/grammars/README.md +11 -1
  538. package/llama/grammars/json.gbnf +1 -1
  539. package/llama/grammars/json_arr.gbnf +1 -1
  540. package/llama/llama.cpp.info.json +4 -0
  541. package/llama/toolchains/win32.host-x64.target-arm64.cmake +41 -0
  542. package/llamaBins/linux-arm64/_nlcBuildMetadata.json +1 -0
  543. package/llamaBins/linux-arm64/llama-addon.node +0 -0
  544. package/llamaBins/linux-armv7l/_nlcBuildMetadata.json +1 -0
  545. package/llamaBins/linux-armv7l/llama-addon.node +0 -0
  546. package/llamaBins/linux-x64/_nlcBuildMetadata.json +1 -0
  547. package/llamaBins/linux-x64/llama-addon.node +0 -0
  548. package/llamaBins/linux-x64-cuda/_nlcBuildMetadata.json +1 -0
  549. package/llamaBins/linux-x64-cuda/llama-addon.node +0 -0
  550. package/llamaBins/linux-x64-vulkan/_nlcBuildMetadata.json +1 -0
  551. package/llamaBins/linux-x64-vulkan/llama-addon.node +0 -0
  552. package/llamaBins/mac-arm64-metal/_nlcBuildMetadata.json +1 -0
  553. package/llamaBins/mac-arm64-metal/default.metallib +0 -0
  554. package/llamaBins/mac-arm64-metal/llama-addon.node +0 -0
  555. package/llamaBins/mac-x64/_nlcBuildMetadata.json +1 -0
  556. package/llamaBins/mac-x64/llama-addon.node +0 -0
  557. package/llamaBins/win-arm64/_nlcBuildMetadata.json +1 -0
  558. package/llamaBins/win-arm64/llama-addon.exp +0 -0
  559. package/llamaBins/win-arm64/llama-addon.lib +0 -0
  560. package/llamaBins/win-arm64/llama-addon.node +0 -0
  561. package/llamaBins/win-x64/_nlcBuildMetadata.json +1 -0
  562. package/llamaBins/win-x64/llama-addon.exp +0 -0
  563. package/llamaBins/win-x64/llama-addon.lib +0 -0
  564. package/llamaBins/win-x64/llama-addon.node +0 -0
  565. package/llamaBins/win-x64-cuda/_nlcBuildMetadata.json +1 -0
  566. package/llamaBins/win-x64-cuda/llama-addon.exp +0 -0
  567. package/llamaBins/win-x64-cuda/llama-addon.lib +0 -0
  568. package/llamaBins/win-x64-cuda/llama-addon.node +0 -0
  569. package/llamaBins/win-x64-vulkan/_nlcBuildMetadata.json +1 -0
  570. package/llamaBins/win-x64-vulkan/llama-addon.exp +0 -0
  571. package/llamaBins/win-x64-vulkan/llama-addon.lib +0 -0
  572. package/llamaBins/win-x64-vulkan/llama-addon.node +0 -0
  573. package/package.json +61 -34
  574. package/templates/packed/electron-typescript-react.json +1 -0
  575. package/templates/packed/node-typescript.json +1 -0
  576. package/templates/packed/node_modules.json +1 -0
  577. package/dist/AbortError.d.ts +0 -2
  578. package/dist/AbortError.js +0 -7
  579. package/dist/AbortError.js.map +0 -1
  580. package/dist/chatWrappers/LlamaChatWrapper.js.map +0 -1
  581. package/dist/chatWrappers/resolveChatWrapperBasedOnModel.d.ts +0 -13
  582. package/dist/chatWrappers/resolveChatWrapperBasedOnModel.js +0 -55
  583. package/dist/chatWrappers/resolveChatWrapperBasedOnModel.js.map +0 -1
  584. package/dist/llamaEvaluator/LlamaBins.d.ts +0 -18
  585. package/dist/llamaEvaluator/LlamaBins.js +0 -5
  586. package/dist/llamaEvaluator/LlamaBins.js.map +0 -1
  587. package/dist/llamaEvaluator/LlamaChat/LlamaChat.js.map +0 -1
  588. package/dist/llamaEvaluator/LlamaChat/utils/FunctionCallGrammar.js.map +0 -1
  589. package/dist/llamaEvaluator/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.js.map +0 -1
  590. package/dist/llamaEvaluator/LlamaChatSession/LlamaChatSession.js.map +0 -1
  591. package/dist/llamaEvaluator/LlamaChatSession/utils/defineChatSessionFunction.js.map +0 -1
  592. package/dist/llamaEvaluator/LlamaContext/LlamaContext.js.map +0 -1
  593. package/dist/llamaEvaluator/LlamaContext/types.d.ts +0 -86
  594. package/dist/llamaEvaluator/LlamaContext/types.js.map +0 -1
  595. package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/firstInFirstOutStrategy.js.map +0 -1
  596. package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/maximumParallelismStrategy.js.map +0 -1
  597. package/dist/llamaEvaluator/LlamaContext/utils/resolveBatchItemsPrioritizingStrategy.d.ts +0 -2
  598. package/dist/llamaEvaluator/LlamaContext/utils/resolveBatchItemsPrioritizingStrategy.js.map +0 -1
  599. package/dist/llamaEvaluator/LlamaGrammar.js.map +0 -1
  600. package/dist/llamaEvaluator/LlamaGrammarEvaluationState.js.map +0 -1
  601. package/dist/llamaEvaluator/LlamaJsonSchemaGrammar.js.map +0 -1
  602. package/dist/llamaEvaluator/LlamaModel.d.ts +0 -119
  603. package/dist/llamaEvaluator/LlamaModel.js +0 -322
  604. package/dist/llamaEvaluator/LlamaModel.js.map +0 -1
  605. package/dist/utils/binariesGithubRelease.js.map +0 -1
  606. package/dist/utils/clearLlamaBuild.d.ts +0 -1
  607. package/dist/utils/clearLlamaBuild.js +0 -12
  608. package/dist/utils/clearLlamaBuild.js.map +0 -1
  609. package/dist/utils/cloneLlamaCppRepo.d.ts +0 -2
  610. package/dist/utils/cloneLlamaCppRepo.js +0 -102
  611. package/dist/utils/cloneLlamaCppRepo.js.map +0 -1
  612. package/dist/utils/compileLLamaCpp.d.ts +0 -8
  613. package/dist/utils/compileLLamaCpp.js +0 -132
  614. package/dist/utils/compileLLamaCpp.js.map +0 -1
  615. package/dist/utils/getBin.js +0 -78
  616. package/dist/utils/getBin.js.map +0 -1
  617. package/dist/utils/getGbnfGrammarForGbnfJsonSchema.d.ts +0 -2
  618. package/dist/utils/getGbnfGrammarForGbnfJsonSchema.js +0 -9
  619. package/dist/utils/getGbnfGrammarForGbnfJsonSchema.js.map +0 -1
  620. package/dist/utils/getReleaseInfo.d.ts +0 -7
  621. package/dist/utils/getReleaseInfo.js +0 -30
  622. package/dist/utils/getReleaseInfo.js.map +0 -1
  623. package/dist/utils/parseModelTypeDescription.d.ts +0 -6
  624. package/dist/utils/parseModelTypeDescription.js +0 -9
  625. package/dist/utils/parseModelTypeDescription.js.map +0 -1
  626. package/dist/utils/resolveChatWrapper.d.ts +0 -4
  627. package/dist/utils/resolveChatWrapper.js +0 -16
  628. package/dist/utils/resolveChatWrapper.js.map +0 -1
  629. package/dist/utils/usedBinFlag.d.ts +0 -6
  630. package/dist/utils/usedBinFlag.js +0 -15
  631. package/dist/utils/usedBinFlag.js.map +0 -1
  632. package/llama/usedBin.json +0 -3
  633. package/llamaBins/mac-arm64/llama-addon.node +0 -0
  634. /package/dist/{utils → bindings/utils}/binariesGithubRelease.d.ts +0 -0
  635. /package/dist/{llamaEvaluator → evaluator}/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.d.ts +0 -0
  636. /package/dist/{llamaEvaluator → evaluator}/LlamaContext/types.js +0 -0
  637. /package/dist/{llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies → evaluator/LlamaContext/utils/batchItemsPrioritizationStrategies}/firstInFirstOutStrategy.d.ts +0 -0
  638. /package/dist/{llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies → evaluator/LlamaContext/utils/batchItemsPrioritizationStrategies}/firstInFirstOutStrategy.js +0 -0
  639. /package/dist/{llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies → evaluator/LlamaContext/utils/batchItemsPrioritizationStrategies}/maximumParallelismStrategy.d.ts +0 -0
  640. /package/dist/{llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies → evaluator/LlamaContext/utils/batchItemsPrioritizationStrategies}/maximumParallelismStrategy.js +0 -0
  641. /package/dist/{llamaEvaluator → evaluator}/LlamaGrammarEvaluationState.d.ts +0 -0
@@ -0,0 +1,33 @@
1
+ export declare function parseFunctionCallMessageTemplate(template?: ChatHistoryFunctionCallMessageTemplate): {
2
+ call: {
3
+ optionalPrefixSpace: boolean;
4
+ prefix: string;
5
+ paramsPrefix: string;
6
+ suffix: string;
7
+ };
8
+ result: {
9
+ prefix: string;
10
+ suffix: string;
11
+ };
12
+ } | null;
13
+ /**
14
+ * Template format for how functions can be called by the model and how their results are fed to the model after the function call.
15
+ * Consists of an array with two elements:
16
+ * 1. The function call template.
17
+ * 2. The function call result template.
18
+ *
19
+ * For example:
20
+ * ```typescript
21
+ * const template: ChatHistoryFunctionCallMessageTemplate = [
22
+ * "[[call: {{functionName}}({{functionParams}})]]"
23
+ * " [[result: {{functionCallResult}}]]"
24
+ * ];
25
+ * ```
26
+ *
27
+ * It's mandatory for the call template to have text before `{{functionName}}` in order for the chat wrapper know when
28
+ * to activate the function calling grammar.
29
+ */
30
+ export type ChatHistoryFunctionCallMessageTemplate = [
31
+ call: `${string}{{functionName}}${string}{{functionParams}}${string}`,
32
+ result: `${string}{{functionCallResult}}${string}`
33
+ ];
@@ -0,0 +1,45 @@
1
+ import { parseTextTemplate } from "../../../utils/parseTextTemplate.js";
2
+ export function parseFunctionCallMessageTemplate(template) {
3
+ if (template == null)
4
+ return null;
5
+ const [functionCallTemplate, functionCallResultTemplate] = template;
6
+ if (functionCallTemplate == null || functionCallResultTemplate == null)
7
+ throw new Error("Both function call and function call result templates are required");
8
+ const parsedFunctionCallTemplate = parseTextTemplate(functionCallTemplate, [{
9
+ text: "{{functionName}}",
10
+ key: "functionName"
11
+ }, {
12
+ text: "{{functionParams}}",
13
+ key: "functionParams"
14
+ }]);
15
+ const parsedFunctionCallResultTemplate = parseTextTemplate(functionCallResultTemplate, [{
16
+ text: "{{functionCallResult}}",
17
+ key: "functionCallResult"
18
+ }]);
19
+ const callPrefix = parsedFunctionCallTemplate.functionName.prefix;
20
+ const callParamsPrefix = parsedFunctionCallTemplate.functionParams.prefix;
21
+ const callSuffix = parsedFunctionCallTemplate.functionParams.suffix;
22
+ const resultPrefix = parsedFunctionCallResultTemplate.functionCallResult.prefix;
23
+ const resultSuffix = parsedFunctionCallResultTemplate.functionCallResult.suffix;
24
+ if (callPrefix.length === 0)
25
+ throw new Error("Function call template must have text before \"{{functionName}}\"");
26
+ if (callSuffix.length === 0)
27
+ throw new Error("Function call template must have text after \"{{functionParams}}\"");
28
+ if (resultPrefix.length === 0)
29
+ throw new Error("Function call result template must have text before \"{{functionCallResult}}\"");
30
+ if (resultSuffix.length === 0)
31
+ throw new Error("Function call result template must have text after \"{{functionCallResult}}\"");
32
+ return {
33
+ call: {
34
+ optionalPrefixSpace: true,
35
+ prefix: callPrefix,
36
+ paramsPrefix: callParamsPrefix,
37
+ suffix: callSuffix
38
+ },
39
+ result: {
40
+ prefix: resultPrefix,
41
+ suffix: resultSuffix
42
+ }
43
+ };
44
+ }
45
+ //# sourceMappingURL=chatHistoryFunctionCallMessageTemplate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chatHistoryFunctionCallMessageTemplate.js","sourceRoot":"","sources":["../../../../src/chatWrappers/generic/utils/chatHistoryFunctionCallMessageTemplate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,iBAAiB,EAAC,MAAM,qCAAqC,CAAC;AAEtE,MAAM,UAAU,gCAAgC,CAAC,QAAiD;IAC9F,IAAI,QAAQ,IAAI,IAAI;QAChB,OAAO,IAAI,CAAC;IAEhB,MAAM,CAAC,oBAAoB,EAAE,0BAA0B,CAAC,GAAG,QAAQ,CAAC;IAEpE,IAAI,oBAAoB,IAAI,IAAI,IAAI,0BAA0B,IAAI,IAAI;QAClE,MAAM,IAAI,KAAK,CAAC,oEAAoE,CAAC,CAAC;IAE1F,MAAM,0BAA0B,GAAG,iBAAiB,CAAC,oBAAoB,EAAE,CAAC;YACxE,IAAI,EAAE,kBAAkB;YACxB,GAAG,EAAE,cAAc;SACtB,EAAE;YACC,IAAI,EAAE,oBAAoB;YAC1B,GAAG,EAAE,gBAAgB;SACxB,CAAC,CAAC,CAAC;IACJ,MAAM,gCAAgC,GAAG,iBAAiB,CAAC,0BAA0B,EAAE,CAAC;YACpF,IAAI,EAAE,wBAAwB;YAC9B,GAAG,EAAE,oBAAoB;SAC5B,CAAC,CAAC,CAAC;IAEJ,MAAM,UAAU,GAAG,0BAA0B,CAAC,YAAY,CAAC,MAAM,CAAC;IAClE,MAAM,gBAAgB,GAAG,0BAA0B,CAAC,cAAc,CAAC,MAAM,CAAC;IAC1E,MAAM,UAAU,GAAG,0BAA0B,CAAC,cAAc,CAAC,MAAM,CAAC;IAEpE,MAAM,YAAY,GAAG,gCAAgC,CAAC,kBAAkB,CAAC,MAAM,CAAC;IAChF,MAAM,YAAY,GAAG,gCAAgC,CAAC,kBAAkB,CAAC,MAAM,CAAC;IAEhF,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,mEAAmE,CAAC,CAAC;IAEzF,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,oEAAoE,CAAC,CAAC;IAE1F,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,gFAAgF,CAAC,CAAC;IAEtG,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,+EAA+E,CAAC,CAAC;IAErG,OAAO;QACH,IAAI,EAAE;YACF,mBAAmB,EAAE,IAAI;YACzB,MAAM,EAAE,UAAU;YAClB,YAAY,EAAE,gBAAgB;YAC9B,MAAM,EAAE,UAAU;SACrB;QACD,MAAM,EAAE;YACJ,MAAM,EAAE,YAAY;YACpB,MAAM,EAAE,YAAY;SACvB;KACJ,CAAC;AACN,CAAC"}
@@ -0,0 +1,42 @@
1
+ import { ChatModelFunctions } from "../../types.js";
2
+ /**
3
+ * Generate documentation about the functions that are available for a model to call.
4
+ * Useful for generating a system message with information about the available functions as part of a chat wrapper.
5
+ */
6
+ export declare class ChatModelFunctionsDocumentationGenerator {
7
+ readonly chatModelFunctions?: ChatModelFunctions;
8
+ readonly hasAnyFunctions: boolean;
9
+ constructor(chatModelFunctions: ChatModelFunctions | undefined);
10
+ /**
11
+ * Example:
12
+ * ```typescript
13
+ * // Retrieve the current date
14
+ * function getDate();
15
+ *
16
+ * // Retrieve the current time
17
+ * function getTime(params: {hours: "24" | "12", seconds: boolean});
18
+ * ```
19
+ * @param options
20
+ * @param [options.documentParams] - Whether to document the parameters of the functions
21
+ */
22
+ getTypeScriptFunctionSignatures({ documentParams }?: {
23
+ documentParams?: boolean;
24
+ }): string;
25
+ /**
26
+ * Example:
27
+ * ```typescript
28
+ * // Retrieve the current date
29
+ * type getDate = () => any;
30
+ *
31
+ * // Retrieve the current time
32
+ * type getTime = (_: {hours: "24" | "12", seconds: boolean}) => any;
33
+ * ```
34
+ * @param options
35
+ * @param [options.documentParams] - Whether to document the parameters of the functions
36
+ * @param [options.reservedFunctionNames] - Function names that are reserved and cannot be used
37
+ */
38
+ getTypeScriptFunctionTypes({ documentParams, reservedFunctionNames }?: {
39
+ documentParams?: boolean;
40
+ reservedFunctionNames?: string[];
41
+ }): string;
42
+ }
@@ -0,0 +1,82 @@
1
+ import { getTypeScriptTypeStringForGbnfJsonSchema } from "../../utils/getTypeScriptTypeStringForGbnfJsonSchema.js";
2
+ /**
3
+ * Generate documentation about the functions that are available for a model to call.
4
+ * Useful for generating a system message with information about the available functions as part of a chat wrapper.
5
+ */
6
+ export class ChatModelFunctionsDocumentationGenerator {
7
+ chatModelFunctions;
8
+ hasAnyFunctions;
9
+ constructor(chatModelFunctions) {
10
+ this.chatModelFunctions = chatModelFunctions;
11
+ this.hasAnyFunctions = Object.keys(this.chatModelFunctions ?? {}).length > 0;
12
+ }
13
+ /**
14
+ * Example:
15
+ * ```typescript
16
+ * // Retrieve the current date
17
+ * function getDate();
18
+ *
19
+ * // Retrieve the current time
20
+ * function getTime(params: {hours: "24" | "12", seconds: boolean});
21
+ * ```
22
+ * @param options
23
+ * @param [options.documentParams] - Whether to document the parameters of the functions
24
+ */
25
+ getTypeScriptFunctionSignatures({ documentParams = true } = {}) {
26
+ const chatModelFunctions = this.chatModelFunctions;
27
+ if (!this.hasAnyFunctions || chatModelFunctions == null)
28
+ return "";
29
+ const functionNames = Object.keys(chatModelFunctions);
30
+ return functionNames
31
+ .map((functionName) => {
32
+ const functionDefinition = chatModelFunctions[functionName];
33
+ let res = "";
34
+ if (functionDefinition?.description != null && functionDefinition.description.trim() !== "")
35
+ res += "// " + functionDefinition.description.split("\n").join("\n// ") + "\n";
36
+ res += "function " + functionName + "(";
37
+ if (documentParams && functionDefinition?.params != null)
38
+ res += "params: " + getTypeScriptTypeStringForGbnfJsonSchema(functionDefinition.params);
39
+ else if (!documentParams && functionDefinition?.params != null)
40
+ res += "params";
41
+ res += ");";
42
+ return res;
43
+ })
44
+ .join("\n\n");
45
+ }
46
+ /**
47
+ * Example:
48
+ * ```typescript
49
+ * // Retrieve the current date
50
+ * type getDate = () => any;
51
+ *
52
+ * // Retrieve the current time
53
+ * type getTime = (_: {hours: "24" | "12", seconds: boolean}) => any;
54
+ * ```
55
+ * @param options
56
+ * @param [options.documentParams] - Whether to document the parameters of the functions
57
+ * @param [options.reservedFunctionNames] - Function names that are reserved and cannot be used
58
+ */
59
+ getTypeScriptFunctionTypes({ documentParams = true, reservedFunctionNames = [] } = {}) {
60
+ const chatModelFunctions = this.chatModelFunctions;
61
+ if (!this.hasAnyFunctions || chatModelFunctions == null)
62
+ return "";
63
+ const functionNames = Object.keys(chatModelFunctions);
64
+ const reservedFunctionNamesSet = new Set(reservedFunctionNames);
65
+ return functionNames
66
+ .map((functionName) => {
67
+ if (reservedFunctionNamesSet.has(functionName))
68
+ throw new Error(`Function name "${functionName}" is reserved and cannot be used`);
69
+ const functionDefinition = chatModelFunctions[functionName];
70
+ let res = "";
71
+ if (functionDefinition?.description != null && functionDefinition.description.trim() !== "")
72
+ res += "// " + functionDefinition.description.split("\n").join("\n// ") + "\n";
73
+ res += "type " + functionName + " = (";
74
+ if (documentParams && functionDefinition?.params != null)
75
+ res += "_: " + getTypeScriptTypeStringForGbnfJsonSchema(functionDefinition.params);
76
+ res += ") => any;";
77
+ return res;
78
+ })
79
+ .join("\n\n");
80
+ }
81
+ }
82
+ //# sourceMappingURL=ChatModelFunctionsDocumentationGenerator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChatModelFunctionsDocumentationGenerator.js","sourceRoot":"","sources":["../../../src/chatWrappers/utils/ChatModelFunctionsDocumentationGenerator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { ChatWrapper } from "../../ChatWrapper.js";
2
+ import { Tokenizer } from "../../types.js";
3
+ import { JinjaTemplateChatWrapperOptions } from "../generic/JinjaTemplateChatWrapper.js";
4
+ export declare function isJinjaTemplateEquivalentToSpecializedChatWrapper(jinjaTemplateWrapperOptions: JinjaTemplateChatWrapperOptions, specializedChatWrapper: ChatWrapper, tokenizer?: Tokenizer): boolean;
@@ -0,0 +1,206 @@
1
+ import { JinjaTemplateChatWrapper } from "../generic/JinjaTemplateChatWrapper.js";
2
+ import { SpecialToken, LlamaText } from "../../utils/LlamaText.js";
3
+ import { compareTokens } from "../../utils/compareTokens.js";
4
+ import { StopGenerationDetector } from "../../utils/StopGenerationDetector.js";
5
+ export function isJinjaTemplateEquivalentToSpecializedChatWrapper(jinjaTemplateWrapperOptions, specializedChatWrapper, tokenizer) {
6
+ const canTestMultipleConvertSystemMessagesToUserMessages = jinjaTemplateWrapperOptions.convertUnsupportedSystemMessagesToUserMessages == null ||
7
+ jinjaTemplateWrapperOptions.convertUnsupportedSystemMessagesToUserMessages === "auto";
8
+ try {
9
+ const jinjaChatWrapper = new JinjaTemplateChatWrapper({
10
+ ...jinjaTemplateWrapperOptions,
11
+ convertUnsupportedSystemMessagesToUserMessages: canTestMultipleConvertSystemMessagesToUserMessages
12
+ ? false
13
+ : jinjaTemplateWrapperOptions.convertUnsupportedSystemMessagesToUserMessages,
14
+ trimLeadingWhitespaceInResponses: false
15
+ });
16
+ if (checkEquivalence(jinjaChatWrapper, specializedChatWrapper, testChatHistories, tokenizer))
17
+ return true;
18
+ const jinjaChatWrapperWithLeadingWhitespaceTrimming = new JinjaTemplateChatWrapper({
19
+ ...jinjaTemplateWrapperOptions,
20
+ convertUnsupportedSystemMessagesToUserMessages: canTestMultipleConvertSystemMessagesToUserMessages
21
+ ? false
22
+ : jinjaTemplateWrapperOptions.convertUnsupportedSystemMessagesToUserMessages,
23
+ trimLeadingWhitespaceInResponses: true
24
+ });
25
+ if (checkEquivalence(jinjaChatWrapperWithLeadingWhitespaceTrimming, specializedChatWrapper, testChatHistories, tokenizer))
26
+ return true;
27
+ }
28
+ catch (err) {
29
+ // Do nothing
30
+ }
31
+ if (!canTestMultipleConvertSystemMessagesToUserMessages)
32
+ return false;
33
+ try {
34
+ const convertSystemMessagesToUserMessagesTemplate = "### System message\n\n{{message}}\n\n----";
35
+ const jinjaChatWrapper = new JinjaTemplateChatWrapper({
36
+ ...jinjaTemplateWrapperOptions,
37
+ convertUnsupportedSystemMessagesToUserMessages: {
38
+ use: "always",
39
+ format: convertSystemMessagesToUserMessagesTemplate
40
+ },
41
+ trimLeadingWhitespaceInResponses: false
42
+ });
43
+ const transformedTestChatHistories = testChatHistories
44
+ .map((history) => (history
45
+ .slice()
46
+ .map((item, index, array) => {
47
+ if (item.type === "system") {
48
+ if (index === 0 && array.length > 1 && array[1].type === "user") {
49
+ array[1] = {
50
+ type: "user",
51
+ text: convertSystemMessagesToUserMessagesTemplate.replace("{{message}}", item.text) + "\n\n" + array[1].text
52
+ };
53
+ return null;
54
+ }
55
+ return {
56
+ type: "user",
57
+ text: convertSystemMessagesToUserMessagesTemplate.replace("{{message}}", item.text)
58
+ };
59
+ }
60
+ return item;
61
+ })
62
+ .filter((item) => item != null)));
63
+ if (checkEquivalence(jinjaChatWrapper, specializedChatWrapper, transformedTestChatHistories, tokenizer))
64
+ return true;
65
+ const jinjaChatWrapperWithLeadingWhitespaceTrimming = new JinjaTemplateChatWrapper({
66
+ ...jinjaTemplateWrapperOptions,
67
+ convertUnsupportedSystemMessagesToUserMessages: {
68
+ use: "always",
69
+ format: convertSystemMessagesToUserMessagesTemplate
70
+ },
71
+ trimLeadingWhitespaceInResponses: true
72
+ });
73
+ if (checkEquivalence(jinjaChatWrapperWithLeadingWhitespaceTrimming, specializedChatWrapper, transformedTestChatHistories, tokenizer))
74
+ return true;
75
+ }
76
+ catch (err) {
77
+ // Do nothing
78
+ }
79
+ return false;
80
+ }
81
+ function checkEquivalence(jinjaChatWrapper, specializedChatWrapper, testChatHistories, tokenizer) {
82
+ for (const testChatHistory of testChatHistories) {
83
+ const jinjaRes = jinjaChatWrapper.generateContextText(testChatHistory);
84
+ const specializedWrapperRes = specializedChatWrapper.generateContextText(testChatHistory);
85
+ if (!compareContextTexts(jinjaRes.contextText, specializedWrapperRes.contextText, tokenizer))
86
+ return false;
87
+ const jinjaHasAllSpecializedStopGenerationTriggers = jinjaRes.stopGenerationTriggers
88
+ .every((trigger) => {
89
+ return [trigger, trigger.trimEnd(), trigger.trimStart(), trigger.trimStart().trimEnd()].some((normalizedJinjaTrigger) => {
90
+ if (normalizedJinjaTrigger.values.length === 0)
91
+ return true;
92
+ const foundSimilarTriggers = specializedWrapperRes.stopGenerationTriggers.some((specializedTrigger) => (normalizedJinjaTrigger.includes(specializedTrigger)));
93
+ if (foundSimilarTriggers)
94
+ return true;
95
+ if (tokenizer != null) {
96
+ const resolvedStopGenerationTrigger = StopGenerationDetector.resolveLlamaTextTrigger(normalizedJinjaTrigger, tokenizer);
97
+ const foundSimilarOrShorterTokenizedTriggers = specializedWrapperRes.stopGenerationTriggers
98
+ .some((specializedTrigger) => {
99
+ const resolvedSpecializedTrigger = StopGenerationDetector.resolveLlamaTextTrigger(specializedTrigger, tokenizer);
100
+ return resolvedSpecializedTrigger.every((item, index) => {
101
+ const resolveTriggerItem = resolvedStopGenerationTrigger[index];
102
+ if (typeof item === "string" && typeof resolveTriggerItem === "string")
103
+ return item === resolveTriggerItem;
104
+ else if (typeof item === "string" || typeof resolveTriggerItem === "string")
105
+ return false;
106
+ return compareTokens(item, resolveTriggerItem);
107
+ });
108
+ });
109
+ if (foundSimilarOrShorterTokenizedTriggers)
110
+ return true;
111
+ }
112
+ return false;
113
+ });
114
+ });
115
+ if (!jinjaHasAllSpecializedStopGenerationTriggers)
116
+ return false;
117
+ }
118
+ return true;
119
+ }
120
+ function compareContextTexts(text1, text2, tokenizer) {
121
+ function compare(text1, text2) {
122
+ if (LlamaText.compare(text1, text2))
123
+ return true;
124
+ if (tokenizer != null) {
125
+ const tokenizedText1 = text1.tokenize(tokenizer);
126
+ const tokenizedText2 = text2.tokenize(tokenizer);
127
+ if (tokenizedText1.length === tokenizedText2.length)
128
+ return tokenizedText1.every((token, index) => compareTokens(token, tokenizedText2[index]));
129
+ }
130
+ return false;
131
+ }
132
+ const trimmedText1 = text1.trimEnd();
133
+ const trimmedText2 = text2.trimEnd();
134
+ const normalizedText1 = removeLeadingBos(trimmedText1);
135
+ const normalizedText2 = removeLeadingBos(trimmedText2);
136
+ const texts1 = (normalizedText1.values.length !== trimmedText1.values.length && tokenizer != null)
137
+ ? [trimmedText1, normalizedText1]
138
+ : [normalizedText1];
139
+ const texts2 = (normalizedText2.values.length !== trimmedText2.values.length && tokenizer != null)
140
+ ? [trimmedText2, normalizedText2]
141
+ : [normalizedText2];
142
+ return texts1.some((text1) => (texts2.some((text2) => (compare(text1, text2)))));
143
+ }
144
+ const testChatHistories = [
145
+ [{
146
+ type: "system",
147
+ text: "System message ~!@#$%^&*()\n*"
148
+ }, {
149
+ type: "user",
150
+ text: "Message 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"
151
+ }, {
152
+ type: "model",
153
+ response: [""]
154
+ }],
155
+ [{
156
+ type: "system",
157
+ text: "System message ~!@#$%^&*()\n*"
158
+ }, {
159
+ type: "user",
160
+ text: "Message 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"
161
+ }, {
162
+ type: "model",
163
+ response: ["Result 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"]
164
+ }],
165
+ [{
166
+ type: "system",
167
+ text: "System message ~!@#$%^&*()\n*"
168
+ }, {
169
+ type: "user",
170
+ text: "Message 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"
171
+ }, {
172
+ type: "model",
173
+ response: ["Result 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"]
174
+ }, {
175
+ type: "user",
176
+ text: "Message2 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"
177
+ }, {
178
+ type: "model",
179
+ response: [""]
180
+ }],
181
+ [{
182
+ type: "system",
183
+ text: "System message ~!@#$%^&*()\n*"
184
+ }, {
185
+ type: "user",
186
+ text: "Message 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"
187
+ }, {
188
+ type: "model",
189
+ response: ["Result 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"]
190
+ }, {
191
+ type: "user",
192
+ text: "Message2 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"
193
+ }, {
194
+ type: "model",
195
+ response: ["Result2 1234567890!@#$%^&*()_+-=[]{}|\\:;\"',./<>?`~"]
196
+ }]
197
+ ];
198
+ function removeLeadingBos(llamaText) {
199
+ if (llamaText.values.length === 0)
200
+ return llamaText;
201
+ const firstValue = llamaText.values[0];
202
+ if (firstValue instanceof SpecialToken && firstValue.value === "BOS")
203
+ return LlamaText(llamaText.values.slice(1));
204
+ return llamaText;
205
+ }
206
+ //# sourceMappingURL=isJinjaTemplateEquivalentToSpecializedChatWrapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isJinjaTemplateEquivalentToSpecializedChatWrapper.js","sourceRoot":"","sources":["../../../src/chatWrappers/utils/isJinjaTemplateEquivalentToSpecializedChatWrapper.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,69 @@
1
+ import { Llama3ChatWrapper } from "../Llama3ChatWrapper.js";
2
+ import { Llama2ChatWrapper } from "../Llama2ChatWrapper.js";
3
+ import { ChatMLChatWrapper } from "../ChatMLChatWrapper.js";
4
+ import { GeneralChatWrapper } from "../GeneralChatWrapper.js";
5
+ import { FalconChatWrapper } from "../FalconChatWrapper.js";
6
+ import { FunctionaryChatWrapper } from "../FunctionaryChatWrapper.js";
7
+ import { AlpacaChatWrapper } from "../AlpacaChatWrapper.js";
8
+ import { GemmaChatWrapper } from "../GemmaChatWrapper.js";
9
+ import { JinjaTemplateChatWrapper } from "../generic/JinjaTemplateChatWrapper.js";
10
+ import { TemplateChatWrapper } from "../generic/TemplateChatWrapper.js";
11
+ import { Tokenizer } from "../../types.js";
12
+ import type { GgufFileInfo } from "../../gguf/types/GgufFileInfoTypes.js";
13
+ export declare const specializedChatWrapperTypeNames: readonly ["general", "llama3Chat", "llama2Chat", "alpacaChat", "functionary", "chatML", "falconChat", "gemma"];
14
+ export type SpecializedChatWrapperTypeName = (typeof specializedChatWrapperTypeNames)[number];
15
+ export declare const templateChatWrapperTypeNames: readonly ["template", "jinjaTemplate"];
16
+ export type TemplateChatWrapperTypeName = (typeof templateChatWrapperTypeNames)[number];
17
+ export declare const resolvableChatWrapperTypeNames: readonly ["auto", "general", "llama3Chat", "llama2Chat", "alpacaChat", "functionary", "chatML", "falconChat", "gemma", "template", "jinjaTemplate"];
18
+ export type ResolvableChatWrapperTypeName = (typeof resolvableChatWrapperTypeNames)[number];
19
+ declare const chatWrappers: {
20
+ readonly general: typeof GeneralChatWrapper;
21
+ readonly llama3Chat: typeof Llama3ChatWrapper;
22
+ readonly llama2Chat: typeof Llama2ChatWrapper;
23
+ readonly alpacaChat: typeof AlpacaChatWrapper;
24
+ readonly functionary: typeof FunctionaryChatWrapper;
25
+ readonly chatML: typeof ChatMLChatWrapper;
26
+ readonly falconChat: typeof FalconChatWrapper;
27
+ readonly gemma: typeof GemmaChatWrapper;
28
+ readonly template: typeof TemplateChatWrapper;
29
+ readonly jinjaTemplate: typeof JinjaTemplateChatWrapper;
30
+ };
31
+ export type ResolveChatWrapperOptions = {
32
+ /**
33
+ * Resolve to a specific chat wrapper type.
34
+ * You better not set this option unless you need to force a specific chat wrapper type.
35
+ *
36
+ * Defaults to `"auto"`.
37
+ */
38
+ type?: "auto" | SpecializedChatWrapperTypeName | TemplateChatWrapperTypeName;
39
+ bosString?: string | null;
40
+ filename?: string;
41
+ fileInfo?: GgufFileInfo;
42
+ tokenizer?: Tokenizer;
43
+ customWrapperSettings?: {
44
+ [wrapper in keyof typeof chatWrappers]?: ConstructorParameters<(typeof chatWrappers)[wrapper]>[0];
45
+ };
46
+ warningLogs?: boolean;
47
+ fallbackToOtherWrappersOnJinjaError?: boolean;
48
+ /**
49
+ * Don't resolve to a Jinja chat wrapper unless `type` is set to a Jinja chat wrapper type.
50
+ */
51
+ noJinja?: boolean;
52
+ };
53
+ /**
54
+ * Resolve to a chat wrapper instance based on the provided information.
55
+ * The more information provided, the better the resolution will be (except for `type`).
56
+ *
57
+ * It's recommended to not set `type` to a specific chat wrapper in order for the resolution to be more flexible, but it is useful for when
58
+ * you need to provide the ability to force a specific chat wrapper type.
59
+ * Note that when setting `type` to a generic chat wrapper type (such as `"template"` or `"jinjaTemplate"`), the `customWrapperSettings`
60
+ * must contain the necessary settings for that chat wrapper to be created.
61
+ *
62
+ * When loading a Jinja chat template from either `fileInfo` or `customWrapperSettings.jinjaTemplate.template`,
63
+ * if the chat template format is invalid, it fallbacks to resolve other chat wrappers,
64
+ * unless `fallbackToOtherWrappersOnJinjaError` is set to `false` (in which case, it will throw an error).
65
+ */
66
+ export declare function resolveChatWrapper({ type, bosString, filename, fileInfo, tokenizer, customWrapperSettings, warningLogs, fallbackToOtherWrappersOnJinjaError, noJinja }: ResolveChatWrapperOptions): any;
67
+ export declare function isSpecializedChatWrapperType(type: string): type is SpecializedChatWrapperTypeName;
68
+ export declare function isTemplateChatWrapperType(type: string): type is TemplateChatWrapperTypeName;
69
+ export {};