Skip to content

Commit

Permalink
Add winesync param
Browse files Browse the repository at this point in the history
  • Loading branch information
flightlessmango committed Nov 29, 2023
1 parent 669f6f9 commit a186112
Show file tree
Hide file tree
Showing 4 changed files with 86 additions and 1 deletion.
14 changes: 13 additions & 1 deletion src/hud_elements.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1392,6 +1392,15 @@ void HudElements::refresh_rate() {
}
}

void HudElements::winesync() {
if (HUDElements.winesync_ptr->valid()) {
ImguiNextColumnFirstItem();
HUDElements.TextColored(HUDElements.colors.engine, "%s", "WSYNC");
ImguiNextColumnOrNewRow();
right_aligned_text(HUDElements.colors.text, HUDElements.ralign_width, "%s", HUDElements.winesync_ptr->get_method().c_str());
}
}

void HudElements::sort_elements(const std::pair<std::string, std::string>& option) {
const auto& param = option.first;
const auto& value = option.second;
Expand Down Expand Up @@ -1436,7 +1445,8 @@ void HudElements::sort_elements(const std::pair<std::string, std::string>& optio
{"graphs", {graphs}},
{"fps_metrics", {fps_metrics}},
{"hdr", {hdr}},
{"refresh_rate", {refresh_rate}}
{"refresh_rate", {refresh_rate}},
{"winesync", {winesync}}
};

auto check_param = display_params.find(param);
Expand Down Expand Up @@ -1548,6 +1558,8 @@ void HudElements::legacy_elements(){
ordered_functions.push_back({exec_name, "exec_name", value});
if (params->enabled[OVERLAY_PARAM_ENABLED_duration])
ordered_functions.push_back({duration, "duration", value});
if (params->enabled[OVERLAY_PARAM_ENABLED_winesync])
ordered_functions.push_back({winesync, "winesync", value});
}

void HudElements::update_exec(){
Expand Down
3 changes: 3 additions & 0 deletions src/hud_elements.h
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
#include <imgui.h>
#include "timing.hpp"
#include <functional>
#include <winesync.h>

struct Function {
std::function<void()> run; // Using std::function instead of a raw function pointer for more flexibility
Expand Down Expand Up @@ -46,6 +47,7 @@ class HudElements{
uint32_t vendorID;
int hdr_status = 0;
int refresh = 0;
std::unique_ptr<WineSync> winesync_ptr = std::make_unique<WineSync>();

void sort_elements(const std::pair<std::string, std::string>& option);
void legacy_elements();
Expand Down Expand Up @@ -89,6 +91,7 @@ class HudElements{
static void fps_metrics();
static void hdr();
static void refresh_rate();
static void winesync();

void convert_colors(const struct overlay_params& params);
void convert_colors(bool do_conv, const struct overlay_params& params);
Expand Down
1 change: 1 addition & 0 deletions src/overlay_params.h
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,7 @@ typedef unsigned long KeySym;
OVERLAY_PARAM_BOOL(inherit) \
OVERLAY_PARAM_BOOL(hdr) \
OVERLAY_PARAM_BOOL(refresh_rate) \
OVERLAY_PARAM_BOOL(winesync) \
OVERLAY_PARAM_CUSTOM(fps_sampling_period) \
OVERLAY_PARAM_CUSTOM(output_folder) \
OVERLAY_PARAM_CUSTOM(output_file) \
Expand Down
69 changes: 69 additions & 0 deletions src/winesync.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
#include "file_utils.h"
#include <filesystem.h>
#include <string>

namespace fs = ghc::filesystem;

class WineSync {
private:
enum syncMethods {
NONE,
ESYNC,
FSYNC,
NTSYNC
};

int method = 0;
bool inside_wine;

const char* methods[4] = {
"None",
"Esync",
"Fsync",
"NTsync"
};

public:
WineSync() {
#ifdef __linux__
// check that's were inside wine
std::string wineProcess = get_exe_path();
auto n = wineProcess.find_last_of('/');
std::string preloader = wineProcess.substr(n + 1);
if (preloader != "wine-preloader" && preloader != "wine64-preloader"){
inside_wine = false;
return;
}

// check which sync wine is using, if any.
fs::path path("/proc/self/map_files/");
for (auto& p : fs::directory_iterator(path)) {
auto filename = p.path().string();
auto sym = read_symlink(filename.c_str());
if (sym.find("esync") != std::string::npos)
method = syncMethods::ESYNC;
else if (sym.find("fsync") != std::string::npos)
method = syncMethods::FSYNC;
else if (sym.find("ntsync") != std::string::npos)
method = syncMethods::NTSYNC;
else if (sym.find("winesync") != std::string::npos)
method = syncMethods::NTSYNC;
if (method){
inside_wine = true;
break;
}
}
#endif
};

bool valid() {
return inside_wine;
}

// return sync method as display name
std::string get_method() {
return methods[method];
}
};

extern std::unique_ptr<WineSync> winesync_ptr;

0 comments on commit a186112

Please sign in to comment.