diff options
author | Charles Kerr <charles.kerr@canonical.com> | 2014-01-22 00:36:07 -0600 |
---|---|---|
committer | Charles Kerr <charles.kerr@canonical.com> | 2014-01-22 00:36:07 -0600 |
commit | d611929649cc4ef6b04ad9c453f14c85e1108842 (patch) | |
tree | a1dc08851e0971f78f80fe7e0e97ed135e32a82e /src/main.cpp | |
parent | 2b857f6ca1c9c67a023fb9ad2eb6ec97f59e4335 (diff) | |
download | ayatana-indicator-datetime-d611929649cc4ef6b04ad9c453f14c85e1108842.tar.gz ayatana-indicator-datetime-d611929649cc4ef6b04ad9c453f14c85e1108842.tar.bz2 ayatana-indicator-datetime-d611929649cc4ef6b04ad9c453f14c85e1108842.zip |
extract LiveState to its own State subclass to make main()'s flow easier to follow
Diffstat (limited to 'src/main.cpp')
-rw-r--r-- | src/main.cpp | 46 |
1 files changed, 12 insertions, 34 deletions
diff --git a/src/main.cpp b/src/main.cpp index 7bd6f9d..6a56163 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -18,24 +18,16 @@ */ #include <datetime/actions-live.h> -#include <datetime/clock.h> -#include <datetime/formatter.h> -#include <datetime/locations-settings.h> +#include <datetime/exporter.h> #include <datetime/menu.h> -#include <datetime/planner-eds.h> -#include <datetime/service.h> -#include <datetime/settings-live.h> -#include <datetime/state.h> -#include <datetime/timezones-live.h> +#include <datetime/state-live.h> -#include <glib/gi18n.h> +#include <glib/gi18n.h> // bindtextdomain() #include <gio/gio.h> #include <libnotify/notify.h> -#include <iostream> - #include <locale.h> -#include <stdlib.h> /* exit() */ +#include <stdlib.h> // exit() using namespace unity::indicator::datetime; @@ -46,7 +38,7 @@ main(int /*argc*/, char** /*argv*/) // It can be removed when https://bugzilla.gnome.org/show_bug.cgi?id=674885 is fixed. g_type_ensure(G_TYPE_DBUS_CONNECTION); - // boilerplate i18n + // init i18n setlocale(LC_ALL, ""); bindtextdomain(GETTEXT_PACKAGE, GNOMELOCALEDIR); textdomain(GETTEXT_PACKAGE); @@ -55,22 +47,8 @@ main(int /*argc*/, char** /*argv*/) if(!notify_init("indicator-datetime-service")) g_critical("libnotify initialization failed"); - // build the state - std::shared_ptr<Settings> settings(new LiveSettings); - std::shared_ptr<Timezones> timezones(new LiveTimezones(settings, TIMEZONE_FILE)); - std::shared_ptr<Clock> clock(new LiveClock(timezones)); - std::shared_ptr<Planner> planner(new PlannerEds); - planner->time = clock->localtime(); - std::shared_ptr<Locations> locations(new SettingsLocations(settings, timezones)); - std::shared_ptr<State> state(new State); - state->settings = settings; - state->timezones = timezones; - state->clock = clock; - state->locations = locations; - state->planner = planner; - state->calendar_day = clock->localtime(); - - // build the menu factory + // build the state and menu factory + std::shared_ptr<State> state(new LiveState); std::shared_ptr<Actions> actions(new LiveActions(state)); MenuFactory factory(actions, state); @@ -80,12 +58,12 @@ main(int /*argc*/, char** /*argv*/) // export them auto loop = g_main_loop_new(nullptr, false); - Service service; - service.name_lost.connect([loop](){ - g_message("exiting: service couldn't acquire or lost ownership of busname"); - g_main_loop_quit(loop); + Exporter exporter; + exporter.name_lost.connect([loop](){ + g_message("%s exiting; failed/lost bus ownership", GETTEXT_PACKAGE); + g_main_loop_quit(loop); }); - //service.publish(actions, menus); + exporter.publish(actions, menus); g_main_loop_run(loop); g_main_loop_unref(loop); return 0; |