Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: fix parser #95

Merged
merged 21 commits into from
Oct 31, 2023
Merged
Changes from 1 commit
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
d26e185
chore: update followup questions preliminary
anfibiacreativa Oct 26, 2023
e9075c6
chore: update styles
anfibiacreativa Oct 26, 2023
4868a48
chore: restyle followup questions
anfibiacreativa Oct 26, 2023
fb45e89
chore: fix parser for follow up questions (before TC)
anfibiacreativa Oct 27, 2023
8b04c0b
chore: fix bug and adapt styles
anfibiacreativa Oct 27, 2023
5a9e5aa
chore: add margin to citations
anfibiacreativa Oct 27, 2023
80436e3
chore: remove commented regex
anfibiacreativa Oct 27, 2023
6449f69
fix: remove unnecessary regex and replace
anfibiacreativa Oct 27, 2023
e0de7af
chore: update global config
anfibiacreativa Oct 27, 2023
1362575
chore: add question icon
anfibiacreativa Oct 27, 2023
8fe2d31
chore: update styles
anfibiacreativa Oct 27, 2023
f79735c
chore: update comments to reflect decisions
anfibiacreativa Oct 27, 2023
65d3533
chore: refine cosmetic styles
anfibiacreativa Oct 30, 2023
bb0baf3
chore: replace icons with iconcloud set
anfibiacreativa Oct 30, 2023
3ea28cd
fix: fix minor bug with index replacement
anfibiacreativa Oct 30, 2023
e7b394e
test: add E2E playwright tests for web app (#89)
shibbas Oct 26, 2023
0ff12b6
docs: update readme with auth info
anfibiacreativa Oct 27, 2023
f7e801f
test: add load tests (#93)
shibbas Oct 27, 2023
f6719f1
test: add playwright test for ask interaction (#94)
shibbas Oct 27, 2023
444eeef
ci: disable playwright for demo
anfibiacreativa Oct 31, 2023
7b1abaf
ci: revert previous commit and disable from UI
anfibiacreativa Oct 31, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 7 additions & 1 deletion packages/chat-component/src/core/parser/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,9 +52,10 @@ export async function parseStreamedMessages({
// followup questions are marked either with the word 'Next Questions:' or '<<text>>' or both at the same time
// these markers may be split across multiple chunks, so we need to buffer them!
// TODO: remove all this logic from the frontend and implement a solution on the backend or with TypeChat

// we start by creating a buffer when we match the first marker
const matchedFollowupQuestionMarker =
(!isFollowupQuestion && chunkValue.includes('Next')) || chunkValue.includes('<<');
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

btw should we still parse Next markers? Is the new model still using Next to format followup questions?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If the updated model uses only << and >> to format followup questions, then I'd suggest changing the condition to:

const matchedFollowupQuestionMarker = !isFollowupQuestion && chunkValue.includes('<<');

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good question. @sinedied can you clarify?

// once we do, we can assume that we are processing a followup question and set the flag to true
if (matchedFollowupQuestionMarker) {
isFollowupQuestion = true;
followupQuestionsBuffer.push(chunkValue);
Expand All @@ -63,13 +64,18 @@ export async function parseStreamedMessages({
isFollowupQuestion = true;
followupQuestionsBuffer.push(chunkValue);
continue;
// if we're already processing questions, we don't need to check for the marker again
// but we need to check if we reached the end of the followup questions
} else if (chunkValue.includes('<<') && isFollowupQuestion) {
isFollowupQuestion = true;
continue;
// this updates the index, so we add each question to a different array entry
// to simplify styling
} else if (chunkValue.includes('?>') || chunkValue.includes('>')) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why are we checking for ?> && > and not ?>> && >>?

Copy link
Member Author

@anfibiacreativa anfibiacreativa Oct 30, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Because in all tests I ran, ?> and the last > were returned as part of 2 different chunks, and there was never a match.

followUpQuestionIndex = followUpQuestionIndex + 1;
isFollowupQuestion = true;
continue;
// additional returns need to be removed, but only after we have processed the whole set of chunks
} else if (isFollowupQuestion) {
isFollowupQuestion = true;
chunkValue = chunkValue.replace(/:?\n/, '');
manekinekko marked this conversation as resolved.
Show resolved Hide resolved
Expand Down