Merge branch 'devs/ajwillia-ms/elm_code'

This commit is contained in:
Andy Williams 2014-11-23 00:20:49 +00:00
commit 48236e79e3
3 changed files with 29 additions and 19 deletions

View File

@ -61,11 +61,10 @@ _elm_code_test_diff_setup(Evas_Object *parent)
{
char *path = "elm_code/tests/testdiff.diff";
Evas_Object *diff;
Elm_Code_File *file;
Elm_Code *code;
code = elm_code_create();
file = elm_code_file_open(code, path);
elm_code_file_open(code, path);
diff = elm_code_diff_widget_add(parent, code);
return diff;

View File

@ -44,32 +44,40 @@ static void _elm_code_diff_widget_parse_diff(Elm_Code_File *diff, Elm_Code_File
{
Eina_List *item;
Elm_Code_Line *line;
int number;
int number, offset;
number = 0;
offset = 0;
EINA_LIST_FOREACH(diff->lines, item, line)
{
if (line->length > 0 && number < 2)
if (line->length > 0)
{
if (line->content[0] == 'd' || line->content[0] == 'i')
continue;
if (line->content[0] == 'd' || line->content[0] == 'i' || line->content[0] == 'n')
{
offset = 0;
continue;
}
}
if (number == 0)
{
elm_code_file_line_append(left, line->content+4, line->length-4);
elm_code_file_line_status_set(left, 1, ELM_CODE_STATUS_TYPE_CHANGED);
}
else if (number == 1)
{
elm_code_file_line_append(right, line->content+4, line->length-4);
elm_code_file_line_status_set(right, 1, ELM_CODE_STATUS_TYPE_CHANGED);
}
else
_elm_code_diff_widget_parse_diff_line(line, number, left, right);
number++;
if (offset == 0)
{
elm_code_file_line_append(left, line->content+4, line->length-4);
elm_code_file_line_status_set(left, number, ELM_CODE_STATUS_TYPE_CHANGED);
}
else if (offset == 1)
{
number--;
elm_code_file_line_append(right, line->content+4, line->length-4);
elm_code_file_line_status_set(right, number, ELM_CODE_STATUS_TYPE_CHANGED);
}
else
{
_elm_code_diff_widget_parse_diff_line(line, number, left, right);
}
offset++;
}
}

View File

@ -169,6 +169,7 @@ _edi_mainview_content_diff_create(Edi_Mainview_Item *item, Evas_Object *parent)
code = elm_code_create();
elm_code_file_open(code, item->path);
diff = elm_code_diff_widget_add(parent, code);
elm_code_diff_widget_font_size_set(diff, 12);
return diff;
}
@ -366,6 +367,8 @@ _edi_mainview_win_stat_done(void *data, Eio_File *handler EINA_UNUSED, const Ein
options->type = "text"; // TODO make a code view
else if (!strncasecmp(mime, "image/", 6))
options->type = "image";
else if (!strcasecmp(mime, "text/x-diff") || !strcasecmp(mime, "text/x-patch"))
options->type = "diff";
else
{
_edi_mainview_choose_type(nf, options, _edi_mainview_choose_type_win_cb);