diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2019-03-15 21:19:48 +0900 |
|---|---|---|
| committer | GitHub <[email protected]> | 2019-03-15 21:19:48 +0900 |
| commit | a1e12011486576dc2e52fe8da11ef377311fe311 (patch) | |
| tree | 03585abea2e64342eb34c4ae35050259df6b0af0 /src/variable.c | |
| parent | 298807fa4e6550958de9cd77e1fa12dfd9a399e4 (diff) | |
| parent | 16b1b2978e4f4d838f3d12e7221139a92429603b (diff) | |
| download | mruby-a1e12011486576dc2e52fe8da11ef377311fe311.tar.gz mruby-a1e12011486576dc2e52fe8da11ef377311fe311.zip | |
Merge pull request #4328 from shuujii/fix-constant-name-validation
Fix constant name validation
Diffstat (limited to 'src/variable.c')
| -rw-r--r-- | src/variable.c | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/src/variable.c b/src/variable.c index 14e9da9ef..b712af261 100644 --- a/src/variable.c +++ b/src/variable.c @@ -428,22 +428,17 @@ mrb_iv_defined(mrb_state *mrb, mrb_value obj, mrb_sym sym) return mrb_obj_iv_defined(mrb, mrb_obj_ptr(obj), sym); } -#define identchar(c) (ISALNUM(c) || (c) == '_' || !ISASCII(c)) - MRB_API mrb_bool mrb_iv_name_sym_p(mrb_state *mrb, mrb_sym iv_name) { const char *s; - mrb_int i, len; + mrb_int len; s = mrb_sym2name_len(mrb, iv_name, &len); if (len < 2) return FALSE; if (s[0] != '@') return FALSE; if (s[1] == '@') return FALSE; - for (i=1; i<len; i++) { - if (!identchar(s[i])) return FALSE; - } - return TRUE; + return mrb_ident_p(s+1, len-1); } MRB_API void @@ -1114,3 +1109,14 @@ mrb_class_find_path(mrb_state *mrb, struct RClass *c) } return path; } + +#define identchar(c) (ISALNUM(c) || (c) == '_' || !ISASCII(c)) + +mrb_bool +mrb_ident_p(const char *s, mrb_int len) +{ + for (mrb_int i = 0; i < len; i++) { + if (!identchar(s[i])) return FALSE; + } + return TRUE; +} |
