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   DBusRMutex **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                                              DBusRMutex             **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