summaryrefslogtreecommitdiffstats
path: root/src/modules/gconf/gconf-helper.c
blob: 72454817572beb676460ec1702841d402c3e1031 (plain)
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
/* $Id$ */

/***
  This file is part of PulseAudio.
 
  PulseAudio 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 License,
  or (at your option) any later version.
 
  PulseAudio 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
  General Public License for more details.
 
  You should have received a copy of the GNU Lesser General Public License
  along with PulseAudio; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
  USA.
***/

#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <string.h>
#include <stdlib.h>
#include <stdio.h>

#include <gconf/gconf-client.h>
#include <glib.h>

#define PA_GCONF_ROOT "/system/pulseaudio"
#define PA_GCONF_PATH_MODULES PA_GCONF_ROOT"/modules"

static void handle_module(GConfClient *client, const char *name) {
    gchar p[1024];
    gboolean enabled, locked;
    int i;

    snprintf(p, sizeof(p), PA_GCONF_PATH_MODULES"/%s/locked", name);
    locked = gconf_client_get_bool(client, p, FALSE);

    if (locked)
        return;

    snprintf(p, sizeof(p), PA_GCONF_PATH_MODULES"/%s/enabled", name);
    enabled = gconf_client_get_bool(client, p, FALSE);
    
    printf("%c%s%c", enabled ? '+' : '-', name, 0);

    if (enabled) {
    
        for (i = 0; i < 10; i++) {
            gchar *n, *a;
            
            snprintf(p, sizeof(p), PA_GCONF_PATH_MODULES"/%s/name%i", name, i);
            if (!(n = gconf_client_get_string(client, p, NULL)) || !*n)
                break;
            
            snprintf(p, sizeof(p), PA_GCONF_PATH_MODULES"/%s/args%i", name, i);
            a = gconf_client_get_string(client, p, NULL);
            
            printf("%s%c%s%c", n, 0, a ? a : "", 0);
            
            g_free(n);
            g_free(a);
        }
        
        printf("%c", 0);
    }
        
    fflush(stdout);
}

static void modules_callback(
        GConfClient* client,
        guint cnxn_id,
        GConfEntry *entry,
        gpointer user_data) {

    const char *n;
    char buf[128];
    
    g_assert(strncmp(entry->key, PA_GCONF_PATH_MODULES"/", sizeof(PA_GCONF_PATH_MODULES)) == 0);

    n = entry->key + sizeof(PA_GCONF_PATH_MODULES);

    g_strlcpy(buf, n, sizeof(buf));
    buf[strcspn(buf, "/")] = 0;

    handle_module(client, buf);
}

int main(int argc, char *argv[]) {
    GMainLoop *g;
    GConfClient *client;
    GSList *modules, *m;

    if (!(client = gconf_client_get_default()))
        goto fail;

    gconf_client_add_dir(client, PA_GCONF_ROOT, GCONF_CLIENT_PRELOAD_RECURSIVE, NULL);
    gconf_client_notify_add(client, PA_GCONF_PATH_MODULES, modules_callback, NULL, NULL, NULL);

    modules = gconf_client_all_dirs(client, PA_GCONF_PATH_MODULES, NULL);

    for (m = modules; m; m = m->next) {
        char *e = strrchr(m->data, '/');
        handle_module(client, e ? e+1 : m->data);
    }
    
    g_slist_free(modules);

    /* Signal the parent that we are now initialized */
    printf("!");
    fflush(stdout);
    
    g = g_main_loop_new(NULL, FALSE);
    g_main_loop_run(g);
    g_main_loop_unref(g);
    
    g_object_unref(G_OBJECT(client));

    return 0;

fail:
    return 1;
}