node-llama-cpp 2.8.4 → 3.0.0-beta.2
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.
- package/README.md +2 -2
- package/dist/ChatWrapper.d.ts +49 -0
- package/dist/ChatWrapper.js +120 -0
- package/dist/ChatWrapper.js.map +1 -0
- package/dist/chatWrappers/AlpacaChatWrapper.d.ts +12 -0
- package/dist/chatWrappers/AlpacaChatWrapper.js +21 -0
- package/dist/chatWrappers/AlpacaChatWrapper.js.map +1 -0
- package/dist/chatWrappers/ChatMLChatWrapper.d.ts +13 -0
- package/dist/chatWrappers/ChatMLChatWrapper.js +83 -0
- package/dist/chatWrappers/ChatMLChatWrapper.js.map +1 -0
- package/dist/chatWrappers/EmptyChatWrapper.d.ts +4 -0
- package/dist/chatWrappers/EmptyChatWrapper.js +5 -0
- package/dist/chatWrappers/EmptyChatWrapper.js.map +1 -0
- package/dist/chatWrappers/FalconChatWrapper.d.ts +21 -0
- package/dist/chatWrappers/FalconChatWrapper.js +104 -0
- package/dist/chatWrappers/FalconChatWrapper.js.map +1 -0
- package/dist/chatWrappers/FunctionaryChatWrapper.d.ts +41 -0
- package/dist/chatWrappers/FunctionaryChatWrapper.js +200 -0
- package/dist/chatWrappers/FunctionaryChatWrapper.js.map +1 -0
- package/dist/chatWrappers/GeneralChatWrapper.d.ts +21 -0
- package/dist/chatWrappers/GeneralChatWrapper.js +112 -0
- package/dist/chatWrappers/GeneralChatWrapper.js.map +1 -0
- package/dist/chatWrappers/LlamaChatWrapper.d.ts +13 -0
- package/dist/chatWrappers/LlamaChatWrapper.js +78 -0
- package/dist/chatWrappers/LlamaChatWrapper.js.map +1 -0
- package/dist/chatWrappers/resolveChatWrapperBasedOnModel.d.ts +13 -0
- package/dist/chatWrappers/resolveChatWrapperBasedOnModel.js +55 -0
- package/dist/chatWrappers/resolveChatWrapperBasedOnModel.js.map +1 -0
- package/dist/cli/cli.js +1 -1
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/commands/ChatCommand.d.ts +2 -1
- package/dist/cli/commands/ChatCommand.js +90 -42
- package/dist/cli/commands/ChatCommand.js.map +1 -1
- package/dist/config.js +1 -1
- package/dist/config.js.map +1 -1
- package/dist/index.d.ts +20 -12
- package/dist/index.js +19 -11
- package/dist/index.js.map +1 -1
- package/dist/llamaEvaluator/LlamaBins.d.ts +18 -4
- package/dist/llamaEvaluator/LlamaBins.js +3 -3
- package/dist/llamaEvaluator/LlamaChat/LlamaChat.d.ts +175 -0
- package/dist/llamaEvaluator/LlamaChat/LlamaChat.js +704 -0
- package/dist/llamaEvaluator/LlamaChat/LlamaChat.js.map +1 -0
- package/dist/llamaEvaluator/LlamaChat/utils/FunctionCallGrammar.d.ts +21 -0
- package/dist/llamaEvaluator/LlamaChat/utils/FunctionCallGrammar.js +120 -0
- package/dist/llamaEvaluator/LlamaChat/utils/FunctionCallGrammar.js.map +1 -0
- package/dist/llamaEvaluator/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.d.ts +16 -0
- package/dist/llamaEvaluator/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.js +117 -0
- package/dist/llamaEvaluator/LlamaChat/utils/contextShiftStrategies/eraseFirstResponseAndKeepFirstSystemChatContextShiftStrategy.js.map +1 -0
- package/dist/llamaEvaluator/LlamaChatSession/LlamaChatSession.d.ts +146 -0
- package/dist/llamaEvaluator/LlamaChatSession/LlamaChatSession.js +211 -0
- package/dist/llamaEvaluator/LlamaChatSession/LlamaChatSession.js.map +1 -0
- package/dist/llamaEvaluator/LlamaChatSession/utils/defineChatSessionFunction.d.ts +7 -0
- package/dist/llamaEvaluator/LlamaChatSession/utils/defineChatSessionFunction.js +8 -0
- package/dist/llamaEvaluator/LlamaChatSession/utils/defineChatSessionFunction.js.map +1 -0
- package/dist/llamaEvaluator/LlamaContext/LlamaContext.d.ts +107 -0
- package/dist/llamaEvaluator/LlamaContext/LlamaContext.js +597 -0
- package/dist/llamaEvaluator/LlamaContext/LlamaContext.js.map +1 -0
- package/dist/llamaEvaluator/LlamaContext/types.d.ts +86 -0
- package/dist/llamaEvaluator/LlamaContext/types.js +2 -0
- package/dist/llamaEvaluator/LlamaContext/types.js.map +1 -0
- package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/firstInFirstOutStrategy.d.ts +5 -0
- package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/firstInFirstOutStrategy.js +16 -0
- package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/firstInFirstOutStrategy.js.map +1 -0
- package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/maximumParallelismStrategy.d.ts +5 -0
- package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/maximumParallelismStrategy.js +42 -0
- package/dist/llamaEvaluator/LlamaContext/utils/batchItemsPrioritizingStrategies/maximumParallelismStrategy.js.map +1 -0
- package/dist/llamaEvaluator/LlamaContext/utils/resolveBatchItemsPrioritizingStrategy.d.ts +2 -0
- package/dist/llamaEvaluator/LlamaContext/utils/resolveBatchItemsPrioritizingStrategy.js +13 -0
- package/dist/llamaEvaluator/LlamaContext/utils/resolveBatchItemsPrioritizingStrategy.js.map +1 -0
- package/dist/llamaEvaluator/LlamaGrammar.d.ts +9 -13
- package/dist/llamaEvaluator/LlamaGrammar.js +10 -15
- package/dist/llamaEvaluator/LlamaGrammar.js.map +1 -1
- package/dist/llamaEvaluator/LlamaGrammarEvaluationState.d.ts +6 -5
- package/dist/llamaEvaluator/LlamaGrammarEvaluationState.js +8 -7
- package/dist/llamaEvaluator/LlamaGrammarEvaluationState.js.map +1 -1
- package/dist/llamaEvaluator/LlamaJsonSchemaGrammar.js +2 -1
- package/dist/llamaEvaluator/LlamaJsonSchemaGrammar.js.map +1 -1
- package/dist/llamaEvaluator/LlamaModel.d.ts +101 -105
- package/dist/llamaEvaluator/LlamaModel.js +305 -57
- package/dist/llamaEvaluator/LlamaModel.js.map +1 -1
- package/dist/types.d.ts +44 -4
- package/dist/types.js +5 -1
- package/dist/types.js.map +1 -1
- package/dist/utils/LlamaText.d.ts +42 -0
- package/dist/utils/LlamaText.js +207 -0
- package/dist/utils/LlamaText.js.map +1 -0
- package/dist/utils/ReplHistory.js +1 -1
- package/dist/utils/ReplHistory.js.map +1 -1
- package/dist/utils/StopGenerationDetector.d.ts +28 -0
- package/dist/utils/StopGenerationDetector.js +205 -0
- package/dist/utils/StopGenerationDetector.js.map +1 -0
- package/dist/utils/TokenStreamRegulator.d.ts +30 -0
- package/dist/utils/TokenStreamRegulator.js +96 -0
- package/dist/utils/TokenStreamRegulator.js.map +1 -0
- package/dist/utils/appendUserMessageToChatHistory.d.ts +2 -0
- package/dist/utils/appendUserMessageToChatHistory.js +18 -0
- package/dist/utils/appendUserMessageToChatHistory.js.map +1 -0
- package/dist/utils/compareTokens.d.ts +2 -0
- package/dist/utils/compareTokens.js +4 -0
- package/dist/utils/compareTokens.js.map +1 -0
- package/dist/utils/findCharacterRemovalCountToFitChatHistoryInContext.d.ts +18 -0
- package/dist/utils/findCharacterRemovalCountToFitChatHistoryInContext.js +61 -0
- package/dist/utils/findCharacterRemovalCountToFitChatHistoryInContext.js.map +1 -0
- package/dist/utils/gbnfJson/GbnfGrammarGenerator.d.ts +1 -0
- package/dist/utils/gbnfJson/GbnfGrammarGenerator.js +17 -0
- package/dist/utils/gbnfJson/GbnfGrammarGenerator.js.map +1 -1
- package/dist/utils/gbnfJson/GbnfTerminal.d.ts +1 -1
- package/dist/utils/gbnfJson/GbnfTerminal.js.map +1 -1
- package/dist/utils/gbnfJson/terminals/GbnfVerbatimText.d.ts +6 -0
- package/dist/utils/gbnfJson/terminals/GbnfVerbatimText.js +21 -0
- package/dist/utils/gbnfJson/terminals/GbnfVerbatimText.js.map +1 -0
- package/dist/utils/gbnfJson/types.d.ts +1 -1
- package/dist/utils/gbnfJson/types.js.map +1 -1
- package/dist/utils/gbnfJson/utils/validateObjectAgainstGbnfSchema.d.ts +1 -0
- package/dist/utils/gbnfJson/utils/validateObjectAgainstGbnfSchema.js.map +1 -1
- package/dist/utils/getBin.d.ts +71 -38
- package/dist/utils/getBin.js.map +1 -1
- package/dist/utils/getGbnfGrammarForGbnfJsonSchema.js +1 -15
- package/dist/utils/getGbnfGrammarForGbnfJsonSchema.js.map +1 -1
- package/dist/utils/getReleaseInfo.d.ts +1 -1
- package/dist/utils/getReleaseInfo.js.map +1 -1
- package/dist/utils/getTypeScriptTypeStringForGbnfJsonSchema.d.ts +2 -0
- package/dist/utils/getTypeScriptTypeStringForGbnfJsonSchema.js +49 -0
- package/dist/utils/getTypeScriptTypeStringForGbnfJsonSchema.js.map +1 -0
- package/dist/utils/parseModelFileName.d.ts +9 -0
- package/dist/utils/parseModelFileName.js +68 -0
- package/dist/utils/parseModelFileName.js.map +1 -0
- package/dist/utils/parseModelTypeDescription.d.ts +6 -0
- package/dist/utils/parseModelTypeDescription.js +9 -0
- package/dist/utils/parseModelTypeDescription.js.map +1 -0
- package/dist/utils/resolveChatWrapper.d.ts +4 -0
- package/dist/utils/resolveChatWrapper.js +16 -0
- package/dist/utils/resolveChatWrapper.js.map +1 -0
- package/dist/utils/truncateTextAndRoundToWords.d.ts +8 -0
- package/dist/utils/truncateTextAndRoundToWords.js +27 -0
- package/dist/utils/truncateTextAndRoundToWords.js.map +1 -0
- package/llama/.clang-format +10 -9
- package/llama/addon.cpp +701 -352
- package/llama/gitRelease.bundle +0 -0
- package/llamaBins/linux-arm64/llama-addon.node +0 -0
- package/llamaBins/linux-armv7l/llama-addon.node +0 -0
- package/llamaBins/linux-x64/llama-addon.node +0 -0
- package/llamaBins/mac-arm64/llama-addon.node +0 -0
- package/llamaBins/mac-x64/llama-addon.node +0 -0
- package/llamaBins/win-x64/llama-addon.node +0 -0
- package/package.json +24 -14
- package/dist/ChatPromptWrapper.d.ts +0 -11
- package/dist/ChatPromptWrapper.js +0 -20
- package/dist/ChatPromptWrapper.js.map +0 -1
- package/dist/chatWrappers/ChatMLChatPromptWrapper.d.ts +0 -12
- package/dist/chatWrappers/ChatMLChatPromptWrapper.js +0 -22
- package/dist/chatWrappers/ChatMLChatPromptWrapper.js.map +0 -1
- package/dist/chatWrappers/EmptyChatPromptWrapper.d.ts +0 -4
- package/dist/chatWrappers/EmptyChatPromptWrapper.js +0 -5
- package/dist/chatWrappers/EmptyChatPromptWrapper.js.map +0 -1
- package/dist/chatWrappers/FalconChatPromptWrapper.d.ts +0 -19
- package/dist/chatWrappers/FalconChatPromptWrapper.js +0 -33
- package/dist/chatWrappers/FalconChatPromptWrapper.js.map +0 -1
- package/dist/chatWrappers/GeneralChatPromptWrapper.d.ts +0 -19
- package/dist/chatWrappers/GeneralChatPromptWrapper.js +0 -38
- package/dist/chatWrappers/GeneralChatPromptWrapper.js.map +0 -1
- package/dist/chatWrappers/LlamaChatPromptWrapper.d.ts +0 -12
- package/dist/chatWrappers/LlamaChatPromptWrapper.js +0 -23
- package/dist/chatWrappers/LlamaChatPromptWrapper.js.map +0 -1
- package/dist/chatWrappers/createChatWrapperByBos.d.ts +0 -2
- package/dist/chatWrappers/createChatWrapperByBos.js +0 -14
- package/dist/chatWrappers/createChatWrapperByBos.js.map +0 -1
- package/dist/chatWrappers/generateContextTextFromConversationHistory.d.ts +0 -23
- package/dist/chatWrappers/generateContextTextFromConversationHistory.js +0 -47
- package/dist/chatWrappers/generateContextTextFromConversationHistory.js.map +0 -1
- package/dist/llamaEvaluator/LlamaChatSession.d.ts +0 -122
- package/dist/llamaEvaluator/LlamaChatSession.js +0 -236
- package/dist/llamaEvaluator/LlamaChatSession.js.map +0 -1
- package/dist/llamaEvaluator/LlamaContext.d.ts +0 -98
- package/dist/llamaEvaluator/LlamaContext.js +0 -140
- package/dist/llamaEvaluator/LlamaContext.js.map +0 -1
- package/dist/utils/getTextCompletion.d.ts +0 -3
- package/dist/utils/getTextCompletion.js +0 -12
- package/dist/utils/getTextCompletion.js.map +0 -1
- package/dist/utils/withLock.d.ts +0 -1
- package/dist/utils/withLock.js +0 -19
- package/dist/utils/withLock.js.map +0 -1
- package/llamaBins/mac-arm64/ggml-metal.metal +0 -5820
- package/llamaBins/mac-x64/ggml-metal.metal +0 -5820
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
export const LlamaText = function LlamaText(strings, ...values) {
|
|
2
|
+
return createLlamaText(createHistoryFromStringsAndValues(strings, values));
|
|
3
|
+
};
|
|
4
|
+
LlamaText.fromJSON = function fromJSON(json) {
|
|
5
|
+
return createLlamaText(json.map((value) => {
|
|
6
|
+
if (typeof value === "string")
|
|
7
|
+
return value;
|
|
8
|
+
else if (SpecialToken.isSpecialTokenJSON(value))
|
|
9
|
+
return SpecialToken.fromJSON(value);
|
|
10
|
+
else {
|
|
11
|
+
void (value);
|
|
12
|
+
throw new Error(`Unknown value type: ${value}`);
|
|
13
|
+
}
|
|
14
|
+
}));
|
|
15
|
+
};
|
|
16
|
+
export class SpecialToken {
|
|
17
|
+
value;
|
|
18
|
+
constructor(value) {
|
|
19
|
+
this.value = value;
|
|
20
|
+
}
|
|
21
|
+
toString() {
|
|
22
|
+
return this.value;
|
|
23
|
+
}
|
|
24
|
+
tokenize(tokenizer) {
|
|
25
|
+
return tokenizer(this.value, true);
|
|
26
|
+
}
|
|
27
|
+
toJSON() {
|
|
28
|
+
return {
|
|
29
|
+
type: "specialToken",
|
|
30
|
+
value: this.value
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
static fromJSON(json) {
|
|
34
|
+
if (json.builtin)
|
|
35
|
+
return new BuiltinSpecialToken(json.value);
|
|
36
|
+
else
|
|
37
|
+
return new SpecialToken(json.value);
|
|
38
|
+
}
|
|
39
|
+
static isSpecialTokenJSON(value) {
|
|
40
|
+
return value != null && typeof value === "object" && value.type === "specialToken";
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
export class BuiltinSpecialToken extends SpecialToken {
|
|
44
|
+
value;
|
|
45
|
+
constructor(value) {
|
|
46
|
+
super(value);
|
|
47
|
+
this.value = value;
|
|
48
|
+
}
|
|
49
|
+
tokenize(tokenizer) {
|
|
50
|
+
return tokenizer(this.value, "builtin");
|
|
51
|
+
}
|
|
52
|
+
toJSON() {
|
|
53
|
+
return {
|
|
54
|
+
type: "specialToken",
|
|
55
|
+
value: this.value,
|
|
56
|
+
builtin: true
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
export function isLlamaText(value) {
|
|
61
|
+
return typeof value === "function" && "type" in value && value.type === "LlamaText";
|
|
62
|
+
}
|
|
63
|
+
export function tokenizeText(text, tokenizer) {
|
|
64
|
+
if (typeof text === "string")
|
|
65
|
+
return tokenizer(text, false);
|
|
66
|
+
else
|
|
67
|
+
return text.tokenize(tokenizer);
|
|
68
|
+
}
|
|
69
|
+
const LlamaTextPrototypeFunctions = {
|
|
70
|
+
mapValues: function mapValues(mapper) {
|
|
71
|
+
return createLlamaText(this.values.map(mapper));
|
|
72
|
+
},
|
|
73
|
+
joinValues(separator) {
|
|
74
|
+
const newValues = [];
|
|
75
|
+
for (let i = 0; i < this.values.length; i++) {
|
|
76
|
+
newValues.push(this.values[i]);
|
|
77
|
+
if (i !== this.values.length - 1) {
|
|
78
|
+
if (isLlamaText(separator))
|
|
79
|
+
newValues.push(...separator.values);
|
|
80
|
+
else
|
|
81
|
+
newValues.push(separator);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return createLlamaText(newValues);
|
|
85
|
+
},
|
|
86
|
+
toString() {
|
|
87
|
+
return this.values
|
|
88
|
+
.map((value) => {
|
|
89
|
+
if (value instanceof SpecialToken)
|
|
90
|
+
return value.toString();
|
|
91
|
+
else
|
|
92
|
+
return value;
|
|
93
|
+
})
|
|
94
|
+
.join("");
|
|
95
|
+
},
|
|
96
|
+
tokenize(tokenizer) {
|
|
97
|
+
let textToTokenize = "";
|
|
98
|
+
const res = [];
|
|
99
|
+
for (const value of this.values) {
|
|
100
|
+
if (value instanceof SpecialToken) {
|
|
101
|
+
res.push(...tokenizer(textToTokenize, false), ...value.tokenize(tokenizer));
|
|
102
|
+
textToTokenize = "";
|
|
103
|
+
}
|
|
104
|
+
else
|
|
105
|
+
textToTokenize += value;
|
|
106
|
+
}
|
|
107
|
+
res.push(...tokenizer(textToTokenize, false));
|
|
108
|
+
return res;
|
|
109
|
+
},
|
|
110
|
+
toJSON() {
|
|
111
|
+
return this.values.map((value) => {
|
|
112
|
+
if (value instanceof SpecialToken)
|
|
113
|
+
return { type: "specialToken", value: value.value };
|
|
114
|
+
else
|
|
115
|
+
return value;
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
function createLlamaText(history) {
|
|
120
|
+
const llamaText = function LlamaText(strings, ...values) {
|
|
121
|
+
return createLlamaText(llamaText.values.concat(createHistoryFromStringsAndValues(strings, values)));
|
|
122
|
+
};
|
|
123
|
+
Object.defineProperties(llamaText, {
|
|
124
|
+
["type"]: {
|
|
125
|
+
value: "LlamaText",
|
|
126
|
+
writable: false,
|
|
127
|
+
configurable: false,
|
|
128
|
+
enumerable: true
|
|
129
|
+
},
|
|
130
|
+
["values"]: {
|
|
131
|
+
value: Object.freeze(history.slice()),
|
|
132
|
+
writable: false,
|
|
133
|
+
configurable: false,
|
|
134
|
+
enumerable: true
|
|
135
|
+
},
|
|
136
|
+
["mapValues"]: {
|
|
137
|
+
value: LlamaTextPrototypeFunctions.mapValues,
|
|
138
|
+
writable: false,
|
|
139
|
+
configurable: false,
|
|
140
|
+
enumerable: false
|
|
141
|
+
},
|
|
142
|
+
["joinValues"]: {
|
|
143
|
+
value: LlamaTextPrototypeFunctions.joinValues,
|
|
144
|
+
writable: false,
|
|
145
|
+
configurable: false,
|
|
146
|
+
enumerable: false
|
|
147
|
+
},
|
|
148
|
+
["toString"]: {
|
|
149
|
+
value: LlamaTextPrototypeFunctions.toString,
|
|
150
|
+
writable: false,
|
|
151
|
+
configurable: false,
|
|
152
|
+
enumerable: false
|
|
153
|
+
},
|
|
154
|
+
["tokenize"]: {
|
|
155
|
+
value: LlamaTextPrototypeFunctions.tokenize,
|
|
156
|
+
writable: false,
|
|
157
|
+
configurable: false,
|
|
158
|
+
enumerable: false
|
|
159
|
+
},
|
|
160
|
+
["toJSON"]: {
|
|
161
|
+
value: LlamaTextPrototypeFunctions.toJSON,
|
|
162
|
+
writable: false,
|
|
163
|
+
configurable: false,
|
|
164
|
+
enumerable: false
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
return llamaText;
|
|
168
|
+
}
|
|
169
|
+
function createHistoryFromStringsAndValues(strings, values) {
|
|
170
|
+
function addItemToRes(res, item) {
|
|
171
|
+
if (item === undefined || item === "")
|
|
172
|
+
return res;
|
|
173
|
+
else if (typeof item === "string" || item instanceof SpecialToken)
|
|
174
|
+
return res.concat([item]);
|
|
175
|
+
else if (isLlamaText(item))
|
|
176
|
+
return res.concat(item.values);
|
|
177
|
+
else if (item instanceof Array) {
|
|
178
|
+
return res.concat(item.reduce((res, value) => {
|
|
179
|
+
if (isLlamaText(value))
|
|
180
|
+
return res.concat(value.values);
|
|
181
|
+
else if (value === "")
|
|
182
|
+
return res;
|
|
183
|
+
return res.concat([value]);
|
|
184
|
+
}, []));
|
|
185
|
+
}
|
|
186
|
+
else if (typeof item === "number" || typeof item === "boolean")
|
|
187
|
+
return res.concat([String(item)]);
|
|
188
|
+
return item;
|
|
189
|
+
}
|
|
190
|
+
if (!isTemplateStringsArray(strings)) {
|
|
191
|
+
return [strings]
|
|
192
|
+
.concat(values)
|
|
193
|
+
.reduce(addItemToRes, []);
|
|
194
|
+
}
|
|
195
|
+
let res = [];
|
|
196
|
+
for (let i = 0; i < strings.length; i++) {
|
|
197
|
+
res.push(strings[i]);
|
|
198
|
+
if (i < values.length)
|
|
199
|
+
res = addItemToRes(res, values[i]);
|
|
200
|
+
}
|
|
201
|
+
return res;
|
|
202
|
+
}
|
|
203
|
+
function isTemplateStringsArray(value) {
|
|
204
|
+
return value instanceof Array && value.raw instanceof Array &&
|
|
205
|
+
value.length === value.raw.length;
|
|
206
|
+
}
|
|
207
|
+
//# sourceMappingURL=LlamaText.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LlamaText.js","sourceRoot":"","sources":["../../src/utils/LlamaText.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReplHistory.js","sourceRoot":"","sources":["../../src/utils/ReplHistory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,UAAU,CAAC;AAC1B,OAAO,EAAC,QAAQ,EAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"ReplHistory.js","sourceRoot":"","sources":["../../src/utils/ReplHistory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Token, Tokenizer } from "../types.js";
|
|
2
|
+
import { LlamaText } from "./LlamaText.js";
|
|
3
|
+
import { QueuedTokenRelease, QueuedTokenReleaseLock } from "./TokenStreamRegulator.js";
|
|
4
|
+
export type StopGenerationTrigger = (string | Token)[];
|
|
5
|
+
export declare class StopGenerationDetector<T extends string = string> {
|
|
6
|
+
recordGeneration({ text, tokens, queuedTokenRelease, startNewChecks }: {
|
|
7
|
+
text: string;
|
|
8
|
+
tokens: Token[];
|
|
9
|
+
queuedTokenRelease?: QueuedTokenRelease;
|
|
10
|
+
startNewChecks?: boolean;
|
|
11
|
+
}): void;
|
|
12
|
+
addStopTrigger(stopTrigger: StopGenerationTrigger, completeEvent?: T): this;
|
|
13
|
+
/** Whether there are some stops that have been found and triggered. */
|
|
14
|
+
get hasTriggeredStops(): boolean;
|
|
15
|
+
/** Whether there are some stops that have been found, but not triggered yet. */
|
|
16
|
+
get hasInProgressStops(): boolean;
|
|
17
|
+
/** Gets the stops that have been found and triggered. */
|
|
18
|
+
getTriggeredStops(): {
|
|
19
|
+
stopTrigger: StopGenerationTrigger;
|
|
20
|
+
events: T[];
|
|
21
|
+
remainingGenerations: (string | Token[])[];
|
|
22
|
+
queuedTokenReleaseLocks: QueuedTokenReleaseLock[];
|
|
23
|
+
}[];
|
|
24
|
+
clearTriggeredStops(): void;
|
|
25
|
+
clearInProgressStops(): void;
|
|
26
|
+
static resolveStopTriggers(stopTriggers: readonly (StopGenerationTrigger | LlamaText)[], tokenizer: Tokenizer): StopGenerationTrigger[];
|
|
27
|
+
static resolveLlamaTextTrigger(llamaText: LlamaText, tokenizer: Tokenizer): StopGenerationTrigger;
|
|
28
|
+
}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { isLlamaText, SpecialToken } from "./LlamaText.js";
|
|
2
|
+
export class StopGenerationDetector {
|
|
3
|
+
/** @internal */ _stopTriggers = new Map();
|
|
4
|
+
/** @internal */ _activeChecks = new Set();
|
|
5
|
+
/** @internal */ _triggeredStops = new Map();
|
|
6
|
+
recordGeneration({ text, tokens, queuedTokenRelease, startNewChecks = true }) {
|
|
7
|
+
const currentActiveChecks = this._activeChecks;
|
|
8
|
+
this._activeChecks = new Set();
|
|
9
|
+
for (const check of currentActiveChecks) {
|
|
10
|
+
let lockUsed = false;
|
|
11
|
+
if (text.length > 0)
|
|
12
|
+
lockUsed ||= this._checkTriggerPart(check, text);
|
|
13
|
+
else {
|
|
14
|
+
this._activeChecks.add(check);
|
|
15
|
+
lockUsed = true;
|
|
16
|
+
}
|
|
17
|
+
if (tokens.length > 0)
|
|
18
|
+
lockUsed ||= this._checkTriggerPart(check, tokens);
|
|
19
|
+
else {
|
|
20
|
+
this._activeChecks.add(check);
|
|
21
|
+
lockUsed = true;
|
|
22
|
+
}
|
|
23
|
+
if (!lockUsed)
|
|
24
|
+
check.queuedTokenReleaseLock?.dispose();
|
|
25
|
+
}
|
|
26
|
+
if (!startNewChecks)
|
|
27
|
+
return;
|
|
28
|
+
for (let i = 0; i < text.length; i++) {
|
|
29
|
+
const char = text[i];
|
|
30
|
+
const currentPart = this._stopTriggers.get(char);
|
|
31
|
+
if (currentPart == null)
|
|
32
|
+
continue;
|
|
33
|
+
const textCheck = {
|
|
34
|
+
queuedTokenReleaseLock: queuedTokenRelease?.createTextIndexLock(i),
|
|
35
|
+
currentPart
|
|
36
|
+
};
|
|
37
|
+
const lockUsed = this._checkTriggerPart(textCheck, text.slice(i + 1));
|
|
38
|
+
if (!lockUsed)
|
|
39
|
+
textCheck.queuedTokenReleaseLock?.dispose();
|
|
40
|
+
}
|
|
41
|
+
for (let i = 0; i < tokens.length; i++) {
|
|
42
|
+
const token = tokens[i];
|
|
43
|
+
const currentPart = this._stopTriggers.get(token);
|
|
44
|
+
if (currentPart == null)
|
|
45
|
+
continue;
|
|
46
|
+
const tokenCheck = {
|
|
47
|
+
queuedTokenReleaseLock: queuedTokenRelease?.createTokenIndexLock(i),
|
|
48
|
+
currentPart
|
|
49
|
+
};
|
|
50
|
+
const lockUsed = this._checkTriggerPart(tokenCheck, tokens.slice(i + 1));
|
|
51
|
+
if (!lockUsed)
|
|
52
|
+
tokenCheck.queuedTokenReleaseLock?.dispose();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
addStopTrigger(stopTrigger, completeEvent) {
|
|
56
|
+
const simplifiedTrigger = simplifyStopTrigger(stopTrigger);
|
|
57
|
+
const triggerValues = simplifiedTrigger
|
|
58
|
+
.map((item) => {
|
|
59
|
+
if (typeof item === "string")
|
|
60
|
+
return item.split("");
|
|
61
|
+
else
|
|
62
|
+
return [item];
|
|
63
|
+
})
|
|
64
|
+
.flat(1);
|
|
65
|
+
let currentMap = this._stopTriggers;
|
|
66
|
+
for (let i = 0; i < triggerValues.length; i++) {
|
|
67
|
+
const value = triggerValues[i];
|
|
68
|
+
const isLast = i === triggerValues.length - 1;
|
|
69
|
+
if (!currentMap.has(value)) {
|
|
70
|
+
currentMap.set(value, {
|
|
71
|
+
next: new Map()
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
const part = currentMap.get(value);
|
|
75
|
+
if (isLast) {
|
|
76
|
+
part.next = undefined;
|
|
77
|
+
part.completesTrigger = simplifiedTrigger;
|
|
78
|
+
part.completeEvents = part.completeEvents ?? new Set();
|
|
79
|
+
if (completeEvent != null)
|
|
80
|
+
part.completeEvents.add(completeEvent);
|
|
81
|
+
}
|
|
82
|
+
else if (part.next == null)
|
|
83
|
+
break;
|
|
84
|
+
else
|
|
85
|
+
currentMap = part.next;
|
|
86
|
+
}
|
|
87
|
+
return this;
|
|
88
|
+
}
|
|
89
|
+
/** Whether there are some stops that have been found and triggered. */
|
|
90
|
+
get hasTriggeredStops() {
|
|
91
|
+
return this._triggeredStops.size > 0;
|
|
92
|
+
}
|
|
93
|
+
/** Whether there are some stops that have been found, but not triggered yet. */
|
|
94
|
+
get hasInProgressStops() {
|
|
95
|
+
return this._activeChecks.size > 0;
|
|
96
|
+
}
|
|
97
|
+
/** Gets the stops that have been found and triggered. */
|
|
98
|
+
getTriggeredStops() {
|
|
99
|
+
const res = [];
|
|
100
|
+
for (const [triggerPart, triggeredStop] of this._triggeredStops.entries()) {
|
|
101
|
+
res.push({
|
|
102
|
+
stopTrigger: triggerPart.completesTrigger,
|
|
103
|
+
events: Array.from(triggerPart.completeEvents ?? new Set()),
|
|
104
|
+
remainingGenerations: Array.from(triggeredStop.remainingGenerations),
|
|
105
|
+
queuedTokenReleaseLocks: Array.from(triggeredStop.queuedTokenReleaseLocks)
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
return res;
|
|
109
|
+
}
|
|
110
|
+
clearTriggeredStops() {
|
|
111
|
+
for (const triggeredStop of this._triggeredStops.values()) {
|
|
112
|
+
for (const queuedTokenReleaseLock of triggeredStop.queuedTokenReleaseLocks)
|
|
113
|
+
queuedTokenReleaseLock.dispose();
|
|
114
|
+
}
|
|
115
|
+
this._triggeredStops.clear();
|
|
116
|
+
}
|
|
117
|
+
clearInProgressStops() {
|
|
118
|
+
for (const check of this._activeChecks)
|
|
119
|
+
check.queuedTokenReleaseLock?.dispose();
|
|
120
|
+
this._activeChecks.clear();
|
|
121
|
+
}
|
|
122
|
+
/** @internal */
|
|
123
|
+
_addFoundStop(part, remainingGeneration, queuedTokenReleaseLock) {
|
|
124
|
+
if (!this._triggeredStops.has(part))
|
|
125
|
+
this._triggeredStops.set(part, {
|
|
126
|
+
remainingGenerations: new Set(),
|
|
127
|
+
queuedTokenReleaseLocks: new Set()
|
|
128
|
+
});
|
|
129
|
+
const triggeredStop = this._triggeredStops.get(part);
|
|
130
|
+
if (remainingGeneration != null)
|
|
131
|
+
triggeredStop.remainingGenerations.add(remainingGeneration);
|
|
132
|
+
if (queuedTokenReleaseLock != null)
|
|
133
|
+
triggeredStop.queuedTokenReleaseLocks.add(queuedTokenReleaseLock);
|
|
134
|
+
}
|
|
135
|
+
/** @internal */
|
|
136
|
+
_checkTriggerPart(check, value) {
|
|
137
|
+
if (check == null)
|
|
138
|
+
return false;
|
|
139
|
+
let part = check.currentPart;
|
|
140
|
+
for (let i = 0; i < value.length && part != null; i++) {
|
|
141
|
+
const item = value[i];
|
|
142
|
+
if (part.next == null) {
|
|
143
|
+
this._addFoundStop(part, value.slice(i), check.queuedTokenReleaseLock);
|
|
144
|
+
return true;
|
|
145
|
+
}
|
|
146
|
+
if (part.next.has(item)) {
|
|
147
|
+
part = part.next.get(item);
|
|
148
|
+
continue;
|
|
149
|
+
}
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
if (part == null)
|
|
153
|
+
return false;
|
|
154
|
+
if (part.next == null) {
|
|
155
|
+
this._addFoundStop(part, undefined, check.queuedTokenReleaseLock);
|
|
156
|
+
return true;
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
this._activeChecks.add({
|
|
160
|
+
...check,
|
|
161
|
+
currentPart: part
|
|
162
|
+
});
|
|
163
|
+
return true;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
static resolveStopTriggers(stopTriggers, tokenizer) {
|
|
167
|
+
return stopTriggers.map((stopTrigger) => {
|
|
168
|
+
if (isLlamaText(stopTrigger))
|
|
169
|
+
return StopGenerationDetector.resolveLlamaTextTrigger(stopTrigger, tokenizer);
|
|
170
|
+
else
|
|
171
|
+
return simplifyStopTrigger(stopTrigger);
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
static resolveLlamaTextTrigger(llamaText, tokenizer) {
|
|
175
|
+
return simplifyStopTrigger(llamaText.values
|
|
176
|
+
.filter(value => value !== "")
|
|
177
|
+
.map((value) => {
|
|
178
|
+
if (typeof value === "string")
|
|
179
|
+
return [value];
|
|
180
|
+
else if (value instanceof SpecialToken)
|
|
181
|
+
return value.tokenize(tokenizer);
|
|
182
|
+
return value;
|
|
183
|
+
})
|
|
184
|
+
.flat(1));
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
function simplifyStopTrigger(stopTrigger) {
|
|
188
|
+
let text = "";
|
|
189
|
+
const res = [];
|
|
190
|
+
for (const item of stopTrigger) {
|
|
191
|
+
if (typeof item === "string") {
|
|
192
|
+
text += item;
|
|
193
|
+
continue;
|
|
194
|
+
}
|
|
195
|
+
if (text !== "") {
|
|
196
|
+
res.push(text);
|
|
197
|
+
text = "";
|
|
198
|
+
}
|
|
199
|
+
res.push(item);
|
|
200
|
+
}
|
|
201
|
+
if (text !== "")
|
|
202
|
+
res.push(text);
|
|
203
|
+
return res;
|
|
204
|
+
}
|
|
205
|
+
//# sourceMappingURL=StopGenerationDetector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StopGenerationDetector.js","sourceRoot":"","sources":["../../src/utils/StopGenerationDetector.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Token } from "../types.js";
|
|
2
|
+
export declare class TokenStreamRegulator {
|
|
3
|
+
addChunk({ tokens, text }: {
|
|
4
|
+
tokens: Token[];
|
|
5
|
+
text: string;
|
|
6
|
+
}): QueuedTokenRelease;
|
|
7
|
+
popFreeChunkTokens(): Token[];
|
|
8
|
+
getPartiallyFreeChunk(): {
|
|
9
|
+
tokens: Token[];
|
|
10
|
+
text: string;
|
|
11
|
+
};
|
|
12
|
+
getAllQueuedChunkTokens(): Token[];
|
|
13
|
+
}
|
|
14
|
+
export declare class QueuedTokenRelease {
|
|
15
|
+
readonly tokens: readonly Token[];
|
|
16
|
+
readonly text: string;
|
|
17
|
+
private constructor();
|
|
18
|
+
get isFree(): boolean;
|
|
19
|
+
get isPartiallyFree(): boolean;
|
|
20
|
+
getFreeTextIndex(): number;
|
|
21
|
+
getFreeTokenIndex(): number;
|
|
22
|
+
createTextIndexLock(startIndex: number): QueuedTokenReleaseLock;
|
|
23
|
+
createTokenIndexLock(startIndex: number): QueuedTokenReleaseLock;
|
|
24
|
+
}
|
|
25
|
+
export declare class QueuedTokenReleaseLock {
|
|
26
|
+
private constructor();
|
|
27
|
+
get index(): number;
|
|
28
|
+
dispose(): void;
|
|
29
|
+
[Symbol.dispose](): void;
|
|
30
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
export class TokenStreamRegulator {
|
|
2
|
+
/** @internal */ _queue = [];
|
|
3
|
+
addChunk({ tokens, text }) {
|
|
4
|
+
const queuedRelease = QueuedTokenRelease._create(tokens, text);
|
|
5
|
+
this._queue.push(queuedRelease);
|
|
6
|
+
return queuedRelease;
|
|
7
|
+
}
|
|
8
|
+
popFreeChunkTokens() {
|
|
9
|
+
const res = [];
|
|
10
|
+
while (this._queue.length > 0 && this._queue[0].isFree)
|
|
11
|
+
res.push(...this._queue.shift().tokens);
|
|
12
|
+
return res;
|
|
13
|
+
}
|
|
14
|
+
getPartiallyFreeChunk() {
|
|
15
|
+
if (this._queue.length > 0 && this._queue[0].isPartiallyFree) {
|
|
16
|
+
const queuedRelease = this._queue[0];
|
|
17
|
+
return {
|
|
18
|
+
tokens: queuedRelease.tokens.slice(0, queuedRelease.getFreeTokenIndex()),
|
|
19
|
+
text: queuedRelease.text.slice(0, queuedRelease.getFreeTextIndex())
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
return {
|
|
23
|
+
tokens: [],
|
|
24
|
+
text: ""
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
getAllQueuedChunkTokens() {
|
|
28
|
+
return this._queue.flatMap((queuedRelease) => queuedRelease.tokens);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export class QueuedTokenRelease {
|
|
32
|
+
/** @internal */ _textLocks = new Set();
|
|
33
|
+
/** @internal */ _tokenLocks = new Set();
|
|
34
|
+
tokens;
|
|
35
|
+
text;
|
|
36
|
+
constructor(tokens, text) {
|
|
37
|
+
this.tokens = tokens;
|
|
38
|
+
this.text = text;
|
|
39
|
+
}
|
|
40
|
+
get isFree() {
|
|
41
|
+
return this._textLocks.size === 0 && this._tokenLocks.size === 0;
|
|
42
|
+
}
|
|
43
|
+
get isPartiallyFree() {
|
|
44
|
+
return this._textLocks.size !== 0 && this._tokenLocks.size !== 0;
|
|
45
|
+
}
|
|
46
|
+
getFreeTextIndex() {
|
|
47
|
+
if (this._textLocks.size === 0)
|
|
48
|
+
return this.text.length;
|
|
49
|
+
return [...this._textLocks]
|
|
50
|
+
.reduce((res, lock) => Math.min(res, lock.index), this.text.length);
|
|
51
|
+
}
|
|
52
|
+
getFreeTokenIndex() {
|
|
53
|
+
if (this._tokenLocks.size === 0)
|
|
54
|
+
return this.tokens.length;
|
|
55
|
+
return [...this._tokenLocks]
|
|
56
|
+
.reduce((res, lock) => Math.min(res, lock.index), this.tokens.length);
|
|
57
|
+
}
|
|
58
|
+
createTextIndexLock(startIndex) {
|
|
59
|
+
const lock = QueuedTokenReleaseLock._create(startIndex, this._textLocks);
|
|
60
|
+
if (startIndex >= 0 && startIndex < this.text.length)
|
|
61
|
+
this._textLocks.add(lock);
|
|
62
|
+
return lock;
|
|
63
|
+
}
|
|
64
|
+
createTokenIndexLock(startIndex) {
|
|
65
|
+
const lock = QueuedTokenReleaseLock._create(startIndex, this._tokenLocks);
|
|
66
|
+
if (startIndex >= 0 && startIndex < this.tokens.length)
|
|
67
|
+
this._tokenLocks.add(lock);
|
|
68
|
+
return lock;
|
|
69
|
+
}
|
|
70
|
+
/** @internal */
|
|
71
|
+
static _create(tokens, text) {
|
|
72
|
+
return new QueuedTokenRelease(tokens, text);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
export class QueuedTokenReleaseLock {
|
|
76
|
+
/** @internal */ _index;
|
|
77
|
+
/** @internal */ _locks;
|
|
78
|
+
constructor(index, locks) {
|
|
79
|
+
this._index = index;
|
|
80
|
+
this._locks = locks;
|
|
81
|
+
}
|
|
82
|
+
get index() {
|
|
83
|
+
return this._index;
|
|
84
|
+
}
|
|
85
|
+
dispose() {
|
|
86
|
+
this._locks.delete(this);
|
|
87
|
+
}
|
|
88
|
+
[Symbol.dispose]() {
|
|
89
|
+
this.dispose();
|
|
90
|
+
}
|
|
91
|
+
/** @internal */
|
|
92
|
+
static _create(length, locks) {
|
|
93
|
+
return new QueuedTokenReleaseLock(length, locks);
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=TokenStreamRegulator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TokenStreamRegulator.js","sourceRoot":"","sources":["../../src/utils/TokenStreamRegulator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export function appendUserMessageToChatHistory(chatHistory, message) {
|
|
2
|
+
const newChatHistory = chatHistory.slice();
|
|
3
|
+
if (newChatHistory.length > 0 && newChatHistory[newChatHistory.length - 1].type === "user") {
|
|
4
|
+
const lastUserMessage = newChatHistory[newChatHistory.length - 1];
|
|
5
|
+
newChatHistory[newChatHistory.length - 1] = {
|
|
6
|
+
...lastUserMessage,
|
|
7
|
+
text: [lastUserMessage.text, message].join("\n\n")
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
newChatHistory.push({
|
|
12
|
+
type: "user",
|
|
13
|
+
text: message
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
return newChatHistory;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=appendUserMessageToChatHistory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"appendUserMessageToChatHistory.js","sourceRoot":"","sources":["../../src/utils/appendUserMessageToChatHistory.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,8BAA8B,CAAC,WAAuC,EAAE,OAAe;IACnG,MAAM,cAAc,GAAG,WAAW,CAAC,KAAK,EAAE,CAAC;IAE3C,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,IAAI,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,EAAE;QACxF,MAAM,eAAe,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAoB,CAAC;QAErF,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG;YACxC,GAAG,eAAe;YAClB,IAAI,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;SACrD,CAAC;KACL;SAAM;QACH,cAAc,CAAC,IAAI,CAAC;YAChB,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,OAAO;SAChB,CAAC,CAAC;KACN;IAED,OAAO,cAAc,CAAC;AAC1B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compareTokens.js","sourceRoot":"","sources":["../../src/utils/compareTokens.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,aAAa,CAAC,MAAa,EAAE,MAAa;IACtD,OAAO,MAAM,KAAK,MAAM,CAAC;AAC7B,CAAC"}
|