31 |
#include "custom_rating_renderer.h" |
#include "custom_rating_renderer.h" |
32 |
#include "custom_type_renderer.h" |
#include "custom_type_renderer.h" |
33 |
|
|
34 |
|
#ifdef ESPEAK |
35 |
|
#include <espeak/speak_lib.h> |
36 |
|
#endif |
37 |
|
|
38 |
#ifdef USE_MAEMO |
#ifdef USE_MAEMO |
39 |
#include <hildon/hildon-banner.h> |
#include <hildon/hildon-banner.h> |
40 |
#if MAEMO_VERSION_MAJOR >= 5 |
#if MAEMO_VERSION_MAJOR >= 5 |
260 |
appdata_t *appdata; |
appdata_t *appdata; |
261 |
GtkTreePath *path; |
GtkTreePath *path; |
262 |
gboolean done; |
gboolean done; |
263 |
} cachelist_expose_t; |
} cachelist_context_t; |
264 |
|
|
265 |
static gboolean cachelist_expose(GtkWidget *widget, GdkEventExpose *event, |
static gboolean cachelist_expose(GtkWidget *widget, GdkEventExpose *event, |
266 |
gpointer user_data) { |
gpointer user_data) { |
267 |
cachelist_expose_t *ce = (cachelist_expose_t*)user_data; |
cachelist_context_t *ce = (cachelist_context_t*)user_data; |
268 |
|
|
269 |
if(event->type == GDK_EXPOSE) { |
if(event->type == GDK_EXPOSE) { |
270 |
if(ce->path && !ce->done) { |
if(ce->path && !ce->done) { |
279 |
} |
} |
280 |
|
|
281 |
static void cachelist_destroy(GtkWidget *widget, gpointer user_data) { |
static void cachelist_destroy(GtkWidget *widget, gpointer user_data) { |
|
cachelist_expose_t *ce = (cachelist_expose_t*)user_data; |
|
282 |
|
|
283 |
printf("cachelist timer removed\n"); |
guint handler_id = |
284 |
g_assert(ce->appdata->cachelist_handler_id); |
(guint)g_object_get_data(G_OBJECT(user_data), "handler_id"); |
285 |
gtk_timeout_remove(ce->appdata->cachelist_handler_id); |
|
286 |
ce->appdata->cachelist_handler_id = 0; |
if(handler_id) { |
287 |
|
gtk_timeout_remove(handler_id); |
288 |
|
g_object_set_data(G_OBJECT(user_data), "handler_id", NULL); |
289 |
|
|
290 |
|
printf("cachelist timer removed\n"); |
291 |
|
} |
292 |
|
|
293 |
|
gpointer *ce = |
294 |
|
g_object_get_data(G_OBJECT(user_data), "ce"); |
295 |
|
g_assert(ce); |
296 |
|
|
297 |
free(user_data); |
free(ce); |
298 |
} |
} |
299 |
|
|
300 |
#define CACHELIST_UPDATE_TIMEOUT (30000) |
#define CACHELIST_UPDATE_TIMEOUT (30000) |
303 |
cache_t *sel_cache); |
cache_t *sel_cache); |
304 |
|
|
305 |
void cachelist_redraw(appdata_t *appdata) { |
void cachelist_redraw(appdata_t *appdata) { |
306 |
|
printf("redrawing cachelist\n"); |
307 |
|
|
308 |
if(!appdata->cur_view) { |
if(!appdata->cur_view) { |
309 |
printf("cachelist redraw: no active view\n"); |
printf("cachelist redraw: no active view\n"); |
310 |
return; |
return; |
320 |
} |
} |
321 |
|
|
322 |
if(redraw) { |
if(redraw) { |
|
GtkWidget *container = appdata->vbox; |
|
|
|
|
323 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
324 |
HildonWindowStack *stack = hildon_window_stack_get_default(); |
HildonWindowStack *stack = hildon_window_stack_get_default(); |
325 |
container = hildon_window_stack_peek(stack); |
GtkWidget *container = hildon_window_stack_peek(stack); |
326 |
|
#else |
327 |
|
GtkWidget *container = appdata->vbox; |
328 |
#endif |
#endif |
329 |
|
|
330 |
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
340 |
} |
} |
341 |
|
|
342 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
343 |
if(container != appdata->vbox) |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
344 |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
#else |
345 |
else |
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
346 |
#endif |
#endif |
|
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
|
347 |
|
|
348 |
gtk_widget_show_all(container); |
gtk_widget_show_all(container); |
349 |
} |
} |
351 |
|
|
352 |
|
|
353 |
static gboolean cachelist_update(gpointer data) { |
static gboolean cachelist_update(gpointer data) { |
354 |
|
appdata_t *appdata = |
355 |
|
(appdata_t*)g_object_get_data(G_OBJECT(data), "appdata"); |
356 |
|
g_assert(appdata); |
357 |
|
|
358 |
printf("cachelist timer fired!\n"); |
printf("cachelist timer fired!\n"); |
359 |
|
|
360 |
appdata_t *appdata = (appdata_t*)data; |
/* check if the widget the timer fired for is the currently */ |
361 |
|
/* visible one (if a search result is being shown, a cachlist */ |
362 |
|
/* may also be present below it) */ |
363 |
|
if(appdata->cur_view != data) { |
364 |
|
printf("-> widget is not the one currently on top, don't redraw\n"); |
365 |
|
return TRUE; |
366 |
|
} |
367 |
|
|
368 |
if(appdata->cur_cache) |
if(appdata->cur_cache) |
369 |
return TRUE; |
return TRUE; |
376 |
|
|
377 |
if(appdata->cachelist_update) |
if(appdata->cachelist_update) |
378 |
cachelist_redraw(appdata); |
cachelist_redraw(appdata); |
379 |
|
else |
380 |
|
printf("update disabled\n"); |
381 |
|
|
382 |
return TRUE; |
return TRUE; |
383 |
} |
} |
384 |
|
|
385 |
static void cachelist_timer_reset(appdata_t *appdata) { |
static void cachelist_timer_reset(GtkWidget *widget) { |
386 |
|
guint handler_id = |
387 |
|
(guint)g_object_get_data(G_OBJECT(widget), "handler_id"); |
388 |
|
g_assert(handler_id); |
389 |
|
|
390 |
|
appdata_t *appdata = |
391 |
|
(appdata_t*)g_object_get_data(G_OBJECT(widget), "appdata"); |
392 |
|
g_assert(appdata); |
393 |
|
|
394 |
printf("cachelist timer reset\n"); |
printf("cachelist timer reset\n"); |
395 |
g_assert(appdata->cachelist_handler_id); |
gtk_timeout_remove(handler_id); |
396 |
gtk_timeout_remove(appdata->cachelist_handler_id); |
g_object_set_data(G_OBJECT(widget), "handler_id", (gpointer) |
397 |
appdata->cachelist_handler_id = |
gtk_timeout_add(CACHELIST_UPDATE_TIMEOUT, cachelist_update, widget)); |
|
gtk_timeout_add(CACHELIST_UPDATE_TIMEOUT, cachelist_update, appdata); |
|
398 |
} |
} |
399 |
|
|
400 |
static gboolean cachelist_update_reset0(GtkWidget *widget, |
static gboolean cachelist_update_reset0(GtkWidget *widget, |
401 |
GdkEventButton *event, |
GdkEventButton *event, |
402 |
gpointer user_data) { |
gpointer user_data) { |
403 |
cachelist_timer_reset((appdata_t*)user_data); |
cachelist_timer_reset(GTK_WIDGET(user_data)); |
404 |
return FALSE; |
return FALSE; |
405 |
} |
} |
406 |
|
|
407 |
static void cachelist_update_reset1(GtkAdjustment *adj, |
static void cachelist_update_reset1(GtkAdjustment *adj, |
408 |
gpointer user_data) { |
gpointer user_data) { |
409 |
cachelist_timer_reset((appdata_t*)user_data); |
cachelist_timer_reset(GTK_WIDGET(user_data)); |
410 |
} |
} |
411 |
|
|
412 |
|
static gboolean on_cachelist_focus_in(GtkWidget *widget, GdkEventFocus *event, |
413 |
|
gpointer data) { |
414 |
|
|
415 |
|
|
416 |
|
/* we don't want a runnign timer yet */ |
417 |
|
if(!g_object_get_data(G_OBJECT(data), "handler_id")) { |
418 |
|
printf("focus received: restarting cachelist timer\n"); |
419 |
|
|
420 |
|
appdata_t *appdata = |
421 |
|
(appdata_t*)g_object_get_data(G_OBJECT(data), "appdata"); |
422 |
|
g_assert(appdata); |
423 |
|
|
424 |
|
g_object_set_data(G_OBJECT(data), "handler_id", (gpointer) |
425 |
|
gtk_timeout_add(CACHELIST_UPDATE_TIMEOUT, cachelist_update, data)); |
426 |
|
} |
427 |
|
|
428 |
|
return FALSE; |
429 |
|
} |
430 |
|
|
431 |
|
static gboolean on_cachelist_focus_out(GtkWidget *widget, GdkEventFocus *event, |
432 |
|
gpointer data) { |
433 |
|
|
434 |
|
guint handler_id = |
435 |
|
(guint)g_object_get_data(G_OBJECT(data), "handler_id"); |
436 |
|
g_assert(handler_id); |
437 |
|
|
438 |
|
gtk_timeout_remove(handler_id); |
439 |
|
g_object_set_data(G_OBJECT(data), "handler_id", NULL); |
440 |
|
|
441 |
|
printf("focus lost: cachelist timer removed\n"); |
442 |
|
|
443 |
|
return FALSE; |
444 |
|
} |
445 |
|
|
446 |
static GtkWidget *cachelist_create(appdata_t *appdata, gpx_t *gpx, |
static GtkWidget *cachelist_create(appdata_t *appdata, gpx_t *gpx, |
447 |
cache_t *sel_cache) { |
cache_t *sel_cache) { |
448 |
GtkCellRenderer *renderer; |
GtkCellRenderer *renderer; |
588 |
g_signal_connect(view, "row-activated", |
g_signal_connect(view, "row-activated", |
589 |
(GCallback)cachelist_view_onRowActivated, appdata); |
(GCallback)cachelist_view_onRowActivated, appdata); |
590 |
|
|
591 |
cachelist_expose_t *ce = malloc(sizeof(cachelist_expose_t)); |
cachelist_context_t *ce = g_new0(cachelist_context_t, 1); |
592 |
ce->appdata = appdata; |
ce->appdata = appdata; |
593 |
ce->path = path; |
ce->path = path; |
594 |
ce->done = FALSE; |
ce->done = FALSE; |
595 |
|
|
596 |
g_signal_connect(view, "expose-event", |
g_signal_connect(view, "expose-event", |
597 |
(GCallback)cachelist_expose, ce); |
(GCallback)cachelist_expose, ce); |
|
g_signal_connect(view, "destroy", |
|
|
(GCallback)cachelist_destroy, ce); |
|
598 |
|
|
599 |
/* put this inside a scrolled view */ |
/* put this inside a scrolled view */ |
600 |
#ifndef USE_PANNABLE_AREA |
#ifndef USE_PANNABLE_AREA |
601 |
GtkWidget *scrolled_window = gtk_scrolled_window_new (NULL, NULL); |
GtkWidget *container = gtk_scrolled_window_new (NULL, NULL); |
602 |
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled_window), |
gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(container), |
603 |
GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC); |
GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC); |
604 |
gtk_container_add(GTK_CONTAINER(scrolled_window), view); |
gtk_container_add(GTK_CONTAINER(container), view); |
605 |
#else |
#else |
606 |
GtkWidget *pannable_area = hildon_pannable_area_new(); |
GtkWidget *container = hildon_pannable_area_new(); |
607 |
|
gtk_container_add(GTK_CONTAINER(container), view); |
|
gtk_container_add(GTK_CONTAINER(pannable_area), view); |
|
608 |
#endif |
#endif |
609 |
|
|
610 |
/* add a timer for automatic update */ |
g_signal_connect(view, "destroy", |
611 |
g_assert(!appdata->cachelist_handler_id); |
(GCallback)cachelist_destroy, container); |
|
appdata->cachelist_handler_id = |
|
|
gtk_timeout_add(CACHELIST_UPDATE_TIMEOUT, cachelist_update, appdata); |
|
612 |
|
|
613 |
/* update timer is being reset if the user scrolls or selects */ |
/* update timer is being reset if the user scrolls or selects */ |
614 |
g_signal_connect(view, "button-press-event", |
g_signal_connect(view, "button-press-event", |
615 |
(GCallback)cachelist_update_reset0, appdata); |
(GCallback)cachelist_update_reset0, container); |
616 |
|
|
617 |
|
/* add a timer for automatic update */ |
618 |
|
g_object_set_data(G_OBJECT(container), "handler_id", (gpointer) |
619 |
|
gtk_timeout_add(CACHELIST_UPDATE_TIMEOUT, cachelist_update, container)); |
620 |
|
|
621 |
|
printf("cachelist timer created\n"); |
622 |
|
|
623 |
|
g_object_set_data(G_OBJECT(container), "appdata", (gpointer)appdata); |
624 |
|
|
625 |
|
g_object_set_data(G_OBJECT(container), "ce", (gpointer)ce); |
626 |
|
|
627 |
|
/* the timer is removed and re-enabled on every focus change event */ |
628 |
|
/* for the main top window */ |
629 |
|
// GtkWidget *root = gtk_widget_get_toplevel(GTK_WIDGET(button))) |
630 |
|
|
631 |
|
g_signal_connect(G_OBJECT(view), "focus-in-event", |
632 |
|
G_CALLBACK(on_cachelist_focus_in), container); |
633 |
|
|
634 |
|
g_signal_connect(G_OBJECT(view), "focus-out-event", |
635 |
|
G_CALLBACK(on_cachelist_focus_out), container); |
636 |
|
|
637 |
#ifndef USE_PANNABLE_AREA |
#ifndef USE_PANNABLE_AREA |
638 |
g_signal_connect(gtk_scrolled_window_get_vadjustment( |
g_signal_connect(gtk_scrolled_window_get_vadjustment( |
639 |
GTK_SCROLLED_WINDOW(scrolled_window)), |
GTK_SCROLLED_WINDOW(container)), |
640 |
"value-changed", |
"value-changed", |
641 |
(GCallback)cachelist_update_reset1, appdata); |
(GCallback)cachelist_update_reset1, container); |
|
|
|
|
return scrolled_window; |
|
642 |
#else |
#else |
643 |
g_signal_connect(hildon_pannable_area_get_vadjustment( |
g_signal_connect(hildon_pannable_area_get_vadjustment( |
644 |
HILDON_PANNABLE_AREA(pannable_area)), |
HILDON_PANNABLE_AREA(container)), |
645 |
"value-changed", |
"value-changed", |
646 |
(GCallback)cachelist_update_reset1, appdata); |
(GCallback)cachelist_update_reset1, container); |
|
|
|
647 |
|
|
|
return pannable_area; |
|
648 |
#endif |
#endif |
649 |
|
return container; |
650 |
} |
} |
651 |
|
|
652 |
#ifndef USE_MAEMO |
#ifndef USE_MAEMO |
898 |
|
|
899 |
GtkWidget *hbox = gtk_hbox_new(FALSE, 0); |
GtkWidget *hbox = gtk_hbox_new(FALSE, 0); |
900 |
|
|
|
gtk_box_pack_start(GTK_BOX(hbox), |
|
|
gtk_image_new_from_stock( GTK_STOCK_DIALOG_QUESTION, |
|
|
GTK_ICON_SIZE_DIALOG), |
|
|
FALSE, FALSE, 0); |
|
|
|
|
901 |
GtkWidget *label = gtk_label_new( |
GtkWidget *label = gtk_label_new( |
902 |
_("Do you want to close this entry only or do " |
_("Do you want to close this entry only or do " |
903 |
"you want to remove it completely from the list?")); |
"you want to remove it completely from the list?")); |
1047 |
|
|
1048 |
appdata->gpxview = gtk_tree_view_new (); |
appdata->gpxview = gtk_tree_view_new (); |
1049 |
|
|
1050 |
|
printf("building gpx list, items = %d\n", appdata->gpxlist_items); |
1051 |
|
|
1052 |
GtkTreeSelection *selection = |
GtkTreeSelection *selection = |
1053 |
gtk_tree_view_get_selection(GTK_TREE_VIEW(appdata->gpxview)); |
gtk_tree_view_get_selection(GTK_TREE_VIEW(appdata->gpxview)); |
1054 |
#ifndef USE_PANNABLE_AREA |
#ifndef USE_PANNABLE_AREA |
1491 |
g_signal_connect(G_OBJECT(context.in_finds), "toggled", |
g_signal_connect(G_OBJECT(context.in_finds), "toggled", |
1492 |
G_CALLBACK(callback_finds_toggled), &context); |
G_CALLBACK(callback_finds_toggled), &context); |
1493 |
|
|
1494 |
#ifndef USE_MAEMO |
context.spinner = number_editor_new(appdata->search_days, 0, 99); |
|
GtkObject *adj = gtk_adjustment_new(appdata->search_days, 0, 99, 1, 10, 10); |
|
|
context.spinner = gtk_spin_button_new(GTK_ADJUSTMENT(adj), 1, 0); |
|
|
#else |
|
|
context.spinner = hildon_number_editor_new(0, 99); |
|
|
hildon_number_editor_set_value(HILDON_NUMBER_EDITOR(context.spinner), |
|
|
appdata->search_days); |
|
|
#endif |
|
1495 |
gtk_box_pack_start_defaults(GTK_BOX(hbox), context.spinner); |
gtk_box_pack_start_defaults(GTK_BOX(hbox), context.spinner); |
1496 |
|
|
1497 |
gtk_box_pack_start_defaults(GTK_BOX(hbox), gtk_label_new(_("days"))); |
gtk_box_pack_start_defaults(GTK_BOX(hbox), gtk_label_new(_("days"))); |
1498 |
|
|
1499 |
gtk_box_pack_start_defaults(GTK_BOX(GTK_DIALOG(dialog)->vbox), hbox); |
gtk_box_pack_start_defaults(GTK_BOX(GTK_DIALOG(dialog)->vbox), hbox); |
1511 |
if(strlen(p) > 0) |
if(strlen(p) > 0) |
1512 |
appdata->search_str = strdup(p); |
appdata->search_str = strdup(p); |
1513 |
|
|
1514 |
#ifndef USE_MAEMO |
appdata->search_days = number_editor_get_value(context.spinner); |
|
appdata->search_days = gtk_spin_button_get_value_as_int( |
|
|
GTK_SPIN_BUTTON(context.spinner)); |
|
|
#else |
|
|
appdata->search_days = hildon_number_editor_get_value( |
|
|
HILDON_NUMBER_EDITOR(context.spinner)); |
|
|
#endif |
|
1515 |
|
|
1516 |
if(check_button_get_active(context.in_finds)) |
if(check_button_get_active(context.in_finds)) |
1517 |
appdata->search |= SEARCH_FINDS; |
appdata->search |= SEARCH_FINDS; |
1547 |
printf("Search for %s (flags = %x)...\n", p, appdata->search); |
printf("Search for %s (flags = %x)...\n", p, appdata->search); |
1548 |
|
|
1549 |
#if !defined(USE_BREAD_CRUMB_TRAIL) && !defined(BCT) |
#if !defined(USE_BREAD_CRUMB_TRAIL) && !defined(BCT) |
1550 |
gpx_t *found = |
|
1551 |
search_do(appdata, appdata->gpx, p, appdata->search, FALSE); |
if(appdata->cur_gpx) |
1552 |
|
appdata->search_results = |
1553 |
|
search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE); |
1554 |
|
else |
1555 |
|
appdata->search_results = |
1556 |
|
search_do(appdata, appdata->gpx, p, appdata->search, FALSE); |
1557 |
|
|
1558 |
/* do search result dialog here ... */ |
/* do search result dialog here ... */ |
1559 |
cachelist_dialog(appdata, found); |
cachelist_dialog(appdata, appdata->search_results); |
1560 |
|
|
1561 |
#ifndef USE_STACKABLE_WINDOW |
#ifndef USE_STACKABLE_WINDOW |
1562 |
search_result_free(found); |
search_result_free(appdata->search_results); |
1563 |
#else |
appdata->search_results = NULL; |
|
appdata->search_results = found; |
|
1564 |
#endif |
#endif |
1565 |
#else |
#else |
1566 |
gpx_t *found = NULL; |
gpx_t *found = NULL; |
1850 |
g_signal_connect_after(button, "clicked", |
g_signal_connect_after(button, "clicked", |
1851 |
G_CALLBACK(on_export_clicked), appdata); |
G_CALLBACK(on_export_clicked), appdata); |
1852 |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
1853 |
|
} |
1854 |
|
|
1855 |
|
/* if search results exist, don't allow another search */ |
1856 |
|
if(!appdata->search_results && |
1857 |
|
((mode == MENU_GPXLIST) || (mode == MENU_CACHELIST))) { |
1858 |
button = gtk_button_new_with_label(_("Search")); |
button = gtk_button_new_with_label(_("Search")); |
1859 |
g_signal_connect_after(button, "clicked", |
g_signal_connect_after(button, "clicked", |
1860 |
G_CALLBACK(cb_menu_search), appdata); |
G_CALLBACK(cb_menu_search), appdata); |
2054 |
|
|
2055 |
void cleanup(appdata_t *appdata) { |
void cleanup(appdata_t *appdata) { |
2056 |
gconf_save_state(appdata); |
gconf_save_state(appdata); |
2057 |
|
|
2058 |
gpx_free_all(appdata->gpx); |
gpx_free_all(appdata->gpx); |
2059 |
|
|
2060 |
|
#ifdef ESPEAK |
2061 |
|
espeak_Terminate(); |
2062 |
|
#endif |
2063 |
|
|
2064 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
2065 |
if(appdata->export_menu) submenu_cleanup(appdata->export_menu); |
if(appdata->export_menu) submenu_cleanup(appdata->export_menu); |
2066 |
if(appdata->tools_menu) submenu_cleanup(appdata->tools_menu); |
if(appdata->tools_menu) submenu_cleanup(appdata->tools_menu); |
2070 |
icons_free(); |
icons_free(); |
2071 |
gps_release(appdata); |
gps_release(appdata); |
2072 |
|
|
|
#ifdef USE_MAEMO |
|
2073 |
if(appdata->search_results) { |
if(appdata->search_results) { |
2074 |
printf("freeing pending search\n"); |
printf("freeing pending search\n"); |
2075 |
search_result_free(appdata->search_results); |
search_result_free(appdata->search_results); |
2076 |
} |
} |
2077 |
|
|
2078 |
|
#ifdef USE_MAEMO |
2079 |
if(appdata->osso_context) |
if(appdata->osso_context) |
2080 |
osso_deinitialize(appdata->osso_context); |
osso_deinitialize(appdata->osso_context); |
2081 |
|
|
2256 |
|
|
2257 |
static void crumb_add(appdata_t *appdata, char *name, int level, |
static void crumb_add(appdata_t *appdata, char *name, int level, |
2258 |
gpointer user_data) { |
gpointer user_data) { |
2259 |
crumb_t *crumb = malloc(sizeof(crumb_t)); |
crumb_t *crumb = g_new0(crumb_t, 1); |
2260 |
crumb->level = level; |
crumb->level = level; |
2261 |
crumb->appdata = appdata; |
crumb->appdata = appdata; |
2262 |
crumb->data = user_data; |
crumb->data = user_data; |
2336 |
} |
} |
2337 |
|
|
2338 |
if(redraw) { |
if(redraw) { |
|
GtkWidget *container = appdata->vbox; |
|
2339 |
|
|
2340 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
2341 |
HildonWindowStack *stack = hildon_window_stack_get_default(); |
HildonWindowStack *stack = hildon_window_stack_get_default(); |
2342 |
container = hildon_window_stack_peek(stack); |
GtkWidget *container = hildon_window_stack_peek(stack); |
2343 |
|
#else |
2344 |
|
GtkWidget *container = appdata->vbox; |
2345 |
#endif |
#endif |
2346 |
|
|
2347 |
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
2360 |
} |
} |
2361 |
|
|
2362 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
|
if(container != appdata->vbox) |
|
2363 |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
2364 |
else |
#else |
|
#endif |
|
2365 |
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
2366 |
|
#endif |
2367 |
|
|
2368 |
gtk_widget_show_all(container); |
gtk_widget_show_all(container); |
2369 |
} |
} |
2391 |
|
|
2392 |
curl_global_init(CURL_GLOBAL_ALL); |
curl_global_init(CURL_GLOBAL_ALL); |
2393 |
|
|
2394 |
|
#ifdef ESPEAK |
2395 |
|
#if ESPEAK_API_REVISION == 1 |
2396 |
|
appdata.espeak.sample_rate = |
2397 |
|
espeak_Initialize(AUDIO_OUTPUT_PLAYBACK, 512, NULL); |
2398 |
|
#else |
2399 |
|
appdata.espeak.sample_rate = |
2400 |
|
espeak_Initialize(AUDIO_OUTPUT_PLAYBACK, 512, NULL, 0); |
2401 |
|
#endif |
2402 |
|
if(appdata.espeak.sample_rate < 0) |
2403 |
|
printf("espeak: init error\n"); |
2404 |
|
else |
2405 |
|
printf("espeak: running at %dhz\n", appdata.espeak.sample_rate); |
2406 |
|
|
2407 |
|
/* set language */ |
2408 |
|
espeak_VOICE voice_spec; |
2409 |
|
voice_spec.name = NULL; |
2410 |
|
voice_spec.languages = _("en"); |
2411 |
|
voice_spec.gender = 0; |
2412 |
|
voice_spec.age = 0; |
2413 |
|
voice_spec.variant = 0; |
2414 |
|
if(EE_OK != espeak_SetVoiceByProperties(&voice_spec)) { |
2415 |
|
printf("failed to set voice spec for %s\n", voice_spec.languages); |
2416 |
|
appdata.espeak.sample_rate = -1; |
2417 |
|
} |
2418 |
|
#endif |
2419 |
|
|
2420 |
#ifdef USE_MAEMO |
#ifdef USE_MAEMO |
2421 |
printf("Installing osso context for \"org.harbaum." APP "\"\n"); |
printf("Installing osso context for \"org.harbaum." APP "\"\n"); |
2422 |
appdata.osso_context = osso_initialize("org.harbaum."APP, |
appdata.osso_context = osso_initialize("org.harbaum."APP, |
2469 |
appdata.clipboard = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); |
appdata.clipboard = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); |
2470 |
gtk_clipboard_set_can_store(appdata.clipboard, NULL, 0); |
gtk_clipboard_set_can_store(appdata.clipboard, NULL, 0); |
2471 |
|
|
2472 |
|
#ifndef USE_STACKABLE_WINDOW |
2473 |
appdata.vbox = gtk_vbox_new(FALSE, 2); |
appdata.vbox = gtk_vbox_new(FALSE, 2); |
2474 |
gtk_container_add(GTK_CONTAINER(appdata.window), appdata.vbox); |
gtk_container_add(GTK_CONTAINER(appdata.window), appdata.vbox); |
|
#ifndef USE_STACKABLE_WINDOW |
|
2475 |
menu_create(&appdata); |
menu_create(&appdata); |
2476 |
#else |
#else |
2477 |
hildon_window_set_app_menu(HILDON_WINDOW(appdata.window), |
hildon_window_set_app_menu(HILDON_WINDOW(appdata.window), |
2504 |
|
|
2505 |
appdata.gconf_client = gconf_client_get_default(); |
appdata.gconf_client = gconf_client_get_default(); |
2506 |
gconf_load_state(&appdata); |
gconf_load_state(&appdata); |
2507 |
|
|
2508 |
gps_init(&appdata); |
gps_init(&appdata); |
2509 |
|
|
2510 |
appdata.cur_view = gpxlist_create_view_and_model(&appdata, NULL); |
appdata.cur_view = gpxlist_create_view_and_model(&appdata, NULL); |
2511 |
|
#ifndef USE_STACKABLE_WINDOW |
2512 |
gtk_box_pack_start_defaults(GTK_BOX(appdata.vbox), appdata.cur_view); |
gtk_box_pack_start_defaults(GTK_BOX(appdata.vbox), appdata.cur_view); |
2513 |
|
#else |
2514 |
|
gtk_container_add(GTK_CONTAINER(appdata.window), appdata.cur_view); |
2515 |
|
#endif |
2516 |
|
|
2517 |
gtk_widget_show_all(GTK_WIDGET(appdata.window)); |
gtk_widget_show_all(GTK_WIDGET(appdata.window)); |
2518 |
gtk_main(); |
gtk_main(); |