aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--jim-clock.c2
-rw-r--r--jim.c4
-rw-r--r--linenoise.c13
3 files changed, 12 insertions, 7 deletions
diff --git a/jim-clock.c b/jim-clock.c
index b342f31..f51b14b 100644
--- a/jim-clock.c
+++ b/jim-clock.c
@@ -6,7 +6,9 @@
*/
/* For strptime() */
+#ifndef _XOPEN_SOURCE
#define _XOPEN_SOURCE 500
+#endif
#include <stdlib.h>
#include <string.h>
diff --git a/jim.c b/jim.c
index b0b642e..4923d97 100644
--- a/jim.c
+++ b/jim.c
@@ -4619,7 +4619,7 @@ void Jim_FreeInterp(Jim_Interp *i)
const char *type = objPtr->typePtr ? objPtr->typePtr->name : "string";
printf("%p (%d) %-10s: '%.20s'" JIM_NL,
- objPtr, objPtr->refCount, type, objPtr->bytes ? objPtr->bytes : "(null)");
+ (void *)objPtr, objPtr->refCount, type, objPtr->bytes ? objPtr->bytes : "(null)");
if (objPtr->typePtr == &sourceObjType) {
printf("FILE %s LINE %d" JIM_NL,
objPtr->internalRep.sourceValue.fileName,
@@ -10353,7 +10353,7 @@ static int JimInfoLevel(Jim_Interp *interp, Jim_Obj *levelObjPtr,
Jim_ListAppendElement(interp, listObj, targetCallFrame->argv[0]);
Jim_ListAppendElement(interp, listObj, Jim_NewStringObj(interp,
- targetCallFrame->filename ? : "", -1));
+ targetCallFrame->filename ? targetCallFrame->filename : "", -1));
Jim_ListAppendElement(interp, listObj, Jim_NewIntObj(interp, targetCallFrame->line));
*objPtrPtr = listObj;
}
diff --git a/linenoise.c b/linenoise.c
index 2c83960..038756b 100644
--- a/linenoise.c
+++ b/linenoise.c
@@ -189,6 +189,9 @@ struct current {
int cols; /* Size of the window, in chars */
};
+/* gcc/glibc insists that we care about the return code of write! */
+#define IGNORE_RC(EXPR) ((EXPR) < 0 ? -1 : 0)
+
/* This is fd_printf() on some systems, but use a different
* name to avoid conflicts
*/
@@ -201,7 +204,7 @@ static void fd_printf(int fd, const char *format, ...)
va_start(args, format);
n = vsnprintf(buf, sizeof(buf), format, args);
va_end(args);
- write(fd, buf, n);
+ IGNORE_RC(write(fd, buf, n));
}
@@ -224,7 +227,7 @@ static int get_char(struct current *current, int pos)
if (pos >= 0 && pos < current->chars) {
int c;
int i = utf8_index(current->buf, pos);
- utf8_tounicode(current->buf + i, &c);
+ (void)utf8_tounicode(current->buf + i, &c);
return c;
}
return -1;
@@ -285,7 +288,7 @@ static void refreshLine(const char *prompt, struct current *current) {
/* Cursor to left edge, then the prompt */
fd_printf(current->fd, "\x1b[0G");
- write(current->fd, prompt, plen);
+ IGNORE_RC(write(current->fd, prompt, plen));
/* Now the current buffer content */
@@ -305,7 +308,7 @@ static void refreshLine(const char *prompt, struct current *current) {
}
if (ch < ' ') {
/* A control character, so write the buffer so far */
- write(current->fd, buf, b);
+ IGNORE_RC(write(current->fd, buf, b));
buf += b + w;
b = 0;
fd_printf(current->fd, "\033[7m^%c\033[0m", ch + '@');
@@ -317,7 +320,7 @@ static void refreshLine(const char *prompt, struct current *current) {
b += w;
}
}
- write(current->fd, buf, b);
+ IGNORE_RC(write(current->fd, buf, b));
/* Erase to right, move cursor to original position */
fd_printf(current->fd, "\x1b[0K" "\x1b[0G\x1b[%dC", pos + pchars + backup);