1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
/*
* Copyright (C) 2014 Michal Ratajsky <michal.ratajsky@gmail.com>
*
* 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 of the licence, 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 MATEMIXER_ENUMS_H
#define MATEMIXER_ENUMS_H
/*
* GTypes are not generated by glib-mkenums, see:
* https://bugzilla.gnome.org/show_bug.cgi?id=621942
*/
typedef enum {
MATE_MIXER_STATE_IDLE = 0,
MATE_MIXER_STATE_CONNECTING,
MATE_MIXER_STATE_READY,
MATE_MIXER_STATE_FAILED,
MATE_MIXER_STATE_UNKNOWN
} MateMixerState;
/**
* MateMixerBackendType:
* @MATE_MIXER_BACKEND_UNKNOWN:
* Unknown or undefined backend type.
* @MATE_MIXER_BACKEND_PULSEAUDIO:
* PulseAudio sound system backend. It has the highest priority and
* will be the first one to try unless you select a specific backend
* to connect to.
* @MATE_MIXER_BACKEND_NULL:
* Fallback backend which never fails to initialize, but provides no
* functionality. This backend has the lowest priority and will be used
* if you do not select a specific backend to connect to and all the
* "real" backends fail to initialize.
*/
typedef enum {
MATE_MIXER_BACKEND_UNKNOWN = 0,
MATE_MIXER_BACKEND_PULSEAUDIO,
MATE_MIXER_BACKEND_NULL
} MateMixerBackendType;
typedef enum { /*< flags >*/
MATE_MIXER_PORT_NO_FLAGS = 0,
MATE_MIXER_PORT_AVAILABLE = 1 << 0,
MATE_MIXER_PORT_INPUT = 1 << 1,
MATE_MIXER_PORT_OUTPUT = 1 << 2
} MateMixerPortFlags;
typedef enum { /*< flags >*/
MATE_MIXER_STREAM_NO_FLAGS = 0,
MATE_MIXER_STREAM_INPUT = 1 << 0,
MATE_MIXER_STREAM_OUTPUT = 1 << 1,
MATE_MIXER_STREAM_CLIENT = 1 << 2,
MATE_MIXER_STREAM_APPLICATION = 1 << 3,
MATE_MIXER_STREAM_EVENT = 1 << 4,
MATE_MIXER_STREAM_HAS_MUTE = 1 << 5,
MATE_MIXER_STREAM_HAS_VOLUME = 1 << 6,
MATE_MIXER_STREAM_HAS_DECIBEL_VOLUME = 1 << 7,
MATE_MIXER_STREAM_HAS_FLAT_VOLUME = 1 << 8,
MATE_MIXER_STREAM_HAS_MONITOR = 1 << 9,
MATE_MIXER_STREAM_CAN_BALANCE = 1 << 10,
MATE_MIXER_STREAM_CAN_FADE = 1 << 11,
MATE_MIXER_STREAM_CAN_SET_VOLUME = 1 << 12,
MATE_MIXER_STREAM_CAN_SUSPEND = 1 << 13
} MateMixerStreamFlags;
typedef enum {
MATE_MIXER_STREAM_UNKNOWN_STATE,
MATE_MIXER_STREAM_RUNNING,
MATE_MIXER_STREAM_IDLE,
MATE_MIXER_STREAM_SUSPENDED
} MateMixerStreamState;
typedef enum {
MATE_MIXER_CHANNEL_UNKNOWN_POSITION,
MATE_MIXER_CHANNEL_MONO,
MATE_MIXER_CHANNEL_FRONT_LEFT,
MATE_MIXER_CHANNEL_FRONT_RIGHT,
MATE_MIXER_CHANNEL_FRONT_CENTER,
MATE_MIXER_CHANNEL_LFE,
MATE_MIXER_CHANNEL_BACK_LEFT,
MATE_MIXER_CHANNEL_BACK_RIGHT,
MATE_MIXER_CHANNEL_FRONT_LEFT_CENTER,
MATE_MIXER_CHANNEL_FRONT_RIGHT_CENTER,
MATE_MIXER_CHANNEL_BACK_CENTER,
MATE_MIXER_CHANNEL_SIDE_LEFT,
MATE_MIXER_CHANNEL_SIDE_RIGHT,
MATE_MIXER_CHANNEL_TOP_FRONT_LEFT,
MATE_MIXER_CHANNEL_TOP_FRONT_RIGHT,
MATE_MIXER_CHANNEL_TOP_FRONT_CENTER,
MATE_MIXER_CHANNEL_TOP_CENTER,
MATE_MIXER_CHANNEL_TOP_BACK_LEFT,
MATE_MIXER_CHANNEL_TOP_BACK_RIGHT,
MATE_MIXER_CHANNEL_TOP_BACK_CENTER
} MateMixerChannelPosition;
#endif /* MATEMIXER_ENUMS_H */
|