SMOLNET PORTAL home about changes
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 <katolaz@freaknet.org>	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
.
Response: text/plain
Original URLgopher://bitreich.org/0/scm/gramscii/commit/3d53fcefe3ca3...
Content-Typetext/plain; charset=utf-8