summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-06-16 22:03:12 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-06-16 22:03:12 +0000
commitaf0429b54eef973077f00d24d40fd17687a86ac0 (patch)
tree4668df34d0323fd1ae4a869d1415e6020410529b
parentdfb0fa0ca6b6d860affae3339f7bec83bb694bb4 (diff)
* st.c, include/ruby/st.h (st_memsize): added. This function returns
the memory usage of st_talbe. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23712 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--include/ruby/st.h1
-rw-r--r--st.c11
3 files changed, 17 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index bf8c371997..a2caf9df92 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Wed Jun 17 06:48:28 2009 Koichi Sasada <ko1@atdot.net>
+
+ * st.c, include/ruby/st.h (st_memsize): added. This function returns
+ the memory usage of st_talbe.
+
Wed Jun 17 06:19:06 2009 Koichi Sasada <ko1@atdot.net>
* include/ruby/ruby.h: New structure RTypedData, added.
diff --git a/include/ruby/st.h b/include/ruby/st.h
index 0c80d3a225..aebdaf569d 100644
--- a/include/ruby/st.h
+++ b/include/ruby/st.h
@@ -107,6 +107,7 @@ int st_numcmp(st_data_t, st_data_t);
int st_numhash(st_data_t);
int st_strcasecmp(const char *s1, const char *s2);
int st_strncasecmp(const char *s1, const char *s2, size_t n);
+size_t st_memsize(st_table *);
#if defined(__cplusplus)
#if 0
diff --git a/st.c b/st.c
index 5fa7e24f53..01f2a43dc4 100644
--- a/st.c
+++ b/st.c
@@ -256,6 +256,17 @@ st_free_table(st_table *table)
free(table);
}
+size_t
+st_memsize(st_table *table)
+{
+ if (table->entries_packed) {
+ return table->num_bins * sizeof (void *) + sizeof(st_table);
+ }
+ else {
+ return table->num_entries * sizeof(struct st_table_entry) + table->num_bins * sizeof (void *) + sizeof(st_table);
+ }
+}
+
#define PTR_NOT_EQUAL(table, ptr, hash_val, key) \
((ptr) != 0 && (ptr->hash != (hash_val) || !EQUAL((table), (key), (ptr)->key)))