Blame snmplib/container_iterator.c

Packit fcad23
/*
Packit fcad23
 * $Id$
Packit fcad23
 *
Packit fcad23
 */
Packit fcad23
Packit fcad23
#include <net-snmp/net-snmp-config.h>
Packit fcad23
#include <net-snmp/net-snmp-features.h>
Packit fcad23
Packit fcad23
#include <stdio.h>
Packit fcad23
#if HAVE_STDLIB_H
Packit fcad23
#include <stdlib.h>
Packit fcad23
#endif
Packit fcad23
#if HAVE_MALLOC_H
Packit fcad23
#include <malloc.h>
Packit fcad23
#endif
Packit fcad23
#include <sys/types.h>
Packit fcad23
#if HAVE_STRING_H
Packit fcad23
#include <string.h>
Packit fcad23
#else
Packit fcad23
#include <strings.h>
Packit fcad23
#endif
Packit fcad23
Packit fcad23
#include <net-snmp/net-snmp-includes.h>
Packit fcad23
#include <net-snmp/types.h>
Packit fcad23
#include <net-snmp/library/snmp_api.h>
Packit fcad23
#include <net-snmp/library/container.h>
Packit fcad23
#include <net-snmp/library/tools.h>
Packit fcad23
#include <net-snmp/library/snmp_assert.h>
Packit fcad23
Packit fcad23
#include <net-snmp/library/container_iterator.h>
Packit fcad23
Packit fcad23
netsnmp_feature_child_of(container_iterator, container_types)
Packit fcad23
Packit fcad23
#ifndef NETSNMP_FEATURE_REMOVE_CONTAINER_ITERATOR
Packit fcad23
/**
Packit fcad23
 *  Holds iterator information containing functions which should be called
Packit fcad23
 *  by the iterator_handler to loop over your data set and sort it in a
Packit fcad23
 *  SNMP specific manner.
Packit fcad23
 *
Packit fcad23
 *  The iterator_info typedef can be used instead of directly calling this
Packit fcad23
 *  struct if you would prefer.
Packit fcad23
 */
Packit fcad23
typedef struct iterator_info_s {
Packit fcad23
   /*
Packit fcad23
    * netsnmp_conatiner  must be first
Packit fcad23
    */
Packit fcad23
   netsnmp_container c;
Packit fcad23
Packit fcad23
   /*
Packit fcad23
    * iterator data
Packit fcad23
    */
Packit fcad23
   Netsnmp_Iterator_Loop_Key *get_first;
Packit fcad23
   Netsnmp_Iterator_Loop_Key *get_next;
Packit fcad23
   
Packit fcad23
   Netsnmp_Iterator_Loop_Data *get_data;
Packit fcad23
Packit fcad23
   Netsnmp_Iterator_Data *free_user_ctx;
Packit fcad23
   
Packit fcad23
   Netsnmp_Iterator_Ctx *init_loop_ctx;
Packit fcad23
   Netsnmp_Iterator_Ctx *cleanup_loop_ctx;
Packit fcad23
   Netsnmp_Iterator_Ctx_Dup *save_pos;
Packit fcad23
   
Packit fcad23
   Netsnmp_Iterator_Data * release_data;
Packit fcad23
   Netsnmp_Iterator_Data * insert_data;
Packit fcad23
   Netsnmp_Iterator_Data * remove_data;
Packit fcad23
Packit fcad23
   Netsnmp_Iterator_Op * get_size;
Packit fcad23
   
Packit fcad23
   int             sorted;
Packit fcad23
   
Packit fcad23
   /** This can be used by client handlers to store any
Packit fcad23
       information they need */
Packit fcad23
   void           *user_ctx;
Packit fcad23
} iterator_info;
Packit fcad23
Packit fcad23
/**********************************************************************
Packit fcad23
 *
Packit fcad23
 * iterator
Packit fcad23
 *
Packit fcad23
 **********************************************************************/
Packit fcad23
static void *
Packit fcad23
_iterator_get(iterator_info *ii, const void *key)
Packit fcad23
{
Packit fcad23
    int cmp, rc = SNMP_ERR_NOERROR;
Packit fcad23
    netsnmp_ref_void best = { NULL };
Packit fcad23
    netsnmp_ref_void tmp = { NULL };
Packit fcad23
    netsnmp_ref_void loop_ctx = { NULL };
Packit fcad23
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_get"));
Packit fcad23
    
Packit fcad23
    if(ii->init_loop_ctx)
Packit fcad23
        ii->init_loop_ctx(ii->user_ctx, &loop_ctx);
Packit fcad23
    
Packit fcad23
    rc = ii->get_first(ii->user_ctx, &loop_ctx, &tmp);
Packit fcad23
    if(SNMP_ERR_NOERROR != rc) {
Packit fcad23
        if(SNMP_ENDOFMIBVIEW != rc)
Packit fcad23
            snmp_log(LOG_ERR, "bad rc %d from get_next\n", rc);
Packit fcad23
    }
Packit fcad23
    else {
Packit fcad23
        for( ;
Packit fcad23
             (NULL != tmp.val) && (SNMP_ERR_NOERROR == rc);
Packit fcad23
             rc = ii->get_next(ii->user_ctx, &loop_ctx, &tmp) ) {
Packit fcad23
            
Packit fcad23
            /*
Packit fcad23
             * if keys are equal, we are done.
Packit fcad23
             */
Packit fcad23
            cmp = ii->c.compare(tmp.val, key);
Packit fcad23
            if(0 == cmp) {
Packit fcad23
                best.val = tmp.val;
Packit fcad23
                if(ii->get_data)
Packit fcad23
                    ii->get_data(ii->user_ctx, &loop_ctx, &best);
Packit fcad23
            }
Packit fcad23
            
Packit fcad23
            /*
Packit fcad23
             * if data is sorted and if key is greater,
Packit fcad23
             * we are done (not found)
Packit fcad23
             */
Packit fcad23
            if((cmp > 0) && ii->sorted)
Packit fcad23
                break;
Packit fcad23
        } /* end for */
Packit fcad23
    }
Packit fcad23
    
Packit fcad23
    if(ii->cleanup_loop_ctx)
Packit fcad23
        ii->cleanup_loop_ctx(ii->user_ctx,&loop_ctx);
Packit fcad23
Packit fcad23
    return best.val;
Packit fcad23
}
Packit fcad23
Packit fcad23
/**
Packit fcad23
 *
Packit fcad23
 * NOTE: the returned data context can be reused, to save from
Packit fcad23
 *   having to allocate memory repeatedly. However, in this case,
Packit fcad23
 *   the get_data and get_pos functions must be implemented to
Packit fcad23
 *   return unique memory that will be saved for later comparisons.
Packit fcad23
 */
Packit fcad23
static void *
Packit fcad23
_iterator_get_next(iterator_info *ii, const void *key)
Packit fcad23
{
Packit fcad23
    int cmp, rc = SNMP_ERR_NOERROR;
Packit fcad23
    netsnmp_ref_void best_val = { NULL };
Packit fcad23
    netsnmp_ref_void best_ctx = { NULL };
Packit fcad23
    netsnmp_ref_void tmp = { NULL };
Packit fcad23
    netsnmp_ref_void loop_ctx = { NULL };
Packit fcad23
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_get_next"));
Packit fcad23
    
Packit fcad23
    /*
Packit fcad23
     * initialize loop context
Packit fcad23
     */
Packit fcad23
    if(ii->init_loop_ctx)
Packit fcad23
        ii->init_loop_ctx(ii->user_ctx, &loop_ctx);
Packit fcad23
    
Packit fcad23
    /*
Packit fcad23
     * get first item
Packit fcad23
     */
Packit fcad23
    rc = ii->get_first(ii->user_ctx, &loop_ctx, &tmp);
Packit fcad23
    if(SNMP_ERR_NOERROR == rc) {
Packit fcad23
        /*
Packit fcad23
         * special case: if key is null, find the first item.
Packit fcad23
         * this is each if the container is sorted, since we're
Packit fcad23
         * already done!  Otherwise, get the next item for the
Packit fcad23
         * first comparison in the loop below.
Packit fcad23
         */
Packit fcad23
        if (NULL == key) {
Packit fcad23
            if(ii->get_data)
Packit fcad23
                ii->save_pos(ii->user_ctx, &loop_ctx, &best_ctx, 1);
Packit fcad23
            best_val.val = tmp.val;
Packit fcad23
            if(ii->sorted)
Packit fcad23
                tmp.val = NULL; /* so we skip for loop */
Packit fcad23
            else
Packit fcad23
                rc = ii->get_next(ii->user_ctx, &loop_ctx, &tmp);
Packit fcad23
        }
Packit fcad23
        /*
Packit fcad23
         * loop over remaining items
Packit fcad23
         */
Packit fcad23
        for( ;
Packit fcad23
             (NULL != tmp.val) && (rc == SNMP_ERR_NOERROR);
Packit fcad23
             rc = ii->get_next(ii->user_ctx, &loop_ctx, &tmp) ) {
Packit fcad23
            
Packit fcad23
            /*
Packit fcad23
             * if we have a key, this is a get-next, and we need to compare
Packit fcad23
             * the key to the tmp value to see if the tmp value is greater
Packit fcad23
             * than the key, but less than any previous match.
Packit fcad23
             *
Packit fcad23
             * if there is no key, this is a get-first, and we need to
Packit fcad23
             * compare the best value agains the tmp value to see if the
Packit fcad23
             * tmp value is lesser than the best match.
Packit fcad23
             */
Packit fcad23
            if(key) /* get next */
Packit fcad23
                cmp = ii->c.compare(tmp.val, key);
Packit fcad23
            else { /* get first */
Packit fcad23
                /*
Packit fcad23
                 * best value and tmp value should never be equal,
Packit fcad23
                 * otherwise we'd be comparing a pointer to itself.
Packit fcad23
                 * (see note on context reuse in comments above function.
Packit fcad23
                 */
Packit fcad23
                if(best_val.val == tmp.val) {
Packit fcad23
                    snmp_log(LOG_ERR,"illegal reuse of data context in "
Packit fcad23
                             "container_iterator\n");
Packit fcad23
                    rc = SNMP_ERR_GENERR;
Packit fcad23
                    break;
Packit fcad23
                }
Packit fcad23
                cmp = ii->c.compare(best_val.val, tmp.val);
Packit fcad23
            }
Packit fcad23
            if(cmp > 0) {
Packit fcad23
                /*
Packit fcad23
                 * if we don't have a key (get-first) or a current best match,
Packit fcad23
                 * then the comparison above is all we need to know that
Packit fcad23
                 * tmp is the best match. otherwise, compare against the
Packit fcad23
                 * current best match.
Packit fcad23
                 */
Packit fcad23
                if((NULL == key) || (NULL == best_val.val) ||
Packit fcad23
                   ((cmp=ii->c.compare(tmp.val, best_val.val)) < 0) ) {
Packit fcad23
                    DEBUGMSGT(("container_iterator:results"," best match\n"));
Packit fcad23
                    best_val.val = tmp.val;
Packit fcad23
                    if(ii->get_data)
Packit fcad23
                        ii->save_pos(ii->user_ctx, &loop_ctx, &best_ctx, 1);
Packit fcad23
                }
Packit fcad23
            }
Packit fcad23
            else if((cmp == 0) && ii->sorted && key) {
Packit fcad23
                /*
Packit fcad23
                 * if keys are equal and container is sorted, then we know
Packit fcad23
                 * the next key will be the one we want.
Packit fcad23
                 * NOTE: if no vars, treat as generr, since we
Packit fcad23
                 *    went past the end of the container when we know
Packit fcad23
                 *    the next item is the one we want. (IGN-A)
Packit fcad23
                 */
Packit fcad23
                rc = ii->get_next(ii->user_ctx, &loop_ctx, &tmp);
Packit fcad23
                if(SNMP_ERR_NOERROR == rc) {
Packit fcad23
                    best_val.val = tmp.val;
Packit fcad23
                    if(ii->get_data)
Packit fcad23
                        ii->save_pos(ii->user_ctx, &loop_ctx, &best_ctx, 1);
Packit fcad23
                }
Packit fcad23
                else if(SNMP_ENDOFMIBVIEW == rc)
Packit fcad23
                    rc = SNMPERR_GENERR; /* not found */
Packit fcad23
                break;
Packit fcad23
            }
Packit fcad23
            
Packit fcad23
        } /* end for */
Packit fcad23
    }
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * no vars is ok, except as noted above (IGN-A)
Packit fcad23
     */
Packit fcad23
    if(SNMP_ENDOFMIBVIEW == rc)
Packit fcad23
        rc = SNMP_ERR_NOERROR;
Packit fcad23
            
Packit fcad23
    /*
Packit fcad23
     * get data, iff necessary
Packit fcad23
     * clear return value iff errors
Packit fcad23
     */
Packit fcad23
    if(SNMP_ERR_NOERROR == rc) {
Packit fcad23
        if(ii->get_data && best_val.val) {
Packit fcad23
            rc = ii->get_data(ii->user_ctx, &best_ctx, &best_val);
Packit fcad23
            if(SNMP_ERR_NOERROR != rc) {
Packit fcad23
                snmp_log(LOG_ERR, "bad rc %d from get_data\n", rc);
Packit fcad23
                best_val.val = NULL;
Packit fcad23
            }
Packit fcad23
        }
Packit fcad23
    }
Packit fcad23
    else if(SNMP_ENDOFMIBVIEW != rc) {
Packit fcad23
        snmp_log(LOG_ERR, "bad rc %d from get_next\n", rc);
Packit fcad23
        best_val.val = NULL;
Packit fcad23
    }
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * if we have a saved loop ctx, clean it up
Packit fcad23
     */
Packit fcad23
    if((best_ctx.val != NULL) && (best_ctx.val != loop_ctx.val) &&
Packit fcad23
       (ii->cleanup_loop_ctx))
Packit fcad23
        ii->cleanup_loop_ctx(ii->user_ctx,&best_ctx);
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * clean up loop ctx
Packit fcad23
     */
Packit fcad23
    if(ii->cleanup_loop_ctx)
Packit fcad23
        ii->cleanup_loop_ctx(ii->user_ctx,&loop_ctx);
Packit fcad23
Packit fcad23
    DEBUGMSGT(("container_iterator:results"," returning %p\n", best_val.val));
Packit fcad23
    return best_val.val;
Packit fcad23
}
Packit fcad23
Packit fcad23
/**********************************************************************
Packit fcad23
 *
Packit fcad23
 * container
Packit fcad23
 *
Packit fcad23
 **********************************************************************/
Packit fcad23
static void
Packit fcad23
_iterator_free(iterator_info *ii)
Packit fcad23
{
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_free"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return;
Packit fcad23
    
Packit fcad23
    if(ii->user_ctx)
Packit fcad23
        ii->free_user_ctx(ii->user_ctx,ii->user_ctx);
Packit fcad23
    
Packit fcad23
    free(ii);
Packit fcad23
}
Packit fcad23
Packit fcad23
static void *
Packit fcad23
_iterator_find(iterator_info *ii, const void *data)
Packit fcad23
{
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_find"));
Packit fcad23
    
Packit fcad23
    if((NULL == ii) || (NULL == data))
Packit fcad23
        return NULL;
Packit fcad23
Packit fcad23
    return _iterator_get(ii, data);
Packit fcad23
}
Packit fcad23
Packit fcad23
static void *
Packit fcad23
_iterator_find_next(iterator_info *ii, const void *data)
Packit fcad23
{
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_find_next"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return NULL;
Packit fcad23
Packit fcad23
    return _iterator_get_next(ii, data);
Packit fcad23
}
Packit fcad23
Packit fcad23
static int
Packit fcad23
_iterator_insert(iterator_info *ii, const void *data)
Packit fcad23
{
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_insert"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    if(NULL == ii->insert_data)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    return ii->insert_data(ii->user_ctx, data);
Packit fcad23
}
Packit fcad23
Packit fcad23
static int
Packit fcad23
_iterator_remove(iterator_info *ii, const void *data)
Packit fcad23
{
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_remove"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    if(NULL == ii->remove_data)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    return ii->remove_data(ii->user_ctx, data);
Packit fcad23
}
Packit fcad23
Packit fcad23
static int
Packit fcad23
_iterator_release(iterator_info *ii, const void *data)
Packit fcad23
{
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_release"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    if(NULL == ii->release_data)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    return ii->release_data(ii->user_ctx, data);
Packit fcad23
}
Packit fcad23
Packit fcad23
static size_t
Packit fcad23
_iterator_size(iterator_info *ii)
Packit fcad23
{
Packit fcad23
    size_t count = 0;
Packit fcad23
    netsnmp_ref_void loop_ctx = { NULL };
Packit fcad23
    netsnmp_ref_void tmp = { NULL };
Packit fcad23
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_size"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return -1;
Packit fcad23
Packit fcad23
    if(NULL != ii->get_size)
Packit fcad23
        return ii->get_size(ii->user_ctx);
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * no get_size. loop and count ourselves
Packit fcad23
     */
Packit fcad23
    if(ii->init_loop_ctx)
Packit fcad23
        ii->init_loop_ctx(ii->user_ctx, &loop_ctx);
Packit fcad23
    
Packit fcad23
    for( ii->get_first(ii->user_ctx, &loop_ctx, &tmp);
Packit fcad23
         NULL != tmp.val;
Packit fcad23
         ii->get_next(ii->user_ctx, &loop_ctx, &tmp) )
Packit fcad23
        ++count;
Packit fcad23
Packit fcad23
    if(ii->cleanup_loop_ctx)
Packit fcad23
        ii->cleanup_loop_ctx(ii->user_ctx,&loop_ctx);
Packit fcad23
Packit fcad23
    return count;
Packit fcad23
}
Packit fcad23
Packit fcad23
static void
Packit fcad23
_iterator_for_each(iterator_info *ii, netsnmp_container_obj_func *f,
Packit fcad23
                   void *ctx)
Packit fcad23
{
Packit fcad23
    netsnmp_ref_void loop_ctx = { NULL };
Packit fcad23
    netsnmp_ref_void tmp = { NULL };
Packit fcad23
Packit fcad23
    DEBUGMSGT(("container_iterator",">%s\n", "_iterator_foreach"));
Packit fcad23
    
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return;
Packit fcad23
Packit fcad23
    if(ii->init_loop_ctx)
Packit fcad23
        ii->init_loop_ctx(ii->user_ctx, &loop_ctx);
Packit fcad23
    
Packit fcad23
    for( ii->get_first(ii->user_ctx, &loop_ctx, &tmp);
Packit fcad23
         NULL != tmp.val;
Packit fcad23
         ii->get_next(ii->user_ctx, &loop_ctx, &tmp) )
Packit fcad23
        (*f) (tmp.val, ctx);
Packit fcad23
Packit fcad23
    if(ii->cleanup_loop_ctx)
Packit fcad23
        ii->cleanup_loop_ctx(ii->user_ctx,&loop_ctx);
Packit fcad23
}
Packit fcad23
Packit fcad23
static void
Packit fcad23
_iterator_clear(netsnmp_container *container, netsnmp_container_obj_func *f,
Packit fcad23
                 void *context)
Packit fcad23
{
Packit fcad23
    snmp_log(LOG_WARNING,"clear is meaningless for iterator container.\n");
Packit fcad23
}
Packit fcad23
Packit fcad23
/**********************************************************************
Packit fcad23
 *
Packit fcad23
 */
Packit fcad23
netsnmp_container*
Packit fcad23
netsnmp_container_iterator_get(void *iterator_user_ctx,
Packit fcad23
                               netsnmp_container_compare * compare,
Packit fcad23
                               Netsnmp_Iterator_Loop_Key * get_first,
Packit fcad23
                               Netsnmp_Iterator_Loop_Key * get_next,
Packit fcad23
                               Netsnmp_Iterator_Loop_Data * get_data,
Packit fcad23
                               Netsnmp_Iterator_Ctx_Dup * save_pos,
Packit fcad23
                               Netsnmp_Iterator_Ctx * init_loop_ctx,
Packit fcad23
                               Netsnmp_Iterator_Ctx * cleanup_loop_ctx,
Packit fcad23
                               Netsnmp_Iterator_Data * free_user_ctx,
Packit fcad23
                               int sorted)
Packit fcad23
{
Packit fcad23
    iterator_info *ii;
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * sanity checks
Packit fcad23
     */
Packit fcad23
    if(get_data && ! save_pos) {
Packit fcad23
        snmp_log(LOG_ERR, "save_pos required with get_data\n");
Packit fcad23
        return NULL;
Packit fcad23
    }
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * allocate memory
Packit fcad23
     */
Packit fcad23
    ii = SNMP_MALLOC_TYPEDEF(iterator_info);
Packit fcad23
    if (NULL==ii) {
Packit fcad23
        snmp_log(LOG_ERR, "couldn't allocate memory\n");
Packit fcad23
        return NULL;
Packit fcad23
    }
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * init container structure with iterator functions
Packit fcad23
     */
Packit fcad23
    ii->c.cfree = (netsnmp_container_rc*)_iterator_free;
Packit fcad23
    ii->c.compare = compare;
Packit fcad23
    ii->c.get_size = (netsnmp_container_size*)_iterator_size;
Packit fcad23
    ii->c.init = NULL;
Packit fcad23
    ii->c.insert = (netsnmp_container_op*)_iterator_insert;
Packit fcad23
    ii->c.remove = (netsnmp_container_op*)_iterator_remove;
Packit fcad23
    ii->c.release = (netsnmp_container_op*)_iterator_release;
Packit fcad23
    ii->c.find = (netsnmp_container_rtn*)_iterator_find;
Packit fcad23
    ii->c.find_next = (netsnmp_container_rtn*)_iterator_find_next;
Packit fcad23
    ii->c.get_subset = NULL;
Packit fcad23
    ii->c.get_iterator = NULL;
Packit fcad23
    ii->c.for_each = (netsnmp_container_func*)_iterator_for_each;
Packit fcad23
    ii->c.clear = _iterator_clear;
Packit fcad23
Packit fcad23
    /*
Packit fcad23
     * init iterator structure with user functions
Packit fcad23
     */
Packit fcad23
    ii->get_first = get_first;
Packit fcad23
    ii->get_next = get_next;
Packit fcad23
    ii->get_data = get_data;
Packit fcad23
    ii->save_pos = save_pos;
Packit fcad23
    ii->init_loop_ctx = init_loop_ctx;
Packit fcad23
    ii->cleanup_loop_ctx = cleanup_loop_ctx;
Packit fcad23
    ii->free_user_ctx = free_user_ctx;
Packit fcad23
    ii->sorted = sorted;
Packit fcad23
Packit fcad23
    ii->user_ctx = iterator_user_ctx;
Packit fcad23
Packit fcad23
    return (netsnmp_container*)ii;
Packit fcad23
}
Packit fcad23
Packit fcad23
void
Packit fcad23
netsnmp_container_iterator_set_data_cb(netsnmp_container *c,
Packit fcad23
                                       Netsnmp_Iterator_Data * insert_data,
Packit fcad23
                                       Netsnmp_Iterator_Data * remove_data,
Packit fcad23
                                       Netsnmp_Iterator_Op * get_size)
Packit fcad23
{
Packit fcad23
    iterator_info *ii = (iterator_info *)c;
Packit fcad23
    if(NULL == ii)
Packit fcad23
        return;
Packit fcad23
    
Packit fcad23
    ii->insert_data = insert_data;
Packit fcad23
    ii->remove_data = remove_data;
Packit fcad23
    ii->get_size = get_size;
Packit fcad23
}
Packit fcad23
#else  /* NETSNMP_FEATURE_REMOVE_CONTAINER_ITERATOR */
Packit fcad23
netsnmp_feature_unused(container_iterator);
Packit fcad23
#endif /* NETSNMP_FEATURE_REMOVE_CONTAINER_ITERATOR */