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:
parent
3deb1c57c6
commit
1623f4e77e
2 changed files with 15 additions and 5 deletions
10
ChangeLog
10
ChangeLog
|
@ -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
|
||||||
|
|
10
symbol.c
10
symbol.c
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue