summaryrefslogtreecommitdiff
path: root/lib/strerror-pr29.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/strerror-pr29.c')
-rw-r--r--lib/strerror-pr29.c75
1 files changed, 75 insertions, 0 deletions
diff --git a/lib/strerror-pr29.c b/lib/strerror-pr29.c
new file mode 100644
index 0000000..d977572
--- /dev/null
+++ b/lib/strerror-pr29.c
@@ -0,0 +1,75 @@
+/* strerror-pr29.c --- Convert PR29 errors into text.
+ * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Simon Josefsson
+ *
+ * This file is part of GNU Libidn.
+ *
+ * GNU Libidn is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * GNU Libidn is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with GNU Libidn; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
+ *
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "pr29.h"
+
+#include "gettext.h"
+#define _(String) dgettext (PACKAGE, String)
+
+/**
+ * pr29_strerror - return string describing pr29 error code
+ * @rc: an #Pr29_rc return code.
+ *
+ * Convert a return code integer to a text string. This string can be
+ * used to output a diagnostic message to the user.
+ *
+ * PR29_SUCCESS: Successful operation. This value is guaranteed to
+ * always be zero, the remaining ones are only guaranteed to hold
+ * non-zero values, for logical comparison purposes.
+ * PR29_PROBLEM: A problem sequence was encountered.
+ * PR29_STRINGPREP_ERROR: The character set conversion failed (only
+ * for pr29_8() and pr29_8z()).
+ *
+ * Return value: Returns a pointer to a statically allocated string
+ * containing a description of the error with the return code @rc.
+ **/
+const char *
+pr29_strerror (Pr29_rc rc)
+{
+ const char *p;
+
+ bindtextdomain (PACKAGE, LOCALEDIR);
+
+ switch (rc)
+ {
+ case PR29_SUCCESS:
+ p = _("Success");
+ break;
+
+ case PR29_PROBLEM:
+ p = _("String not idempotent under Unicode NFKC normalization");
+ break;
+
+ case PR29_STRINGPREP_ERROR:
+ p = _("String preparation failed");
+ break;
+
+ default:
+ p = _("Unknown error");
+ break;
+ }
+
+ return p;
+}