1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157
|
#define SATDUMP_DLL_EXPORT 1
#include "init.h"
#include "logger.h"
#include "core/module.h"
#include "core/pipeline.h"
#include <filesystem>
#include "core/plugin.h"
#include "satdump_vars.h"
#include "core/config.h"
#include "common/tracking/tle.h"
#include "products/products.h"
#include "imgui/pfd/portable-file-dialogs.h"
#include "core/opencl.h"
#include "common/dsp/buffer.h"
namespace satdump
{
SATDUMP_DLL std::string user_path;
SATDUMP_DLL std::string tle_file_override = "";
SATDUMP_DLL bool tle_do_update_on_init = true;
void initSatdump(bool is_gui)
{
logger->info(" _____ __ ____ ");
logger->info(" / ___/____ _/ /_/ __ \\__ ______ ___ ____ ");
logger->info(" \\__ \\/ __ `/ __/ / / / / / / __ `__ \\/ __ \\");
logger->info(" ___/ / /_/ / /_/ /_/ / /_/ / / / / / / /_/ /");
logger->info("/____/\\__,_/\\__/_____/\\__,_/_/ /_/ /_/ .___/ ");
logger->info(" /_/ ");
logger->info("Starting SatDump v" + (std::string)SATDUMP_VERSION);
logger->info("");
#ifdef _WIN32
if (std::filesystem::exists("satdump_cfg.json"))
user_path = "./config";
else
user_path = std::string(getenv("APPDATA")) + "/satdump";
#elif __ANDROID__
user_path = ".";
#else
user_path = std::string(getenv("HOME")) + "/.config/satdump";
#endif
try
{
if (std::filesystem::exists("satdump_cfg.json"))
config::loadConfig("satdump_cfg.json", user_path);
else
config::loadConfig(satdump::RESPATH + "satdump_cfg.json", user_path);
}
catch (std::exception &e)
{
logger->critical("Error loading SatDump config! SatDump will now exit. Error:\n%s", e.what());
if(is_gui)
pfd::message("SatDump", "Error loading SatDump config! SatDump will now exit. Error:\n\n" +
std::string(e.what()), pfd::choice::ok, pfd::icon::error);
exit(1);
}
if (config::main_cfg["satdump_general"].contains("log_to_file"))
{
bool log_file = config::main_cfg["satdump_general"]["log_to_file"]["value"];
if (log_file)
initFileSink();
}
if (config::main_cfg["satdump_general"].contains("log_level"))
{
std::string log_level = config::main_cfg["satdump_general"]["log_level"]["value"];
if (log_level == "trace")
setConsoleLevel(slog::LOG_TRACE);
else if (log_level == "debug")
setConsoleLevel(slog::LOG_DEBUG);
else if (log_level == "info")
setConsoleLevel(slog::LOG_INFO);
else if (log_level == "warn")
setConsoleLevel(slog::LOG_WARN);
else if (log_level == "error")
setConsoleLevel(slog::LOG_ERROR);
else if (log_level == "critical")
setConsoleLevel(slog::LOG_CRIT);
}
loadPlugins();
// Let plugins know we started
eventBus->fire_event<config::RegisterPluginConfigHandlersEvent>({config::plugin_config_handlers});
registerModules();
// Load pipelines
if (std::filesystem::exists("pipelines") && std::filesystem::is_directory("pipelines"))
loadPipelines("pipelines");
else
loadPipelines(satdump::RESPATH + "pipelines");
// List them
logger->debug("Registered pipelines :");
for (Pipeline &pipeline : pipelines)
logger->debug(" - " + pipeline.name);
#ifdef USE_OPENCL
// OpenCL
opencl::initOpenCL();
#endif
// TLEs
if (tle_file_override == "")
{
loadTLEFileIntoRegistry(user_path + "/satdump_tles.txt");
if (tle_do_update_on_init)
autoUpdateTLE(user_path + "/satdump_tles.txt");
}
else
{
if (std::filesystem::exists(tle_file_override))
loadTLEFileIntoRegistry(tle_file_override);
else
logger->error("TLE File doesn't exist : " + tle_file_override);
}
// Products
registerProducts();
// Set DSP buffer sizes if they have been changed
if (config::main_cfg.contains("advanced_settings"))
{
if (config::main_cfg["advanced_settings"].contains("default_buffer_size"))
{
int new_sz = config::main_cfg["advanced_settings"]["default_buffer_size"].get<int>();
dsp::STREAM_BUFFER_SIZE = new_sz;
dsp::RING_BUF_SZ = new_sz;
logger->warn("DSP Buffer size was changed to %d", new_sz);
}
}
// Let plugins know we started
eventBus->fire_event<SatDumpStartedEvent>({});
#ifdef BUILD_IS_DEBUG
// If in debug, warn the user!
logger->error("██████╗ █████╗ ███╗ ██╗ ██████╗ ███████╗██████╗ ");
logger->error("██╔══██╗██╔══██╗████╗ ██║██╔════╝ ██╔════╝██╔══██╗");
logger->error("██║ ██║███████║██╔██╗ ██║██║ ███╗█████╗ ██████╔╝");
logger->error("██║ ██║██╔══██║██║╚██╗██║██║ ██║██╔══╝ ██╔══██╗");
logger->error("██████╔╝██║ ██║██║ ╚████║╚██████╔╝███████╗██║ ██║");
logger->error("╚═════╝ ╚═╝ ╚═╝╚═╝ ╚═══╝ ╚═════╝ ╚══════╝╚═╝ ╚═╝");
logger->error("SatDump has NOT been built in Release mode.");
logger->error("If you are not a developer but intending to use the software,");
logger->error("you probably do not want this. If so, make sure to");
logger->error("specify -DCMAKE_BUILD_TYPE=Release in CMake.");
#endif
}
}
|