summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDavid Henningsson <david.henningsson@canonical.com>2015-11-26 18:29:58 +0100
committerTanu Kaskinen <tanuk@iki.fi>2015-12-14 05:01:53 +0200
commitd97460045ceb71a0c3541c2753bb7fe519950285 (patch)
tree03bdffd21a039c880fef143ae4cbad1e93e76aa9 /src
parentf61a16b8b17b3f50234768713d0245e42e5c5aff (diff)
downloadpulseaudio-d97460045ceb71a0c3541c2753bb7fe519950285.tar.gz
typedefs.h: Move some typedefs to a separate file
The relationship between sinks, sources, cards, profiles, and ports is becoming ever more intertwined, to the point that if you try to include one file from the other, you're likely to end up with some weird error somewhere else. Work around this by creating a new typedefs.h, which does not depend on anything else, and just creates a few typedefs. (Can be expanded with more typedefs in the future if the need arises.) Signed-off-by: David Henningsson <david.henningsson@canonical.com>
Diffstat (limited to 'src')
-rw-r--r--src/pulsecore/card.h7
-rw-r--r--src/pulsecore/client.h3
-rw-r--r--src/pulsecore/core.h3
-rw-r--r--src/pulsecore/device-port.h3
-rw-r--r--src/pulsecore/sink-input.h3
-rw-r--r--src/pulsecore/sink.h4
-rw-r--r--src/pulsecore/source-output.h3
-rw-r--r--src/pulsecore/source.h3
-rw-r--r--src/pulsecore/typedefs.h37
9 files changed, 47 insertions, 19 deletions
diff --git a/src/pulsecore/card.h b/src/pulsecore/card.h
index a72c8c254..30bfc0ecd 100644
--- a/src/pulsecore/card.h
+++ b/src/pulsecore/card.h
@@ -20,8 +20,7 @@
along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
***/
-typedef struct pa_card pa_card;
-
+#include <pulsecore/typedefs.h>
#include <pulse/proplist.h>
#include <pulsecore/core.h>
#include <pulsecore/module.h>
@@ -35,7 +34,7 @@ typedef enum pa_available {
PA_AVAILABLE_YES = 2,
} pa_available_t;
-typedef struct pa_card_profile {
+struct pa_card_profile {
pa_card *card;
char *name;
char *description;
@@ -59,7 +58,7 @@ typedef struct pa_card_profile {
unsigned max_source_channels;
/* .. followed by some implementation specific data */
-} pa_card_profile;
+};
#define PA_CARD_PROFILE_DATA(d) ((void*) ((uint8_t*) d + PA_ALIGN(sizeof(pa_card_profile))))
diff --git a/src/pulsecore/client.h b/src/pulsecore/client.h
index cd55348ed..eb8173d32 100644
--- a/src/pulsecore/client.h
+++ b/src/pulsecore/client.h
@@ -22,8 +22,7 @@
#include <inttypes.h>
-typedef struct pa_client pa_client;
-
+#include <pulsecore/typedefs.h>
#include <pulse/proplist.h>
#include <pulsecore/core.h>
#include <pulsecore/module.h>
diff --git a/src/pulsecore/core.h b/src/pulsecore/core.h
index 6a8affc5a..aefc1eb65 100644
--- a/src/pulsecore/core.h
+++ b/src/pulsecore/core.h
@@ -20,12 +20,11 @@
along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
***/
+#include <pulsecore/typedefs.h>
#include <pulse/mainloop-api.h>
#include <pulse/sample.h>
#include <pulsecore/cpu.h>
-typedef struct pa_core pa_core;
-
/* This is a bitmask that encodes the cause why a sink/source is
* suspended. */
typedef enum pa_suspend_cause {
diff --git a/src/pulsecore/device-port.h b/src/pulsecore/device-port.h
index e3224fd48..85c41fa83 100644
--- a/src/pulsecore/device-port.h
+++ b/src/pulsecore/device-port.h
@@ -22,14 +22,13 @@
along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
***/
-typedef struct pa_device_port pa_device_port;
-
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <inttypes.h>
+#include <pulsecore/typedefs.h>
#include <pulse/def.h>
#include <pulsecore/object.h>
#include <pulsecore/hashmap.h>
diff --git a/src/pulsecore/sink-input.h b/src/pulsecore/sink-input.h
index 457f0187d..86deab278 100644
--- a/src/pulsecore/sink-input.h
+++ b/src/pulsecore/sink-input.h
@@ -23,8 +23,7 @@
#include <inttypes.h>
-typedef struct pa_sink_input pa_sink_input;
-
+#include <pulsecore/typedefs.h>
#include <pulse/sample.h>
#include <pulse/format.h>
#include <pulsecore/memblockq.h>
diff --git a/src/pulsecore/sink.h b/src/pulsecore/sink.h
index 3ae824036..5df109e55 100644
--- a/src/pulsecore/sink.h
+++ b/src/pulsecore/sink.h
@@ -21,11 +21,9 @@
along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
***/
-typedef struct pa_sink pa_sink;
-typedef struct pa_sink_volume_change pa_sink_volume_change;
-
#include <inttypes.h>
+#include <pulsecore/typedefs.h>
#include <pulse/def.h>
#include <pulse/format.h>
#include <pulse/sample.h>
diff --git a/src/pulsecore/source-output.h b/src/pulsecore/source-output.h
index 24555e465..26be4846c 100644
--- a/src/pulsecore/source-output.h
+++ b/src/pulsecore/source-output.h
@@ -22,8 +22,7 @@
#include <inttypes.h>
-typedef struct pa_source_output pa_source_output;
-
+#include <pulsecore/typedefs.h>
#include <pulse/sample.h>
#include <pulse/format.h>
#include <pulsecore/memblockq.h>
diff --git a/src/pulsecore/source.h b/src/pulsecore/source.h
index 9ee078343..19fb41bd5 100644
--- a/src/pulsecore/source.h
+++ b/src/pulsecore/source.h
@@ -21,11 +21,10 @@
along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
***/
-typedef struct pa_source pa_source;
-typedef struct pa_source_volume_change pa_source_volume_change;
#include <inttypes.h>
+#include <pulsecore/typedefs.h>
#include <pulse/def.h>
#include <pulse/format.h>
#include <pulse/sample.h>
diff --git a/src/pulsecore/typedefs.h b/src/pulsecore/typedefs.h
new file mode 100644
index 000000000..3652f8f76
--- /dev/null
+++ b/src/pulsecore/typedefs.h
@@ -0,0 +1,37 @@
+#ifndef footypedefshfoo
+#define footypedefshfoo
+
+/***
+ This file is part of PulseAudio.
+
+ Copyright 2015 Canonical Ltd.
+ Written by David Henningsson <david.henningsson@canonical.com>
+
+ PulseAudio is free software; you can redistribute it and/or modify
+ it under the terms of the GNU Lesser General Public License as published
+ by the Free Software Foundation; either version 2.1 of the License,
+ or (at your option) any later version.
+
+ PulseAudio is distributed in the hope that it will be useful, but
+ WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public License
+ along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
+***/
+
+typedef struct pa_card pa_card;
+typedef struct pa_card_profile pa_card_profile;
+typedef struct pa_client pa_client;
+typedef struct pa_core pa_core;
+typedef struct pa_device_port pa_device_port;
+typedef struct pa_sink pa_sink;
+typedef struct pa_sink_volume_change pa_sink_volume_change;
+typedef struct pa_sink_input pa_sink_input;
+typedef struct pa_source pa_source;
+typedef struct pa_source_volume_change pa_source_volume_change;
+typedef struct pa_source_output pa_source_output;
+
+
+#endif