1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00

* symbol.c (is_identchar): use ISDIGIT instead of rb_enc_isalnum.

Though rb_enc_isalnum is encoding aware function, its argument here
  is *m, which is a single byte. Therefore ISDIGIT is faster.

* symbol.c (is_special_global_name): ditto.

* symbol.c (rb_enc_symname_type): ditto.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@55178 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
naruse 2016-05-26 16:51:49 +00:00
parent 3deb1c57c6
commit 1623f4e77e
2 changed files with 15 additions and 5 deletions

View file

@ -1,3 +1,13 @@
Fri May 27 01:00:36 2016 NARUSE, Yui <naruse@ruby-lang.org>
* symbol.c (is_identchar): use ISDIGIT instead of rb_enc_isalnum.
Though rb_enc_isalnum is encoding aware function, its argument here
is *m, which is a single byte. Therefore ISDIGIT is faster.
* symbol.c (is_special_global_name): ditto.
* symbol.c (rb_enc_symname_type): ditto.
Fri May 27 00:39:40 2016 Nobuyoshi Nakada <nobu@ruby-lang.org> Fri May 27 00:39:40 2016 Nobuyoshi Nakada <nobu@ruby-lang.org>
* include/ruby/ruby.h (rb_scan_args): add nul padding here to * include/ruby/ruby.h (rb_scan_args): add nul padding here to

View file

@ -28,7 +28,7 @@ static ID register_static_symid_str(ID, VALUE);
#define REGISTER_SYMID(id, name) register_static_symid((id), (name), strlen(name), enc) #define REGISTER_SYMID(id, name) register_static_symid((id), (name), strlen(name), enc)
#include "id.c" #include "id.c"
#define is_identchar(p,e,enc) (rb_enc_isalnum((unsigned char)(*(p)),(enc)) || (*(p)) == '_' || !ISASCII(*(p))) #define is_identchar(p,e,enc) (ISALNUM((unsigned char)*(p)) || (*(p)) == '_' || !ISASCII(*(p)))
#define op_tbl_count numberof(op_tbl) #define op_tbl_count numberof(op_tbl)
STATIC_ASSERT(op_tbl_name_size, sizeof(op_tbl[0].name) == 3); STATIC_ASSERT(op_tbl_name_size, sizeof(op_tbl[0].name) == 3);
@ -177,11 +177,11 @@ is_special_global_name(const char *m, const char *e, rb_encoding *enc)
} }
} }
else { else {
if (!rb_enc_isdigit(*m, enc)) return 0; if (!ISDIGIT(*m)) return 0;
do { do {
if (!ISASCII(*m)) mb = 1; if (!ISASCII(*m)) mb = 1;
++m; ++m;
} while (m < e && rb_enc_isdigit(*m, enc)); } while (m < e && ISDIGIT(*m));
} }
return m == e ? mb + 1 : 0; return m == e ? mb + 1 : 0;
} }
@ -278,9 +278,9 @@ rb_enc_symname_type(const char *name, long len, rb_encoding *enc, unsigned int a
break; break;
default: default:
type = rb_enc_isupper(*m, enc) ? ID_CONST : ID_LOCAL; type = ISUPPER(*m) ? ID_CONST : ID_LOCAL;
id: id:
if (m >= e || (*m != '_' && !rb_enc_isalpha(*m, enc) && ISASCII(*m))) { if (m >= e || (*m != '_' && !ISALPHA(*m) && ISASCII(*m))) {
if (len > 1 && *(e-1) == '=') { if (len > 1 && *(e-1) == '=') {
type = rb_enc_symname_type(name, len-1, enc, allowed_attrset); type = rb_enc_symname_type(name, len-1, enc, allowed_attrset);
if (type != ID_ATTRSET) return ID_ATTRSET; if (type != ID_ATTRSET) return ID_ATTRSET;