summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShilpa Singh <shilpa.singh@samsung.com>2020-04-07 20:23:46 +0900
committerShinwoo Kim <cinoo.kim@samsung.com>2020-04-07 20:23:46 +0900
commitea75b6913455c28eb54c74af2f4e461266aed6f8 (patch)
tree93f109ed01aa8ac31e072d01fb12a6e0884e761d
parentf47371330a6d031a7421cb560511767a3a87a625 (diff)
downloadefl-ea75b6913455c28eb54c74af2f4e461266aed6f8.tar.gz
elm_entry, accessibility: Send utf8 text instead of markup to ATSPI client
Summary: Markup text cannot be read as per expectation by a text to speech engine, hence send text in UTF8 format Test Plan: Test the text returned by connecting to object:text-changed:insert and object:text-changed:delete events in ATSPI-clients Reviewers: kimcinoo Subscribers: cedric, #reviewers, #committers Tags: #efl Differential Revision: https://phab.enlightenment.org/D11660
-rw-r--r--src/lib/elementary/elm_entry.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/lib/elementary/elm_entry.c b/src/lib/elementary/elm_entry.c
index 60008e6326..af8445b432 100644
--- a/src/lib/elementary/elm_entry.c
+++ b/src/lib/elementary/elm_entry.c
@@ -2263,17 +2263,19 @@ _entry_changed_user_signal_cb(void *data,
Efl_Access_Text_Change_Info atspi_info;
if (edje_info && edje_info->insert)
{
- atspi_info.content = edje_info->change.insert.content;
+ atspi_info.content = elm_entry_markup_to_utf8(edje_info->change.insert.content);
atspi_info.pos = edje_info->change.insert.pos;
atspi_info.len = edje_info->change.insert.plain_length;
- efl_access_object_event_emit( data, EFL_ACCESS_TEXT_EVENT_ACCESS_TEXT_INSERTED, &atspi_info);
+ efl_access_object_event_emit(data, EFL_ACCESS_TEXT_EVENT_ACCESS_TEXT_INSERTED, &atspi_info);
+ free((void *)atspi_info.content);
}
else if (edje_info && !edje_info->insert)
{
- atspi_info.content = edje_info->change.del.content;
+ atspi_info.content = elm_entry_markup_to_utf8(edje_info->change.del.content);
atspi_info.pos = MIN(edje_info->change.del.start, edje_info->change.del.end);
atspi_info.len = MAX(edje_info->change.del.start, edje_info->change.del.end) - atspi_info.pos;
- efl_access_object_event_emit( data, EFL_ACCESS_TEXT_EVENT_ACCESS_TEXT_REMOVED, &atspi_info);
+ efl_access_object_event_emit(data, EFL_ACCESS_TEXT_EVENT_ACCESS_TEXT_REMOVED, &atspi_info);
+ free((void *)atspi_info.content);
}
}
}