summaryrefslogtreecommitdiff
path: root/scene/gui
diff options
context:
space:
mode:
authormvl <marnicq_the_best@hotmail.com>2020-07-24 01:42:40 +0200
committermvl <marnicq_the_best@hotmail.com>2020-08-31 20:09:28 +0200
commit4318ad94acb2f1f3dabfed1d5159da6fe013b529 (patch)
tree50f17cb7362429c21e3453524e294a8bce62829b /scene/gui
parent2cfc5b8680bf7c1f75b02f83f7ecc26d1e49021f (diff)
Fix bug where leading and trailing spaces werent taken into account with center and right allignment.
Diffstat (limited to 'scene/gui')
-rw-r--r--scene/gui/label.cpp18
1 files changed, 17 insertions, 1 deletions
diff --git a/scene/gui/label.cpp b/scene/gui/label.cpp
index f49acc1b96..321f907cc7 100644
--- a/scene/gui/label.cpp
+++ b/scene/gui/label.cpp
@@ -188,7 +188,7 @@ void Label::_notification(int p_what) {
int spaces = 0;
while (to && to->char_pos >= 0) {
taken += to->pixel_width;
- if (to != from && to->space_count) {
+ if (to->space_count) {
spaces += to->space_count;
}
to = to->next;
@@ -420,6 +420,22 @@ void Label::regenerate_word_cache() {
wc->space_count = space_count;
current_word_size = 0;
space_count = 0;
+ } else if ((i == xl_text.length() || current == '\n') && last != nullptr && space_count != 0) {
+ //in case there are trailing white spaces we add a placeholder word cache with just the spaces
+ WordCache *wc = memnew(WordCache);
+ if (word_cache) {
+ last->next = wc;
+ } else {
+ word_cache = wc;
+ }
+ last = wc;
+
+ wc->pixel_width = 0;
+ wc->char_pos = 0;
+ wc->word_len = 0;
+ wc->space_count = space_count;
+ current_word_size = 0;
+ space_count = 0;
}
if (current == '\n') {