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