ichange screen management -- dynamic array of lines - gramscii - A simple editor for ASCII box-and-arrow charts Err bitreich.org 70 1Log /scm/gramscii/log.gph bitreich.org 70 1Files /scm/gramscii/files.gph bitreich.org 70 1Refs /scm/gramscii/refs.gph bitreich.org 70 1Tags /scm/gramscii/tag bitreich.org 70 1README /scm/gramscii/file/README.md.gph bitreich.org 70 1LICENSE /scm/gramscii/file/COPYING.gph bitreich.org 70 i--- Err bitreich.org 70 1commit 3d53fcefe3ca3e6f25d1731c2caa0c1c0e676453 /scm/gramscii/commit/3d53fcefe3ca3e6f25d1731c2caa0c1c0e676453.gph bitreich.org 70 1parent 0adbc2a776c36b736bb5acb7184ba559d9428bc4 /scm/gramscii/commit/0adbc2a776c36b736bb5acb7184ba559d9428bc4.gph bitreich.org 70 hAuthor: KatolaZ URL:mailto:katolaz@freaknet.org bitreich.org 70 iDate: Fri, 26 Jul 2019 22:55:56 +0100 Err bitreich.org 70 i Err bitreich.org 70 ichange screen management -- dynamic array of lines Err bitreich.org 70 i Err bitreich.org 70 iDiffstat: Err bitreich.org 70 i M TODO | 6 +++--- Err bitreich.org 70 i M gramscii.c | 36 ++++++++++++++++++++++++++------ Err bitreich.org 70 i Err bitreich.org 70 i2 files changed, 33 insertions(+), 9 deletions(-) Err bitreich.org 70 i--- Err bitreich.org 70 1diff --git a/TODO b/TODO /scm/gramscii/file/TODO.gph bitreich.org 70 i@@ -1,5 +1,4 @@ Err bitreich.org 70 i + optimize redraws (redraw only the modified rectangle) Err bitreich.org 70 i-+ change screen management (i.e., dynamic array of lines) Err bitreich.org 70 i - add screen geometry option (-g 25x80?) Err bitreich.org 70 i - read file at point Err bitreich.org 70 i - read output of command (!) Err bitreich.org 70 i@@ -10,7 +9,7 @@ Err bitreich.org 70 i + parse arrows (text-mode will allow movements as well) Err bitreich.org 70 i - (?) implement CTRL+G as abort (aside ESC) Err bitreich.org 70 i - add crop command (c) Err bitreich.org 70 i-- remove extra blanks until EOL when saving to file Err bitreich.org 70 i+- (?) remove extra blanks until EOL when saving to file Err bitreich.org 70 i + visual selection Err bitreich.org 70 i - crop-to Err bitreich.org 70 i - yank/put Err bitreich.org 70 i@@ -20,8 +19,9 @@ Err bitreich.org 70 i - manage special chars (DEL/CANC) during text insert Err bitreich.org 70 i (also do not print unmanaged chars!) Err bitreich.org 70 i - allow scrolling (both vertical and horizontal) Err bitreich.org 70 i-- catch SIGWINCH and react appropriately (after scroll is Err bitreich.org 70 i+- catch SIGWINCH and react appropriately (after scrolling is Err bitreich.org 70 i enabled) Err bitreich.org 70 i+* change screen management (i.e., dynamic array of lines) Err bitreich.org 70 i * add action multiplier (e.g., "7h" moves left by 7 cols) Err bitreich.org 70 i * add scripting mode option ("-s"?) Err bitreich.org 70 i * auto-arrow 'A' (automatic end-char) Err bitreich.org 70 1diff --git a/gramscii.c b/gramscii.c /scm/gramscii/file/gramscii.c.gph bitreich.org 70 i@@ -136,6 +136,11 @@ void cleanup(int s){ Err bitreich.org 70 i exit(0); Err bitreich.org 70 i } Err bitreich.org 70 i Err bitreich.org 70 i+void exit_cleanup(void){ Err bitreich.org 70 i+ cleanup(0); Err bitreich.org 70 i+} Err bitreich.org 70 i+ Err bitreich.org 70 i+ Err bitreich.org 70 i /*** Status bar ***/ Err bitreich.org 70 i Err bitreich.org 70 i char* state_str(){ Err bitreich.org 70 i@@ -201,6 +206,7 @@ char get_key(FILE *fc, char *msg){ Err bitreich.org 70 i printf("%*s", WIDTH, ""); Err bitreich.org 70 i printf("\033[%d;1f\033[7m", HEIGHT+1); Err bitreich.org 70 i printf("%s", msg); Err bitreich.org 70 i+ fflush(stdout); Err bitreich.org 70 i printf("\033[0m"); Err bitreich.org 70 i fflush(stdout); Err bitreich.org 70 i return fgetc(fc); Err bitreich.org 70 i@@ -242,14 +248,33 @@ void show_cursor(){ Err bitreich.org 70 i Err bitreich.org 70 i Err bitreich.org 70 i void set_xy(int _x, int _y, char c){ Err bitreich.org 70 i- /* FIXME: check if x and y are valid!!!! */ Err bitreich.org 70 i+ line_t *tmp; Err bitreich.org 70 i+ if (_y >= num_lines){ Err bitreich.org 70 i+ tmp = realloc(screen, (_y + LONG_STEP)* sizeof(line_t)); Err bitreich.org 70 i+ if (tmp == NULL){ Err bitreich.org 70 i+ fprintf(stderr, "Unable to allocate memory for more lines"); Err bitreich.org 70 i+ exit(1); Err bitreich.org 70 i+ } Err bitreich.org 70 i+ else while ( num_lines < _y + LONG_STEP){ Err bitreich.org 70 i+ screen[num_lines].sz = WIDTH+1; Err bitreich.org 70 i+ screen[num_lines].s = malloc((screen[num_lines].sz) * sizeof(char)); Err bitreich.org 70 i+ if (screen[num_lines].s == NULL){ Err bitreich.org 70 i+ perror("allocating screen[num_lines].s"); Err bitreich.org 70 i+ exit(1); Err bitreich.org 70 i+ } Err bitreich.org 70 i+ memset(screen[num_lines].s, BG, screen[num_lines].sz); Err bitreich.org 70 i+ screen[num_lines].lst = 0; Err bitreich.org 70 i+ screen[num_lines].s[screen[num_lines].lst+1]='\0'; Err bitreich.org 70 i+ num_lines ++; Err bitreich.org 70 i+ } Err bitreich.org 70 i+ } Err bitreich.org 70 i if (screen[_y].sz < _x + 2){ Err bitreich.org 70 i screen[_y].sz = (_x +2) * 2; Err bitreich.org 70 i screen[_y].s = realloc(screen[_y].s, screen[_y].sz * sizeof(char)); Err bitreich.org 70 i } Err bitreich.org 70 i while (screen[_y].lst<_x){ Err bitreich.org 70 i+ screen[_y].lst ++; Err bitreich.org 70 i screen[_y].s[screen[_y].lst] = BG; Err bitreich.org 70 i- screen[_y].lst += 1; Err bitreich.org 70 i } Err bitreich.org 70 i screen[_y].s[_x] = c; Err bitreich.org 70 i if (_x == screen[_y].lst) Err bitreich.org 70 i@@ -806,7 +831,7 @@ void check_modified(FILE *fc){ Err bitreich.org 70 i if (!is_yes(get_key(fc, "Unsaved changes. Write to file [y/n]?")) ){ Err bitreich.org 70 i return; Err bitreich.org 70 i } Err bitreich.org 70 i- write_file(0); Err bitreich.org 70 i+ write_file(fc); Err bitreich.org 70 i } Err bitreich.org 70 i } Err bitreich.org 70 i Err bitreich.org 70 i@@ -905,7 +930,7 @@ void init_screen(){ Err bitreich.org 70 i exit(1); Err bitreich.org 70 i } Err bitreich.org 70 i memset(screen[i].s, BG, screen[i].sz); Err bitreich.org 70 i- screen[i].lst = WIDTH; Err bitreich.org 70 i+ screen[i].lst = 0; Err bitreich.org 70 i screen[i].s[screen[i].lst+1]='\0'; Err bitreich.org 70 i } Err bitreich.org 70 i reset_styles(); Err bitreich.org 70 i@@ -917,6 +942,7 @@ void init(){ Err bitreich.org 70 i signal(SIGINT, cleanup); Err bitreich.org 70 i signal(SIGTERM, cleanup); Err bitreich.org 70 i signal(SIGQUIT, cleanup); Err bitreich.org 70 i+ atexit(exit_cleanup); Err bitreich.org 70 i Err bitreich.org 70 i tcgetattr(0, &t1); Err bitreich.org 70 i t2 = t1; Err bitreich.org 70 i@@ -981,7 +1007,6 @@ void commands(FILE *fc){ Err bitreich.org 70 i case 'q': Err bitreich.org 70 i check_modified(fc);/** FALLTHROUGH **/ Err bitreich.org 70 i case 'Q': Err bitreich.org 70 i- cleanup(0); Err bitreich.org 70 i exit(0); Err bitreich.org 70 i break; Err bitreich.org 70 i } Err bitreich.org 70 i@@ -1028,6 +1053,5 @@ int main(int argc, char *argv[]){ Err bitreich.org 70 i argc--; Err bitreich.org 70 i } Err bitreich.org 70 i commands(stdin); Err bitreich.org 70 i- cleanup(0); Err bitreich.org 70 i return 0; Err bitreich.org 70 i } Err bitreich.org 70 .