mirror of
https://github.com/godotengine/godot.git
synced 2025-12-31 01:49:10 +03:00
[TextServer] Fix duplicated losing span info, and RID leak.
This commit is contained in:
@@ -4495,9 +4495,10 @@ RID TextServerAdvanced::_shaped_text_duplicate(const RID &p_shaped) {
|
||||
MutexLock lock(sd->mutex);
|
||||
|
||||
ShapedTextDataAdvanced *new_sd = memnew(ShapedTextDataAdvanced);
|
||||
new_sd->parent = p_shaped;
|
||||
new_sd->start = sd->start;
|
||||
new_sd->end = sd->end;
|
||||
new_sd->first_span = sd->first_span;
|
||||
new_sd->last_span = sd->last_span;
|
||||
new_sd->text = sd->text;
|
||||
new_sd->hb_buffer = hb_buffer_create();
|
||||
new_sd->utf16 = new_sd->text.utf16();
|
||||
@@ -4517,7 +4518,12 @@ RID TextServerAdvanced::_shaped_text_duplicate(const RID &p_shaped) {
|
||||
for (int i = 0; i < TextServer::SPACING_MAX; i++) {
|
||||
new_sd->extra_spacing[i] = sd->extra_spacing[i];
|
||||
}
|
||||
full_copy(new_sd);
|
||||
for (const KeyValue<Variant, ShapedTextDataAdvanced::EmbeddedObject> &E : sd->objects) {
|
||||
new_sd->objects[E.key] = E.value;
|
||||
}
|
||||
for (int i = 0; i < sd->spans.size(); i++) {
|
||||
new_sd->spans.push_back(sd->spans[i]);
|
||||
}
|
||||
new_sd->valid.clear();
|
||||
|
||||
return shaped_owner.make_rid(new_sd);
|
||||
|
||||
@@ -3336,6 +3336,8 @@ RID TextServerFallback::_shaped_text_duplicate(const RID &p_shaped) {
|
||||
new_sd->parent = p_shaped;
|
||||
new_sd->start = sd->start;
|
||||
new_sd->end = sd->end;
|
||||
new_sd->first_span = sd->first_span;
|
||||
new_sd->last_span = sd->last_span;
|
||||
new_sd->text = sd->text;
|
||||
new_sd->orientation = sd->orientation;
|
||||
new_sd->direction = sd->direction;
|
||||
@@ -3351,7 +3353,12 @@ RID TextServerFallback::_shaped_text_duplicate(const RID &p_shaped) {
|
||||
for (int i = 0; i < TextServer::SPACING_MAX; i++) {
|
||||
new_sd->extra_spacing[i] = sd->extra_spacing[i];
|
||||
}
|
||||
full_copy(new_sd);
|
||||
for (const KeyValue<Variant, ShapedTextDataFallback::EmbeddedObject> &E : sd->objects) {
|
||||
new_sd->objects[E.key] = E.value;
|
||||
}
|
||||
for (int i = 0; i < sd->spans.size(); i++) {
|
||||
new_sd->spans.push_back(sd->spans[i]);
|
||||
}
|
||||
new_sd->valid.clear();
|
||||
|
||||
return shaped_owner.make_rid(new_sd);
|
||||
|
||||
@@ -155,6 +155,7 @@ Ref<TextLine> TextLine::duplicate() const {
|
||||
Ref<TextLine> copy;
|
||||
copy.instantiate();
|
||||
if (rid.is_valid()) {
|
||||
TS->free_rid(copy->rid);
|
||||
copy->rid = TS->shaped_text_duplicate(rid);
|
||||
}
|
||||
copy->dirty = true;
|
||||
|
||||
@@ -328,11 +328,13 @@ Ref<TextParagraph> TextParagraph::duplicate() const {
|
||||
Ref<TextParagraph> copy;
|
||||
copy.instantiate();
|
||||
if (dropcap_rid.is_valid()) {
|
||||
TS->free_rid(copy->dropcap_rid);
|
||||
copy->dropcap_rid = TS->shaped_text_duplicate(dropcap_rid);
|
||||
}
|
||||
copy->dropcap_lines = dropcap_lines;
|
||||
copy->dropcap_margins = dropcap_margins;
|
||||
if (rid.is_valid()) {
|
||||
TS->free_rid(copy->rid);
|
||||
copy->rid = TS->shaped_text_duplicate(rid);
|
||||
}
|
||||
copy->lines_dirty = true;
|
||||
|
||||
Reference in New Issue
Block a user