Use getline instead of readline
This commit is contained in:
parent
2252a0148d
commit
ea23115af4
2
Makefile
2
Makefile
|
@ -1,6 +1,6 @@
|
||||||
all: sxiv
|
all: sxiv
|
||||||
|
|
||||||
VERSION=git-20110525
|
VERSION=git-20110529
|
||||||
|
|
||||||
CC?=gcc
|
CC?=gcc
|
||||||
DESTDIR?=
|
DESTDIR?=
|
||||||
|
|
25
main.c
25
main.c
|
@ -16,6 +16,8 @@
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define _XOPEN_SOURCE 700
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -59,7 +61,7 @@ img_t img;
|
||||||
tns_t tns;
|
tns_t tns;
|
||||||
win_t win;
|
win_t win;
|
||||||
|
|
||||||
const char **filenames;
|
char **filenames;
|
||||||
int filecnt, fileidx;
|
int filecnt, fileidx;
|
||||||
size_t filesize;
|
size_t filesize;
|
||||||
|
|
||||||
|
@ -88,7 +90,7 @@ void remove_file(int n, unsigned char silent) {
|
||||||
|
|
||||||
if (n + 1 < filecnt)
|
if (n + 1 < filecnt)
|
||||||
memmove(filenames + n, filenames + n + 1, (filecnt - n - 1) *
|
memmove(filenames + n, filenames + n + 1, (filecnt - n - 1) *
|
||||||
sizeof(const char*));
|
sizeof(char*));
|
||||||
if (n + 1 < tns.cnt) {
|
if (n + 1 < tns.cnt) {
|
||||||
memmove(tns.thumbs + n, tns.thumbs + n + 1, (tns.cnt - n - 1) *
|
memmove(tns.thumbs + n, tns.thumbs + n + 1, (tns.cnt - n - 1) *
|
||||||
sizeof(thumb_t));
|
sizeof(thumb_t));
|
||||||
|
@ -150,7 +152,7 @@ void update_title() {
|
||||||
win_set_title(&win, win_title);
|
win_set_title(&win, win_title);
|
||||||
}
|
}
|
||||||
|
|
||||||
int check_append(const char *filename) {
|
int check_append(char *filename) {
|
||||||
if (!filename)
|
if (!filename)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -160,8 +162,7 @@ int check_append(const char *filename) {
|
||||||
} else {
|
} else {
|
||||||
if (fileidx == filecnt) {
|
if (fileidx == filecnt) {
|
||||||
filecnt *= 2;
|
filecnt *= 2;
|
||||||
filenames = (const char**) s_realloc(filenames,
|
filenames = (char**) s_realloc(filenames, filecnt * sizeof(char*));
|
||||||
filecnt * sizeof(const char*));
|
|
||||||
}
|
}
|
||||||
filenames[fileidx++] = filename;
|
filenames[fileidx++] = filename;
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -173,8 +174,9 @@ int fncmp(const void *a, const void *b) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
int i, start;
|
int i, len, start;
|
||||||
const char *filename;
|
size_t n;
|
||||||
|
char *filename = NULL;
|
||||||
struct stat fstats;
|
struct stat fstats;
|
||||||
r_dir_t dir;
|
r_dir_t dir;
|
||||||
|
|
||||||
|
@ -196,13 +198,16 @@ int main(int argc, char **argv) {
|
||||||
else
|
else
|
||||||
filecnt = options->filecnt;
|
filecnt = options->filecnt;
|
||||||
|
|
||||||
filenames = (const char**) s_malloc(filecnt * sizeof(const char*));
|
filenames = (char**) s_malloc(filecnt * sizeof(char*));
|
||||||
fileidx = 0;
|
fileidx = 0;
|
||||||
|
|
||||||
if (options->from_stdin) {
|
if (options->from_stdin) {
|
||||||
while ((filename = readline(stdin))) {
|
while ((len = getline(&filename, &n, stdin)) > 0) {
|
||||||
|
if (filename[len-1] == '\n')
|
||||||
|
filename[len-1] = '\0';
|
||||||
if (!*filename || !check_append(filename))
|
if (!*filename || !check_append(filename))
|
||||||
free((void*) filename);
|
free(filename);
|
||||||
|
filename = NULL;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (i = 0; i < options->filecnt; ++i) {
|
for (i = 0; i < options->filecnt; ++i) {
|
||||||
|
|
|
@ -124,7 +124,7 @@ void parse_options(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_options.filenames = (const char**) argv + optind;
|
_options.filenames = argv + optind;
|
||||||
_options.filecnt = argc - optind;
|
_options.filecnt = argc - optind;
|
||||||
_options.from_stdin = _options.filecnt == 1 &&
|
_options.from_stdin = _options.filecnt == 1 &&
|
||||||
strcmp(_options.filenames[0], "-") == 0;
|
strcmp(_options.filenames[0], "-") == 0;
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
#include "image.h"
|
#include "image.h"
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
const char **filenames;
|
char **filenames;
|
||||||
unsigned char from_stdin;
|
unsigned char from_stdin;
|
||||||
int filecnt;
|
int filecnt;
|
||||||
int startnum;
|
int startnum;
|
||||||
|
|
36
util.c
36
util.c
|
@ -297,39 +297,3 @@ int r_mkdir(const char *path) {
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
char* readline(FILE *stream) {
|
|
||||||
size_t len;
|
|
||||||
char *buf, *s, *end;
|
|
||||||
|
|
||||||
if (!stream || feof(stream) || ferror(stream))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
len = FNAME_LEN;
|
|
||||||
s = buf = (char*) s_malloc(len * sizeof(char));
|
|
||||||
|
|
||||||
do {
|
|
||||||
*s = '\0';
|
|
||||||
fgets(s, len - (s - buf), stream);
|
|
||||||
if ((end = strchr(s, '\n'))) {
|
|
||||||
*end = '\0';
|
|
||||||
} else if (strlen(s) + 1 == len - (s - buf)) {
|
|
||||||
buf = (char*) s_realloc(buf, 2 * len * sizeof(char));
|
|
||||||
s = buf + len - 1;
|
|
||||||
len *= 2;
|
|
||||||
} else {
|
|
||||||
s += strlen(s);
|
|
||||||
}
|
|
||||||
} while (!end && !feof(stream) && !ferror(stream));
|
|
||||||
|
|
||||||
if (ferror(stream)) {
|
|
||||||
s = NULL;
|
|
||||||
} else {
|
|
||||||
s = (char*) s_malloc((strlen(buf) + 1) * sizeof(char));
|
|
||||||
strcpy(s, buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
free(buf);
|
|
||||||
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue