diff options
| author | KOBAYASHI Shuji <[email protected]> | 2021-01-27 11:42:18 +0900 |
|---|---|---|
| committer | KOBAYASHI Shuji <[email protected]> | 2021-01-27 11:42:18 +0900 |
| commit | 504788bf89242c0be0c6027d59da5f5ec89b0d24 (patch) | |
| tree | 41a4d6ede8e24caa532ae2b88a68572269c5850c /src/symbol.c | |
| parent | 73418a90faf9d83834191318888b74289cc3ddea (diff) | |
| download | mruby-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.c | 4 |
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; |
