#include "gui.h" #include "../ta-log.h" const char* logLevels[5]={ "ERROR", "warning", "info", "debug", "trace" }; FurnaceGUIColors logColors[5]={ GUI_COLOR_LOGLEVEL_ERROR, GUI_COLOR_LOGLEVEL_WARNING, GUI_COLOR_LOGLEVEL_INFO, GUI_COLOR_LOGLEVEL_DEBUG, GUI_COLOR_LOGLEVEL_TRACE }; void FurnaceGUI::drawLog() { if (nextWindow==GUI_WINDOW_LOG) { logOpen=true; ImGui::SetNextWindowFocus(); nextWindow=GUI_WINDOW_NOTHING; } if (!logOpen) return; if (ImGui::Begin("Log Viewer",&logOpen)) { ImGui::Checkbox("Follow",&followLog); ImGui::SameLine(); ImGui::Text("Level"); ImGui::SameLine(); ImGui::SetNextItemWidth(ImGui::GetContentRegionAvail().x); ImGui::Combo("##LogLevel",&logLevel,logLevels,5); if (ImGui::BeginTable("LogView",3,ImGuiTableFlags_ScrollY|ImGuiTableFlags_BordersInnerV)) { ImGui::PushFont(patFont); float timeChars=ImGui::CalcTextSize("00:00:00").x; float levelChars=ImGui::CalcTextSize("warning").x; ImGui::TableSetupColumn("c0",ImGuiTableColumnFlags_WidthFixed,timeChars); ImGui::TableSetupColumn("c1",ImGuiTableColumnFlags_WidthFixed,levelChars); ImGui::TableSetupColumn("c2",ImGuiTableColumnFlags_WidthStretch); ImGui::TableNextRow(ImGuiTableRowFlags_Headers); ImGui::TableNextColumn(); ImGui::TextUnformatted("time"); ImGui::TableNextColumn(); ImGui::TextUnformatted("level"); ImGui::TableNextColumn(); ImGui::TextUnformatted("message"); int pos=logPosition; for (int i=0; i