add emacs indentation variables to source files in line with current vim settings
[monky] / src / audacious.h
1 /* -*- mode: c; c-basic-offset: 4; tab-width: 4; indent-tabs-mode: t -*-
2  *
3  * audacious.h:  conky support for audacious music player
4  *
5  * Copyright (C) 2005-2007 Philip Kovacs pkovacs@users.sourceforge.net
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with this library; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301
20  * USA.
21  *
22  * vim: ts=4 sw=4 noet ai cindent syntax=c
23  *
24  */
25
26 #ifndef AUDACIOUS_H
27 #define AUDACIOUS_H
28
29 #include "timed_thread.h"
30
31 enum _audacious_items {
32         AUDACIOUS_STATUS = 0,
33         AUDACIOUS_TITLE,
34         AUDACIOUS_LENGTH,
35         AUDACIOUS_LENGTH_SECONDS,
36         AUDACIOUS_POSITION,
37         AUDACIOUS_POSITION_SECONDS,
38         AUDACIOUS_BITRATE,
39         AUDACIOUS_FREQUENCY,
40         AUDACIOUS_CHANNELS,
41         AUDACIOUS_FILENAME,
42         AUDACIOUS_PLAYLIST_LENGTH,
43         AUDACIOUS_PLAYLIST_POSITION,
44         AUDACIOUS_MAIN_VOLUME,
45 };
46
47 /* 12 slots for the audacious values */
48 typedef char audacious_t[13][128];
49
50 /* type for data exchange with main thread */
51 typedef struct audacious_s {
52   audacious_t items;  /* e.g. items[AUDACIOUS_STATUS] */
53   int max_title_len;  /* e.g. ${audacious_title 50} */
54   timed_thread *p_timed_thread;
55 } AUDACIOUS_S;
56
57 /* create a worker thread for audacious media player status */
58 int create_audacious_thread(void);
59
60 /* destroy audacious media player worker thread */
61 int destroy_audacious_thread(void);
62
63 /* Service routine for the conky main thread */
64 void update_audacious(void);
65
66 /* Thread functions */
67 void *audacious_thread_func(void *);
68
69 #endif