[Spice-devel] [PATCH spice-server v2 1/2] stream-device: Separate declaration in a separate header
Frediano Ziglio
fziglio at redhat.com
Wed Mar 7 08:26:15 UTC 2018
Move public declaration (stream_device_connect) from char-device.h
to a new stream-device.h.
Add type declaration for StreamDevice.
This allows to use the type outside the implementation file and
make easier to extend the interface without changing char-device.h
header.
Signed-off-by: Frediano Ziglio <fziglio at redhat.com>
---
server/Makefile.am | 1 +
server/char-device.h | 1 -
server/reds.c | 3 ++-
server/stream-device.c | 20 ++++----------------
server/stream-device.h | 49 +++++++++++++++++++++++++++++++++++++++++++++++++
5 files changed, 56 insertions(+), 18 deletions(-)
create mode 100644 server/stream-device.h
diff --git a/server/Makefile.am b/server/Makefile.am
index 38c346c2..a7f6e2a5 100644
--- a/server/Makefile.am
+++ b/server/Makefile.am
@@ -168,6 +168,7 @@ libserver_la_SOURCES = \
stream-channel.c \
stream-channel.h \
stream-device.c \
+ stream-device.h \
sw-canvas.c \
tree.c \
tree.h \
diff --git a/server/char-device.h b/server/char-device.h
index 54a1ef93..dccd576d 100644
--- a/server/char-device.h
+++ b/server/char-device.h
@@ -236,7 +236,6 @@ RedCharDevice *spicevmc_device_connect(RedsState *reds,
uint8_t channel_type);
void spicevmc_device_disconnect(RedsState *reds,
SpiceCharDeviceInstance *char_device);
-RedCharDevice *stream_device_connect(RedsState *reds, SpiceCharDeviceInstance *sin);
SpiceCharDeviceInterface *spice_char_device_get_interface(SpiceCharDeviceInstance *instance);
diff --git a/server/reds.c b/server/reds.c
index a31ed4e9..9660476c 100644
--- a/server/reds.c
+++ b/server/reds.c
@@ -74,6 +74,7 @@
#include "red-client.h"
#include "glib-compat.h"
#include "net-utils.h"
+#include "stream-device.h"
#define REDS_MAX_STAT_NODES 100
@@ -3108,7 +3109,7 @@ static int spice_server_char_device_add_interface(SpiceServer *reds,
if (strcmp(char_device->portname, "org.spice-space.webdav.0") == 0) {
dev_state = spicevmc_device_connect(reds, char_device, SPICE_CHANNEL_WEBDAV);
} else if (strcmp(char_device->portname, "com.redhat.stream.0") == 0) {
- dev_state = stream_device_connect(reds, char_device);
+ dev_state = RED_CHAR_DEVICE(stream_device_connect(reds, char_device));
} else {
dev_state = spicevmc_device_connect(reds, char_device, SPICE_CHANNEL_PORT);
}
diff --git a/server/stream-device.c b/server/stream-device.c
index dc58dce6..fd73e784 100644
--- a/server/stream-device.c
+++ b/server/stream-device.c
@@ -19,25 +19,14 @@
#include <config.h>
#endif
+#include "stream-device.h"
+
#include <spice/stream-device.h>
-#include "char-device.h"
#include "stream-channel.h"
#include "cursor-channel.h"
#include "reds.h"
-#define TYPE_STREAM_DEVICE stream_device_get_type()
-
-#define STREAM_DEVICE(obj) \
- (G_TYPE_CHECK_INSTANCE_CAST((obj), TYPE_STREAM_DEVICE, StreamDevice))
-#define STREAM_DEVICE_CLASS(klass) \
- (G_TYPE_CHECK_CLASS_CAST((klass), TYPE_STREAM_DEVICE, StreamDeviceClass))
-#define STREAM_DEVICE_GET_CLASS(obj) \
- (G_TYPE_INSTANCE_GET_CLASS((obj), TYPE_STREAM_DEVICE, StreamDeviceClass))
-
-typedef struct StreamDevice StreamDevice;
-typedef struct StreamDeviceClass StreamDeviceClass;
-
struct StreamDevice {
RedCharDevice parent;
@@ -64,7 +53,6 @@ struct StreamDeviceClass {
RedCharDeviceClass parent_class;
};
-static GType stream_device_get_type(void) G_GNUC_CONST;
static StreamDevice *stream_device_new(SpiceCharDeviceInstance *sin, RedsState *reds);
G_DEFINE_TYPE(StreamDevice, stream_device, RED_TYPE_CHAR_DEVICE)
@@ -504,7 +492,7 @@ stream_device_stream_queue_stat(void *opaque, const StreamQueueStat *stats G_GNU
}
}
-RedCharDevice *
+StreamDevice *
stream_device_connect(RedsState *reds, SpiceCharDeviceInstance *sin)
{
SpiceCharDeviceInterface *sif;
@@ -516,7 +504,7 @@ stream_device_connect(RedsState *reds, SpiceCharDeviceInstance *sin)
sif->state(sin, 1);
}
- return RED_CHAR_DEVICE(dev);
+ return dev;
}
static void
diff --git a/server/stream-device.h b/server/stream-device.h
new file mode 100644
index 00000000..501629c1
--- /dev/null
+++ b/server/stream-device.h
@@ -0,0 +1,49 @@
+/* -*- Mode: C; c-basic-offset: 4; indent-tabs-mode: nil -*- */
+/*
+ Copyright (C) 2018 Red Hat, Inc.
+
+ This library 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.
+
+ This library 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
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, see <http://www.gnu.org/licenses/>.
+*/
+
+#ifndef STREAM_DEVICE_H
+#define STREAM_DEVICE_H
+
+#include "char-device.h"
+
+G_BEGIN_DECLS
+
+/**
+ * This type it's a RedCharDevice class.
+ * A pointer to StreamDevice can be converted to a RedCharDevice.
+ */
+typedef struct StreamDevice StreamDevice;
+typedef struct StreamDeviceClass StreamDeviceClass;
+
+#define TYPE_STREAM_DEVICE stream_device_get_type()
+
+#define STREAM_DEVICE(obj) \
+ (G_TYPE_CHECK_INSTANCE_CAST((obj), TYPE_STREAM_DEVICE, StreamDevice))
+#define STREAM_DEVICE_CLASS(klass) \
+ (G_TYPE_CHECK_CLASS_CAST((klass), TYPE_STREAM_DEVICE, StreamDeviceClass))
+#define IS_STREAM_DEVICE(obj) \
+ (G_TYPE_CHECK_INSTANCE_TYPE((obj), TYPE_STREAM_DEVICE))
+#define STREAM_DEVICE_GET_CLASS(obj) \
+ (G_TYPE_INSTANCE_GET_CLASS((obj), TYPE_STREAM_DEVICE, StreamDeviceClass))
+
+GType stream_device_get_type(void) G_GNUC_CONST;
+StreamDevice *stream_device_connect(RedsState *reds, SpiceCharDeviceInstance *sin);
+
+G_END_DECLS
+
+#endif /* STREAM_DEVICE_H */
--
2.14.3
More information about the Spice-devel
mailing list