Fix brightray::GetApplicationName(), ..Version() on Linux (#11980)

* add brightray API to override app version

* in atom browser, use brightray app version API

* on Linux, have GetApplicationVersion() use brightray version API

* on Linux, implement brightray::GetApplicationName()

* fix typo in brightray API

* make browser.GetName() logic follow GetVersion() logic

* improve variable name in OverrideApplicationVersion declaration

* fix typo in brightray impl
This commit is contained in:
Charles Kerr 2018-02-20 10:16:51 -06:00 committed by GitHub
parent dc62e51ba4
commit 8d086a43cb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 84 additions and 24 deletions

View file

@ -97,27 +97,21 @@ void Browser::Shutdown() {
} }
std::string Browser::GetVersion() const { std::string Browser::GetVersion() const {
if (version_override_.empty()) { std::string ret = brightray::GetOverriddenApplicationVersion();
std::string version = GetExecutableFileVersion(); if (ret.empty())
if (!version.empty()) ret = GetExecutableFileVersion();
return version; return ret;
}
return version_override_;
} }
void Browser::SetVersion(const std::string& version) { void Browser::SetVersion(const std::string& version) {
version_override_ = version; brightray::OverrideApplicationVersion(version);
} }
std::string Browser::GetName() const { std::string Browser::GetName() const {
if (name_override_.empty()) { std::string ret = name_override_;
std::string name = GetExecutableFileProductName(); if (ret.empty())
if (!name.empty()) ret = GetExecutableFileProductName();
return name; return ret;
}
return name_override_;
} }
void Browser::SetName(const std::string& name) { void Browser::SetName(const std::string& name) {

View file

@ -273,7 +273,6 @@ class Browser : public WindowListObserver {
// The browser is being shutdown. // The browser is being shutdown.
bool is_shutdown_; bool is_shutdown_;
std::string version_override_;
std::string name_override_; std::string name_override_;
int badge_count_ = 0; int badge_count_ = 0;

View file

@ -2,18 +2,74 @@
// Use of this source code is governed by the MIT license that can be // Use of this source code is governed by the MIT license that can be
// found in the LICENSE file. // found in the LICENSE file.
#include "brightray/common/application_info.h"
#include <gio/gdesktopappinfo.h>
#include <gio/gio.h>
#include <memory>
#include <string> #include <string>
#include "atom/common/atom_version.h" #include "atom/common/atom_version.h"
#include "base/environment.h"
#include "base/logging.h"
#include "chrome/browser/ui/libgtkui/gtk_util.h"
namespace {
GDesktopAppInfo* get_desktop_app_info() {
std::unique_ptr<base::Environment> env(base::Environment::Create());
const std::string desktop_id = libgtkui::GetDesktopName(env.get());
return desktop_id.empty() ? nullptr
: g_desktop_app_info_new(desktop_id.c_str());
}
} // namespace
namespace brightray { namespace brightray {
std::string GetApplicationName() { std::string GetApplicationName() {
return ATOM_PRODUCT_NAME; // attempt #1: the string set in app.setName()
std::string ret = GetOverriddenApplicationName();
// attempt #2: the 'Name' entry from .desktop file's [Desktop] section
if (ret.empty()) {
GDesktopAppInfo* info = get_desktop_app_info();
if (info != nullptr) {
char* str = g_desktop_app_info_get_string(info, "Name");
g_clear_object(&info);
if (str != nullptr)
ret = str;
g_clear_pointer(&str, g_free);
}
}
// attempt #3: Electron's name
if (ret.empty()) {
ret = ATOM_PRODUCT_NAME;
}
return ret;
} }
std::string GetApplicationVersion() { std::string GetApplicationVersion() {
return ATOM_VERSION_STRING; std::string ret;
// ensure ATOM_PRODUCT_NAME and ATOM_PRODUCT_STRING match up
if (GetApplicationName() == ATOM_PRODUCT_NAME)
ret = ATOM_VERSION_STRING;
// try to use the string set in app.setVersion()
if (ret.empty())
ret = GetOverriddenApplicationVersion();
// no known version number; return some safe fallback
if (ret.empty()) {
LOG(WARNING) << "No version found. Was app.setVersion() called?";
ret = "0.0";
}
return ret;
} }
} // namespace brightray } // namespace brightray

View file

@ -4,15 +4,23 @@ namespace brightray {
namespace { namespace {
std::string g_overriden_application_name; std::string g_overridden_application_name;
std::string g_overridden_application_version;
} }
void OverrideApplicationName(const std::string& name) { void OverrideApplicationName(const std::string& name) {
g_overriden_application_name = name; g_overridden_application_name = name;
} }
std::string GetOverridenApplicationName() { std::string GetOverriddenApplicationName() {
return g_overriden_application_name; return g_overridden_application_name;
}
void OverrideApplicationVersion(const std::string& version) {
g_overridden_application_version = version;
}
std::string GetOverriddenApplicationVersion() {
return g_overridden_application_version;
} }
} // namespace brightray } // namespace brightray

View file

@ -10,7 +10,10 @@
namespace brightray { namespace brightray {
void OverrideApplicationName(const std::string& name); void OverrideApplicationName(const std::string& name);
std::string GetOverridenApplicationName(); std::string GetOverriddenApplicationName();
void OverrideApplicationVersion(const std::string& version);
std::string GetOverriddenApplicationVersion();
std::string GetApplicationName(); std::string GetApplicationName();
std::string GetApplicationVersion(); std::string GetApplicationVersion();

View file

@ -47,7 +47,7 @@ PCWSTR GetRawAppUserModelID() {
if (SUCCEEDED(GetCurrentProcessExplicitAppUserModelID(&current_app_id))) { if (SUCCEEDED(GetCurrentProcessExplicitAppUserModelID(&current_app_id))) {
g_app_user_model_id = current_app_id; g_app_user_model_id = current_app_id;
} else { } else {
std::string name = GetOverridenApplicationName(); std::string name = GetOverriddenApplicationName();
if (name.empty()) { if (name.empty()) {
name = GetApplicationName(); name = GetApplicationName();
} }