SMOLNET PORTAL home about changes
itowards dynamic screen management - 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 0adbc2a776c36b736bb5acb7184ba559d9428bc4	/scm/gramscii/commit/0adbc2a776c36b736bb5acb7184ba559d9428bc4.gph	bitreich.org	70
1parent 8f25f7b9abb68e2efbc732a69f09d795ad79433c	/scm/gramscii/commit/8f25f7b9abb68e2efbc732a69f09d795ad79433c.gph	bitreich.org	70
hAuthor: KatolaZ <katolaz@freaknet.org>	URL:mailto:katolaz@freaknet.org	bitreich.org	70
iDate:   Fri, 26 Jul 2019 22:13:33 +0100	Err	bitreich.org	70
i	Err	bitreich.org	70
itowards dynamic screen management	Err	bitreich.org	70
i	Err	bitreich.org	70
iDiffstat:	Err	bitreich.org	70
i  M Makefile                            |       5 +++--	Err	bitreich.org	70
i  M TODO                                |       3 +--	Err	bitreich.org	70
i  M gramscii.c                          |      67 ++++++++++++++++++++-----------	Err	bitreich.org	70
i	Err	bitreich.org	70
i3 files changed, 48 insertions(+), 27 deletions(-)	Err	bitreich.org	70
i---	Err	bitreich.org	70
1diff --git a/Makefile b/Makefile	/scm/gramscii/file/Makefile.gph	bitreich.org	70
i@@ -17,8 +17,9 @@ options:	Err	bitreich.org	70
i         @echo "-+-+-+-+-+-+-+-+-+-+-" 	Err	bitreich.org	70
i         	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-gramscii: ${INC}	Err	bitreich.org	70
i-	Err	bitreich.org	70
i+gramscii: ${SRC} ${INC}	Err	bitreich.org	70
i+        $(CC) $(CFLAGS) -o gramscii ${SRC}	Err	bitreich.org	70
i+        	Err	bitreich.org	70
i clean:	Err	bitreich.org	70
i         @echo cleaning	Err	bitreich.org	70
i         @rm -f $(SRC:.c=)	Err	bitreich.org	70
1diff --git a/TODO b/TODO	/scm/gramscii/file/TODO.gph	bitreich.org	70
i@@ -1,5 +1,5 @@	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++ 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@@ -48,4 +48,3 @@	Err	bitreich.org	70
i * set different line styles (done for hl, vl, corner)	Err	bitreich.org	70
i * add status bar	Err	bitreich.org	70
i * implement box	Err	bitreich.org	70
i- 	Err	bitreich.org	70
1diff --git a/gramscii.c b/gramscii.c	/scm/gramscii/file/gramscii.c.gph	bitreich.org	70
i@@ -33,6 +33,13 @@	Err	bitreich.org	70
i 	Err	bitreich.org	70
i #include "arg.h"	Err	bitreich.org	70
i 	Err	bitreich.org	70
i+typedef struct{	Err	bitreich.org	70
i+        int sz;	Err	bitreich.org	70
i+        int lst;	Err	bitreich.org	70
i+        char *s;	Err	bitreich.org	70
i+} line_t;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+	Err	bitreich.org	70
i #define MOVE   0x00	Err	bitreich.org	70
i #define BOX    0x01	Err	bitreich.org	70
i #define ARROW  0x02	Err	bitreich.org	70
i@@ -71,9 +78,10 @@	Err	bitreich.org	70
i #define MIN(x,y)  (x) < (y) ? (x) : (y)	Err	bitreich.org	70
i #define MAX(x,y)  (x) > (y) ? (x) : (y)	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-/** #define DEBUG 1 **/	Err	bitreich.org	70
i+#define DEBUG 1 	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-char **screen;	Err	bitreich.org	70
i+line_t *screen;	Err	bitreich.org	70
i+int num_lines;	Err	bitreich.org	70
i int WIDTH, HEIGHT;	Err	bitreich.org	70
i 	Err	bitreich.org	70
i int state;	Err	bitreich.org	70
i@@ -113,7 +121,7 @@ struct termios t1, t2, t3;	Err	bitreich.org	70
i void dump_lines(){	Err	bitreich.org	70
i         int i;	Err	bitreich.org	70
i         for (i=0; i<HEIGHT; i++){	Err	bitreich.org	70
i-                printf("%s\n", screen[i]);	Err	bitreich.org	70
i+                printf("%s\n", screen[i].s);	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i }	Err	bitreich.org	70
i 	Err	bitreich.org	70
i@@ -179,7 +187,7 @@ void status_bar(){	Err	bitreich.org	70
i         else	Err	bitreich.org	70
i                 printf(" *%s*", fname );	Err	bitreich.org	70
i #ifdef DEBUG	Err	bitreich.org	70
i-        printf("  '%d'  ", screen[y][x]);	Err	bitreich.org	70
i+        printf("  '%d'  ", screen[y].s[x]);	Err	bitreich.org	70
i #endif	Err	bitreich.org	70
i         printf("\033[0m");	Err	bitreich.org	70
i         fflush(stdout);	Err	bitreich.org	70
i@@ -232,13 +240,24 @@ void show_cursor(){	Err	bitreich.org	70
i         fflush(stdout);	Err	bitreich.org	70
i }	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-void set_cur(char c){	Err	bitreich.org	70
i-        screen[y][x] = c;	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+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-        screen[y][x] = c;	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].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+                screen[_y].s[_x+1] = '\0';	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+void set_cur(char c){	Err	bitreich.org	70
i+        set_xy(x, y, c);	Err	bitreich.org	70
i }	Err	bitreich.org	70
i 	Err	bitreich.org	70
i void draw_xy(int x, int y, char c){	Err	bitreich.org	70
i@@ -254,7 +273,7 @@ void update_current(){	Err	bitreich.org	70
i         if (silent)	Err	bitreich.org	70
i                 return;	Err	bitreich.org	70
i         printf("\033[%d'%df",y+1,x+1);	Err	bitreich.org	70
i-        putchar(screen[y][x]);	Err	bitreich.org	70
i+        putchar(screen[y].s[x]);	Err	bitreich.org	70
i         fflush(stdout);	Err	bitreich.org	70
i }	Err	bitreich.org	70
i 	Err	bitreich.org	70
i@@ -282,7 +301,7 @@ void erase_box(int x1, int y1, char c){	Err	bitreich.org	70
i void erase_screen(){	Err	bitreich.org	70
i         int i;	Err	bitreich.org	70
i         for(i=0;i<HEIGHT; i++)	Err	bitreich.org	70
i-                erase_line(screen[i]);	Err	bitreich.org	70
i+                erase_line(screen[i].s);	Err	bitreich.org	70
i }	Err	bitreich.org	70
i 	Err	bitreich.org	70
i void check_bound(){	Err	bitreich.org	70
i@@ -311,7 +330,7 @@ void redraw(){	Err	bitreich.org	70
i                 return;	Err	bitreich.org	70
i         printf("\033[2J\033[1;1H");	Err	bitreich.org	70
i         for (i=0;i<HEIGHT;i++){	Err	bitreich.org	70
i-                fprintf(stdout,"%s\n",screen[i]);	Err	bitreich.org	70
i+                fprintf(stdout,"%s\n",screen[i].s);	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i         status_bar();	Err	bitreich.org	70
i         show_cursor();	Err	bitreich.org	70
i@@ -774,7 +793,7 @@ void write_file(FILE *fc){	Err	bitreich.org	70
i                 return;	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i         for (i=0; i<HEIGHT; i++){	Err	bitreich.org	70
i-                fprintf(fout, "%s\n", screen[i]);	Err	bitreich.org	70
i+                fprintf(fout, "%s\n", screen[i].s);	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i         fclose(fout);	Err	bitreich.org	70
i         modified = 0;	Err	bitreich.org	70
i@@ -800,10 +819,10 @@ void load_file(FILE *fc){	Err	bitreich.org	70
i         get_string(fc, "Load file: ", newfname, 255);	Err	bitreich.org	70
i         if ((fin=fopen(newfname, "r")) != NULL){	Err	bitreich.org	70
i                 i = 0;	Err	bitreich.org	70
i-                while((fgets(screen[i], WIDTH+2, fin)) != NULL && i<HEIGHT)	Err	bitreich.org	70
i-                        screen[i++][WIDTH-1]='\0';	Err	bitreich.org	70
i+                while((fgets(screen[i].s, WIDTH+2, fin)) != NULL && i<HEIGHT)	Err	bitreich.org	70
i+                        screen[i++].s[WIDTH-1]='\0';	Err	bitreich.org	70
i                 for(;i<HEIGHT; i++){	Err	bitreich.org	70
i-                        erase_line(screen[i]);	Err	bitreich.org	70
i+                        erase_line(screen[i].s);	Err	bitreich.org	70
i                 }	Err	bitreich.org	70
i                 fclose(fin);	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i@@ -872,24 +891,26 @@ void init_screen(){	Err	bitreich.org	70
i                 WIDTH=80;	Err	bitreich.org	70
i                 HEIGHT=24;	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i-        screen = malloc(HEIGHT * sizeof(char *));	Err	bitreich.org	70
i+        screen = malloc(HEIGHT * sizeof(line_t));	Err	bitreich.org	70
i+        num_lines = HEIGHT;	Err	bitreich.org	70
i         if (screen == NULL){	Err	bitreich.org	70
i                 perror("allocating screen");	Err	bitreich.org	70
i                 exit(1);	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i         for (i=0; i<HEIGHT; i++){	Err	bitreich.org	70
i-                screen[i] = malloc((WIDTH+1) * sizeof(char));	Err	bitreich.org	70
i-                if (screen[i] == NULL){	Err	bitreich.org	70
i-                        perror("allocating screen[i]");	Err	bitreich.org	70
i+                screen[i].sz = WIDTH+1;	Err	bitreich.org	70
i+                screen[i].s = malloc((screen[i].sz) * sizeof(char));	Err	bitreich.org	70
i+                if (screen[i].s == NULL){	Err	bitreich.org	70
i+                        perror("allocating screen[i].s");	Err	bitreich.org	70
i                         exit(1);	Err	bitreich.org	70
i                 }	Err	bitreich.org	70
i-                memset(screen[i], ' ', WIDTH * sizeof(char));	Err	bitreich.org	70
i-                screen[i][WIDTH]='\0';	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].s[screen[i].lst+1]='\0';	Err	bitreich.org	70
i         }	Err	bitreich.org	70
i         reset_styles();	Err	bitreich.org	70
i }	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-	Err	bitreich.org	70
i void init(){	Err	bitreich.org	70
i 	Err	bitreich.org	70
i         signal(SIGHUP, cleanup);	Err	bitreich.org	70
.
Response: text/plain
Original URLgopher://bitreich.org/0/scm/gramscii/commit/0adbc2a776c36...
Content-Typetext/plain; charset=utf-8