From: Chris Wilson Date: Thu, 10 Jul 2014 20:01:57 +0000 (+0100) Subject: configure: Provide a poor man's replacement for getline() X-Git-Tag: 2.99.913~32 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=251bcc32eed37ee10eb14ce2278ecbdcc40a7cde;p=platform%2Fupstream%2Fxf86-video-intel.git configure: Provide a poor man's replacement for getline() uClibc is one such library that doesn't implement getline() Reported-by: Ben Widawsky Signed-off-by: Chris Wilson --- diff --git a/configure.ac b/configure.ac index 8e4d833..eec9f89 100644 --- a/configure.ac +++ b/configure.ac @@ -818,6 +818,9 @@ if test "x$debug_msg" = "x"; then debug_msg=" none" fi +AC_CONFIG_LIBOBJ_DIR(libobj) +AC_REPLACE_FUNCS(getline) + DRIVER_NAME="intel" AC_SUBST([DRIVER_NAME]) AC_SUBST([moduledir]) diff --git a/libobj/getline.c b/libobj/getline.c new file mode 100644 index 0000000..5acdf8d --- /dev/null +++ b/libobj/getline.c @@ -0,0 +1,51 @@ +#include +#include +#include + +extern int getline(char **line, size_t *len, FILE *file); + +int getline(char **line, size_t *len, FILE *file) +{ + char *ptr, *end; + int c; + + if (*line == NULL) { + errno = EINVAL; + if (*len == 0) + *line = malloc(4096); + if (*line == NULL) + return -1; + + *len = 4096; + } + + ptr = *line; + end = *line + *len; + + while ((c = fgetc(file)) != EOF) { + if (ptr + 1 >= end) { + char *newline; + int offset; + + newline = realloc(*line, *len + 4096); + if (newline == NULL) + return -1; + + offset = ptr - *line; + + *line = newline; + *len += 4096; + + ptr = *line + offset; + end = *line + *len; + } + + *ptr++ = c; + if (c == '\n') { + *ptr = '\0'; + return ptr - *line; + } + } + *ptr = '\0'; + return -1; +} diff --git a/src/sna/sna.h b/src/sna/sna.h index 431fe97..6e70c56 100644 --- a/src/sna/sna.h +++ b/src/sna/sna.h @@ -1222,4 +1222,9 @@ static inline void sigtrap_put(void) #define RR_Rotate_All (RR_Rotate_0 | RR_Rotate_90 | RR_Rotate_180 | RR_Rotate_270) #define RR_Reflect_All (RR_Reflect_X | RR_Reflect_Y) +#ifndef HAVE_GETLINE +#include +extern int getline(char **line, size_t *len, FILE *file); +#endif + #endif /* _SNA_H */