From: Bruno Haible <bruno@clisp.org>
Date: Mon, 3 May 2010 08:07:34 +0000 (+0200)
Subject: wctob: Fix for weird platforms.
X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3a59228aa9e83e507b62eb5281817accccee72ba;p=pspp

wctob: Fix for weird platforms.
---

diff --git a/ChangeLog b/ChangeLog
index 2f7dd4547c..797a381415 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2010-05-03  Bruno Haible  <bruno@clisp.org>
+
+	wctob: Fix for weird platforms.
+	* lib/wctob.c (wctob): When wint_t is larger than wchar_t, check the
+	argument value.
+
 2010-05-03  Jim Meyering  <meyering@redhat.com>
 
 	maint.mk: remove obsolete comments
diff --git a/lib/wctob.c b/lib/wctob.c
index 1d1cc7b1c6..8a66ec9c1b 100644
--- a/lib/wctob.c
+++ b/lib/wctob.c
@@ -1,5 +1,5 @@
 /* Convert wide character to unibyte character.
-   Copyright (C) 2008, 2009, 2010 Free Software Foundation, Inc.
+   Copyright (C) 2008, 2010 Free Software Foundation, Inc.
    Written by Bruno Haible <bruno@clisp.org>, 2008.
 
    This program is free software: you can redistribute it and/or modify
@@ -30,8 +30,9 @@ wctob (wint_t wc)
 
   if (!(MB_CUR_MAX <= sizeof (buf)))
     abort ();
-  if (wctomb (buf, wc) == 1)
-    return (unsigned char) buf[0];
-  else
-    return EOF;
+  /* Handle the case where WEOF is a value that does not fit in a wchar_t.  */
+  if (wc == (wchar_t)wc)
+    if (wctomb (buf, (wchar_t)wc) == 1)
+      return (unsigned char) buf[0];
+  return EOF;
 }