ncurses 5.7 - patch 20090221
[ncurses.git] / ncurses / widechar / lib_unget_wch.c
index 7a062fd2f30ed14d256ad3b1419038965fd2d8e8..bb2c4a084b15f51d37d7540fb7dd6f6b4897c78f 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
 /****************************************************************************
- * Copyright (c) 2002 Free Software Foundation, Inc.                        *
+ * Copyright (c) 2002-2007,2008 Free Software Foundation, Inc.              *
  *                                                                          *
  * Permission is hereby granted, free of charge, to any person obtaining a  *
  * copy of this software and associated documentation files (the            *
  *                                                                          *
  * Permission is hereby granted, free of charge, to any person obtaining a  *
  * copy of this software and associated documentation files (the            *
 
 #include <curses.priv.h>
 
 
 #include <curses.priv.h>
 
-MODULE_ID("$Id: lib_unget_wch.c,v 1.3 2002/06/29 21:11:02 tom Exp $")
+MODULE_ID("$Id: lib_unget_wch.c,v 1.10 2008/06/07 14:50:37 tom Exp $")
+
+/*
+ * Wrapper for wcrtomb() which obtains the length needed for the given
+ * wide-character 'source'.
+ */
+NCURSES_EXPORT(size_t)
+_nc_wcrtomb(char *target, wchar_t source, mbstate_t * state)
+{
+    int result;
+
+    if (target == 0) {
+       wchar_t temp[2];
+       const wchar_t *tempp = temp;
+       temp[0] = source;
+       temp[1] = 0;
+       result = wcsrtombs(NULL, &tempp, 0, state);
+    } else {
+       result = wcrtomb(target, source, state);
+    }
+    if (!isEILSEQ(result) && (result == 0))
+       result = 1;
+    return result;
+}
 
 NCURSES_EXPORT(int)
 unget_wch(const wchar_t wch)
 
 NCURSES_EXPORT(int)
 unget_wch(const wchar_t wch)
@@ -49,25 +72,29 @@ unget_wch(const wchar_t wch)
     size_t length;
     int n;
 
     size_t length;
     int n;
 
-    T((T_CALLED("unget_wch(%#lx)"), wch));
+    T((T_CALLED("unget_wch(%#lx)"), (unsigned long) wch));
 
 
-    memset(&state, 0, sizeof(state));
-    length = wcrtomb(0, wch, &state);
+    init_mb(state);
+    length = _nc_wcrtomb(0, wch, &state);
 
     if (length != (size_t) (-1)
        && length != 0) {
 
     if (length != (size_t) (-1)
        && length != 0) {
-       char *string = malloc(length);
+       char *string;
 
 
-       memset(&state, 0, sizeof(state));
-       wcrtomb(string, wch, &state);
+       if ((string = (char *) malloc(length)) != 0) {
+           init_mb(state);
+           wcrtomb(string, wch, &state);
 
 
-       for (n = (int) (length - 1); n >= 0; --n) {
-           if (ungetch(string[n]) != OK) {
-               result = ERR;
-               break;
+           for (n = (int) (length - 1); n >= 0; --n) {
+               if (_nc_ungetch(SP, string[n]) != OK) {
+                   result = ERR;
+                   break;
+               }
            }
            }
+           free(string);
+       } else {
+           result = ERR;
        }
        }
-       free(string);
     } else {
        result = ERR;
     }
     } else {
        result = ERR;
     }