MC Edit: column_highlighting flag is a member of WEdit struct.

Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
Andrew Borodin 2010-05-30 18:52:54 +04:00
parent 2cc2f34912
commit dfe9bc887a
6 changed files with 41 additions and 44 deletions

View File

@ -332,6 +332,4 @@ extern int option_edit_bottom_extreme;
extern const char *option_whole_chars_search; extern const char *option_whole_chars_search;
extern int search_create_bookmark; extern int search_create_bookmark;
extern int column_highlighting;
#endif /* MC_EDIT_IMPL_H */ #endif /* MC_EDIT_IMPL_H */

View File

@ -75,6 +75,7 @@ struct WEdit
unsigned int screen_modified:1; /* File has been changed since the last screen draw */ unsigned int screen_modified:1; /* File has been changed since the last screen draw */
unsigned int delete_file:1; /* New file, needs to be deleted unless modified */ unsigned int delete_file:1; /* New file, needs to be deleted unless modified */
unsigned int highlight:1; /* There is a selected block */ unsigned int highlight:1; /* There is a selected block */
unsigned int column_highlight:1;
unsigned int utf8:1; /* It's multibyte file codeset */ unsigned int utf8:1; /* It's multibyte file codeset */
long prev_col; /* recent column position of the cursor - used when moving long prev_col; /* recent column position of the cursor - used when moving
up or down past lines that are shorter than the current line */ up or down past lines that are shorter than the current line */

View File

@ -2302,7 +2302,7 @@ edit_left_word_move (WEdit * edit, int s)
for (;;) for (;;)
{ {
int c1, c2; int c1, c2;
if (column_highlighting if (edit->column_highlight
&& edit->mark1 != edit->mark2 && edit->mark1 != edit->mark2
&& edit->over_col == 0 && edit->curs1 == edit_bol (edit, edit->curs1)) && edit->over_col == 0 && edit->curs1 == edit_bol (edit, edit->curs1))
break; break;
@ -2334,7 +2334,7 @@ edit_right_word_move (WEdit * edit, int s)
for (;;) for (;;)
{ {
int c1, c2; int c1, c2;
if (column_highlighting if (edit->column_highlight
&& edit->mark1 != edit->mark2 && edit->mark1 != edit->mark2
&& edit->over_col == 0 && edit->curs1 == edit_eol (edit, edit->curs1)) && edit->over_col == 0 && edit->curs1 == edit_eol (edit, edit->curs1))
break; break;
@ -2389,7 +2389,7 @@ static void
edit_left_char_move_cmd (WEdit * edit) edit_left_char_move_cmd (WEdit * edit)
{ {
int cw = 1; int cw = 1;
if (column_highlighting if (edit->column_highlight
&& option_cursor_beyond_eol && option_cursor_beyond_eol
&& edit->mark1 != edit->mark2 && edit->mark1 != edit->mark2
&& edit->over_col == 0 && edit->curs1 == edit_bol (edit, edit->curs1)) && edit->over_col == 0 && edit->curs1 == edit_bol (edit, edit->curs1))
@ -2519,10 +2519,10 @@ edit_do_undo (WEdit * edit)
edit_delete (edit, 1); edit_delete (edit, 1);
break; break;
case COLUMN_ON: case COLUMN_ON:
column_highlighting = 1; edit->column_highlight = 1;
break; break;
case COLUMN_OFF: case COLUMN_OFF:
column_highlighting = 0; edit->column_highlight = 0;
break; break;
} }
if (ac >= 256 && ac < 512) if (ac >= 256 && ac < 512)
@ -2897,7 +2897,7 @@ edit_execute_key_command (WEdit * edit, unsigned long command, int char_for_inse
edit_push_key_press (edit); edit_push_key_press (edit);
edit_execute_cmd (edit, command, char_for_insertion); edit_execute_cmd (edit, command, char_for_insertion);
if (column_highlighting) if (edit->column_highlight)
edit->force |= REDRAW_PAGE; edit->force |= REDRAW_PAGE;
} }
@ -2916,12 +2916,12 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
/* The next key press will unhighlight the found string, so update /* The next key press will unhighlight the found string, so update
* the whole page */ * the whole page */
if (edit->found_len || column_highlighting) if (edit->found_len || edit->column_highlight)
edit->force |= REDRAW_PAGE; edit->force |= REDRAW_PAGE;
if (command / 100 == 6) if (command / 100 == 6)
{ /* a highlight command like shift-arrow */ { /* a highlight command like shift-arrow */
column_highlighting = 0; edit->column_highlight = 0;
if (!edit->highlight || (edit->mark2 != -1 && edit->mark1 != edit->mark2)) if (!edit->highlight || (edit->mark2 != -1 && edit->mark1 != edit->mark2))
{ {
edit_mark_cmd (edit, 1); /* clear */ edit_mark_cmd (edit, 1); /* clear */
@ -3020,9 +3020,9 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
{ {
if (!option_persistent_selections) if (!option_persistent_selections)
{ {
if (column_highlighting) if (edit->column_highlight)
edit_push_action (edit, COLUMN_ON); edit_push_action (edit, COLUMN_ON);
column_highlighting = 0; edit->column_highlight = 0;
edit_mark_cmd (edit, 1); edit_mark_cmd (edit, 1);
} }
} }
@ -3160,19 +3160,19 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
break; break;
case CK_Page_Up_Alt_Highlight: case CK_Page_Up_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Page_Up: case CK_Page_Up:
case CK_Page_Up_Highlight: case CK_Page_Up_Highlight:
edit_move_up (edit, edit->num_widget_lines - 1, 1); edit_move_up (edit, edit->num_widget_lines - 1, 1);
break; break;
case CK_Page_Down_Alt_Highlight: case CK_Page_Down_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Page_Down: case CK_Page_Down:
case CK_Page_Down_Highlight: case CK_Page_Down_Highlight:
edit_move_down (edit, edit->num_widget_lines - 1, 1); edit_move_down (edit, edit->num_widget_lines - 1, 1);
break; break;
case CK_Left_Alt_Highlight: case CK_Left_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Left: case CK_Left:
case CK_Left_Highlight: case CK_Left_Highlight:
if (option_fake_half_tabs) if (option_fake_half_tabs)
@ -3190,7 +3190,7 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
edit_left_char_move_cmd (edit); edit_left_char_move_cmd (edit);
break; break;
case CK_Right_Alt_Highlight: case CK_Right_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Right: case CK_Right:
case CK_Right_Highlight: case CK_Right_Highlight:
if (option_fake_half_tabs) if (option_fake_half_tabs)
@ -3223,37 +3223,37 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
edit_right_word_move_cmd (edit); edit_right_word_move_cmd (edit);
break; break;
case CK_Up_Alt_Highlight: case CK_Up_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Up: case CK_Up:
case CK_Up_Highlight: case CK_Up_Highlight:
edit_move_up (edit, 1, 0); edit_move_up (edit, 1, 0);
break; break;
case CK_Down_Alt_Highlight: case CK_Down_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Down: case CK_Down:
case CK_Down_Highlight: case CK_Down_Highlight:
edit_move_down (edit, 1, 0); edit_move_down (edit, 1, 0);
break; break;
case CK_Paragraph_Up_Alt_Highlight: case CK_Paragraph_Up_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Paragraph_Up: case CK_Paragraph_Up:
case CK_Paragraph_Up_Highlight: case CK_Paragraph_Up_Highlight:
edit_move_up_paragraph (edit, 0); edit_move_up_paragraph (edit, 0);
break; break;
case CK_Paragraph_Down_Alt_Highlight: case CK_Paragraph_Down_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Paragraph_Down: case CK_Paragraph_Down:
case CK_Paragraph_Down_Highlight: case CK_Paragraph_Down_Highlight:
edit_move_down_paragraph (edit, 0); edit_move_down_paragraph (edit, 0);
break; break;
case CK_Scroll_Up_Alt_Highlight: case CK_Scroll_Up_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Scroll_Up: case CK_Scroll_Up:
case CK_Scroll_Up_Highlight: case CK_Scroll_Up_Highlight:
edit_move_up (edit, 1, 1); edit_move_up (edit, 1, 1);
break; break;
case CK_Scroll_Down_Alt_Highlight: case CK_Scroll_Down_Alt_Highlight:
column_highlighting = 1; edit->column_highlight = 1;
case CK_Scroll_Down: case CK_Scroll_Down:
case CK_Scroll_Down_Highlight: case CK_Scroll_Down_Highlight:
edit_move_down (edit, 1, 1); edit_move_down (edit, 1, 1);
@ -3298,16 +3298,16 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
case CK_Mark: case CK_Mark:
if (edit->mark2 >= 0) if (edit->mark2 >= 0)
{ {
if (column_highlighting) if (edit->column_highlight)
edit_push_action (edit, COLUMN_ON); edit_push_action (edit, COLUMN_ON);
column_highlighting = 0; edit->column_highlight = 0;
} }
edit_mark_cmd (edit, 0); edit_mark_cmd (edit, 0);
break; break;
case CK_Column_Mark: case CK_Column_Mark:
if (!column_highlighting) if (!edit->column_highlight)
edit_push_action (edit, COLUMN_OFF); edit_push_action (edit, COLUMN_OFF);
column_highlighting = 1; edit->column_highlight = 1;
edit_mark_cmd (edit, 0); edit_mark_cmd (edit, 0);
break; break;
case CK_Mark_All: case CK_Mark_All:
@ -3315,9 +3315,9 @@ edit_execute_cmd (WEdit * edit, unsigned long command, int char_for_insertion)
edit->force |= REDRAW_PAGE; edit->force |= REDRAW_PAGE;
break; break;
case CK_Unmark: case CK_Unmark:
if (column_highlighting) if (edit->column_highlight)
edit_push_action (edit, COLUMN_ON); edit_push_action (edit, COLUMN_ON);
column_highlighting = 0; edit->column_highlight = 0;
edit_mark_cmd (edit, 1); edit_mark_cmd (edit, 1);
break; break;

View File

@ -1150,7 +1150,7 @@ eval_marks (WEdit * edit, long *start_mark, long *end_mark)
*end_mark = max (edit->mark1, edit->curs1); *end_mark = max (edit->mark1, edit->curs1);
edit->column2 = edit->curs_col + edit->over_col; edit->column2 = edit->curs_col + edit->over_col;
} }
if (column_highlighting if (edit->column_highlight
&& (((edit->mark1 > edit->curs1) && (edit->column1 < edit->column2)) && (((edit->mark1 > edit->curs1) && (edit->column1 < edit->column2))
|| ((edit->mark1 < edit->curs1) && (edit->column1 > edit->column2)))) || ((edit->mark1 < edit->curs1) && (edit->column1 > edit->column2))))
{ {
@ -1321,7 +1321,7 @@ edit_block_copy_cmd (WEdit * edit)
edit_push_markers (edit); edit_push_markers (edit);
if (column_highlighting) if (edit->column_highlight)
{ {
edit_insert_column_of_text (edit, copy_buf, size, abs (edit->column2 - edit->column1)); edit_insert_column_of_text (edit, copy_buf, size, abs (edit->column2 - edit->column1));
} }
@ -1334,11 +1334,11 @@ edit_block_copy_cmd (WEdit * edit)
g_free (copy_buf); g_free (copy_buf);
edit_scroll_screen_over_cursor (edit); edit_scroll_screen_over_cursor (edit);
if (column_highlighting) if (edit->column_highlight)
{ {
edit_set_markers (edit, 0, 0, 0, 0); edit_set_markers (edit, 0, 0, 0, 0);
edit_push_action (edit, COLUMN_ON); edit_push_action (edit, COLUMN_ON);
column_highlighting = 0; edit->column_highlight = 0;
} }
else if (start_mark < current && end_mark > current) else if (start_mark < current && end_mark > current)
edit_set_markers (edit, start_mark, end_mark + end_mark - start_mark, 0, 0); edit_set_markers (edit, start_mark, end_mark + end_mark - start_mark, 0, 0);
@ -1359,7 +1359,7 @@ edit_block_move_cmd (WEdit * edit)
if (eval_marks (edit, &start_mark, &end_mark)) if (eval_marks (edit, &start_mark, &end_mark))
return; return;
if (column_highlighting) if (edit->column_highlight)
{ {
edit_update_curs_col (edit); edit_update_curs_col (edit);
x = edit->curs_col; x = edit->curs_col;
@ -1381,7 +1381,7 @@ edit_block_move_cmd (WEdit * edit)
edit_push_markers (edit); edit_push_markers (edit);
current = edit->curs1; current = edit->curs1;
if (column_highlighting) if (edit->column_highlight)
{ {
long line; long line;
int size, c1, c2; int size, c1, c2;
@ -1415,7 +1415,7 @@ edit_block_move_cmd (WEdit * edit)
} }
edit_set_markers (edit, 0, 0, 0, 0); edit_set_markers (edit, 0, 0, 0, 0);
edit_push_action (edit, COLUMN_ON); edit_push_action (edit, COLUMN_ON);
column_highlighting = 0; edit->column_highlight = 0;
} }
else else
{ {
@ -1489,7 +1489,7 @@ edit_block_delete (WEdit * edit)
if (eval_marks (edit, &start_mark, &end_mark)) if (eval_marks (edit, &start_mark, &end_mark))
return 0; return 0;
if (column_highlighting && edit->mark2 < 0) if (edit->column_highlight && edit->mark2 < 0)
edit_mark_cmd (edit, 0); edit_mark_cmd (edit, 0);
if ((end_mark - start_mark) > option_max_undo / 2) if ((end_mark - start_mark) > option_max_undo / 2)
{ {
@ -1523,7 +1523,7 @@ edit_block_delete (WEdit * edit)
count = start_mark; count = start_mark;
if (start_mark < end_mark) if (start_mark < end_mark)
{ {
if (column_highlighting) if (edit->column_highlight)
{ {
if (edit->mark2 < 0) if (edit->mark2 < 0)
edit_mark_cmd (edit, 0); edit_mark_cmd (edit, 0);
@ -2074,7 +2074,7 @@ edit_get_block (WEdit * edit, long start, long finish, int *l)
{ {
unsigned char *s, *r; unsigned char *s, *r;
r = s = g_malloc0 (finish - start + 1); r = s = g_malloc0 (finish - start + 1);
if (column_highlighting) if (edit->column_highlight)
{ {
*l = 0; *l = 0;
/* copy from buffer, excluding chars that are out of the column 'margins' */ /* copy from buffer, excluding chars that are out of the column 'margins' */
@ -2114,7 +2114,7 @@ edit_save_block (WEdit * edit, const char *filename, long start, long finish)
if (file == -1) if (file == -1)
return 0; return 0;
if (column_highlighting) if (edit->column_highlight)
{ {
int r; int r;
r = mc_write (file, VERTICAL_MAGIC, sizeof (VERTICAL_MAGIC)); r = mc_write (file, VERTICAL_MAGIC, sizeof (VERTICAL_MAGIC));

View File

@ -118,7 +118,7 @@ status_string (WEdit * edit, char *s, int w)
if (simple_statusbar) if (simple_statusbar)
g_snprintf (s, w, g_snprintf (s, w,
"%c%c%c%c %3ld %5ld/%ld %6ld/%ld %s %s", "%c%c%c%c %3ld %5ld/%ld %6ld/%ld %s %s",
edit->mark1 != edit->mark2 ? (column_highlighting ? 'C' : 'B') : '-', edit->mark1 != edit->mark2 ? (edit->column_highlight ? 'C' : 'B') : '-',
edit->modified ? 'M' : '-', edit->modified ? 'M' : '-',
edit->macro_i < 0 ? '-' : 'R', edit->macro_i < 0 ? '-' : 'R',
edit->overwrite == 0 ? '-' : 'O', edit->overwrite == 0 ? '-' : 'O',
@ -134,7 +134,7 @@ status_string (WEdit * edit, char *s, int w)
else else
g_snprintf (s, w, g_snprintf (s, w,
"[%c%c%c%c] %2ld L:[%3ld+%2ld %3ld/%3ld] *(%-4ld/%4ldb) %s %s", "[%c%c%c%c] %2ld L:[%3ld+%2ld %3ld/%3ld] *(%-4ld/%4ldb) %s %s",
edit->mark1 != edit->mark2 ? (column_highlighting ? 'C' : 'B') : '-', edit->mark1 != edit->mark2 ? (edit->column_highlight ? 'C' : 'B') : '-',
edit->modified ? 'M' : '-', edit->modified ? 'M' : '-',
edit->macro_i < 0 ? '-' : 'R', edit->macro_i < 0 ? '-' : 'R',
edit->overwrite == 0 ? '-' : 'O', edit->overwrite == 0 ? '-' : 'O',
@ -470,7 +470,7 @@ edit_draw_this_line (WEdit * edit, long b, long row, long start_col, long end_co
p->style |= MOD_CURSOR; p->style |= MOD_CURSOR;
if (q >= m1 && q < m2) if (q >= m1 && q < m2)
{ {
if (column_highlighting) if (edit->column_highlight)
{ {
int x; int x;
x = edit_move_forward3 (edit, b, 0, q); x = edit_move_forward3 (edit, b, 0, q);

View File

@ -54,8 +54,6 @@
#include "src/cmddef.h" #include "src/cmddef.h"
#include "src/keybind.h" #include "src/keybind.h"
int column_highlighting = 0;
static cb_ret_t edit_callback (Widget *, widget_msg_t msg, int parm); static cb_ret_t edit_callback (Widget *, widget_msg_t msg, int parm);
static char * static char *