diff options
author | Lennart Poettering <lennart@poettering.net> | 2007-07-31 22:44:53 +0000 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2007-07-31 22:44:53 +0000 |
commit | 0defdfb5607889c35fdefff4af31eb8b0ae0cbcf (patch) | |
tree | 8a8a93281aa32baa815185de5b2cb869f30376bf /src/pulsecore/object.h | |
parent | a82505e72f6680258b8162b846c98c64bea45c37 (diff) |
A lot of updates, all necessary to get the native protocol ported:
* add an int64_t argument to pa_asyncmsgq because it is very difficult to pass 64 values otherwise
* simplify subclassing in pa_object
* s/drop/unlink/ at some places
* port the native protocol to the lock-free core (not tested, compiles fine)
* move synchronisation of playback streams into pa_sink_input
* add "start_corked" field to pa_sink_input_new_data
* allow casting of NULL values in pa_object
git-svn-id: file:///home/lennart/svn/public/pulseaudio/branches/lennart@1562 fefdeb5f-60dc-0310-8127-8f9354f1896f
Diffstat (limited to 'src/pulsecore/object.h')
-rw-r--r-- | src/pulsecore/object.h | 25 |
1 files changed, 11 insertions, 14 deletions
diff --git a/src/pulsecore/object.h b/src/pulsecore/object.h index 270f289d..9c62f74a 100644 --- a/src/pulsecore/object.h +++ b/src/pulsecore/object.h @@ -38,20 +38,19 @@ struct pa_object { PA_REFCNT_DECLARE; const char *type_name; void (*free)(pa_object *o); - int (*check_type)(pa_object *o, const char *type_name); + int (*check_type)(const char *type_name); }; -pa_object *pa_object_new_internal(size_t size, const char *type_name, int (*check_type)(pa_object *o, const char *type_name)); -#define pa_object_new(type, check_type) ((type*) pa_object_new_internal(sizeof(type), #type, check_type) +pa_object *pa_object_new_internal(size_t size, const char *type_name, int (*check_type)(const char *type_name)); +#define pa_object_new(type) ((type*) pa_object_new_internal(sizeof(type), #type, type##_check_type) #define pa_object_free ((void (*) (pa_object* o)) pa_xfree) -int pa_object_check_type(pa_object *o, const char *type); +int pa_object_check_type(const char *type); static inline int pa_object_isinstance(void *o) { pa_object *obj = (pa_object*) o; - pa_assert(obj); - return obj->check_type(obj, "pa_object"); + return obj ? obj->check_type("pa_object") : 0; } pa_object *pa_object_ref(pa_object *o); @@ -63,19 +62,18 @@ static inline int pa_object_refcnt(pa_object *o) { static inline pa_object* pa_object_cast(void *o) { pa_object *obj = (pa_object*) o; - pa_assert(obj->check_type(obj, "pa_object")); + pa_assert(!obj || obj->check_type("pa_object")); return obj; } -#define pa_object_assert_ref(o) pa_assert(pa_object_refcnt(o)) +#define pa_object_assert_ref(o) pa_assert(pa_object_refcnt(o) > 0) #define PA_OBJECT(o) pa_object_cast(o) #define PA_DECLARE_CLASS(c) \ static inline int c##_isinstance(void *o) { \ pa_object *obj = (pa_object*) o; \ - pa_assert(obj); \ - return obj->check_type(obj, #c); \ + return obj ? obj->check_type(#c) : 1; \ } \ static inline c* c##_cast(void *o) { \ pa_assert(c##_isinstance(o)); \ @@ -95,14 +93,13 @@ static inline pa_object* pa_object_cast(void *o) { } \ struct __stupid_useless_struct_to_allow_trailing_semicolon -#define PA_DEFINE_CHECK_TYPE(c, func, parent) \ - int func(pa_object *o, const char *type) { \ - pa_assert(o); \ +#define PA_DEFINE_CHECK_TYPE(c, parent) \ + int c##_check_type(const char *type) { \ pa_assert(type); \ if (type == #c || \ strcmp(type, #c) == 0) \ return 1; \ - return parent(o, type); \ + return parent##_check_type(type); \ } \ struct __stupid_useless_struct_to_allow_trailing_semicolon |