#pragma once #ifndef MANGOHUD_LOGGING_H #define MANGOHUD_LOGGING_H #include #include #include #include #include #include #include "timing.hpp" #include "overlay_params.h" using namespace std; struct logData{ double fps; uint64_t frametime; float cpu_load; int gpu_load; int cpu_temp; int gpu_temp; int gpu_core_clock; int gpu_mem_clock; int gpu_power; float gpu_vram_used; float ram_used; Clock::duration previous; }; class Logger { public: Logger(overlay_params* in_params); void start_logging(); void stop_logging(); void try_log(); bool is_active() const { return m_logging_on; } void wait_until_data_valid(); void notify_data_valid(); auto last_log_end() const noexcept { return m_log_end; } auto last_log_begin() const noexcept { return m_log_start; } const std::vector& get_log_data() const noexcept { return m_log_array; } void clear_log_data() noexcept { m_log_array.clear(); } void upload_last_log(); void upload_last_logs(); private: std::vector m_log_array; std::vector m_log_files; Clock::time_point m_log_start; Clock::time_point m_log_end; bool m_logging_on; std::mutex m_values_valid_mtx; std::condition_variable m_values_valid_cv; bool m_values_valid; overlay_params* m_params; }; extern std::unique_ptr logger; extern string os, cpu, gpu, ram, kernel, driver, cpusched; extern bool sysInfoFetched; extern double fps; extern uint64_t frametime; extern logData currentLogData; string exec(string command); void autostart_log(int sleep); #endif //MANGOHUD_LOGGING_H