summaryrefslogtreecommitdiff
path: root/util/utf.h
diff options
context:
space:
mode:
authorPatrick Ohly <patrick.ohly@intel.com>2013-06-28 14:45:49 +0000
committerPatrick Ohly <patrick.ohly@intel.com>2013-06-28 14:45:49 +0000
commit903813bda215d5937caf0745824bdcde9d2e3cec (patch)
treee5c0e14ffc8019b11d134ab97b27f5f43b62e67c /util/utf.h
downloadre2-903813bda215d5937caf0745824bdcde9d2e3cec.tar.gz
re2-903813bda215d5937caf0745824bdcde9d2e3cec.tar.bz2
re2-903813bda215d5937caf0745824bdcde9d2e3cec.zip
Imported Upstream version 20130115upstream/20130115
Diffstat (limited to 'util/utf.h')
-rw-r--r--util/utf.h43
1 files changed, 43 insertions, 0 deletions
diff --git a/util/utf.h b/util/utf.h
new file mode 100644
index 0000000..06ff8f0
--- /dev/null
+++ b/util/utf.h
@@ -0,0 +1,43 @@
+/*
+ * The authors of this software are Rob Pike and Ken Thompson.
+ * Copyright (c) 2002 by Lucent Technologies.
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose without fee is hereby granted, provided that this entire notice
+ * is included in all copies of any software which is or includes a copy
+ * or modification of this software and in all copies of the supporting
+ * documentation for such software.
+ * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED
+ * WARRANTY. IN PARTICULAR, NEITHER THE AUTHORS NOR LUCENT TECHNOLOGIES MAKE ANY
+ * REPRESENTATION OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY
+ * OF THIS SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE.
+ *
+ * This file and rune.cc have been converted to compile as C++ code
+ * in name space re2.
+ */
+#ifndef RE2_UTIL_UTF_H__
+#define RE2_UTIL_UTF_H__
+
+#include <stdint.h>
+
+namespace re2 {
+
+typedef signed int Rune; /* Code-point values in Unicode 4.0 are 21 bits wide.*/
+
+enum
+{
+ UTFmax = 4, /* maximum bytes per rune */
+ Runesync = 0x80, /* cannot represent part of a UTF sequence (<) */
+ Runeself = 0x80, /* rune and UTF sequences are the same (<) */
+ Runeerror = 0xFFFD, /* decoding error in UTF */
+ Runemax = 0x10FFFF, /* maximum rune value */
+};
+
+int runetochar(char* s, const Rune* r);
+int chartorune(Rune* r, const char* s);
+int fullrune(const char* s, int n);
+int utflen(const char* s);
+char* utfrune(const char*, Rune);
+
+} // namespace re2
+
+#endif // RE2_UTIL_UTF_H__