diff options
| author | skandhas <[email protected]> | 2012-12-03 13:55:23 +0800 |
|---|---|---|
| committer | skandhas <[email protected]> | 2012-12-03 13:55:23 +0800 |
| commit | fc89106792a125933b180e6905eec529160811d3 (patch) | |
| tree | d76c0847f3461fce963ca4088779af143142b397 /src | |
| parent | 97545127162aca8354c2436308bf1f5b284a2340 (diff) | |
| download | mruby-fc89106792a125933b180e6905eec529160811d3.tar.gz mruby-fc89106792a125933b180e6905eec529160811d3.zip | |
add function:check_const_name
Diffstat (limited to 'src')
| -rw-r--r-- | src/class.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/class.c b/src/class.c index 618a6d1f6..09ca3eb7f 100644 --- a/src/class.c +++ b/src/class.c @@ -7,6 +7,7 @@ #include "mruby.h" #include <stdarg.h> #include <stdio.h> +#include <ctype.h> #include "mruby/class.h" #include "mruby/proc.h" #include "mruby/string.h" @@ -1442,6 +1443,18 @@ mrb_sym_value(mrb_state *mrb, mrb_value val) return mrb_symbol(val); } +static void +check_const_name(mrb_state *mrb, mrb_sym id) +{ + const char *s; + int len; + + s = mrb_sym2name_len(mrb, id, &len); + if (len < 1 || !ISUPPER(*s)) { + mrb_name_error(mrb, id, "wrong constant name %s", s); + } +} + mrb_value mrb_mod_const_defined(mrb_state *mrb, mrb_value mod) { |
