зеркало из https://github.com/github/ruby.git
* st.c (st_keys): define st_keys() for performance improvement of
Hash#keys and Array#uniq. * st.h: ditto. * hash.c (rb_hash_keys): use st_keys(). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@43238 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
4599d3efd7
Коммит
026955e375
|
@ -1,3 +1,12 @@
|
|||
Thu Oct 10 21:00:38 2013 Masaki Matsushita <glass.saga@gmail.com>
|
||||
|
||||
* st.c (st_keys): define st_keys() for performance improvement of
|
||||
Hash#keys and Array#uniq.
|
||||
|
||||
* st.h: ditto.
|
||||
|
||||
* hash.c (rb_hash_keys): use st_keys().
|
||||
|
||||
Thu Oct 10 17:25:28 2013 Koichi Sasada <ko1@atdot.net>
|
||||
|
||||
* vm.c (vm_exec): support :b_return event for "lambda{return}.call".
|
||||
|
|
15
hash.c
15
hash.c
|
@ -1663,13 +1663,6 @@ rb_hash_to_h(VALUE hash)
|
|||
return hash;
|
||||
}
|
||||
|
||||
static int
|
||||
keys_i(VALUE key, VALUE value, VALUE ary)
|
||||
{
|
||||
rb_ary_push(ary, key);
|
||||
return ST_CONTINUE;
|
||||
}
|
||||
|
||||
/*
|
||||
* call-seq:
|
||||
* hsh.keys -> array
|
||||
|
@ -1685,12 +1678,10 @@ keys_i(VALUE key, VALUE value, VALUE ary)
|
|||
VALUE
|
||||
rb_hash_keys(VALUE hash)
|
||||
{
|
||||
VALUE ary;
|
||||
st_table *table = RHASH(hash)->ntbl;
|
||||
|
||||
ary = rb_ary_new_capa(RHASH_SIZE(hash));
|
||||
rb_hash_foreach(hash, keys_i, ary);
|
||||
|
||||
return ary;
|
||||
if (!table) return rb_ary_new();
|
||||
return st_keys(table);
|
||||
}
|
||||
|
||||
static int
|
||||
|
|
|
@ -112,6 +112,7 @@ int st_update(st_table *table, st_data_t key, st_update_callback_func *func, st_
|
|||
int st_foreach(st_table *, int (*)(ANYARGS), st_data_t);
|
||||
int st_foreach_check(st_table *, int (*)(ANYARGS), st_data_t, st_data_t);
|
||||
int st_reverse_foreach(st_table *, int (*)(ANYARGS), st_data_t);
|
||||
VALUE st_keys(st_table *table);
|
||||
void st_add_direct(st_table *, st_data_t, st_data_t);
|
||||
void st_free_table(st_table *);
|
||||
void st_cleanup_safe(st_table *, st_data_t);
|
||||
|
|
31
st.c
31
st.c
|
@ -1091,6 +1091,37 @@ st_foreach(st_table *table, int (*func)(ANYARGS), st_data_t arg)
|
|||
return 0;
|
||||
}
|
||||
|
||||
VALUE
|
||||
st_keys(st_table *table)
|
||||
{
|
||||
st_table_entry *ptr = NULL;
|
||||
st_data_t key, never = (st_data_t)Qundef;
|
||||
VALUE keys = rb_ary_new_capa(table->num_entries);
|
||||
|
||||
if (table->entries_packed) {
|
||||
st_index_t i;
|
||||
|
||||
for (i = 0; i < table->real_entries; i++) {
|
||||
key = PKEY(table, i);
|
||||
if (key == never) continue;
|
||||
rb_ary_push(keys, (VALUE)key);
|
||||
}
|
||||
}
|
||||
else {
|
||||
ptr = table->head;
|
||||
}
|
||||
|
||||
if (ptr != 0) {
|
||||
do {
|
||||
key = ptr->key;
|
||||
if (key != never) rb_ary_push(keys, (VALUE)key);
|
||||
ptr = ptr->fore;
|
||||
} while (ptr && table->head);
|
||||
}
|
||||
|
||||
return keys;
|
||||
}
|
||||
|
||||
#if 0 /* unused right now */
|
||||
int
|
||||
st_reverse_foreach(st_table *table, int (*func)(ANYARGS), st_data_t arg)
|
||||
|
|
Загрузка…
Ссылка в новой задаче