From 57e2aa0356b21b40c9fc5c53edc8bfaebd95a60e Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Thu, 6 Jul 2017 22:23:56 +0200 Subject: proto/simconnect: add version list for reference Our manifests are out of what. This'll help. Provided-by: @ronh991 in --- proto-simconnect/simconnect versions.txt | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 proto-simconnect/simconnect versions.txt (limited to 'proto-simconnect') diff --git a/proto-simconnect/simconnect versions.txt b/proto-simconnect/simconnect versions.txt new file mode 100644 index 00000000..dde71f8f --- /dev/null +++ b/proto-simconnect/simconnect versions.txt @@ -0,0 +1,20 @@ +#define LVERS_ORIG "10.0.60905.0" +#define LVERS_SP1B1 "10.0.61232.0" +#define LVERS_SP1B2 "10.0.61233.0" +#define LVERS_SP1B3 "10.0.61234.0" +#define LVERS_SP1B4 "10.0.61240.0" +#define LVERS_SP1 "10.0.61242.0" +#define LVERS_ACCA1 "10.0.61245.0" +#define LVERS_ACCB1 "10.0.61246.0" +#define LVERS_ACCB2 "10.0.61247.0" +#define LVERS_ACCB3 "10.0.61248.0" +#define LVERS_ACCSP2 "10.0.61259.0" +#define LVERS_STEAM "10.0.62607.0" +#define LVERS_STEAM2 "10.0.62608.0" +#define LVERS_STEAM3 "10.0.62609.0" +#define LVERS_STEAM4 "10.0.62610.0" +#define LVERS_STEAM5 "10.0.62611.0" +#define LVERS_STEAM6 "10.0.62612.0" +#define LVERS_STEAM7 "10.0.62613.0" +#define LVERS_STEAM8 "10.0.62614.0" +#define LVERS_STEAM9 "10.0.62615.0" -- cgit v1.2.3 From fa8e4da6148fa00e77fc3a4be55769d40a1db057 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Fri, 7 Jul 2017 03:13:45 +0200 Subject: proto/simconnect: fix WinSxS library versions We had all the wrong versions assigned to comboboxen. With the correct versions, Prepar3D works with its own SimConnect redist named "SP2-XPACK". The library version is the same as SP2 and the combobox item exists only to help users. --- compat/math-imports.hpp | 45 +++++++++++++++++ proto-simconnect/fsx_p3d_sp2_xpack.manifest | 8 +++ proto-simconnect/fsx_rtm.manifest | 8 +++ proto-simconnect/fsx_sp1.manifest | 8 +++ proto-simconnect/fsx_sp2.manifest | 8 +++ proto-simconnect/fsx_steam_last.manifest | 8 +++ proto-simconnect/fsx_steam_orig.manifest | 8 +++ proto-simconnect/ftnoir-protocol-sc.rc | 9 ++-- proto-simconnect/ftnoir_protocol_sc.cpp | 66 ++++++++++++------------- proto-simconnect/ftnoir_protocol_sc.h | 4 +- proto-simconnect/ftnoir_sccontrols.ui | 19 ++++++- proto-simconnect/manifest-template.in | 8 +++ proto-simconnect/scserver.manifest | 13 ----- proto-simconnect/scserver_acceleration.manifest | 13 ----- proto-simconnect/scserver_sp2.manifest | 13 ----- 15 files changed, 159 insertions(+), 79 deletions(-) create mode 100644 compat/math-imports.hpp create mode 100644 proto-simconnect/fsx_p3d_sp2_xpack.manifest create mode 100644 proto-simconnect/fsx_rtm.manifest create mode 100644 proto-simconnect/fsx_sp1.manifest create mode 100644 proto-simconnect/fsx_sp2.manifest create mode 100644 proto-simconnect/fsx_steam_last.manifest create mode 100644 proto-simconnect/fsx_steam_orig.manifest create mode 100644 proto-simconnect/manifest-template.in delete mode 100644 proto-simconnect/scserver.manifest delete mode 100644 proto-simconnect/scserver_acceleration.manifest delete mode 100644 proto-simconnect/scserver_sp2.manifest (limited to 'proto-simconnect') diff --git a/compat/math-imports.hpp b/compat/math-imports.hpp new file mode 100644 index 00000000..ad70f361 --- /dev/null +++ b/compat/math-imports.hpp @@ -0,0 +1,45 @@ +#pragma once + +#include +#include + +namespace otr_math +{ + +using std::copysign; + +using std::sqrt; +using std::pow; + +using std::fabs; +using std::fmin; +using std::fmax; + +using std::atan; +using std::atan2; +using std::asin; +using std::acos; + +using std::sin; +using std::cos; +using std::tan; + +using std::round; +using std::fmod; + +using std::uintptr_t; +using std::intptr_t; + +using std::int64_t; +using std::int32_t; + +using std::uint64_t; +using std::uint32_t; + +template +static inline constexpr auto signum(T x) +{ + return (T() < x) - (x < T()); +} + +} // ns otr_math diff --git a/proto-simconnect/fsx_p3d_sp2_xpack.manifest b/proto-simconnect/fsx_p3d_sp2_xpack.manifest new file mode 100644 index 00000000..25a62765 --- /dev/null +++ b/proto-simconnect/fsx_p3d_sp2_xpack.manifest @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/fsx_rtm.manifest b/proto-simconnect/fsx_rtm.manifest new file mode 100644 index 00000000..760de973 --- /dev/null +++ b/proto-simconnect/fsx_rtm.manifest @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/fsx_sp1.manifest b/proto-simconnect/fsx_sp1.manifest new file mode 100644 index 00000000..ee746740 --- /dev/null +++ b/proto-simconnect/fsx_sp1.manifest @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/fsx_sp2.manifest b/proto-simconnect/fsx_sp2.manifest new file mode 100644 index 00000000..25a62765 --- /dev/null +++ b/proto-simconnect/fsx_sp2.manifest @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/fsx_steam_last.manifest b/proto-simconnect/fsx_steam_last.manifest new file mode 100644 index 00000000..b8cbaca4 --- /dev/null +++ b/proto-simconnect/fsx_steam_last.manifest @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/fsx_steam_orig.manifest b/proto-simconnect/fsx_steam_orig.manifest new file mode 100644 index 00000000..f1b3314c --- /dev/null +++ b/proto-simconnect/fsx_steam_orig.manifest @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/ftnoir-protocol-sc.rc b/proto-simconnect/ftnoir-protocol-sc.rc index c89eb9a7..5f47a5c9 100644 --- a/proto-simconnect/ftnoir-protocol-sc.rc +++ b/proto-simconnect/ftnoir-protocol-sc.rc @@ -1,4 +1,7 @@ #include -142 RT_MANIFEST scserver.manifest -143 RT_MANIFEST scserver_sp2.manifest -144 RT_MANIFEST scserver_acceleration.manifest \ No newline at end of file +142 RT_MANIFEST fsx_rtm.manifest +143 RT_MANIFEST fsx_sp1.manifest +144 RT_MANIFEST fsx_sp2.manifest +145 RT_MANIFEST fsx_p3d_sp2_xpack.manifest +146 RT_MANIFEST fsx_steam_orig.manifest +147 RT_MANIFEST fsx_steam_last.manifest diff --git a/proto-simconnect/ftnoir_protocol_sc.cpp b/proto-simconnect/ftnoir_protocol_sc.cpp index be0c23c4..cfe973a7 100644 --- a/proto-simconnect/ftnoir_protocol_sc.cpp +++ b/proto-simconnect/ftnoir_protocol_sc.cpp @@ -26,7 +26,7 @@ simconnect::~simconnect() void simconnect::run() { - HANDLE event = CreateEvent(NULL, FALSE, FALSE, nullptr); + HANDLE event = CreateEventA(NULL, FALSE, FALSE, nullptr); if (event == nullptr) { @@ -38,60 +38,57 @@ void simconnect::run() { HRESULT hr; - qDebug() << "simconnect: starting"; - if (SUCCEEDED(hr = simconnect_open(&hSimConnect, "opentrack", nullptr, 0, event, 0))) { if (!SUCCEEDED(hr = simconnect_subscribetosystemevent(hSimConnect, 0, "Frame"))) { qDebug() << "simconnect: can't subscribe to frame event:" << hr; - - should_reconnect = true; // will free simconnect handle and continue the loop } Timer tm; - int idle_seconds = 0; + should_reconnect = false; - while (!isInterruptionRequested()) - { - if (should_reconnect) + if (SUCCEEDED(hr)) + while (!isInterruptionRequested()) { - should_reconnect = false; - break; - } - - if (WaitForSingleObject(event, 10) == WAIT_OBJECT_0) - { - tm.start(); - idle_seconds = 0; + if (should_reconnect) + break; - if (!SUCCEEDED(hr = simconnect_calldispatch(hSimConnect, processNextSimconnectEvent, reinterpret_cast(this)))) + if (WaitForSingleObject(event, 100) == WAIT_OBJECT_0) { - qDebug() << "simconnect: calldispatch failed:" << hr; - break; + tm.start(); + + if (!SUCCEEDED(hr = simconnect_calldispatch(hSimConnect, processNextSimconnectEvent, reinterpret_cast(this)))) + { + qDebug() << "simconnect: calldispatch failed:" << hr; + break; + } } - } - else - { - if (int(tm.elapsed_seconds()) > idle_seconds) + else { - idle_seconds++; - qDebug() << "simconnect: can't process event for" << int(tm.elapsed_seconds()) << "seconds"; + const int idle_seconds = tm.elapsed_seconds(); + + static constexpr int max_idle_seconds = 2; + + if (idle_seconds >= max_idle_seconds) + { + qDebug() << "simconnect: reconnect"; + break; + } } } - } (void) simconnect_close(hSimConnect); } else - { qDebug() << "simconnect: can't open handle:" << hr; - } if (!isInterruptionRequested()) - Sleep(100); + Sleep(3000); } + qDebug() << "simconnect: exit"; + CloseHandle(event); } @@ -120,8 +117,8 @@ public: { hactctx = INVALID_HANDLE_VALUE; actctx_cookie = 0; - ACTCTXA actx = {0}; - actx.cbSize = sizeof(ACTCTXA); + ACTCTXA actx = {}; + actx.cbSize = sizeof(actx); actx.lpResourceName = MAKEINTRESOURCEA(resid); actx.dwFlags = ACTCTX_FLAG_RESOURCE_NAME_VALID; #ifdef _MSC_VER @@ -229,9 +226,12 @@ void CALLBACK simconnect::processNextSimconnectEvent(SIMCONNECT_RECV* pData, DWO default: break; case SIMCONNECT_RECV_ID_EXCEPTION: + qDebug() << "simconnect: got exception"; + //self.should_reconnect = true; + break; case SIMCONNECT_RECV_ID_QUIT: + qDebug() << "simconnect: got quit event"; self.should_reconnect = true; - qDebug() << "simconnect: received ID_QUIT event"; break; case SIMCONNECT_RECV_ID_EVENT_FRAME: self.handle(); diff --git a/proto-simconnect/ftnoir_protocol_sc.h b/proto-simconnect/ftnoir_protocol_sc.h index 93376885..151dd741 100644 --- a/proto-simconnect/ftnoir_protocol_sc.h +++ b/proto-simconnect/ftnoir_protocol_sc.h @@ -3,7 +3,7 @@ * ISC License (ISC) * * * * Copyright (c) 2015, Wim Vriend * - * Copyright (c) 2014, Stanislaw Halik * + * Copyright (c) 2014, 2017 Stanislaw Halik * * * * Permission to use, copy, modify, and/or distribute this software for any * * purpose with or without fee is hereby granted, provided that the above * @@ -30,7 +30,7 @@ struct settings : opts { value sxs_manifest; settings() : opts("proto-simconnect"), - sxs_manifest(b, "sxs-manifest-version", 0) + sxs_manifest(b, "simconnect-manifest", 2) {} }; diff --git a/proto-simconnect/ftnoir_sccontrols.ui b/proto-simconnect/ftnoir_sccontrols.ui index 887d6d80..7a607096 100644 --- a/proto-simconnect/ftnoir_sccontrols.ui +++ b/proto-simconnect/ftnoir_sccontrols.ui @@ -51,6 +51,11 @@ 0 + + + RTM + + SP1 @@ -58,12 +63,22 @@ - SP2 + SP2 -- Acceleration + + + + + Prepar3d SP2 XPACK + + + + + Steam FSX (older) - Acceleration + Steam FSX (new) diff --git a/proto-simconnect/manifest-template.in b/proto-simconnect/manifest-template.in new file mode 100644 index 00000000..fdf2c74a --- /dev/null +++ b/proto-simconnect/manifest-template.in @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/proto-simconnect/scserver.manifest b/proto-simconnect/scserver.manifest deleted file mode 100644 index d342cfda..00000000 --- a/proto-simconnect/scserver.manifest +++ /dev/null @@ -1,13 +0,0 @@ - - - - - - - - - - - - - diff --git a/proto-simconnect/scserver_acceleration.manifest b/proto-simconnect/scserver_acceleration.manifest deleted file mode 100644 index 06459587..00000000 --- a/proto-simconnect/scserver_acceleration.manifest +++ /dev/null @@ -1,13 +0,0 @@ - - - - - - - - - - - - - diff --git a/proto-simconnect/scserver_sp2.manifest b/proto-simconnect/scserver_sp2.manifest deleted file mode 100644 index 3020d16c..00000000 --- a/proto-simconnect/scserver_sp2.manifest +++ /dev/null @@ -1,13 +0,0 @@ - - - - - - - - - - - - - -- cgit v1.2.3