|
|
@ -359,26 +359,35 @@ void drawBar (char *s) |
|
|
|
/* Open a file and put it into a buffer line by line */ |
|
|
|
/* Open a file and put it into a buffer line by line */ |
|
|
|
void fileOpen (char *filename) |
|
|
|
void fileOpen (char *filename) |
|
|
|
{ |
|
|
|
{ |
|
|
|
FILE *fp = fopen(filename, "r"); |
|
|
|
FILE *fd = fopen(filename, "a+"); |
|
|
|
if (fp == NULL) die("Cannot open file", BAD_FILE); |
|
|
|
if (fd == NULL) die("Cannot open file", BAD_FILE); |
|
|
|
|
|
|
|
|
|
|
|
/* Init the linebuffer */ |
|
|
|
/* Check if the file is empty first */ |
|
|
|
char *line = NULL; |
|
|
|
fseek (fd, 0, SEEK_END); |
|
|
|
/* Set linecap to 0 so getline will atumatically allocate
|
|
|
|
int size = ftell(fd); |
|
|
|
* memory for the line buffer*/ |
|
|
|
if (size) { |
|
|
|
size_t linecap = 0; |
|
|
|
rewind(fd); |
|
|
|
ssize_t linelen; |
|
|
|
|
|
|
|
|
|
|
|
/* Init the linebuffer */ |
|
|
|
/* getline returns -1 if no new line is present */ |
|
|
|
char *line = NULL; |
|
|
|
while ((linelen = getline(&line, &linecap, fp)) != -1) { |
|
|
|
/* Set linecap to 0 so getline will atumatically allocate
|
|
|
|
while (linelen > 0 && (line[linelen - 1] == '\n' || line[linelen - 1] == '\r')) |
|
|
|
* memory for the line buffer*/ |
|
|
|
linelen--; |
|
|
|
size_t linecap = 0; |
|
|
|
rowAddLast(&rows, line, linelen); |
|
|
|
ssize_t linelen; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* getline returns -1 if no new line is present */ |
|
|
|
|
|
|
|
while ((linelen = getline(&line, &linecap, fd)) != -1) { |
|
|
|
|
|
|
|
while (linelen > 0 && (line[linelen - 1] == '\n' || line[linelen - 1] == '\r')) |
|
|
|
|
|
|
|
linelen--; |
|
|
|
|
|
|
|
rowAddLast(&rows, line, linelen); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
/* free the line buffer */ |
|
|
|
|
|
|
|
free(line); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
rowAddLast(&rows, " ", 1); |
|
|
|
} |
|
|
|
} |
|
|
|
/* free the line buffer */ |
|
|
|
|
|
|
|
free(line); |
|
|
|
|
|
|
|
/* close the file */ |
|
|
|
/* close the file */ |
|
|
|
fclose(fp); |
|
|
|
fclose(fd); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/*------------------------------------- file operations ----------------------------------*/ |
|
|
|
/*------------------------------------- file operations ----------------------------------*/ |
|
|
@ -581,7 +590,7 @@ void updateInfo (void) |
|
|
|
|
|
|
|
|
|
|
|
getmaxyx(stdscr, t.dim.y, t.dim.x); |
|
|
|
getmaxyx(stdscr, t.dim.y, t.dim.x); |
|
|
|
t.dim.y -= 1; |
|
|
|
t.dim.y -= 1; |
|
|
|
t.pad = decimalSize(rows.rownum - 1); |
|
|
|
t.pad = decimalSize(rows.rownum > 1 ? rows.rownum - 1 : 2); |
|
|
|
t.dim.x -= t.pad + 1; |
|
|
|
t.dim.x -= t.pad + 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|