Provided by: libglobus-common-doc_18.11-1_all bug

NAME

       globus_handle_table - Handle Table for Reference Counting Data

        - Handle Table for Reference Counting Data.

SYNOPSIS

   Macros
       #define GLOBUS_NULL_HANDLE

   Typedefs
       typedef struct globus_l_handle_table_s * globus_handle_table_t
           Handle table abstract type.
       typedef int globus_handle_t
           Handle abstract type.
       typedef void(* globus_handle_destructor_t) (void *datum)
           Handle datum destructor.

   Functions
       int globus_handle_table_init (globus_handle_table_t *handle_table,
           globus_handle_destructor_t destructor)
       int globus_handle_table_destroy (globus_handle_table_t *handle_table)
           Destroy a handle table.
       globus_handle_t globus_handle_table_insert (globus_handle_table_t *handle_table, void
           *value, int initial_refs)
       globus_bool_t globus_handle_table_increment_reference_by (globus_handle_table_t
           *handle_table, globus_handle_t handle, unsigned int inc)
           Increment the reference count for handle.
       globus_bool_t globus_handle_table_decrement_reference (globus_handle_table_t
           *handle_table, globus_handle_t handle)
           Remove a reference to a handle.
       globus_bool_t globus_handle_table_increment_reference (globus_handle_table_t
           *handle_table, globus_handle_t handle)
           Add a reference to a handle table entry.
       void * globus_handle_table_lookup (globus_handle_table_t *handle_table, globus_handle_t
           handle)
           Resolve a handle its datum.

Detailed Description

       Handle Table for Reference Counting Data.

       The globus_handle_table_t abstraction provides a reference-counting handle table to
       automatically free data when there are no more references to it. Each datum in the
       globus_handle_table_t container has a count associated with it which may be incremented
       and decremented in single steps or by an increment. While a handle has any references to
       it, the globus_handle_table_lookup() will return the datum associated with the handle,
       otherwise it will return NULL. The value of a globus_handle_t is not reused until INT_MAX
       data have been inserted into the handle table.

Macro Definition Documentation

   #define GLOBUS_NULL_HANDLE
       Invalid handle value

Typedef Documentation

   typedef void(* globus_handle_destructor_t) (void *datum)
       Handle datum destructor.

       Parameters
           datum Datum to destroy

Function Documentation

   globus_bool_t globus_handle_table_decrement_reference (globus_handle_table_t * handle_table,
       globus_handle_t handle)
       Remove a reference to a handle. Remove a reference to a handle table entry, calling its
       destructor if no more references exist for the handle.

       Parameters
           handle_table The table that the handle was created in.
           handle
            The handle to a datum to decrement the reference count for.

       Returns
           The globus_handle_table_decrement_reference() function returns a boolean value
           indicating whether the handle still references a valid datum.

   int globus_handle_table_destroy (globus_handle_table_t * handle_table)
       Destroy a handle table. Destroy a handle table and call the destructor for all objects
       associated with it.

       Parameters
           handle_table Pointer to the handle table to destroy

   globus_bool_t globus_handle_table_increment_reference (globus_handle_table_t * handle_table,
       globus_handle_t handle)
       Add a reference to a handle table entry.

       Parameters
           handle_table The table that the handle was created in.
           handle
            The handle to a datum to increment the reference count for.

       Returns
           The globus_handle_table_increment_reference() function returns a boolean value
           indicating whether the handle still references a valid datum.

   globus_bool_t globus_handle_table_increment_reference_by (globus_handle_table_t *
       handle_table, globus_handle_t handle, unsigned int inc)
       Increment the reference count for handle.

       Parameters
           handle_table The table that the handle was created in.
           handle
            The handle to a datum to increment the reference count for.
           inc The number of references to add the handle.

       Returns
           The globus_handle_table_increment_reference_by() function returns a boolean value
           indicating whether the handle still references a valid datum.

   int globus_handle_table_init (globus_handle_table_t * handle_table, globus_handle_destructor_t
       destructor)
       Initialize a table of unique reference counted handles.

       Parameters
           handle_table the table of unique handles we want to use.
           destructor Function to call to free the data associated with a handle when the
           handle's reference count reaches 0 or the handle table is destroyed.

   globus_handle_t globus_handle_table_insert (globus_handle_table_t * handle_table, void *
       value, int initial_refs)
       Insert a datum into a handle table

       Insert a value into the handle table, and return a unique handle to it.

       Parameters
           handle_table Handle table to add the value to
           value The value to insert into the table
           initial_refs The initial reference count of this value in the table

       Returns
           The globus_handle_table_insert() function returns a unique handle to value.

   void* globus_handle_table_lookup (globus_handle_table_t * handle_table, globus_handle_t
       handle)
       Resolve a handle its datum.

       Parameters
           handle_table The table that the handle was created in.
           handle
            The handle to a datum to resolve

       Returns
           The globus_handle_table_lookup() function returns the datum associated with the handle
           in the handle table, or NULL if the handle does not reference valid data.

Author

       Generated automatically by Doxygen for globus_common from the source code.