More debugging
[gregoa/zavai.git] / src / zavai.vala
1 /*
2  * zavai - simple interface to the OpenMoko (or to the FSO stack)
3  *
4  * Copyright (C) 2009  Enrico Zini <enrico@enricozini.org>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  */
20
21 using GLib;
22
23 //string VERSION = "0.1";
24
25 void on_alarm()
26 {
27         stderr.printf("RETURNED\n");
28 }
29
30 static int main (string[] args) {
31         Gtk.init (ref args);
32
33         // parser = Parser(usage="usage: %prog [options]",
34         //                 version="%prog "+ VERSION,
35         //                 description="Simple interactive interface for the OpenMoko")
36         // parser.add_option("-v", "--verbose", action="store_true", help="verbose mode")
37         // 
38         // (opts, args) = parser.parse_args()
39         // 
40         // if not opts.verbose:
41         //     zavai.set_quiet()
42         // 
43         // # Read configuration
44         // zavai.info("Loading configuration")
45         // conf = zavai.Config()
46         // 
47         // # Set up dbus
48         // dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)
49         // dbus_system_bus = dbus.SystemBus()
50
51         // Set up zavai
52         zavai.config = new zavai.Config();
53         zavai.registry = new zavai.Registry();
54         zavai.app = new zavai.Zavai();
55
56         zavai.registry.register_resource("zavai", zavai.app);
57
58         zavai.gps.init();
59
60         zavai.registry.register_menu("menu.main", new zavai.Menu("Main menu"));
61
62         // TODO: register the rest of menus here
63         zavai.ui.gps.init();
64         zavai.ui.kbd.init();
65         zavai.ui.wm.init();
66         zavai.ui.debug.init();
67
68         zavai.app.show_applet("menu.main");
69
70         // # Register main factories
71         // registry.register(conf, "conf")
72         // registry.register_factory(zavai.GPX, "gpx")
73         // registry.register_factory(zavai.Audio, "audio")
74
75         // # Load plugins
76         // zavai.info("Loading plugins")
77         // for p in zavai.load_plugins(nick="zavai"):
78         //     try:
79         //         p.init(conf = conf, registry = registry)
80         //     except Exception, e:
81         //         print >>sys.stderr, "Exception caught loading plugin %s: skipping plugin" % p
82         //         print >>sys.stderr, "Exception details:"
83         //         import traceback
84         //         details = traceback.format_exc()
85         //         print >>sys.stderr, "\t"+details.rstrip().replace("\n", "\n\t")
86
87         // # Shutdown the main loop on SIGINT
88         // def on_kill(signum, frame):
89         //     gtk.main_quit()
90         // signal.signal(signal.SIGINT, on_kill)
91         // signal.signal(signal.SIGTERM, on_kill)
92
93         // zavai.info("Starting")
94         // app = registry.resource("app")
95         // app.connect("destroy", gtk.main_quit)
96         // app.run()
97
98 /*
99         dynamic DBus.Object otime = zavai.registry.sbus.get_object(
100                         "org.freesmartphone.otimed",
101                         "/org/freesmartphone/Time/Alarm",
102                         "org.freesmartphone.Time.Alarm");
103
104         otime.ClearAlarm();
105         otime.SetAlarm(time_t() + 10);
106
107         dynamic DBus.Object notification = zavai.registry.sbus.get_object(
108                         "org.freesmartphone",
109                         "org/freesmartphone/Notification",
110                         "org.freesmartphone.Notification");
111         notification.Alarm += on_alarm;
112 */
113
114         zavai.app.run();
115         Gtk.main();
116         //registry.loop.run();
117
118         // zavai.info("Shutting down")
119         zavai.registry.shutdown();
120
121         return 0;
122 }