From 897d4e31b0e5b29405480ed3236bc8c5c6cac3fa Mon Sep 17 00:00:00 2001 From: Koichi Sasada Date: Sat, 7 Mar 2020 03:55:54 +0900 Subject: check ar_table first. RHASH_AR_TABLE_SIZE() has assertion that it is a ar_talbe. The last commit breaks this assumption so check ar_table first. (cherry picked from commit c3584dfacce4d0f2058d8403de6fdce4fd4d686b) --- hash.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'hash.c') diff --git a/hash.c b/hash.c index e35aabe6ac..b546f6246b 100644 --- a/hash.c +++ b/hash.c @@ -747,11 +747,14 @@ ar_free_and_clear_table(VALUE hash) static void ar_try_convert_table(VALUE hash) { - st_table *new_tab; + if (!RHASH_AR_TABLE_P(hash)) return; + const unsigned size = RHASH_AR_TABLE_SIZE(hash); + + st_table *new_tab; st_index_t i; - if (!RHASH_AR_TABLE_P(hash) || size < RHASH_AR_TABLE_MAX_SIZE) { + if (size < RHASH_AR_TABLE_MAX_SIZE) { return; } -- cgit v1.2.3