Skip to content

Commit

Permalink
Add an option to disable ImPlot
Browse files Browse the repository at this point in the history
The ImPlot dependency causes significant library size and build time
increases (at least for debug builds) so add an option to disable it

This change also adds more mentions of the ImPlot dependency in the
documentation (and adds a warning about missing ImPlot)
  • Loading branch information
TheComputerGuy96 committed Dec 22, 2024
1 parent e8f8406 commit b179742
Show file tree
Hide file tree
Showing 8 changed files with 21 additions and 11 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -438,7 +438,7 @@ Parameters that are enabled by default have to be explicitly disabled. These (cu
| `text_outline_color=` | Set the color of `text_outline`. Default = `000000` |
| `text_outline_thickness=` | Set the thickness of `text_outline`. Default = `1.5` |
| `throttling_status` | Show if GPU is throttling based on Power, current, temp or "other" (Only shows if throttling is currently happening). Currently disabled by default for Nvidia as it causes lag on 3000 series |
| `throttling_status_graph` | Same as `throttling_status` but displays throttling in the frametime graph and only power and temp throttling |
| `throttling_status_graph` | Same as `throttling_status` but displays throttling in the frametime graph and only power and temp throttling (requires ImPlot dependency) |
| `time`<br>`time_format=%T` | Display local time. See [std::put_time](https://en.cppreference.com/w/cpp/io/manip/put_time) for formatting help. NOTE: Sometimes apps may set `TZ` (timezone) environment variable to UTC/GMT |
| `time_no_label` | Remove the label before time |
| `toggle_fps_limit` | Cycle between FPS limits (needs at least two values set with `fps_limit`). Defaults to `Shift_L+F1` |
Expand Down
2 changes: 1 addition & 1 deletion data/MangoHud.conf
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ frametime
### Display GPU throttling status based on Power, current, temp or "other"
## Only shows if throttling is currently happening
throttling_status
## Same as throttling_status but displays throttling on the frametime graph
## Same as throttling_status but displays throttling on the frametime graph (requires ImPlot dependency)
#throttling_status_graph

### Display miscellaneous information
Expand Down
3 changes: 2 additions & 1 deletion meson.build
Original file line number Diff line number Diff line change
Expand Up @@ -224,8 +224,9 @@ if get_option('mangoapp')
endif
dearimgui_dep = dependency('imgui', fallback: ['imgui'], required: true, default_options: imgui_options)

if is_unixy
if is_unixy and get_option('with_implot').enabled()
implot_dep = dependency('implot', fallback: ['implot'], required: true, default_options: ['default_library=static'])
pre_args += '-DHAVE_IMPLOT'
else
implot_dep = null_dep
implot_lib = static_library('nulllib', [])
Expand Down
1 change: 1 addition & 0 deletions meson_options.txt
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ option('with_xnvctrl', type : 'feature', value : 'enabled', description: 'Enable
option('with_x11', type : 'feature', value : 'enabled')
option('with_wayland', type : 'feature', value : 'enabled')
option('with_dbus', type : 'feature', value : 'enabled')
option('with_implot', type : 'feature', value : 'enabled', description: 'Enable ImPlot support (required for throttling graph; disable for smaller debug library size)')
option('loglevel', type: 'combo', choices : ['trace', 'debug', 'info', 'warn', 'err', 'critical', 'off'], value : 'info', description: 'Max log level in non-debug build')
option('mangoapp', type: 'boolean', value : false)
option('mangohudctl', type: 'boolean', value : false)
Expand Down
4 changes: 2 additions & 2 deletions src/app/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
#include <GL/glew.h>
#include <GLFW/glfw3.h>
#include "amdgpu.h"
#ifdef __linux__
#ifdef HAVE_IMPLOT
#include "implot.h"
#endif

Expand Down Expand Up @@ -241,7 +241,7 @@ static GLFWwindow* init(const char* glsl_version){
glfwMakeContextCurrent(window);
glfwSwapInterval(1); // Enable vsync
ImGui::CreateContext();
#ifdef __linux__
#ifdef HAVE_IMPLOT
ImPlot::CreateContext();
#endif
ImGuiIO& io = ImGui::GetIO(); (void)io;
Expand Down
4 changes: 2 additions & 2 deletions src/gl/gl_hud.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
#include <unistd.h>
#include <spdlog/spdlog.h>
#include <imgui.h>
#ifdef __linux__
#ifdef HAVE_IMPLOT
#include <implot.h>
#endif
#include "gl_hud.h"
Expand Down Expand Up @@ -158,7 +158,7 @@ void imgui_create(void *ctx, const gl_wsi plat)
IMGUI_CHECKVERSION();
ImGuiContext *saved_ctx = ImGui::GetCurrentContext();
state.imgui_ctx = ImGui::CreateContext();
#ifdef __linux__
#ifdef HAVE_IMPLOT
ImPlot::CreateContext();
#endif
ImGuiIO& io = ImGui::GetIO(); (void)io;
Expand Down
11 changes: 8 additions & 3 deletions src/hud_elements.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
#include <IconsForkAwesome.h>
#include "version.h"
#include "blacklist.h"
#ifdef __linux__
#ifdef HAVE_IMPLOT
#include "implot.h"
#endif
#include "amdgpu.h"
Expand Down Expand Up @@ -811,7 +811,7 @@ void HudElements::frame_timing(){
NULL, min_time, max_time,
ImVec2(width, height));
} else {
#ifndef __linux__
#ifndef HAVE_IMPLOT
ImGui::PlotLines(hash, get_time_stat, HUDElements.sw_stats,
ARRAY_SIZE(HUDElements.sw_stats->frames_stats), 0,
NULL, min_time, max_time,
Expand Down Expand Up @@ -853,7 +853,7 @@ void HudElements::frame_timing(){
}
}
ImGui::EndChild();
#ifdef __linux__
#ifdef HAVE_IMPLOT
if (HUDElements.params->enabled[OVERLAY_PARAM_ENABLED_throttling_status_graph] && gpus->active_gpu()->throttling()){
ImGui::Dummy(ImVec2(0.0f, real_font_size.y / 2));

Expand All @@ -873,6 +873,11 @@ void HudElements::frame_timing(){
}
ImGui::PopFont();
ImGui::PopStyleColor();
#else
static unsigned int once;

if (HUDElements.params->enabled[OVERLAY_PARAM_ENABLED_throttling_status_graph] && !once++)
SPDLOG_DEBUG("Throttling status graph requires ImPlot");
#endif
}
}
Expand Down
5 changes: 4 additions & 1 deletion src/vulkan.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,9 @@
#include "file_utils.h"
#ifdef __linux__
#include <dlfcn.h>
#endif

#ifdef HAVE_IMPLOT
#include "implot.h"
#endif

Expand Down Expand Up @@ -1319,7 +1322,7 @@ static void setup_swapchain_data(struct swapchain_data *data,
data->format = pCreateInfo->imageFormat;

data->imgui_context = ImGui::CreateContext(data->font_atlas);
#ifdef __linux__
#ifdef HAVE_IMPLOT
ImPlot::CreateContext();
#endif
ImGui::SetCurrentContext(data->imgui_context);
Expand Down

0 comments on commit b179742

Please sign in to comment.