1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
|
/* This file is part of the Zebra server.
Copyright (C) Index Data
Zebra is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 2, or (at your option) any later
version.
Zebra is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#if HAVE_CONFIG_H
#include <config.h>
#endif
#include <assert.h>
#include "index.h"
struct context_control {
int ref_count;
void (*filter_destroy)(void *data);
};
static void my_inc(struct rset_key_control *kc)
{
struct context_control *cp;
assert(kc);
cp = kc->context;
(cp->ref_count)++;
}
static void my_dec(struct rset_key_control *kc)
{
struct context_control *cp;
assert(kc);
cp = kc->context;
(cp->ref_count)--;
if (cp->ref_count == 0)
{
if (cp->filter_destroy)
(*cp->filter_destroy)(kc->filter_data);
xfree(cp);
xfree(kc);
}
}
struct rset_key_control *zebra_key_control_create(ZebraHandle zh)
{
struct rset_key_control *kc = xmalloc(sizeof(*kc));
struct context_control *cp = xmalloc(sizeof(*cp));
kc->context = cp;
kc->key_size = sizeof(struct it_key);
kc->cmp = key_compare;
kc->key_logdump_txt = key_logdump_txt;
kc->getseq = key_get_seq;
if (zh->m_segment_indexing)
{
kc->scope = 3; /* segment + seq is "same" record */
kc->get_segment = key_get_segment;
}
else
{
kc->scope = 2; /* seq is "same" record */
kc->get_segment = 0;
}
zebra_limit_for_rset(zh->m_limit,
&kc->filter_func,
&cp->filter_destroy,
&kc->filter_data);
kc->inc = my_inc;
kc->dec = my_dec;
cp->ref_count = 1;
return kc;
}
/*
* Local variables:
* c-basic-offset: 4
* c-file-style: "Stroustrup"
* indent-tabs-mode: nil
* End:
* vim: shiftwidth=4 tabstop=8 expandtab
*/
|