Merge pull request #16718 from Haoming02/bracket-checker-order

[Bracket Checker] Also check for the order of brackets
This commit is contained in:
w-e-w 2024-12-18 02:37:30 +09:00 committed by GitHub
commit e8c3b1f2a0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -1,36 +1,69 @@
// Stable Diffusion WebUI - Bracket checker // Stable Diffusion WebUI - Bracket Checker
// By Hingashi no Florin/Bwin4L & @akx // By @Bwin4L, @akx, @w-e-w, @Haoming02
// Counts open and closed brackets (round, square, curly) in the prompt and negative prompt text boxes in the txt2img and img2img tabs. // Counts open and closed brackets (round, square, curly) in the prompt and negative prompt text boxes in the txt2img and img2img tabs.
// If there's a mismatch, the keyword counter turns red and if you hover on it, a tooltip tells you what's wrong. // If there's a mismatch, the keyword counter turns red, and if you hover on it, a tooltip tells you what's wrong.
function checkBrackets(textArea, counterElem) {
const pairs = [
['(', ')', 'round brackets'],
['[', ']', 'square brackets'],
['{', '}', 'curly brackets']
];
function checkBrackets(textArea, counterElt) {
const counts = {}; const counts = {};
textArea.value.matchAll(/(?<!\\)(?:\\\\)*?([(){}[\]])/g).forEach(bracket => { const errors = new Set();
counts[bracket[1]] = (counts[bracket[1]] || 0) + 1; let i = 0;
});
const errors = [];
function checkPair(open, close, kind) { while (i < textArea.value.length) {
if (counts[open] !== counts[close]) { let char = textArea.value[i];
errors.push( let escaped = false;
`${open}...${close} - Detected ${counts[open] || 0} opening and ${counts[close] || 0} closing ${kind}.` while (char === '\\' && i + 1 < textArea.value.length) {
); escaped = !escaped;
i++;
char = textArea.value[i];
}
if (escaped) {
i++;
continue;
}
for (const [open, close, label] of pairs) {
if (char === open) {
counts[label] = (counts[label] || 0) + 1;
} else if (char === close) {
counts[label] = (counts[label] || 0) - 1;
if (counts[label] < 0) {
errors.add(`Incorrect order of ${label}.`);
}
}
}
i++;
}
for (const [open, close, label] of pairs) {
if (counts[label] == undefined) {
continue;
}
if (counts[label] > 0) {
errors.add(`${open} ... ${close} - Detected ${counts[label]} more opening than closing ${label}.`);
} else if (counts[label] < 0) {
errors.add(`${open} ... ${close} - Detected ${-counts[label]} more closing than opening ${label}.`);
} }
} }
checkPair('(', ')', 'round brackets'); counterElem.title = [...errors].join('\n');
checkPair('[', ']', 'square brackets'); counterElem.classList.toggle('error', errors.size !== 0);
checkPair('{', '}', 'curly brackets');
counterElt.title = errors.join('\n');
counterElt.classList.toggle('error', errors.length !== 0);
} }
function setupBracketChecking(id_prompt, id_counter) { function setupBracketChecking(id_prompt, id_counter) {
var textarea = gradioApp().querySelector("#" + id_prompt + " > label > textarea"); const textarea = gradioApp().querySelector(`#${id_prompt} > label > textarea`);
var counter = gradioApp().getElementById(id_counter); const counter = gradioApp().getElementById(id_counter);
if (textarea && counter) { if (textarea && counter) {
textarea.addEventListener("input", () => checkBrackets(textarea, counter)); onEdit(`${id_prompt}_BracketChecking`, textarea, 400, () => checkBrackets(textarea, counter));
} }
} }