aboutsummaryrefslogtreecommitdiffstats
path: root/javascript
diff options
context:
space:
mode:
authormissionfloyd <missionfloyd@users.noreply.github.com>2023-04-20 07:34:13 +0000
committermissionfloyd <missionfloyd@users.noreply.github.com>2023-04-20 07:34:13 +0000
commitee172c0fc13aeb3a8c1f4a8da63551dcb93fc5ec (patch)
treee526e86b6956447c19388243520e2b18048c325d /javascript
parentfbd34a68478caa528507fab830e3ac33a26fc6f4 (diff)
downloadstable-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.js26
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;
}