Home | History | Annotate | Download | only in dbus
      1 /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
      2 /* dbus-dataslot.h  storing data on objects
      3  *
      4  * Copyright (C) 2003 Red Hat, Inc.
      5  *
      6  * Licensed under the Academic Free License version 2.1
      7  *
      8  * This program is free software; you can redistribute it and/or modify
      9  * it under the terms of the GNU General Public License as published by
     10  * the Free Software Foundation; either version 2 of the License, or
     11  * (at your option) any later version.
     12  *
     13  * This program is distributed in the hope that it will be useful,
     14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
     15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     16  * GNU General Public License for more details.
     17  *
     18  * You should have received a copy of the GNU General Public License
     19  * along with this program; if not, write to the Free Software
     20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
     21  *
     22  */
     23 #ifndef DBUS_DATASLOT_H
     24 #define DBUS_DATASLOT_H
     25 
     26 #include <dbus/dbus-internals.h>
     27 
     28 DBUS_BEGIN_DECLS
     29 
     30 typedef struct DBusDataSlotAllocator DBusDataSlotAllocator;
     31 typedef struct DBusDataSlotList DBusDataSlotList;
     32 
     33 /** Opaque typedef for DBusDataSlot */
     34 typedef struct DBusDataSlot DBusDataSlot;
     35 /** DBusDataSlot is used to store application data on the connection */
     36 struct DBusDataSlot
     37 {
     38   void *data;                      /**< The application data */
     39   DBusFreeFunction free_data_func; /**< Free the application data */
     40 };
     41 
     42 typedef struct DBusAllocatedSlot DBusAllocatedSlot;
     43 
     44 /** An allocated slot for storing data
     45  */
     46 struct DBusAllocatedSlot
     47 {
     48   dbus_int32_t slot_id;  /**< ID of this slot */
     49   int          refcount; /**< Number of uses of the slot */
     50 };
     51 
     52 /**
     53  * An allocator that tracks a set of slot IDs.
     54  */
     55 struct DBusDataSlotAllocator
     56 {
     57   DBusAllocatedSlot *allocated_slots; /**< Allocated slots */
     58   int  n_allocated_slots; /**< number of slots malloc'd */
     59   int  n_used_slots;      /**< number of slots used */
     60   DBusMutex **lock_loc;   /**< location of thread lock */
     61 };
     62 
     63 /**
     64  * Data structure that stores the actual user data set at a given
     65  * slot.
     66  */
     67 struct DBusDataSlotList
     68 {
     69   DBusDataSlot *slots;   /**< Data slots */
     70   int           n_slots; /**< Slots we have storage for in data_slots */
     71 };
     72 
     73 dbus_bool_t _dbus_data_slot_allocator_init  (DBusDataSlotAllocator  *allocator);
     74 dbus_bool_t _dbus_data_slot_allocator_alloc (DBusDataSlotAllocator  *allocator,
     75                                              DBusMutex              **mutex_loc,
     76                                              int                    *slot_id_p);
     77 void        _dbus_data_slot_allocator_free  (DBusDataSlotAllocator  *allocator,
     78                                              int                    *slot_id_p);
     79 void        _dbus_data_slot_list_init       (DBusDataSlotList       *list);
     80 dbus_bool_t _dbus_data_slot_list_set        (DBusDataSlotAllocator  *allocator,
     81                                              DBusDataSlotList       *list,
     82                                              int                     slot,
     83                                              void                   *data,
     84                                              DBusFreeFunction        free_data_func,
     85                                              DBusFreeFunction       *old_free_func,
     86                                              void                  **old_data);
     87 void*       _dbus_data_slot_list_get        (DBusDataSlotAllocator  *allocator,
     88                                              DBusDataSlotList       *list,
     89                                              int                     slot);
     90 void        _dbus_data_slot_list_clear      (DBusDataSlotList       *list);
     91 void        _dbus_data_slot_list_free       (DBusDataSlotList       *list);
     92 
     93 
     94 DBUS_END_DECLS
     95 
     96 #endif /* DBUS_DATASLOT_H */
     97