isave to file works - 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 52a48d7718c6467da380a51f49327323e15e00c7 /scm/gramscii/commit/52a48d7718c6467da380a51f49327323e15e00c7.gph bitreich.org 70
1parent a2bf8545d73621de7cfa3a06663d1b94fdc668c4 /scm/gramscii/commit/a2bf8545d73621de7cfa3a06663d1b94fdc668c4.gph bitreich.org 70
hAuthor: KatolaZ <katolaz@freaknet.org> URL:mailto:katolaz@freaknet.org bitreich.org 70
iDate: Fri, 19 Jul 2019 18:03:29 +0100 Err bitreich.org 70
i Err bitreich.org 70
isave to file works Err bitreich.org 70
i Err bitreich.org 70
iDiffstat: Err bitreich.org 70
i M TODO | 16 +++++++++++----- Err bitreich.org 70
i M gramscii.c | 110 +++++++++++++++++++++++++------ Err bitreich.org 70
i Err bitreich.org 70
i2 files changed, 102 insertions(+), 24 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,14 +1,20 @@ Err bitreich.org 70
i + optimize redraws (i.e., avoid to redraw if possible) Err bitreich.org 70
i - (?) change cursor shape according to action Err bitreich.org 70
i-- save to file Err bitreich.org 70
i-- implement auto-arrow 'A' (automatic end-char) Err bitreich.org 70
i-- implement delete 'x' or 'd' Err bitreich.org 70
i+- auto-arrow 'A' (automatic end-char) Err bitreich.org 70
i+- delete -- 'x' or 'd' Err bitreich.org 70
i+- load from file Err bitreich.org 70
i+- read file at point Err bitreich.org 70
i+- visual selection Err bitreich.org 70
i+ - crop Err bitreich.org 70
i+ - fill Err bitreich.org 70
i+ - delete Err bitreich.org 70
i+ - yank/put Err bitreich.org 70
i+- undo (by storing lines changed across insert/remove operations) 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-- load from file Err bitreich.org 70
i-- insert file at position Err bitreich.org 70
i - get screen geometry Err bitreich.org 70
i - allow scrolling (both vertical and horizontal) Err bitreich.org 70
i+* save to file Err bitreich.org 70
i * implement arrow 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
1diff --git a/gramscii.c b/gramscii.c /scm/gramscii/file/gramscii.c.gph bitreich.org 70
i@@ -41,6 +41,10 @@ Err bitreich.org 70
i #define ARR_D 'v' Err bitreich.org 70
i Err bitreich.org 70
i Err bitreich.org 70
i+#define HOME 0x01 Err bitreich.org 70
i+#define END 0x02 Err bitreich.org 70
i+#define MIDDLE 0x04 Err bitreich.org 70
i+ 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@@ -71,7 +75,7 @@ char line_v; Err bitreich.org 70
i char mark_st; Err bitreich.org 70
i char mark_end; Err bitreich.org 70
i Err bitreich.org 70
i-struct termios t1, t2; Err bitreich.org 70
i+struct termios t1, t2, t3; Err bitreich.org 70
i Err bitreich.org 70
i Err bitreich.org 70
i void cleanup(int s){ Err bitreich.org 70
i@@ -245,6 +249,13 @@ void draw_box(int x1, int y1, int fix){ Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i Err bitreich.org 70
i+void move_around(char c){ Err bitreich.org 70
i+ Err bitreich.org 70
i+ Err bitreich.org 70
i+ Err bitreich.org 70
i+} Err bitreich.org 70
i+ Err bitreich.org 70
i+ Err bitreich.org 70
i void get_box(){ Err bitreich.org 70
i char c; Err bitreich.org 70
i int orig_x=x, orig_y=y; Err bitreich.org 70
i@@ -285,28 +296,12 @@ void get_box(){ Err bitreich.org 70
i Err bitreich.org 70
i Err bitreich.org 70
i int progr_x(int dir){ Err bitreich.org 70
i- switch(dir){ Err bitreich.org 70
i- case DIR_L: Err bitreich.org 70
i- return -1; Err bitreich.org 70
i- case DIR_R: Err bitreich.org 70
i- return +1; Err bitreich.org 70
i- default: Err bitreich.org 70
i- return 0; Err bitreich.org 70
i- } Err bitreich.org 70
i- return 0; Err bitreich.org 70
i+ return dir == DIR_L ? -1 : dir == DIR_R ? 1: 0; Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i Err bitreich.org 70
i int progr_y(int dir){ Err bitreich.org 70
i- switch(dir){ Err bitreich.org 70
i- case DIR_D: Err bitreich.org 70
i- return +1; Err bitreich.org 70
i- case DIR_U: Err bitreich.org 70
i- return -1; Err bitreich.org 70
i- default: Err bitreich.org 70
i- return 0; Err bitreich.org 70
i- } Err bitreich.org 70
i- return 0; Err bitreich.org 70
i+ return dir == DIR_U ? -1 : dir == DIR_D ? 1: 0; Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i Err bitreich.org 70
i@@ -412,9 +407,58 @@ void get_arrow(){ Err bitreich.org 70
i state = MOVE; Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i+char get_key(char *s){ Err bitreich.org 70
i+ Err bitreich.org 70
i+ printf("\033[%d;1f\033[7m", HEIGHT+1); Err bitreich.org 70
i+ printf("%100s", " "); Err bitreich.org 70
i+ printf("\033[%d;1f\033[7m", HEIGHT+1); Err bitreich.org 70
i+ printf("%s ", s); Err bitreich.org 70
i+ printf("\033[0m"); Err bitreich.org 70
i+ return getchar(); Err bitreich.org 70
i+} Err bitreich.org 70
i+ Err bitreich.org 70
i+void get_string(char *s, int sz){ Err bitreich.org 70
i+ Err bitreich.org 70
i+ printf("\033[%d;1f\033[7m", HEIGHT+1); Err bitreich.org 70
i+ printf("%100s", " "); Err bitreich.org 70
i+ printf("\033[%d;1f\033[7m", HEIGHT+1); Err bitreich.org 70
i+ /* We must activate echo now */ Err bitreich.org 70
i+ t3 = t2; Err bitreich.org 70
i+ t3.c_lflag |= (ECHO | ICANON); Err bitreich.org 70
i+ tcsetattr(0, TCSANOW, &t3); Err bitreich.org 70
i+ printf("Write to: "); Err bitreich.org 70
i+ printf("\033[0m"); Err bitreich.org 70
i+ fgets(s, sz, stdin); Err bitreich.org 70
i+ s[strlen(s)-1] = '\0'; Err bitreich.org 70
i+ tcsetattr(0, TCSANOW, &t2); Err bitreich.org 70
i+} Err bitreich.org 70
i+ Err bitreich.org 70
i+int is_yes(char c){ Err bitreich.org 70
i+ return c=='y' ? 1 : c == 'Y'? 1 : 0; Err bitreich.org 70
i+} Err bitreich.org 70
i+ Err bitreich.org 70
i void write_file(){ Err bitreich.org 70
i char fname[256]; Err bitreich.org 70
i FILE *f; Err bitreich.org 70
i+ int i; Err bitreich.org 70
i+ Err bitreich.org 70
i+ get_string(fname, 255); Err bitreich.org 70
i+ if (f=fopen(fname, "r")){ Err bitreich.org 70
i+ if (!is_yes(get_key("File exists. Overwrite [y/N]?")) ){ Err bitreich.org 70
i+ fclose(f); Err bitreich.org 70
i+ return; Err bitreich.org 70
i+ } Err bitreich.org 70
i+ fclose(f); Err bitreich.org 70
i+ } Err bitreich.org 70
i+ if((f=fopen(fname, "w"))==NULL){ Err bitreich.org 70
i+ get_key("Error opening file."); 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(f, "%s\n", screen[i]); Err bitreich.org 70
i+ } Err bitreich.org 70
i+ fclose(f); Err bitreich.org 70
i+ get_key("File saved."); Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i void toggle_hline(){ Err bitreich.org 70
i@@ -450,6 +494,25 @@ void toggle_end_mark(){ Err bitreich.org 70
i mark_end = end_marks[cur_end]; Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i+void go_to(int where){ Err bitreich.org 70
i+ switch(where){ Err bitreich.org 70
i+ case HOME: Err bitreich.org 70
i+ x = y = 0; Err bitreich.org 70
i+ break; Err bitreich.org 70
i+ case END: Err bitreich.org 70
i+ x = WIDTH-1; Err bitreich.org 70
i+ y = HEIGHT-1; Err bitreich.org 70
i+ break; Err bitreich.org 70
i+ case MIDDLE: Err bitreich.org 70
i+ x = WIDTH/2; Err bitreich.org 70
i+ y = HEIGHT/2; Err bitreich.org 70
i+ break; Err bitreich.org 70
i+ } Err bitreich.org 70
i+ check_bound(); Err bitreich.org 70
i+ show_cursor(); Err bitreich.org 70
i+} Err bitreich.org 70
i+ Err bitreich.org 70
i+ Err bitreich.org 70
i void commands(){ Err bitreich.org 70
i Err bitreich.org 70
i char c; Err bitreich.org 70
i@@ -494,6 +557,15 @@ void commands(){ Err bitreich.org 70
i case 'w': Err bitreich.org 70
i write_file(); Err bitreich.org 70
i break; Err bitreich.org 70
i+ case 'g': Err bitreich.org 70
i+ go_to(HOME); Err bitreich.org 70
i+ break; Err bitreich.org 70
i+ case 'G': Err bitreich.org 70
i+ go_to(END); Err bitreich.org 70
i+ break; Err bitreich.org 70
i+ case 'm': Err bitreich.org 70
i+ go_to(MIDDLE); Err bitreich.org 70
i+ break; Err bitreich.org 70
i case '-': Err bitreich.org 70
i toggle_hline(); Err bitreich.org 70
i break; Err bitreich.org 70
.
Response:
text/plain