mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-05 19:14:27 +03:00
add more...
This commit is contained in:
parent
eac001af97
commit
2377115b8e
@ -230,7 +230,7 @@ void book_mark_dec (WEdit * edit, int line)
|
|||||||
appended after each other and the last one is always the one found
|
appended after each other and the last one is always the one found
|
||||||
by collapsed_found() i.e. last in is the one seen */
|
by collapsed_found() i.e. last in is the one seen */
|
||||||
|
|
||||||
static inline struct collapsed_lines *double_collapsed (WEdit * edit, struct collapsed_lines *p)
|
static inline struct collapsed_lines *double_collapse (WEdit * edit, struct collapsed_lines *p)
|
||||||
{
|
{
|
||||||
(void) edit;
|
(void) edit;
|
||||||
|
|
||||||
@ -241,7 +241,7 @@ static inline struct collapsed_lines *double_collapsed (WEdit * edit, struct col
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* returns the first collapsed region on or before this line */
|
/* returns the first collapsed region on or before this line */
|
||||||
struct collapsed_lines *collapsed_find (WEdit * edit, int start_line)
|
struct collapsed_lines *collapse_find (WEdit * edit, int start_line)
|
||||||
{
|
{
|
||||||
struct collapsed_lines *p;
|
struct collapsed_lines *p;
|
||||||
if (!edit->collapsed) {
|
if (!edit->collapsed) {
|
||||||
@ -257,11 +257,11 @@ struct collapsed_lines *collapsed_find (WEdit * edit, int start_line)
|
|||||||
if (p->next) {
|
if (p->next) {
|
||||||
if (p->next->start_line > start_line) {
|
if (p->next->start_line > start_line) {
|
||||||
edit->collapsed = p;
|
edit->collapsed = p;
|
||||||
return double_collapsed (edit, p);
|
return double_collapse (edit, p);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
edit->collapsed = p;
|
edit->collapsed = p;
|
||||||
return double_collapsed (edit, p);
|
return double_collapse (edit, p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -273,11 +273,11 @@ struct collapsed_lines *collapsed_find (WEdit * edit, int start_line)
|
|||||||
if (p->next) {
|
if (p->next) {
|
||||||
if (p->next->start_line > start_line) {
|
if (p->next->start_line > start_line) {
|
||||||
edit->collapsed = p;
|
edit->collapsed = p;
|
||||||
return double_collapsed (edit, p);
|
return double_collapse (edit, p);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
edit->collapsed = p;
|
edit->collapsed = p;
|
||||||
return double_collapsed (edit, p);
|
return double_collapse (edit, p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -287,12 +287,13 @@ struct collapsed_lines *collapsed_find (WEdit * edit, int start_line)
|
|||||||
|
|
||||||
/* insert a collapsed at this line */
|
/* insert a collapsed at this line */
|
||||||
void
|
void
|
||||||
collapsed_insert (WEdit *edit,
|
collapse_insert (WEdit *edit,
|
||||||
const unsigned long start_line,
|
const unsigned long start_line,
|
||||||
const unsigned long end_line, int state)
|
const unsigned long end_line, int state)
|
||||||
{
|
{
|
||||||
struct collapsed_lines *p, *q;
|
struct collapsed_lines *p, *q;
|
||||||
p = collapsed_find (edit, start_line);
|
mc_log("collapse_insert: %ld, %ld\n", start_line, end_line);
|
||||||
|
p = collapse_find (edit, start_line);
|
||||||
if (p->start_line == start_line) {
|
if (p->start_line == start_line) {
|
||||||
/* already exists */
|
/* already exists */
|
||||||
}
|
}
|
||||||
@ -317,7 +318,7 @@ collapsed_insert (WEdit *edit,
|
|||||||
* return start_line, end_line if found region
|
* return start_line, end_line if found region
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
int collapsed_query (WEdit * edit, const unsigned long line,
|
int collapse_query (WEdit * edit, const unsigned long line,
|
||||||
unsigned long *start_line,
|
unsigned long *start_line,
|
||||||
unsigned long *end_line,
|
unsigned long *end_line,
|
||||||
int *state)
|
int *state)
|
||||||
@ -330,7 +331,7 @@ int collapsed_query (WEdit * edit, const unsigned long line,
|
|||||||
|
|
||||||
if (!edit->collapsed)
|
if (!edit->collapsed)
|
||||||
return 0;
|
return 0;
|
||||||
for (p = collapsed_find (edit, line); p; p = p->prev) {
|
for (p = collapse_find (edit, line); p; p = p->prev) {
|
||||||
if (p->start_line != line)
|
if (p->start_line != line)
|
||||||
return 0;
|
return 0;
|
||||||
*start_line = p->start_line;
|
*start_line = p->start_line;
|
||||||
|
16
edit/edit.c
16
edit/edit.c
@ -2667,6 +2667,22 @@ edit_execute_cmd (WEdit *edit, int command, int char_for_insertion)
|
|||||||
edit_mark_cmd (edit, 1);
|
edit_mark_cmd (edit, 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CK_Toggle_Line_Status:
|
||||||
|
option_line_status ^= 1;
|
||||||
|
if ( option_line_status ) {
|
||||||
|
option_line_status_width = LINE_STATUS_WIDTH;
|
||||||
|
} else {
|
||||||
|
option_line_status_width = 0;
|
||||||
|
}
|
||||||
|
edit->force |= REDRAW_PAGE;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CK_Add_Collapse_Region:
|
||||||
|
if ( edit->mark1 != edit->mark2 ) {
|
||||||
|
collapse_insert (edit, edit->curs_line, edit->curs_line + 10, 1);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case CK_Toggle_Bookmark:
|
case CK_Toggle_Bookmark:
|
||||||
book_mark_clear (edit, edit->curs_line, BOOK_MARK_FOUND_COLOR);
|
book_mark_clear (edit, edit->curs_line, BOOK_MARK_FOUND_COLOR);
|
||||||
if (book_mark_query_color (edit, edit->curs_line, BOOK_MARK_COLOR))
|
if (book_mark_query_color (edit, edit->curs_line, BOOK_MARK_COLOR))
|
||||||
|
@ -239,11 +239,11 @@ void book_mark_flush (WEdit * edit, int c);
|
|||||||
void book_mark_inc (WEdit * edit, int line);
|
void book_mark_inc (WEdit * edit, int line);
|
||||||
void book_mark_dec (WEdit * edit, int line);
|
void book_mark_dec (WEdit * edit, int line);
|
||||||
|
|
||||||
struct collapsed_lines *collapsed_find (WEdit * edit, int start_line);
|
struct collapsed_lines *collapse_find (WEdit * edit, int start_line);
|
||||||
void collapsed_insert (WEdit *edit,
|
void collapse_insert (WEdit *edit,
|
||||||
const unsigned long start_line,
|
const unsigned long start_line,
|
||||||
const unsigned long end_line, int state);
|
const unsigned long end_line, int state);
|
||||||
int collapsed_query (WEdit * edit, const unsigned long line,
|
int collapse_query (WEdit * edit, const unsigned long line,
|
||||||
unsigned long *start_line,
|
unsigned long *start_line,
|
||||||
unsigned long *end_line,
|
unsigned long *end_line,
|
||||||
int *state);
|
int *state);
|
||||||
|
@ -101,6 +101,8 @@
|
|||||||
#define CK_User_Menu 425
|
#define CK_User_Menu 425
|
||||||
#define CK_Find_Definition 426
|
#define CK_Find_Definition 426
|
||||||
|
|
||||||
|
#define CK_Add_Collapse_Region 428
|
||||||
|
|
||||||
/* application control */
|
/* application control */
|
||||||
#define CK_Save_Desktop 451
|
#define CK_Save_Desktop 451
|
||||||
#define CK_New_Window 452
|
#define CK_New_Window 452
|
||||||
@ -112,6 +114,7 @@
|
|||||||
#define CK_Maximize 458
|
#define CK_Maximize 458
|
||||||
|
|
||||||
#define CK_Toggle_Syntax 480
|
#define CK_Toggle_Syntax 480
|
||||||
|
#define CK_Toggle_Line_Status 490
|
||||||
|
|
||||||
/* macro */
|
/* macro */
|
||||||
#define CK_Begin_Record_Macro 501
|
#define CK_Begin_Record_Macro 501
|
||||||
|
@ -348,6 +348,9 @@ edit_draw_this_line (WEdit *edit, long b, long row, long start_col,
|
|||||||
int i;
|
int i;
|
||||||
int utf8lag = 0;
|
int utf8lag = 0;
|
||||||
|
|
||||||
|
unsigned long sl,el;
|
||||||
|
int stat;
|
||||||
|
|
||||||
edit_get_syntax_color (edit, b - 1, &color);
|
edit_get_syntax_color (edit, b - 1, &color);
|
||||||
q = edit_move_forward3 (edit, b, start_col - edit->start_col, 0);
|
q = edit_move_forward3 (edit, b, start_col - edit->start_col, 0);
|
||||||
start_col_real = (col =
|
start_col_real = (col =
|
||||||
@ -365,6 +368,9 @@ edit_draw_this_line (WEdit *edit, long b, long row, long start_col,
|
|||||||
if (book_mark_query_color (edit, cur_line, BOOK_MARK_COLOR)){
|
if (book_mark_query_color (edit, cur_line, BOOK_MARK_COLOR)){
|
||||||
g_snprintf (line_stat, 2, "*");
|
g_snprintf (line_stat, 2, "*");
|
||||||
}
|
}
|
||||||
|
if (collapse_query (edit, cur_line, &sl, &el, &stat)){
|
||||||
|
g_snprintf (line_stat, 2, "+");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (col + 16 > -edit->start_col) {
|
if (col + 16 > -edit->start_col) {
|
||||||
eval_marks (edit, &m1, &m2);
|
eval_marks (edit, &m1, &m2);
|
||||||
|
@ -114,6 +114,7 @@ static const edit_key_map_type common_key_map[] = {
|
|||||||
{ ALT ('-'), CK_Load_Prev_File },
|
{ ALT ('-'), CK_Load_Prev_File },
|
||||||
{ ALT ('='), CK_Load_Next_File },
|
{ ALT ('='), CK_Load_Next_File },
|
||||||
{ ALT (KEY_BACKSPACE), CK_Delete_Word_Left },
|
{ ALT (KEY_BACKSPACE), CK_Delete_Word_Left },
|
||||||
|
{ ALT ('n'), CK_Toggle_Line_Status },
|
||||||
|
|
||||||
{ XCTRL ('k'), CK_Delete_To_Line_End },
|
{ XCTRL ('k'), CK_Delete_To_Line_End },
|
||||||
{ XCTRL ('l'), CK_Refresh },
|
{ XCTRL ('l'), CK_Refresh },
|
||||||
@ -124,6 +125,7 @@ static const edit_key_map_type common_key_map[] = {
|
|||||||
{ XCTRL ('q'), CK_Insert_Literal },
|
{ XCTRL ('q'), CK_Insert_Literal },
|
||||||
{ XCTRL ('a'), CK_Execute_Macro },
|
{ XCTRL ('a'), CK_Execute_Macro },
|
||||||
{ XCTRL ('r'), CK_Begin_End_Macro },
|
{ XCTRL ('r'), CK_Begin_End_Macro },
|
||||||
|
{ XCTRL ('e'), CK_Add_Collapse_Region },
|
||||||
|
|
||||||
{ KEY_F (1), CK_Help },
|
{ KEY_F (1), CK_Help },
|
||||||
{ KEY_F (2), CK_Save },
|
{ KEY_F (2), CK_Save },
|
||||||
|
Loading…
Reference in New Issue
Block a user