1 /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
2 /* dbus-dataslot.h storing data on objects
4 * Copyright (C) 2003 Red Hat, Inc.
6 * Licensed under the Academic Free License version 2.1
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.
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.
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
23 #ifndef DBUS_DATASLOT_H
24 #define DBUS_DATASLOT_H
26 #include <dbus/dbus-internals.h>
30 typedef struct DBusDataSlotAllocator DBusDataSlotAllocator;
31 typedef struct DBusDataSlotList DBusDataSlotList;
33 /** Opaque typedef for DBusDataSlot */
34 typedef struct DBusDataSlot DBusDataSlot;
35 /** DBusDataSlot is used to store application data on the connection */
38 void *data; /**< The application data */
39 DBusFreeFunction free_data_func; /**< Free the application data */
42 typedef struct DBusAllocatedSlot DBusAllocatedSlot;
44 /** An allocated slot for storing data
46 struct DBusAllocatedSlot
48 dbus_int32_t slot_id; /**< ID of this slot */
49 int refcount; /**< Number of uses of the slot */
53 * An allocator that tracks a set of slot IDs.
55 struct DBusDataSlotAllocator
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 DBusGlobalLock lock; /**< index of thread lock */
63 #define _DBUS_DATA_SLOT_ALLOCATOR_INIT(x) { NULL, 0, 0, x }
66 * Data structure that stores the actual user data set at a given
69 struct DBusDataSlotList
71 DBusDataSlot *slots; /**< Data slots */
72 int n_slots; /**< Slots we have storage for in data_slots */
75 dbus_bool_t _dbus_data_slot_allocator_init (DBusDataSlotAllocator *allocator,
77 dbus_bool_t _dbus_data_slot_allocator_alloc (DBusDataSlotAllocator *allocator,
79 void _dbus_data_slot_allocator_free (DBusDataSlotAllocator *allocator,
81 void _dbus_data_slot_list_init (DBusDataSlotList *list);
82 dbus_bool_t _dbus_data_slot_list_set (DBusDataSlotAllocator *allocator,
83 DBusDataSlotList *list,
86 DBusFreeFunction free_data_func,
87 DBusFreeFunction *old_free_func,
89 void* _dbus_data_slot_list_get (DBusDataSlotAllocator *allocator,
90 DBusDataSlotList *list,
92 void _dbus_data_slot_list_clear (DBusDataSlotList *list);
93 void _dbus_data_slot_list_free (DBusDataSlotList *list);
98 #endif /* DBUS_DATASLOT_H */