Some copy-pasted code removed as a result.
---
trunk/evas/src/lib/canvas/evas_object_textblock.c | 62 ++++-----------------
1 files changed, 11 insertions(+), 51 deletions(-)
diff --git a/trunk/evas/src/lib/canvas/evas_object_textblock.c
b/trunk/evas/src/lib/canvas/evas_object_textblock.c
index 826239a..73acc56 100644
--- a/trunk/evas/src/lib/canvas/evas_object_textblock.c
+++ b/trunk/evas/src/lib/canvas/evas_object_textblock.c
@@ -126,7 +126,14 @@ struct _Evas_Object_Textblock
{
DATA32 magic;
Evas_Textblock_Style *style;
+
+ /*
+ * Dedicated first cursor, immune to deletion and returned by
+ * evas_object_textblock_cursor_get(). For the sake of consistency (and
+ * avoiding code duplication) it is stored in cursors list as first element.
+ */
Evas_Textblock_Cursor *cursor;
+
Eina_List *cursors;
Evas_Object_Textblock_Node *nodes;
Evas_Object_Textblock_Line *lines;
@@ -382,10 +389,6 @@ _nodes_next_merge(const Evas_Object *obj,
Evas_Object_Textblock_Node *cur)
/* Fixup cursors */
o = obj->object_data;
- if (next == o->cursor->node) {
- o->cursor->node = cur;
- o->cursor->pos += cur_len;
- }
EINA_LIST_FOREACH(o->cursors, l, cursor) {
if (next == cursor->node) {
cursor->node = cur;
@@ -2826,11 +2829,10 @@ evas_object_textblock_text_markup_set(Evas_Object *obj,
const char *text)
}
{
Eina_List *l;
- Evas_Textblock_Cursor *data;
+ Evas_Textblock_Cursor *cursor;
- evas_textblock_cursor_node_first(o->cursor);
- EINA_LIST_FOREACH(o->cursors, l, data)
- evas_textblock_cursor_node_first(data);
+ EINA_LIST_FOREACH(o->cursors, l, cursor)
+ evas_textblock_cursor_node_first(cursor);
}
}
@@ -3544,14 +3546,6 @@ evas_textblock_cursor_text_append(Evas_Textblock_Cursor
*cur, const char *text)
Eina_List *l;
Evas_Textblock_Cursor *data;
- if (cur != o->cursor)
- {
- if (cur->node == o->cursor->node)
- {
- if (o->cursor->pos > cur->pos)
- o->cursor->pos += strlen(text);
- }
- }
EINA_LIST_FOREACH(o->cursors, l, data)
{
if (data != cur)
@@ -3622,16 +3616,6 @@ evas_textblock_cursor_text_prepend(Evas_Textblock_Cursor
*cur, const char *text)
Eina_List *l;
Evas_Textblock_Cursor *data;
- if (cur != o->cursor)
- {
- if (cur->node == o->cursor->node)
- {
- if ((o->cursor->node) &&
- (o->cursor->node->type == NODE_TEXT) &&
- (o->cursor->pos >= cur->pos))
- o->cursor->pos += strlen(text);
- }
- }
EINA_LIST_FOREACH(o->cursors, l, data)
{
if (data != cur)
@@ -3858,15 +3842,6 @@ evas_textblock_cursor_node_delete(Evas_Textblock_Cursor
*cur)
Eina_List *l;
Evas_Textblock_Cursor *data;
- if (cur != o->cursor)
- {
- if (n == o->cursor->node)
- {
- o->cursor->node = cur->node;
- o->cursor->pos = cur->pos;
- o->cursor->eol = cur->eol;
- }
- }
EINA_LIST_FOREACH(o->cursors, l, data)
{
if (data != cur)
@@ -3947,14 +3922,6 @@ evas_textblock_cursor_char_delete(Evas_Textblock_Cursor
*cur)
Eina_List *l;
Evas_Textblock_Cursor *data;
- if (cur != o->cursor)
- {
- if ((n == o->cursor->node) &&
- (o->cursor->pos > ppos))
- {
- o->cursor->pos -= (index - ppos);
- }
- }
EINA_LIST_FOREACH(o->cursors, l, data)
{
if (data != cur)
@@ -4224,10 +4191,6 @@ evas_textblock_cursor_range_delete(Evas_Textblock_Cursor
*cur1, Evas_Textblock_C
Eina_List *l;
Evas_Textblock_Cursor *data;
- if ((cur1 != o->cursor) && (cur2 != o->cursor))
- {
- evas_textblock_cursor_copy(cur1, o->cursor);
- }
EINA_LIST_FOREACH(o->cursors, l, data)
{
if ((data != cur1) && (data != cur2))
@@ -4880,9 +4843,6 @@ evas_object_textblock_clear(Evas_Object *obj)
TB_HEAD();
_nodes_clear(obj);
- o->cursor->node = NULL;
- o->cursor->pos = 0;
- o->cursor->eol = 0;
EINA_LIST_FOREACH(o->cursors, l, cur)
{
cur->node = NULL;
@@ -5006,6 +4966,7 @@ evas_object_textblock_new(void)
o = calloc(1, sizeof(Evas_Object_Textblock));
o->magic = MAGIC_OBJ_TEXTBLOCK;
o->cursor = calloc(1, sizeof(Evas_Textblock_Cursor));
+ o->cursors = eina_list_append(NULL, o->cursor);
return o;
}
@@ -5017,7 +4978,6 @@ evas_object_textblock_free(Evas_Object *obj)
evas_object_textblock_clear(obj);
evas_object_textblock_style_set(obj, NULL);
o = (Evas_Object_Textblock *)(obj->object_data);
- free(o->cursor);
while (o->cursors)
{
Evas_Textblock_Cursor *cur;
--
1.6.3.3
------------------------------------------------------------------------------
Download Intel® Parallel Studio Eval
Try the new software tools for yourself. Speed compiling, find bugs
proactively, and fine-tune applications for parallel performance.
See why Intel Parallel Studio got high marks during beta.
http://p.sf.net/sfu/intel-sw-dev
_______________________________________________
enlightenment-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/enlightenment-devel