edit-widget.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #ifndef MC_EDIT_WIDGET_H
  2. #define MC_EDIT_WIDGET_H
  3. #include "../src/dialog.h" /* Widget */
  4. #include "edit.h"
  5. #define MAX_MACRO_LENGTH 1024
  6. #define N_LINE_CACHES 32
  7. #define BOOK_MARK_COLOR ((25 << 8) | 5)
  8. #define BOOK_MARK_FOUND_COLOR ((26 << 8) | 4)
  9. struct _book_mark {
  10. int line; /* line number */
  11. int c; /* color */
  12. struct _book_mark *next;
  13. struct _book_mark *prev;
  14. };
  15. struct syntax_rule {
  16. unsigned short keyword;
  17. unsigned char end;
  18. unsigned char context;
  19. unsigned char _context;
  20. unsigned char border;
  21. };
  22. struct WEdit {
  23. Widget widget;
  24. int num_widget_lines;
  25. int num_widget_columns;
  26. char *filename; /* Name of the file */
  27. char *dir; /* NULL if filename is absolute */
  28. /* dynamic buffers and cursor position for editor: */
  29. long curs1; /* position of the cursor from the beginning of the file. */
  30. long curs2; /* position from the end of the file */
  31. unsigned char *buffers1[MAXBUFF + 1]; /* all data up to curs1 */
  32. unsigned char *buffers2[MAXBUFF + 1]; /* all data from end of file down to curs2 */
  33. /* search variables */
  34. long search_start; /* First character to start searching from */
  35. int found_len; /* Length of found string or 0 if none was found */
  36. long found_start; /* the found word from a search - start position */
  37. /* display information */
  38. long last_byte; /* Last byte of file */
  39. long start_display; /* First char displayed */
  40. long start_col; /* First displayed column, negative */
  41. long max_column; /* The maximum cursor position ever reached used to calc hori scroll bar */
  42. long curs_row; /* row position of cursor on the screen */
  43. long curs_col; /* column position on screen */
  44. int force; /* how much of the screen do we redraw? */
  45. int overwrite:1; /* Overwrite on type mode (as opposed to insert) */
  46. int modified:1; /* File has been modified and needs saving */
  47. int loading_done:1; /* File has been loaded into the editor */
  48. int locked:1; /* We hold lock on current file */
  49. int screen_modified:1; /* File has been changed since the last screen draw */
  50. int delete_file:1; /* New file, needs to be deleted unless modified */
  51. int highlight:1; /* There is a selected block */
  52. long prev_col; /* recent column position of the cursor - used when moving
  53. up or down past lines that are shorter than the current line */
  54. long curs_line; /* line number of the cursor. */
  55. long start_line; /* line number of the top of the page */
  56. /* file info */
  57. long total_lines; /* total lines in the file */
  58. long mark1; /* position of highlight start */
  59. long mark2; /* position of highlight end */
  60. int column1; /* position of column highlight start */
  61. int column2; /* position of column highlight end */
  62. long bracket; /* position of a matching bracket */
  63. /* cache speedup for line lookups */
  64. int caches_valid;
  65. int line_numbers[N_LINE_CACHES];
  66. long line_offsets[N_LINE_CACHES];
  67. struct _book_mark *book_mark;
  68. /* undo stack and pointers */
  69. unsigned long stack_pointer;
  70. long *undo_stack;
  71. unsigned long stack_size;
  72. unsigned long stack_size_mask;
  73. unsigned long stack_bottom;
  74. int stack_disable:1; /* If not 0, don't save events in the undo stack */
  75. struct stat stat1; /* Result of mc_fstat() on the file */
  76. /* syntax higlighting */
  77. struct _syntax_marker *syntax_marker;
  78. struct context_rule **rules;
  79. long last_get_rule;
  80. struct syntax_rule rule;
  81. char *syntax_type; /* description of syntax highlighting type being used */
  82. GTree *defines; /* List of defines */
  83. /* macro stuff */
  84. int macro_i; /* index to macro[], -1 if not recording a macro */
  85. int macro_depth; /* depth of the macro recursion */
  86. struct macro macro[MAX_MACRO_LENGTH];
  87. };
  88. #endif