/* Copyright 2013, Sebastian Reichel * Copyright 2017-2018, Johannes Rudolph * Copyright 2018, Malte Modler * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ public MainLoop loop; public AudioPlayer audio; public ScannerSession scanner; public CursesUI ui; private static void play(string file) { try { audio.play_system(file); } catch(IOError e) { ui.log(MessageType.WARNING, _("could not play audio: %s").printf(e.message)); } catch(DBusError e) { ui.log(MessageType.WARNING, _("could not play audio: %s").printf(e.message)); } } public void msg_handler(MessageType type, string message) { ui.log(type, message); } public void msg_overlay_handler(string title, string message) { ui.log_overlay(title, message, 5); } public void log_handler(string? log_domain, LogLevelFlags flags, string message) { ui.log(MessageType.INFO, message); } public static int main(string[] args) { loop = new MainLoop(); Intl.setlocale(LocaleCategory.ALL, ""); Intl.textdomain("shopsystem"); /* handle unix signals */ Unix.signal_add(Posix.Signal.TERM, handle_signals); Unix.signal_add(Posix.Signal.INT, handle_signals); try { audio = Bus.get_proxy_sync(BusType.SYSTEM, "io.mainframe.shopsystem.AudioPlayer", "/io/mainframe/shopsystem/audio"); scanner = Bus.get_proxy_sync(BusType.SYSTEM, "io.mainframe.shopsystem.ScannerSession", "/io/mainframe/shopsystem/scanner_session"); } catch(IOError e) { error(_("IO Error: %s\n"), e.message); } string binarylocation = File.new_for_path(args[0]).get_parent().get_path(); ui = new CursesUI(binarylocation); Log.set_default_handler(log_handler); scanner.msg.connect(msg_handler); scanner.msg_overlay.connect(msg_overlay_handler); ui.log(MessageType.INFO, _("Shop System has been started")); play("startup.ogg"); /* run mainloop */ loop.run(); ui.log(MessageType.INFO, _("Stopping Shop System")); play("shutdown.ogg"); /* leave curses mode */ ui.exit(); return 0; } bool handle_signals() { loop.quit(); return false; }