summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2018-12-17 15:59:31 +0900
committerGitHub <[email protected]>2018-12-17 15:59:31 +0900
commitea71f1165bcae2e70b2811fbab270612b7ac5eea (patch)
tree72b9516a663caf936631386da725d58a45729518
parentec812c646fa9740e6309712065c26e0563795178 (diff)
parent62dd4d89fc6da2c38a9bc1913c1f25566a9e443e (diff)
downloadmruby-ea71f1165bcae2e70b2811fbab270612b7ac5eea.tar.gz
mruby-ea71f1165bcae2e70b2811fbab270612b7ac5eea.zip
Merge pull request #4188 from dearblue/mrb_hash_size
Add `mrb_hash_size()` function
-rw-r--r--include/mruby/hash.h13
-rw-r--r--src/hash.c14
2 files changed, 23 insertions, 4 deletions
diff --git a/include/mruby/hash.h b/include/mruby/hash.h
index 911a96042..ce51b2016 100644
--- a/include/mruby/hash.h
+++ b/include/mruby/hash.h
@@ -166,6 +166,19 @@ MRB_API mrb_value mrb_hash_values(mrb_state *mrb, mrb_value hash);
MRB_API mrb_value mrb_hash_clear(mrb_state *mrb, mrb_value hash);
/*
+ * Get hash size.
+ *
+ * Equivalent to:
+ *
+ * hash.size
+ *
+ * @param mrb The mruby state reference.
+ * @param hash The target hash.
+ * @return The hash size.
+ */
+MRB_API mrb_int mrb_hash_size(mrb_state *mrb, mrb_value hash);
+
+/*
* Copies the hash.
*
*
diff --git a/src/hash.c b/src/hash.c
index 3d6c2ed7d..2f60eb74a 100644
--- a/src/hash.c
+++ b/src/hash.c
@@ -1133,6 +1133,15 @@ mrb_hash_aset(mrb_state *mrb, mrb_value self)
return val;
}
+MRB_API mrb_int
+mrb_hash_size(mrb_state *mrb, mrb_value hash)
+{
+ htable *t = RHASH_TBL(hash);
+
+ if (!t) return 0;
+ return t->size;
+}
+
/* 15.2.13.4.20 */
/* 15.2.13.4.25 */
/*
@@ -1150,10 +1159,7 @@ mrb_hash_aset(mrb_state *mrb, mrb_value self)
static mrb_value
mrb_hash_size_m(mrb_state *mrb, mrb_value self)
{
- htable *t = RHASH_TBL(self);
-
- if (!t) return mrb_fixnum_value(0);
- return mrb_fixnum_value(t->size);
+ return mrb_fixnum_value(mrb_hash_size(mrb, self));
}
MRB_API mrb_bool