From 2ba76cf04e2ab988f059ba4dfef03147116b9224 Mon Sep 17 00:00:00 2001 From: Takashi Sakamoto Date: Mon, 18 Nov 2019 13:22:44 +0900 Subject: [PATCH] ctl: elem_info_int: add object to represent information for integer type element --- src/ctl/alsactl.map | 2 ++ src/ctl/elem-info-int.c | 14 +++++++++++ src/ctl/elem-info-int.h | 47 +++++++++++++++++++++++++++++++++++++ src/ctl/meson.build | 2 ++ tests/alsactl-elem-info-int | 18 ++++++++++++++ tests/meson.build | 1 + 6 files changed, 84 insertions(+) create mode 100644 src/ctl/elem-info-int.c create mode 100644 src/ctl/elem-info-int.h create mode 100644 tests/alsactl-elem-info-int diff --git a/src/ctl/alsactl.map b/src/ctl/alsactl.map index ae2a381..f828f09 100644 --- a/src/ctl/alsactl.map +++ b/src/ctl/alsactl.map @@ -34,6 +34,8 @@ ALSA_GOBJECT_0_0_0 { "alsactl_elem_info_bool_get_type"; "alsactl_elem_info_bool_new"; + + "alsactl_elem_info_int_get_type"; local: *; }; diff --git a/src/ctl/elem-info-int.c b/src/ctl/elem-info-int.c new file mode 100644 index 0000000..64ac570 --- /dev/null +++ b/src/ctl/elem-info-int.c @@ -0,0 +1,14 @@ +// SPDX-License-Identifier: LGPL-3.0-or-later +#include "elem-info-int.h" + +G_DEFINE_TYPE(ALSACtlElemInfoInt, alsactl_elem_info_int, ALSACTL_TYPE_ELEM_INFO) + +static void alsactl_elem_info_int_class_init(ALSACtlElemInfoIntClass *klass) +{ + return; +} + +static void alsactl_elem_info_int_init(ALSACtlElemInfoInt *self) +{ + return; +} diff --git a/src/ctl/elem-info-int.h b/src/ctl/elem-info-int.h new file mode 100644 index 0000000..433fabd --- /dev/null +++ b/src/ctl/elem-info-int.h @@ -0,0 +1,47 @@ +// SPDX-License-Identifier: LGPL-3.0-or-later +#ifndef __ALSA_GOBJECT_ALSACTL_ELEM_INFO_INT__H__ +#define __ALSA_GOBJECT_ALSACTL_ELEM_INFO_INT__H__ + +#include +#include + +#include + +#define ALSACTL_TYPE_ELEM_INFO_INT (alsactl_elem_info_int_get_type()) + +#define ALSACTL_ELEM_INFO_INT(obj) \ + (G_TYPE_CHECK_INSTANCE_CAST((obj), \ + ALSACTL_TYPE_ELEM_INFO_INT, \ + ALSACtlElemInfoInt)) +#define ALSACTL_IS_ELEM_INFO_INT(obj) \ + (G_TYPE_CHECK_INSTANCE_TYPE((obj), \ + ALSACTL_TYPE_ELEM_INFO_INT)) + +#define ALSACTL_ELEM_INFO_INT_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_CAST((klass), \ + ALSACTL_TYPE_ELEM_INFO_INT, \ + ALSACtlElemInfoIntClass)) +#define ALSACTL_IS_ELEM_INFO_INT_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_TYPE((klass), \ + ALSACTL_TYPE_ELEM_INFO_INT)) +#define ALSACTL_ELEM_INFO_INT_GET_CLASS(obj) \ + (G_TYPE_INSTANCE_GET_CLASS((obj), \ + ALSACTL_TYPE_ELEM_INFO_INT, \ + ALSACtlElemInfoIntClass)) + +typedef struct _ALSACtlElemInfoInt ALSACtlElemInfoInt; +typedef struct _ALSACtlElemInfoIntClass ALSACtlElemInfoIntClass; + +struct _ALSACtlElemInfoInt { + ALSACtlElemInfo parent_instance; +}; + +struct _ALSACtlElemInfoIntClass { + ALSACtlElemInfoClass parent_class; +}; + +GType alsactl_elem_info_int_get_type(void) G_GNUC_CONST; + +G_END_DECLS + +#endif diff --git a/src/ctl/meson.build b/src/ctl/meson.build index fe2f630..f4f6b01 100644 --- a/src/ctl/meson.build +++ b/src/ctl/meson.build @@ -15,6 +15,7 @@ sources = files( 'elem-id.c', 'elem-info.c', 'elem-info-bool.c', + 'elem-info-int.c', ) headers = files( @@ -24,6 +25,7 @@ headers = files( 'elem-id.h', 'elem-info.h', 'elem-info-bool.h', + 'elem-info-int.h', ) privates = files( diff --git a/tests/alsactl-elem-info-int b/tests/alsactl-elem-info-int new file mode 100644 index 0000000..168e2e9 --- /dev/null +++ b/tests/alsactl-elem-info-int @@ -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('ALSACtl', '0.0') +from gi.repository import ALSACtl + +target = ALSACtl.ElemInfoInt() +props = () +methods = () +signals = () + +if not test(target, props, methods, signals): + exit(ENXIO) diff --git a/tests/meson.build b/tests/meson.build index 5a3e07c..157164c 100644 --- a/tests/meson.build +++ b/tests/meson.build @@ -8,6 +8,7 @@ tests = { 'alsactl-card-info', 'alsactl-elem-info', 'alsactl-elem-info-bool', + 'alsactl-elem-info-int', ], } -- 2.47.3