From ef642f5baf2b75e17940b11c0df7c40b4b3183c2 Mon Sep 17 00:00:00 2001 From: Heiner Lohaus Date: Tue, 7 Jan 2025 15:21:43 +0100 Subject: [PATCH] Improve merge_messages in GUI --- g4f/gui/client/static/js/chat.v1.js | 52 +++++++++++++++++++---------- 1 file changed, 34 insertions(+), 18 deletions(-) diff --git a/g4f/gui/client/static/js/chat.v1.js b/g4f/gui/client/static/js/chat.v1.js index cb32f5da9c7..036bca14534 100644 --- a/g4f/gui/client/static/js/chat.v1.js +++ b/g4f/gui/client/static/js/chat.v1.js @@ -994,30 +994,48 @@ const new_conversation = async () => { function merge_messages(message1, message2) { let newContent = message2; + // Remove start tokens if (newContent.startsWith("```")) { - const index = str.indexOf("\n"); - newContent = newContent.substring(index); + const index = newContent.indexOf("\n"); + if (index != -1) { + newContent = newContent.substring(index); + } } else if (newContent.startsWith("...")) { newContent = " " + newContent.substring(3); - } - // Remove duplicate words - if (newContent.indexOf(" ") > 0) { - let words = message1.trim().split(" "); - let lastWord = words[words.length - 1]; - if (newContent.startsWith(lastWord)) { - newContent = newContent.substring(lastWord.length); + } else { + // Remove duplicate lines + let lines = message1.trim().split("\n"); + let lastLine = lines[lines.length - 1]; + let foundLastLine = newContent.indexOf(lastLine + "\n"); + if (foundLastLine != -1) { + foundLastLine += 1; + } else { + foundLastLine = newContent.indexOf(lastLine); + } + if (foundLastLine != -1) { + newContent = newContent.substring(foundLastLine + lastLine.length); + } + // Remove duplicate words + if (foundLastLine == -1 && newContent.indexOf(" ") > 0) { + let words = message1.trim().split(" "); + let lastWord = words[words.length - 1]; + if (newContent.startsWith(lastWord)) { + newContent = newContent.substring(lastWord.length); + } } - } - // Remove duplicate lines - let lines = message1.trim().split("\n"); - let lastLine = lines[lines.length - 1]; - while (newContent && lastLine && newContent.startsWith(lastLine)) { - newContent = newContent.substring(lastLine.length); - lastLine = lines[lines.length - 1]; } return message1 + newContent; } +// console.log(merge_messages("Hello", "Hello,\nhow are you?")); +// console.log(merge_messages("Hello", "Hello, how are you?")); +// console.log(merge_messages("Hello", "Hello,\nhow are you?")); +// console.log(merge_messages("Hello,\n", "Hello,\nhow are you?")); +// console.log(merge_messages("Hello,\n", "how are you?")); +// console.log(merge_messages("1 != 2", "1 != 2;")); +// console.log(merge_messages("1 != 2", "```python\n1 != 2;")); +// console.log(merge_messages("1 != 2;\n1 != 3;\n", "1 != 2;\n1 != 3;\n")); + const load_conversation = async (conversation_id, scroll=true) => { let conversation = await get_conversation(conversation_id); let messages = conversation?.items || []; @@ -1039,7 +1057,6 @@ const load_conversation = async (conversation_id, scroll=true) => { let last_model = null; let providers = []; let buffer = ""; - let last_usage = null; let completion_tokens = 0; messages.forEach((item, i) => { @@ -1051,7 +1068,6 @@ const load_conversation = async (conversation_id, scroll=true) => { buffer = buffer.replace(/ \[aborted\]$/g, "").replace(/ \[error\]$/g, ""); buffer += merge_messages(buffer, item.content); last_model = item.provider?.model; - last_usage = item.usage; providers.push(item.provider?.name); let next_i = parseInt(i) + 1; let next_provider = item.provider ? item.provider : (messages.length > next_i ? messages[next_i].provider : null);