Skip to content

Commit b17c347

Browse files
committed
merge revision(s) 22882,22961,22971:
* gc.c (run_final): calls free function. [ruby-core:22578] * gc.c (rb_gc_call_finalizer_at_exit): leave Thread objects unfinalized. [ruby-dev:38168] * gc.c (run_final): frees zombies only. [ruby-dev:38171] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_6@23077 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
1 parent fffffd6 commit b17c347

File tree

3 files changed

+22
-5
lines changed

3 files changed

+22
-5
lines changed

ChangeLog

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,16 @@
1+
Fri Mar 27 19:12:40 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
2+
3+
* gc.c (run_final): frees zombies only. [ruby-dev:38171]
4+
5+
Fri Mar 27 19:12:40 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
6+
7+
* gc.c (rb_gc_call_finalizer_at_exit): leave Thread objects
8+
unfinalized. [ruby-dev:38168]
9+
10+
Fri Mar 27 19:12:40 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
11+
12+
* gc.c (run_final): calls free function. [ruby-core:22578]
13+
114
Mon Mar 23 19:00:59 2009 Nobuyoshi Nakada <nobu@ruby-lang.org>
215

316
* ext/thread/thread.c (rb_queue_pop, rb_queue_push): should not lock

gc.c

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1898,6 +1898,9 @@ run_final(obj)
18981898

18991899
objid = rb_obj_id(obj); /* make obj into id */
19001900
rb_thread_critical = Qtrue;
1901+
if (BUILTIN_TYPE(obj) == T_DEFERRED && RDATA(obj)->dfree) {
1902+
(*RDATA(obj)->dfree)(DATA_PTR(obj));
1903+
}
19011904
args[1] = 0;
19021905
args[2] = (VALUE)ruby_safe_level;
19031906
for (i=0; i<RARRAY(finalizers)->len; i++) {
@@ -1966,7 +1969,8 @@ rb_gc_call_finalizer_at_exit()
19661969
p = heaps[i].slot; pend = p + heaps[i].limit;
19671970
while (p < pend) {
19681971
if (BUILTIN_TYPE(p) == T_DATA &&
1969-
DATA_PTR(p) && RANY(p)->as.data.dfree) {
1972+
DATA_PTR(p) && RANY(p)->as.data.dfree &&
1973+
RANY(p)->as.basic.klass != rb_cThread) {
19701974
p->as.free.flags = 0;
19711975
if ((long)RANY(p)->as.data.dfree == -1) {
19721976
RUBY_CRITICAL(free(DATA_PTR(p)));

version.h

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,15 @@
11
#define RUBY_VERSION "1.8.6"
2-
#define RUBY_RELEASE_DATE "2009-03-23"
2+
#define RUBY_RELEASE_DATE "2009-03-27"
33
#define RUBY_VERSION_CODE 186
4-
#define RUBY_RELEASE_CODE 20090323
5-
#define RUBY_PATCHLEVEL 365
4+
#define RUBY_RELEASE_CODE 20090327
5+
#define RUBY_PATCHLEVEL 366
66

77
#define RUBY_VERSION_MAJOR 1
88
#define RUBY_VERSION_MINOR 8
99
#define RUBY_VERSION_TEENY 6
1010
#define RUBY_RELEASE_YEAR 2009
1111
#define RUBY_RELEASE_MONTH 3
12-
#define RUBY_RELEASE_DAY 23
12+
#define RUBY_RELEASE_DAY 27
1313

1414
#ifdef RUBY_EXTERN
1515
RUBY_EXTERN const char ruby_version[];

0 commit comments

Comments
 (0)