Index: lib/elm_list.c
===================================================================
--- lib/elm_list.c	(revision 82027)
+++ lib/elm_list.c	(working copy)
@@ -584,7 +584,6 @@
           {
              const char *stacking;
 
-             /* FIXME: separators' themes seem to be b0rked */
              if (it->is_separator)
                elm_widget_theme_object_set
                  (obj, VIEW(it), "separator", sd->h_mode ?
@@ -615,37 +614,41 @@
                   else if (!strcmp(stacking, "above"))
                     evas_object_raise(VIEW(it));
                }
-             edje_object_part_text_escaped_set
-               (VIEW(it), "elm.text", it->label);
 
-             if ((!it->icon) && (minh[0] > 0))
+             if (!it->is_separator)
                {
-                  it->icon = evas_object_rectangle_add
-                      (evas_object_evas_get(VIEW(it)));
-                  evas_object_color_set(it->icon, 0, 0, 0, 0);
-                  it->dummy_icon = EINA_TRUE;
+                  edje_object_part_text_escaped_set
+                     (VIEW(it), "elm.text", it->label);
+
+                  if ((!it->icon) && (minh[0] > 0))
+                    {
+                       it->icon = evas_object_rectangle_add
+                          (evas_object_evas_get(VIEW(it)));
+                       evas_object_color_set(it->icon, 0, 0, 0, 0);
+                       it->dummy_icon = EINA_TRUE;
+                    }
+                  if ((!it->end) && (minh[1] > 0))
+                    {
+                       it->end = evas_object_rectangle_add
+                          (evas_object_evas_get(VIEW(it)));
+                       evas_object_color_set(it->end, 0, 0, 0, 0);
+                       it->dummy_end = EINA_TRUE;
+                    }
+                  if (it->icon)
+                    {
+                       evas_object_size_hint_min_set(it->icon, minw[0], minh[0]);
+                       evas_object_size_hint_max_set(it->icon, 99999, 99999);
+                       edje_object_part_swallow
+                          (VIEW(it), "elm.swallow.icon", it->icon);
+                    }
+                  if (it->end)
+                    {
+                       evas_object_size_hint_min_set(it->end, minw[1], minh[1]);
+                       evas_object_size_hint_max_set(it->end, 99999, 99999);
+                       edje_object_part_swallow
+                          (VIEW(it), "elm.swallow.end", it->end);
+                    }
                }
-             if ((!it->end) && (minh[1] > 0))
-               {
-                  it->end = evas_object_rectangle_add
-                      (evas_object_evas_get(VIEW(it)));
-                  evas_object_color_set(it->end, 0, 0, 0, 0);
-                  it->dummy_end = EINA_TRUE;
-               }
-             if (it->icon)
-               {
-                  evas_object_size_hint_min_set(it->icon, minw[0], minh[0]);
-                  evas_object_size_hint_max_set(it->icon, 99999, 99999);
-                  edje_object_part_swallow
-                    (VIEW(it), "elm.swallow.icon", it->icon);
-               }
-             if (it->end)
-               {
-                  evas_object_size_hint_min_set(it->end, minw[1], minh[1]);
-                  evas_object_size_hint_max_set(it->end, 99999, 99999);
-                  edje_object_part_swallow
-                    (VIEW(it), "elm.swallow.end", it->end);
-               }
              if (!it->fixed)
                {
                   // this may call up user and it may modify the list item
@@ -655,10 +658,12 @@
                   if (it->deleted)
                     continue;
                   mw = mh = -1;
-                  elm_coords_finger_size_adjust(1, &mw, 1, &mh);
+                  if (!it->is_separator)
+                    elm_coords_finger_size_adjust(1, &mw, 1, &mh);
                   edje_object_size_min_restricted_calc
                     (VIEW(it), &mw, &mh, mw, mh);
-                  elm_coords_finger_size_adjust(1, &mw, 1, &mh);
+                  if (!it->is_separator)
+                    elm_coords_finger_size_adjust(1, &mw, 1, &mh);
                   evas_object_size_hint_min_set(VIEW(it), mw, mh);
                   evas_object_show(VIEW(it));
                }
@@ -684,7 +689,9 @@
              it->fixed = EINA_TRUE;
              it->is_even = it->even;
           }
-        i++;
+
+        if (!it->is_separator)
+          i++;
      }
 
    _elm_list_mode_set_internal(obj);
@@ -1613,7 +1620,6 @@
    eo_do(obj, elm_scrollable_interface_bounce_allow_set(EINA_FALSE, _elm_config->thumbscroll_bounce_enable));
 
    priv->box = elm_box_add(obj);
-   elm_box_homogeneous_set(priv->box, EINA_TRUE);
    evas_object_size_hint_weight_set(priv->box, EVAS_HINT_EXPAND, 0.0);
    evas_object_size_hint_align_set(priv->box, EVAS_HINT_FILL, 0.0);
 
Index: bin/test_list.c
===================================================================
--- bin/test_list.c	(revision 82027)
+++ bin/test_list.c	(working copy)
@@ -1226,4 +1226,115 @@
    evas_object_show(win);
 }
 
+void
+test_list_separator(void        *data __UNUSED__,
+                    Evas_Object *obj __UNUSED__,
+                    void        *event_info __UNUSED__)
+{
+   Evas_Object *win, *li, *ic, *ic2, *bx, *bxx;
+   char buf[PATH_MAX];
+   Elm_Object_Item *list_it_sep;
+
+   win = elm_win_util_standard_add("list", "List Separator");
+   elm_win_autodel_set(win, EINA_TRUE);
+
+   bxx = elm_box_add(win);
+   evas_object_size_hint_weight_set(bxx, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   elm_win_resize_object_add(win, bxx);
+   evas_object_show(bxx);
+
+   li = elm_list_add(win);
+   evas_object_size_hint_weight_set(li, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_align_set(li, EVAS_HINT_FILL, EVAS_HINT_FILL);
+
+   elm_box_pack_end(bxx, li);
+
+   ic = elm_icon_add(win);
+   snprintf(buf, sizeof(buf), "%s/images/logo_small.png", elm_app_data_dir_get());
+   elm_image_file_set(ic, buf, NULL);
+   elm_image_resizable_set(ic, 1, 1);
+   elm_list_item_append(li, "Hello", ic, NULL, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   ic = elm_icon_add(win);
+   snprintf(buf, sizeof(buf), "%s/images/logo_small.png", elm_app_data_dir_get());
+   elm_image_resizable_set(ic, 0, 0);
+   elm_image_file_set(ic, buf, NULL);
+   elm_list_item_append(li, "world", ic, NULL, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   ic = elm_icon_add(win);
+   elm_icon_standard_set(ic, "edit");
+   elm_image_resizable_set(ic, 0, 0);
+   elm_list_item_append(li, ".", ic, NULL, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   ic = elm_icon_add(win);
+   elm_icon_standard_set(ic, "delete");
+   elm_image_resizable_set(ic, 0, 0);
+   ic2 = elm_icon_add(win);
+   elm_icon_standard_set(ic2, "clock");
+   elm_image_resizable_set(ic2, 0, 0);
+   elm_list_item_append(li, "How", ic, ic2, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   bx = elm_box_add(win);
+   elm_box_horizontal_set(bx, EINA_TRUE);
+
+   ic = elm_icon_add(win);
+   snprintf(buf, sizeof(buf), "%s/images/logo_small.png", elm_app_data_dir_get());
+   elm_image_file_set(ic, buf, NULL);
+   elm_image_resizable_set(ic, 0, 0);
+   evas_object_size_hint_align_set(ic, 0.5, 0.5);
+   elm_box_pack_end(bx, ic);
+   evas_object_show(ic);
+
+   ic = elm_icon_add(win);
+   snprintf(buf, sizeof(buf), "%s/images/logo_small.png", elm_app_data_dir_get());
+   elm_image_file_set(ic, buf, NULL);
+   elm_image_resizable_set(ic, 0, 0);
+   evas_object_size_hint_align_set(ic, 0.5, 0.0);
+   elm_box_pack_end(bx, ic);
+   evas_object_show(ic);
+
+   ic = elm_icon_add(win);
+   snprintf(buf, sizeof(buf), "%s/images/logo_small.png", elm_app_data_dir_get());
+   elm_image_file_set(ic, buf, NULL);
+   elm_image_resizable_set(ic, 0, 0);
+   evas_object_size_hint_align_set(ic, 0.0, EVAS_HINT_EXPAND);
+   elm_box_pack_end(bx, ic);
+   evas_object_show(ic);
+   elm_list_item_append(li, "are", bx, NULL, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   elm_list_item_append(li, "you", NULL, NULL, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   elm_list_item_append(li, "doing", NULL, NULL, NULL, NULL);
+
+   list_it_sep = elm_list_item_append(li, NULL, NULL, NULL, NULL, NULL);
+   elm_list_item_separator_set(list_it_sep, EINA_TRUE);
+
+   elm_list_item_append(li, "?", NULL, NULL, NULL, NULL);
+
+   elm_list_go(li);
+
+   evas_object_show(li);
+
+   evas_object_resize(win, 320, 300);
+   evas_object_show(win);
+}
+
 #endif
Index: bin/test.c
===================================================================
--- bin/test.c	(revision 82027)
+++ bin/test.c	(working copy)
@@ -74,6 +74,7 @@
 void test_list5(void *data, Evas_Object *obj, void *event_info);
 void test_list6(void *data, Evas_Object *obj, void *event_info);
 void test_list7(void *data, Evas_Object *obj, void *event_info);
+void test_list_separator(void *data, Evas_Object *obj, void *event_info);
 void test_inwin(void *data, Evas_Object *obj, void *event_info);
 void test_inwin2(void *data, Evas_Object *obj, void *event_info);
 void test_scaling(void *data, Evas_Object *obj, void *event_info);
@@ -579,6 +580,7 @@
    ADD_TEST(NULL, "Lists", "List 5", test_list5);
    ADD_TEST(NULL, "Lists", "List 6", test_list6);
    ADD_TEST(NULL, "Lists", "List 7", test_list7);
+   ADD_TEST(NULL, "Lists", "List Separator", test_list_separator);
    ADD_TEST(NULL, "Lists", "Genlist", test_genlist);
    ADD_TEST(NULL, "Lists", "Genlist 2", test_genlist2);
    ADD_TEST(NULL, "Lists", "Genlist 3", test_genlist3);
