[Groonga-commit] groonga/groonga at 2a0e46f [master] select: clean by focusing on grn_select_data

Back to archive index

Kouhei Sutou null+****@clear*****
Wed May 4 23:59:07 JST 2016


Kouhei Sutou	2016-05-04 23:59:07 +0900 (Wed, 04 May 2016)

  New Revision: 2a0e46fb0030acec05b7214676650c7cb95e2421
  https://github.com/groonga/groonga/commit/2a0e46fb0030acec05b7214676650c7cb95e2421

  Message:
    select: clean by focusing on grn_select_data

  Modified files:
    lib/proc/proc_select.c

  Modified: lib/proc/proc_select.c (+45 -35)
===================================================================
--- lib/proc/proc_select.c    2016-05-04 22:47:46 +0900 (6d465e4)
+++ lib/proc/proc_select.c    2016-05-04 23:59:07 +0900 (761b497)
@@ -1216,41 +1216,57 @@ exit :
   return ctx->rc;
 }
 
-static void
-proc_select_find_all_drilldown_labels(grn_ctx *ctx, grn_user_data *user_data,
-                                      grn_obj *labels)
+static grn_bool
+grn_select_data_fill_drilldown_labels(grn_ctx *ctx,
+                                      grn_user_data *user_data,
+                                      grn_select_data *data)
 {
   grn_obj *vars = GRN_PROC_GET_VARS();
   grn_table_cursor *cursor;
+  const char *prefix = "drilldown[";
+  int prefix_len;
+
+  data->drilldown_labels = grn_table_create(ctx, NULL, 0, NULL,
+                                            GRN_OBJ_TABLE_HASH_KEY,
+                                            grn_ctx_at(ctx, GRN_DB_SHORT_TEXT),
+                                            NULL);
+  if (!data->drilldown_labels) {
+    return GRN_FALSE;
+  }
+
   cursor = grn_table_cursor_open(ctx, vars, NULL, 0, NULL, 0, 0, -1, 0);
-  if (cursor) {
-    const char *prefix = "drilldown[";
-    int prefix_len = strlen(prefix);
-    while (grn_table_cursor_next(ctx, cursor)) {
-      void *key;
-      char *name;
-      int name_len;
-      name_len = grn_table_cursor_get_key(ctx, cursor, &key);
-      name = key;
-      if (name_len > prefix_len + 1 &&
-          strncmp(prefix, name, prefix_len) == 0) {
-        const char *label_end;
-        size_t label_len;
-        label_end = memchr(name + prefix_len + 1,
-                           ']',
-                           name_len - prefix_len - 1);
-        if (!label_end) {
-          continue;
-        }
-        label_len = (label_end - name) - prefix_len;
-        grn_table_add(ctx, labels,
-                      name + prefix_len,
-                      label_len,
-                      NULL);
+  if (!cursor) {
+    return GRN_FALSE;
+  }
+
+  prefix_len = strlen(prefix);
+  while (grn_table_cursor_next(ctx, cursor)) {
+    void *key;
+    char *name;
+    int name_len;
+    name_len = grn_table_cursor_get_key(ctx, cursor, &key);
+    name = key;
+    if (name_len > prefix_len + 1 &&
+        strncmp(prefix, name, prefix_len) == 0) {
+      const char *label_end;
+      size_t label_len;
+      label_end = memchr(name + prefix_len + 1,
+                         ']',
+                         name_len - prefix_len - 1);
+      if (!label_end) {
+        continue;
       }
+      label_len = (label_end - name) - prefix_len;
+      grn_table_add(ctx,
+                    data->drilldown_labels,
+                    name + prefix_len,
+                    label_len,
+                    NULL);
     }
-    grn_table_cursor_close(ctx, cursor);
   }
+  grn_table_cursor_close(ctx, cursor);
+
+  return GRN_TRUE;
 }
 
 static grn_bool
@@ -1293,16 +1309,10 @@ grn_select_data_fill_drilldowns(grn_ctx *ctx,
     unsigned int i;
     grn_table_cursor *cursor = NULL;
 
-    data->drilldown_labels = grn_table_create(ctx, NULL, 0, NULL,
-                                              GRN_OBJ_TABLE_HASH_KEY,
-                                              grn_ctx_at(ctx, GRN_DB_SHORT_TEXT),
-                                              NULL);
-    if (!data->drilldown_labels) {
+    if (!grn_select_data_fill_drilldown_labels(ctx, user_data, data)) {
       return GRN_FALSE;
     }
 
-    proc_select_find_all_drilldown_labels(ctx, user_data,
-                                          data->drilldown_labels);
     cursor = grn_table_cursor_open(ctx, data->drilldown_labels,
                                    NULL, 0, NULL, 0, 0, -1, 0);
     if (!cursor) {
-------------- next part --------------
HTML����������������������������...
Download 



More information about the Groonga-commit mailing list
Back to archive index