ENH: GUI: add arm64 check logic for windows
jira: no-jira Change-Id: Ic788d4ae9218b909eae5ce571d4436c39e77230a
This commit is contained in:
parent
7ef9a21123
commit
323184e42c
|
@ -1411,6 +1411,20 @@ GUI_App::GUI_App()
|
|||
this->init_download_path();
|
||||
|
||||
reset_to_active();
|
||||
|
||||
#if defined(__WINDOWS__)
|
||||
SYSTEM_INFO sysInfo;
|
||||
GetNativeSystemInfo(&sysInfo);
|
||||
switch (sysInfo.wProcessorArchitecture) {
|
||||
case PROCESSOR_ARCHITECTURE_ARM64:
|
||||
m_is_arm64 = true;
|
||||
break;
|
||||
case PROCESSOR_ARCHITECTURE_AMD64:
|
||||
default:
|
||||
m_is_arm64 = false;
|
||||
break;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void GUI_App::shutdown()
|
||||
|
|
|
@ -238,6 +238,9 @@ private:
|
|||
#ifdef __linux__
|
||||
bool m_opengl_initialized{ false };
|
||||
#endif
|
||||
#if defined(__WINDOWS__)
|
||||
bool m_is_arm64{false};
|
||||
#endif
|
||||
|
||||
//import model from mall
|
||||
wxString m_download_file_url;
|
||||
|
@ -577,6 +580,10 @@ public:
|
|||
std::string get_download_model_name() {return m_mall_model_download_name;}
|
||||
|
||||
std::string get_remote_version_str() { return version_info.version_str; }
|
||||
#if defined(__WINDOWS__)
|
||||
bool is_running_on_arm64() { return m_is_arm64; }
|
||||
#endif
|
||||
|
||||
|
||||
void load_url(wxString url);
|
||||
void open_mall_page_dialog();
|
||||
|
|
|
@ -746,6 +746,12 @@ void Http::set_extra_headers(std::map<std::string, std::string> headers)
|
|||
extra_headers.swap(headers);
|
||||
}
|
||||
|
||||
std::map<std::string, std::string> Http::get_extra_headers()
|
||||
{
|
||||
std::lock_guard<std::mutex> l(g_mutex);
|
||||
return extra_headers;
|
||||
}
|
||||
|
||||
bool Http::ca_file_supported()
|
||||
{
|
||||
::CURL *curl = ::curl_easy_init();
|
||||
|
|
|
@ -89,6 +89,7 @@ public:
|
|||
|
||||
//BBS set global header for each http request
|
||||
static void set_extra_headers(std::map<std::string, std::string> headers);
|
||||
static std::map<std::string, std::string> get_extra_headers();
|
||||
|
||||
~Http();
|
||||
|
||||
|
|
|
@ -1168,6 +1168,16 @@ void PresetUpdater::priv::sync_plugins(std::string http_url, std::string plugin_
|
|||
}
|
||||
}
|
||||
|
||||
#if defined(__WINDOWS__)
|
||||
if (GUI::wxGetApp().is_running_on_arm64()) {
|
||||
//set to arm64 for plugins
|
||||
std::map<std::string, std::string> current_headers = Slic3r::Http::get_extra_headers();
|
||||
current_headers["X-BBL-OS-Type"] = "win_arm64";
|
||||
|
||||
Slic3r::Http::set_extra_headers(current_headers);
|
||||
BOOST_LOG_TRIVIAL(info) << boost::format("set X-BBL-OS-Type to win_arm64");
|
||||
}
|
||||
#endif
|
||||
try {
|
||||
std::map<std::string, Resource> resources
|
||||
{
|
||||
|
@ -1178,6 +1188,16 @@ void PresetUpdater::priv::sync_plugins(std::string http_url, std::string plugin_
|
|||
catch (std::exception& e) {
|
||||
BOOST_LOG_TRIVIAL(warning) << format("[BBL Updater] sync_plugins: %1%", e.what());
|
||||
}
|
||||
#if defined(__WINDOWS__)
|
||||
if (GUI::wxGetApp().is_running_on_arm64()) {
|
||||
//set back
|
||||
std::map<std::string, std::string> current_headers = Slic3r::Http::get_extra_headers();
|
||||
current_headers["X-BBL-OS-Type"] = "windows";
|
||||
|
||||
Slic3r::Http::set_extra_headers(current_headers);
|
||||
BOOST_LOG_TRIVIAL(info) << boost::format("set X-BBL-OS-Type back to windows");
|
||||
}
|
||||
#endif
|
||||
|
||||
bool result = get_cached_plugins_version(cached_version, force_upgrade);
|
||||
if (result) {
|
||||
|
|
Loading…
Reference in New Issue