diff options
author | missionfloyd <missionfloyd@users.noreply.github.com> | 2023-04-20 07:34:13 +0000 |
---|---|---|
committer | missionfloyd <missionfloyd@users.noreply.github.com> | 2023-04-20 07:34:13 +0000 |
commit | ee172c0fc13aeb3a8c1f4a8da63551dcb93fc5ec (patch) | |
tree | e526e86b6956447c19388243520e2b18048c325d /javascript | |
parent | fbd34a68478caa528507fab830e3ac33a26fc6f4 (diff) | |
download | stable-diffusion-webui-gfx803-ee172c0fc13aeb3a8c1f4a8da63551dcb93fc5ec.tar.gz stable-diffusion-webui-gfx803-ee172c0fc13aeb3a8c1f4a8da63551dcb93fc5ec.tar.bz2 stable-diffusion-webui-gfx803-ee172c0fc13aeb3a8c1f4a8da63551dcb93fc5ec.zip |
Simplify finding word boundaries
This also makes it work with prompts without spaces between words
Diffstat (limited to 'javascript')
-rw-r--r-- | javascript/edit-attention.js | 26 |
1 files changed, 9 insertions, 17 deletions
diff --git a/javascript/edit-attention.js b/javascript/edit-attention.js index 01d37074..80d7c01c 100644 --- a/javascript/edit-attention.js +++ b/javascript/edit-attention.js @@ -46,26 +46,18 @@ function keyupEditAttention(event){ function selectCurrentWord(){
if (selectionStart !== selectionEnd) return false;
- const delimiters = ".,\/#!$%\^&\*;:{}=\-_`~()";
+ const delimiters = ".,\/#!$%\^&\*;:{}=\-_`~() ";
- // Select the current word, find the start and end of the word (first space before and after)
- const wordStart = text.substring(0, selectionStart).lastIndexOf(" ") + 1;
- const wordEnd = text.substring(selectionEnd).indexOf(" ");
- // If there is no space after the word, select to the end of the string
- if (wordEnd === -1) {
- selectionEnd = text.length;
- } else {
- selectionEnd += wordEnd;
+ // seek backward until to find beggining
+ while (!delimiters.includes(text[selectionStart - 1]) && selectionStart > 0) {
+ selectionStart--;
}
- selectionStart = wordStart;
-
- // Remove all punctuation at the end and beginning of the word
- while (delimiters.includes(text[selectionStart])) {
- selectionStart++;
- }
- while (delimiters.includes(text[selectionEnd - 1])) {
- selectionEnd--;
+
+ // seek forward to find end
+ while (!delimiters.includes(text[selectionEnd]) && selectionEnd < text.length) {
+ selectionEnd++;
}
+
target.setSelectionRange(selectionStart, selectionEnd);
return true;
}
|