bytecode.c (exec_byte_code): Use h->count instead of HASH_TABLE_SIZE
authorVibhav Pant <vibhavp@gmail.com>
Thu, 9 Feb 2017 13:42:59 +0000 (19:12 +0530)
committerVibhav Pant <vibhavp@gmail.com>
Thu, 9 Feb 2017 13:42:59 +0000 (19:12 +0530)
src/bytecode.c

index fb10a6d69140110240480330ef281ba8e25f44ca..299c651b90e00602ce184065a59052dd6c627ef6 100644 (file)
@@ -1425,10 +1425,17 @@ exec_byte_code (Lisp_Object bytestr, Lisp_Object vector, Lisp_Object maxdepth,
 #endif
             ptrdiff_t i;
             struct Lisp_Hash_Table *h = XHASH_TABLE(jmp_table);
-            if (HASH_TABLE_SIZE (h) <= 5)
+
+#ifdef BYTE_CODE_SAFE
+            /* Hash tables for switch are declared with :size set to exact
+               number of cases, so this should always be true.  */
+            eassert (HASH_TABLE_SIZE (h) == h->count);
+#endif
+
+            if (h->count <= 5)
               { /* Do a linear search if there are not many cases
                    FIXME: 5 is arbitrarily chosen.  */
-                for (i = 0; i < HASH_TABLE_SIZE (h); i++)
+                for (i = 0; i < h->count; i++)
                   {
 #ifdef BYTE_CODE_SAFE
                     eassert (!NILP (HASH_HASH (h, i)));