1
0
Fork 0
mirror of https://github.com/Ellpeck/MLEM.git synced 2024-11-26 14:38:34 +01:00

Compare commits

...

2 commits

2 changed files with 27 additions and 9 deletions

View file

@ -12,9 +12,15 @@ Jump to version:
## 6.2.0 (In Development) ## 6.2.0 (In Development)
### MLEM
Fixes
- Fixed control characters being included in TextInput
### MLEM.Ui ### MLEM.Ui
Fixes Fixes
- Fixed images not updating their hidden state properly when the displayed texture changes - Fixed images not updating their hidden state properly when the displayed texture changes
- Fixed control characters being included in TextField
- Fixed a multiline text field's cursor not returning to the default position when the last character is removed
## 6.1.0 ## 6.1.0

View file

@ -415,16 +415,20 @@ namespace MLEM.Input {
} }
private bool FilterText(ref string text, bool removeMismatching) { private bool FilterText(ref string text, bool removeMismatching) {
if (removeMismatching) {
var result = new StringBuilder(); var result = new StringBuilder();
foreach (var codePoint in new CodePointSource(text)) { foreach (var codePoint in new CodePointSource(text)) {
var character = char.ConvertFromUtf32(codePoint); var character = char.ConvertFromUtf32(codePoint);
if (this.InputRule(this, character)) // don't include control characters
if (character.Length == 1 && char.IsControl(character, 0))
continue;
if (this.InputRule(this, character)) {
result.Append(character); result.Append(character);
} else if (!removeMismatching) {
// if we don't remove mismatching characters, we just fail
return false;
}
} }
text = result.ToString(); text = result.ToString();
} else if (!this.InputRule(this, text))
return false;
return true; return true;
} }
@ -508,6 +512,14 @@ namespace MLEM.Input {
private void UpdateCaretData() { private void UpdateCaretData() {
if (this.splitText != null) { if (this.splitText != null) {
// the code below will never execute if our text is empty, so reset our caret position fully
if (this.splitText.Length <= 0) {
this.caretLine = 0;
this.caretPosInLine = 0;
this.caretDrawOffset = 0;
return;
}
var line = 0; var line = 0;
var index = 0; var index = 0;
for (var d = 0; d < this.splitText.Length; d++) { for (var d = 0; d < this.splitText.Length; d++) {