/* Copyright (c) 2014-2015, Stanislaw Halik <sthalik@misaki.pl> * 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. */ #pragma once #include "main-settings.hpp" #include "api/plugin-support.hpp" #include "pipeline.hpp" #include "shortcuts.h" #include "export.hpp" #include "tracklogger.hpp" #include "logic/runtime-libraries.hpp" #include "api/plugin-support.hpp" #include "compat/tr.hpp" #include <QObject> #include <QFrame> #include <memory> #include <vector> #include <tuple> #include <functional> class OTR_LOGIC_EXPORT Work final : public TR { Q_OBJECT using dylibptr = std::shared_ptr<dylib>; static std::unique_ptr<TrackLogger> make_logger(main_settings &s); static QString browse_datalogging_file(main_settings &s); public: using fn_t = std::function<void(bool)>; using key_tuple = std::tuple<key_opts&, fn_t, bool>; main_settings s; // tracker needs settings, so settings must come before it runtime_libraries libs; // idem std::unique_ptr<TrackLogger> logger; // must come before tracker, since tracker depends on it pipeline pipeline_; Shortcuts sc; std::vector<key_tuple> keys; Work(Mappings& m, event_handler& ev, QFrame* frame, const dylibptr& tracker, const dylibptr& filter, const dylibptr& proto); void reload_shortcuts(); bool is_ok() const; };