[Groonga-mysql-commit] mroonga/mroonga [master] fix crash on 'flush tables'.

Back to archive index

null+****@clear***** null+****@clear*****
2011年 10月 6日 (木) 13:25:11 JST


Kouhei Sutou	2011-10-06 04:25:11 +0000 (Thu, 06 Oct 2011)

  New Revision: c59a9752f6318253f0196af12c427287eb4f633b

  Log:
    fix crash on 'flush tables'.
    
    fix how to get cached db from cursor.

  Modified files:
    ha_mroonga.cc

  Modified: ha_mroonga.cc (+19 -14)
===================================================================
--- ha_mroonga.cc    2011-10-06 04:24:26 +0000 (69efcc4)
+++ ha_mroonga.cc    2011-10-06 04:25:11 +0000 (802d7cd)
@@ -1957,35 +1957,40 @@ int ha_mroonga::storage_create_index(TABLE *table, const char *grn_table_name,
 
 int ha_mroonga::close_databases()
 {
-  int error = 0;
-  grn_hash_cursor *hash_cursor;
   MRN_DBUG_ENTER_METHOD();
+
+  int error = 0;
   pthread_mutex_lock(&mrn_db_mutex);
-  hash_cursor =
-    grn_hash_cursor_open(ctx, mrn_hash, NULL, 0, NULL, 0, 0, -1, 0);
-  if (ctx->rc) {
-    my_message(ER_ERROR_ON_READ, ctx->errbuf, MYF(0));
+
+  grn_hash_cursor *hash_cursor;
+  hash_cursor = grn_hash_cursor_open(&mrn_ctx, mrn_hash,
+                                     NULL, 0, NULL, 0,
+                                     0, -1, 0);
+  if (mrn_ctx.rc) {
+    my_message(ER_ERROR_ON_READ, mrn_ctx.errbuf, MYF(0));
     DBUG_RETURN(ER_ERROR_ON_READ);
   }
 
-  while (grn_hash_cursor_next(ctx, hash_cursor) != GRN_ID_NIL) {
-    if (ctx->rc) {
+  while (grn_hash_cursor_next(&mrn_ctx, hash_cursor) != GRN_ID_NIL) {
+    if (mrn_ctx.rc) {
       error = ER_ERROR_ON_READ;
-      my_message(error, ctx->errbuf, MYF(0));
+      my_message(error, mrn_ctx.errbuf, MYF(0));
       break;
     }
+    void *value;
     grn_obj *db;
-    grn_hash_cursor_get_value(ctx, hash_cursor, (void **)&(db));
-    grn_rc rc = grn_hash_cursor_delete(ctx, hash_cursor, NULL);
+    grn_hash_cursor_get_value(&mrn_ctx, hash_cursor, &value);
+    memcpy(&db, value, sizeof(grn_obj *));
+    grn_rc rc = grn_hash_cursor_delete(&mrn_ctx, hash_cursor, NULL);
     if (rc)
     {
       error = ER_ERROR_ON_READ;
-      my_message(error, ctx->errbuf, MYF(0));
+      my_message(error, mrn_ctx.errbuf, MYF(0));
       break;
     }
-    grn_obj_close(ctx, db);
+    grn_obj_close(&mrn_ctx, db);
   }
-  grn_hash_cursor_close(ctx, hash_cursor);
+  grn_hash_cursor_close(&mrn_ctx, hash_cursor);
 
   pthread_mutex_unlock(&mrn_db_mutex);
   DBUG_RETURN(error);




Groonga-mysql-commit メーリングリストの案内
Back to archive index