summaryrefslogtreecommitdiffhomepage
path: root/src/symbol.c
diff options
context:
space:
mode:
authorKOBAYASHI Shuji <[email protected]>2021-01-27 11:42:18 +0900
committerKOBAYASHI Shuji <[email protected]>2021-01-27 11:42:18 +0900
commit504788bf89242c0be0c6027d59da5f5ec89b0d24 (patch)
tree41a4d6ede8e24caa532ae2b88a68572269c5850c /src/symbol.c
parent73418a90faf9d83834191318888b74289cc3ddea (diff)
downloadmruby-504788bf89242c0be0c6027d59da5f5ec89b0d24.tar.gz
mruby-504788bf89242c0be0c6027d59da5f5ec89b0d24.zip
Avoid 'possible loss of data' casting in binary search
Because it may not be expected result. example: https://wandbox.org/permlink/F5Mp7IEJ1VY3CFLp
Diffstat (limited to 'src/symbol.c')
-rw-r--r--src/symbol.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/symbol.c b/src/symbol.c
index 0ea99533e..1d2c7c776 100644
--- a/src/symbol.c
+++ b/src/symbol.c
@@ -31,11 +31,13 @@ static const struct {
static mrb_sym
presym_find(const char *name, size_t len)
{
+ if (presym_table[MRB_PRESYM_MAX-1].len < len) return 0;
+
mrb_sym start, idx, presym_size = MRB_PRESYM_MAX;
int cmp;
for (start = 0; presym_size != 0; presym_size/=2) {
idx = start+presym_size/2;
- cmp = (int)(len-presym_table[idx].len);
+ cmp = (int)len-(int)presym_table[idx].len;
if (cmp == 0) {
cmp = memcmp(name, presym_table[idx].name, len);
if (cmp == 0) return idx+1;