]> code.delx.au - pulseaudio/commitdiff
device-port: Fix the circular dependency problem more cleanly.
authorTanu Kaskinen <tanuk@iki.fi>
Sun, 27 Nov 2011 15:16:53 +0000 (17:16 +0200)
committerTanu Kaskinen <tanuk@iki.fi>
Sun, 27 Nov 2011 15:22:42 +0000 (17:22 +0200)
Declaring structs before including anything ensures that the
structs are available for everybody in case of circular includes.

src/pulsecore/device-port.h

index 7e7ed8de0fbc35e72af4d5faf8956ae791a0d8ec..b6341258db8bc34a9c6470ac5f6e0eaadaa92cb0 100644 (file)
@@ -24,6 +24,7 @@
   USA.
 ***/
 
+typedef struct pa_device_port pa_device_port;
 
 #ifdef HAVE_CONFIG_H
 #include <config.h>
 #include <pulse/def.h>
 #include <pulsecore/object.h>
 #include <pulsecore/hashmap.h>
-
-/* Note: Including core.h here leads to circular references
-   (device-port.h -> core.h -> sink.h -> device-port.h), hence the line below instead */
-struct pa_core;
-
-typedef struct pa_device_port pa_device_port;
+#include <pulsecore/core.h>
 
 struct pa_device_port {
     pa_object parent; /* Needed for reference counting */
-    struct pa_core *core;
+    pa_core *core;
 
     char *name;
     char *description;
@@ -63,7 +59,7 @@ PA_DECLARE_PUBLIC_CLASS(pa_device_port);
 
 #define PA_DEVICE_PORT_DATA(d) ((void*) ((uint8_t*) d + PA_ALIGN(sizeof(pa_device_port))))
 
-pa_device_port *pa_device_port_new(struct pa_core *c, const char *name, const char *description, size_t extra);
+pa_device_port *pa_device_port_new(pa_core *c, const char *name, const char *description, size_t extra);
 
 void pa_device_port_hashmap_free(pa_hashmap *h);