diff --git a/src/lib/evas/canvas/evas_object_textblock.c b/src/lib/evas/canvas/evas_object_textblock.c index 9ed2a33918..d1f6123562 100644 --- a/src/lib/evas/canvas/evas_object_textblock.c +++ b/src/lib/evas/canvas/evas_object_textblock.c @@ -7295,7 +7295,14 @@ _efl_canvas_text_style_set(Eo *eo_obj, Efl_Canvas_Text_Data *o, const char *key, ts = evas_textblock_style_new(); evas_textblock_style_set(ts, style); ts->key = eina_stringshare_add(key); - o->styles = eina_list_append(o->styles, ts); + + /* If the given key value is NULL, newly created Evas Textblock Style + * has to be assigned to o->style. */ + if (ts->key) + o->styles = eina_list_append(o->styles, ts); + else + o->style = ts; + _textblock_style_generic_set(eo_obj, ts, &tmp); } else if (ts && style) diff --git a/src/tests/evas/evas_test_textblock.c b/src/tests/evas/evas_test_textblock.c index 03e92adb9a..715ec1fd33 100644 --- a/src/tests/evas/evas_test_textblock.c +++ b/src/tests/evas/evas_test_textblock.c @@ -4480,6 +4480,48 @@ EFL_START_TEST(evas_textblock_annotation) } EFL_END_TEST; +#define START_EFL_CANVAS_TEXT_TEST() \ + Evas *evas; \ + Eo *txt; \ + Efl_Text_Cursor_Cursor *cur; \ + evas = EVAS_TEST_INIT_EVAS(); \ + evas_font_hinting_set(evas, EVAS_FONT_HINTING_AUTO); \ + txt = efl_add(EFL_CANVAS_TEXT_CLASS, evas); \ + fail_if(!txt); \ + efl_canvas_text_legacy_newline_set(txt, EINA_FALSE); \ + efl_canvas_text_style_set(txt, NULL, style_buf); \ + fail_if(!efl_canvas_text_style_get(txt, NULL) || \ + strcmp(style_buf, efl_canvas_text_style_get(txt, NULL))); \ + cur = efl_text_cursor_new(txt); \ + fail_if(!cur); \ +do \ +{ \ +} \ +while (0) + +#define END_EFL_CANVAS_TEXT_TEST() \ +do \ +{ \ + efl_text_cursor_free(txt, cur); \ + efl_del(txt); \ + evas_free(evas); \ +} \ +while (0) + +EFL_START_TEST(efl_canvas_text_simple) +{ + START_EFL_CANVAS_TEXT_TEST(); + + /* It is simple test for Efl_Canvas_Text. + * The main object is "txt". */ + const char *buf = "This is a
test."; + efl_text_set(txt, buf); + fail_if(strcmp(efl_text_get(txt), buf)); + + END_EFL_CANVAS_TEXT_TEST(); +} +EFL_END_TEST + EFL_START_TEST(efl_canvas_text_cursor) { START_TB_TEST(); @@ -4541,6 +4583,7 @@ void evas_test_textblock(TCase *tc) #endif tcase_add_test(tc, evas_textblock_text_iface); tcase_add_test(tc, evas_textblock_annotation); + tcase_add_test(tc, efl_canvas_text_simple); tcase_add_test(tc, efl_canvas_text_cursor); }