瀏覽代碼

Properly mark proc used in call credentials for garbage collection

murgatroid99 9 年之前
父節點
當前提交
3eaaf39eff
共有 1 個文件被更改,包括 7 次插入1 次删除
  1. 7 1
      src/ruby/ext/grpc/rb_call_credentials.c

+ 7 - 1
src/ruby/ext/grpc/rb_call_credentials.c

@@ -57,6 +57,10 @@ typedef struct grpc_rb_call_credentials {
   /* Holder of ruby objects involved in contructing the credentials */
   /* Holder of ruby objects involved in contructing the credentials */
   VALUE mark;
   VALUE mark;
 
 
+  /* The proc called when getting the credentials. Same pointer as
+     wrapped->state */
+  VALUE proc;
+
   /* The actual credentials */
   /* The actual credentials */
   grpc_call_credentials *wrapped;
   grpc_call_credentials *wrapped;
 } grpc_rb_call_credentials;
 } grpc_rb_call_credentials;
@@ -164,11 +168,11 @@ static void grpc_rb_call_credentials_mark(void *p) {
     return;
     return;
   }
   }
   wrapper = (grpc_rb_call_credentials *)p;
   wrapper = (grpc_rb_call_credentials *)p;
-
   /* If it's not already cleaned up, mark the mark object */
   /* If it's not already cleaned up, mark the mark object */
   if (wrapper->mark != Qnil) {
   if (wrapper->mark != Qnil) {
     rb_gc_mark(wrapper->mark);
     rb_gc_mark(wrapper->mark);
   }
   }
+  rb_gc_mark(wrapper->proc);
 }
 }
 
 
 static rb_data_type_t grpc_rb_call_credentials_data_type = {
 static rb_data_type_t grpc_rb_call_credentials_data_type = {
@@ -187,6 +191,7 @@ static rb_data_type_t grpc_rb_call_credentials_data_type = {
 static VALUE grpc_rb_call_credentials_alloc(VALUE cls) {
 static VALUE grpc_rb_call_credentials_alloc(VALUE cls) {
   grpc_rb_call_credentials *wrapper = ALLOC(grpc_rb_call_credentials);
   grpc_rb_call_credentials *wrapper = ALLOC(grpc_rb_call_credentials);
   wrapper->wrapped = NULL;
   wrapper->wrapped = NULL;
+  wrapper->proc = Qnil;
   wrapper->mark = Qnil;
   wrapper->mark = Qnil;
   return TypedData_Wrap_Struct(cls, &grpc_rb_call_credentials_data_type, wrapper);
   return TypedData_Wrap_Struct(cls, &grpc_rb_call_credentials_data_type, wrapper);
 }
 }
@@ -267,6 +272,7 @@ static VALUE grpc_rb_call_credentials_init(VALUE self, VALUE proc) {
     return Qnil;
     return Qnil;
   }
   }
 
 
+  wrapper->proc = proc;
   wrapper->wrapped = creds;
   wrapper->wrapped = creds;
   rb_ivar_set(self, id_callback, proc);
   rb_ivar_set(self, id_callback, proc);