From 4018fe02a4eaa1534e66d952ae0cb0402a50dfe6 Mon Sep 17 00:00:00 2001 From: Takashi Sakamoto Date: Wed, 20 Nov 2019 22:10:39 +0900 Subject: [PATCH] seq: queue_timer: add abstract object to represent timer attached to queue Signed-off-by: Takashi Sakamoto --- src/seq/alsaseq.map | 2 ++ src/seq/meson.build | 2 ++ src/seq/queue-timer.c | 14 ++++++++++++ src/seq/queue-timer.h | 47 +++++++++++++++++++++++++++++++++++++++ tests/alsaseq-queue-timer | 18 +++++++++++++++ tests/meson.build | 1 + 6 files changed, 84 insertions(+) create mode 100644 src/seq/queue-timer.c create mode 100644 src/seq/queue-timer.h create mode 100644 tests/alsaseq-queue-timer diff --git a/src/seq/alsaseq.map b/src/seq/alsaseq.map index da80e11..01b58d7 100644 --- a/src/seq/alsaseq.map +++ b/src/seq/alsaseq.map @@ -152,6 +152,8 @@ ALSA_GOBJECT_0_0_0 { "alsaseq_queue_tempo_new"; "alsaseq_queue_tempo_get_skew"; "alsaseq_queue_tempo_set_skew"; + + "alsaseq_queue_timer_get_type"; local: *; }; diff --git a/src/seq/meson.build b/src/seq/meson.build index fe0e78a..1768eea 100644 --- a/src/seq/meson.build +++ b/src/seq/meson.build @@ -29,6 +29,7 @@ sources = files( 'queue-info.c', 'queue-status.c', 'queue-tempo.c', + 'queue-timer.c', ) headers = files( @@ -52,6 +53,7 @@ headers = files( 'queue-info.h', 'queue-status.h', 'queue-tempo.h', + 'queue-timer.h', ) privates = files( diff --git a/src/seq/queue-timer.c b/src/seq/queue-timer.c new file mode 100644 index 0000000..763ca9c --- /dev/null +++ b/src/seq/queue-timer.c @@ -0,0 +1,14 @@ +// SPDX-License-Identifier: LGPL-3.0-or-later +#include "queue-timer.h" + +G_DEFINE_ABSTRACT_TYPE(ALSASeqQueueTimer, alsaseq_queue_timer, G_TYPE_OBJECT) + +static void alsaseq_queue_timer_class_init(ALSASeqQueueTimerClass *klass) +{ + return; +} + +static void alsaseq_queue_timer_init(ALSASeqQueueTimer *self) +{ + return; +} diff --git a/src/seq/queue-timer.h b/src/seq/queue-timer.h new file mode 100644 index 0000000..e7b8212 --- /dev/null +++ b/src/seq/queue-timer.h @@ -0,0 +1,47 @@ +// SPDX-License-Identifier: LGPL-3.0-or-later +#ifndef __ALSA_GOBJECT_ALSASEQ_QUEUE_TIMER__H__ +#define __ALSA_GOBJECT_ALSASEQ_QUEUE_TIMER__H__ + +#include +#include + +G_BEGIN_DECLS + +#define ALSASEQ_TYPE_QUEUE_TIMER (alsaseq_queue_timer_get_type()) + +#define ALSASEQ_QUEUE_TIMER(obj) \ + (G_TYPE_CHECK_INSTANCE_CAST((obj), \ + ALSASEQ_TYPE_QUEUE_TIMER, \ + ALSASeqQueueTimer)) +#define ALSASEQ_IS_QUEUE_TIMER(obj) \ + (G_TYPE_CHECK_INSTANCE_TYPE((obj), \ + ALSASEQ_TYPE_QUEUE_TIMER)) + +#define ALSASEQ_QUEUE_TIMER_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_CAST((klass), \ + ALSASEQ_TYPE_QUEUE_TIMER, \ + ALSASeqQueueTimerClass)) +#define ALSASEQ_IS_QUEUE_TIMER_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_TYPE((klass), \ + ALSASEQ_TYPE_QUEUE_TIMER)) +#define ALSASEQ_QUEUE_TIMER_GET_CLASS(obj) \ + (G_TYPE_INSTANCE_GET_CLASS((obj), \ + ALSASEQ_TYPE_QUEUE_TIMER, \ + ALSASeqQueueTimerClass)) + +typedef struct _ALSASeqQueueTimer ALSASeqQueueTimer; +typedef struct _ALSASeqQueueTimerClass ALSASeqQueueTimerClass; + +struct _ALSASeqQueueTimer { + GObject parent_instance; +}; + +struct _ALSASeqQueueTimerClass { + GObjectClass parent_class; +}; + +GType alsaseq_queue_timer_get_type() G_GNUC_CONST; + +G_END_DECLS + +#endif diff --git a/tests/alsaseq-queue-timer b/tests/alsaseq-queue-timer new file mode 100644 index 0000000..673c0dd --- /dev/null +++ b/tests/alsaseq-queue-timer @@ -0,0 +1,18 @@ +#!/usr/bin/env python3 + +from sys import exit +from errno import ENXIO + +from helper import test + +import gi +gi.require_version('ALSASeq', '0.0') +from gi.repository import ALSASeq + +target = ALSASeq.QueueTimer +props = () +methods = () +signals = () + +if not test(target, props, methods, signals): + exit(ENXIO) diff --git a/tests/meson.build b/tests/meson.build index e4f5f19..aa42c9e 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -42,6 +42,7 @@ tests = { 'alsaseq-queue-info', 'alsaseq-queue-status', 'alsaseq-queue-tempo', + 'alsaseq-queue-timer', ], } -- 2.47.3