2009-11-05 16:39:52 +00:00
|
|
|
diff --git a/src/chars.c b/src/chars.c
|
|
|
|
index 0061621..14c1267 100644
|
|
|
|
--- a/src/chars.c
|
|
|
|
+++ b/src/chars.c
|
|
|
|
@@ -79,6 +79,16 @@ bool is_byte(int c)
|
2009-09-21 13:50:12 +00:00
|
|
|
return ((unsigned int)c == (unsigned char)c);
|
|
|
|
}
|
|
|
|
|
|
|
|
+static void mbtowc_reset(void)
|
|
|
|
+{
|
2009-11-05 16:39:52 +00:00
|
|
|
+ IGNORE_CALL_RESULT(mbtowc(NULL, NULL, 0));
|
2009-09-21 13:50:12 +00:00
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static void wctomb_reset(void)
|
|
|
|
+{
|
2009-11-05 16:39:52 +00:00
|
|
|
+ IGNORE_CALL_RESULT(wctomb(NULL, 0));
|
2009-09-21 13:50:12 +00:00
|
|
|
+}
|
|
|
|
+
|
|
|
|
/* This function is equivalent to isalnum() for multibyte characters. */
|
|
|
|
bool is_alnum_mbchar(const char *c)
|
|
|
|
{
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -89,7 +99,7 @@ bool is_alnum_mbchar(const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
wchar_t wc;
|
|
|
|
|
|
|
|
if (mbtowc(&wc, c, MB_CUR_MAX) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
wc = bad_wchar;
|
|
|
|
}
|
|
|
|
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -109,7 +119,7 @@ bool is_blank_mbchar(const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
wchar_t wc;
|
|
|
|
|
|
|
|
if (mbtowc(&wc, c, MB_CUR_MAX) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
wc = bad_wchar;
|
|
|
|
}
|
|
|
|
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -156,7 +166,7 @@ bool is_cntrl_mbchar(const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
wchar_t wc;
|
|
|
|
|
|
|
|
if (mbtowc(&wc, c, MB_CUR_MAX) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
wc = bad_wchar;
|
|
|
|
}
|
|
|
|
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -177,7 +187,7 @@ bool is_punct_mbchar(const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
int c_mb_len = mbtowc(&wc, c, MB_CUR_MAX);
|
|
|
|
|
|
|
|
if (c_mb_len < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
wc = bad_wchar;
|
|
|
|
}
|
|
|
|
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -243,14 +253,14 @@ char *control_mbrep(const char *c, char *crep, int *crep_len)
|
2009-09-21 13:50:12 +00:00
|
|
|
wchar_t wc;
|
|
|
|
|
|
|
|
if (mbtowc(&wc, c, MB_CUR_MAX) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
*crep_len = bad_mbchar_len;
|
|
|
|
strncpy(crep, bad_mbchar, *crep_len);
|
|
|
|
} else {
|
|
|
|
*crep_len = wctomb(crep, control_wrep(wc));
|
|
|
|
|
|
|
|
if (*crep_len < 0) {
|
|
|
|
- wctomb(NULL, 0);
|
|
|
|
+ wctomb_reset();
|
|
|
|
*crep_len = 0;
|
|
|
|
}
|
|
|
|
}
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -278,14 +288,14 @@ char *mbrep(const char *c, char *crep, int *crep_len)
|
2009-09-21 13:50:12 +00:00
|
|
|
|
|
|
|
/* Reject invalid Unicode characters. */
|
|
|
|
if (mbtowc(&wc, c, MB_CUR_MAX) < 0 || !is_valid_unicode(wc)) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
*crep_len = bad_mbchar_len;
|
|
|
|
strncpy(crep, bad_mbchar, *crep_len);
|
|
|
|
} else {
|
|
|
|
*crep_len = wctomb(crep, wc);
|
|
|
|
|
|
|
|
if (*crep_len < 0) {
|
|
|
|
- wctomb(NULL, 0);
|
|
|
|
+ wctomb_reset();
|
|
|
|
*crep_len = 0;
|
|
|
|
}
|
|
|
|
}
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -311,7 +321,7 @@ int mbwidth(const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
int width;
|
|
|
|
|
|
|
|
if (mbtowc(&wc, c, MB_CUR_MAX) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
wc = bad_wchar;
|
|
|
|
}
|
|
|
|
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -356,7 +366,7 @@ char *make_mbchar(long chr, int *chr_mb_len)
|
2009-09-21 13:50:12 +00:00
|
|
|
|
|
|
|
/* Reject invalid Unicode characters. */
|
|
|
|
if (*chr_mb_len < 0 || !is_valid_unicode((wchar_t)chr)) {
|
|
|
|
- wctomb(NULL, 0);
|
|
|
|
+ wctomb_reset();
|
|
|
|
*chr_mb_len = 0;
|
|
|
|
}
|
|
|
|
} else {
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -388,7 +398,7 @@ int parse_mbchar(const char *buf, char *chr, size_t *col)
|
2009-09-21 13:50:12 +00:00
|
|
|
/* If buf contains an invalid multibyte character, only
|
|
|
|
* interpret buf's first byte. */
|
|
|
|
if (buf_mb_len < 0) {
|
|
|
|
- mblen(NULL, 0);
|
2009-11-05 16:39:52 +00:00
|
|
|
+ IGNORE_CALL_RESULT(mblen(NULL, 0));
|
2009-09-21 13:50:12 +00:00
|
|
|
buf_mb_len = 1;
|
|
|
|
} else if (buf_mb_len == 0)
|
|
|
|
buf_mb_len++;
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -545,7 +555,7 @@ int mbstrncasecmp(const char *s1, const char *s2, size_t n)
|
2009-09-21 13:50:12 +00:00
|
|
|
s1_mb_len = parse_mbchar(s1, s1_mb, NULL);
|
|
|
|
|
|
|
|
if (mbtowc(&ws1, s1_mb, s1_mb_len) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
ws1 = (unsigned char)*s1_mb;
|
|
|
|
bad_s1_mb = TRUE;
|
|
|
|
}
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -553,7 +563,7 @@ int mbstrncasecmp(const char *s1, const char *s2, size_t n)
|
2009-09-21 13:50:12 +00:00
|
|
|
s2_mb_len = parse_mbchar(s2, s2_mb, NULL);
|
|
|
|
|
|
|
|
if (mbtowc(&ws2, s2_mb, s2_mb_len) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
ws2 = (unsigned char)*s2_mb;
|
|
|
|
bad_s2_mb = TRUE;
|
|
|
|
}
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -781,7 +791,7 @@ char *mbstrchr(const char *s, const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
int c_mb_len = mbtowc(&wc, c, MB_CUR_MAX);
|
|
|
|
|
|
|
|
if (c_mb_len < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
wc = (unsigned char)*c;
|
|
|
|
bad_c_mb = TRUE;
|
|
|
|
}
|
2009-11-05 16:39:52 +00:00
|
|
|
@@ -790,7 +800,7 @@ char *mbstrchr(const char *s, const char *c)
|
2009-09-21 13:50:12 +00:00
|
|
|
int s_mb_len = parse_mbchar(s, s_mb, NULL);
|
|
|
|
|
|
|
|
if (mbtowc(&ws, s_mb, s_mb_len) < 0) {
|
|
|
|
- mbtowc(NULL, NULL, 0);
|
|
|
|
+ mbtowc_reset();
|
|
|
|
ws = (unsigned char)*s;
|
|
|
|
bad_s_mb = TRUE;
|
|
|
|
}
|
2009-11-05 16:39:52 +00:00
|
|
|
diff --git a/src/files.c b/src/files.c
|
|
|
|
index 9840ec7..923b787 100644
|
|
|
|
--- a/src/files.c
|
|
|
|
+++ b/src/files.c
|
|
|
|
@@ -1082,7 +1082,7 @@ char *get_full_path(const char *origpath)
|
2009-09-21 13:50:12 +00:00
|
|
|
/* Finally, go back to the path specified in d_here,
|
|
|
|
* where we were before. We don't check for a chdir()
|
|
|
|
* error, since we can do nothing if we get one. */
|
|
|
|
- chdir(d_here);
|
2009-10-13 11:37:22 +00:00
|
|
|
+ IGNORE_CALL_RESULT(chdir(d_here));
|
|
|
|
|
|
|
|
/* Free d_here, since we're done using it. */
|
|
|
|
free(d_here);
|
2009-11-05 16:39:52 +00:00
|
|
|
diff --git a/src/nano.h b/src/nano.h
|
|
|
|
index 195f548..2f1796b 100644
|
|
|
|
--- a/src/nano.h
|
|
|
|
+++ b/src/nano.h
|
2009-10-13 11:37:22 +00:00
|
|
|
@@ -44,6 +44,9 @@
|
|
|
|
#include <sys/param.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
+/* Suppress warnings for __attribute__((warn_unused_result)) */
|
|
|
|
+#define IGNORE_CALL_RESULT(call) do { if (call) {} } while(0)
|
|
|
|
+
|
|
|
|
/* Macros for flags. */
|
|
|
|
#define SET(bit) flags |= bit
|
|
|
|
#define UNSET(bit) flags &= ~bit
|