summaryrefslogtreecommitdiff
path: root/ext.c
diff options
context:
space:
mode:
authorArnold D. Robbins <arnold@skeeve.com>2012-12-09 22:11:01 +0200
committerArnold D. Robbins <arnold@skeeve.com>2012-12-09 22:11:01 +0200
commitae9e583a257264f4580d07354e79aac63db72695 (patch)
tree5a03a771ec6588c0dede291c56df8ec9cb783f7a /ext.c
parenta5a114bf6c6f2efdcd7889ebf0d7f9f3ec235a74 (diff)
parentd283194601bc7cb7c071317a8d53a89a3cbac40d (diff)
downloadgawk-ae9e583a257264f4580d07354e79aac63db72695.tar.gz
Merge branch 'master' into array-iface
Diffstat (limited to 'ext.c')
-rw-r--r--ext.c48
1 files changed, 44 insertions, 4 deletions
diff --git a/ext.c b/ext.c
index 54098e51..ff0beb9a 100644
--- a/ext.c
+++ b/ext.c
@@ -37,6 +37,42 @@ extern SRCFILE *srcfiles;
#include <dlfcn.h>
+/*
+ * is_letter --- function to check letters
+ * isalpha() isn't good enough since it can look at the locale.
+ * Underscore counts as a letter in awk identifiers
+ */
+
+static bool
+is_letter(unsigned char c)
+{
+ switch (c) {
+ case 'a': case 'b': case 'c': case 'd': case 'e': case 'f':
+ case 'g': case 'h': case 'i': case 'j': case 'k': case 'l':
+ case 'm': case 'n': case 'o': case 'p': case 'q': case 'r':
+ case 's': case 't': case 'u': case 'v': case 'w': case 'x':
+ case 'y': case 'z':
+ case 'A': case 'B': case 'C': case 'D': case 'E': case 'F':
+ case 'G': case 'H': case 'I': case 'J': case 'K': case 'L':
+ case 'M': case 'N': case 'O': case 'P': case 'Q': case 'R':
+ case 'S': case 'T': case 'U': case 'V': case 'W': case 'X':
+ case 'Y': case 'Z':
+ case '_':
+ return true;
+ default:
+ return false;
+ }
+}
+
+/* is_identifier_char --- return true if a character can be used in an identifier */
+
+static bool
+is_identifier_char(unsigned char c)
+{
+ return (is_letter(c) || isdigit(c));
+}
+
+
#define INIT_FUNC "dl_load"
/* load_ext --- load an external library */
@@ -184,10 +220,14 @@ make_builtin(const awk_ext_func_t *funcinfo)
if (sp == NULL || *sp == '\0')
fatal(_("make_builtin: missing function name"));
+ if (! is_letter(*sp))
+ return false;
+
+ sp++;
+
while ((c = *sp++) != '\0') {
- if ((sp == &name[1] && c != '_' && ! isalpha((unsigned char) c))
- || (sp > &name[1] && ! is_identchar((unsigned char) c)))
- fatal(_("make_builtin: illegal character `%c' in function name `%s'"), c, name);
+ if (! is_identifier_char(c))
+ return false;
}
f = lookup(name);
@@ -239,7 +279,7 @@ make_old_builtin(const char *name, NODE *(*func)(int), int count) /* temporary *
while ((c = *sp++) != '\0') {
if ((sp == & name[1] && c != '_' && ! isalpha((unsigned char) c))
- || (sp > &name[1] && ! is_identchar((unsigned char) c)))
+ || (sp > &name[1] && ! is_identifier_char((unsigned char) c)))
fatal(_("extension: illegal character `%c' in function name `%s'"), c, name);
}