From a888e4b960497fb73c049f18978e2c25e3987df5 Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Wed, 6 Aug 2014 23:34:16 +0800 Subject: [PATCH] linux: Only use global menu bar under Unity. Fixes atom/atom#3182. --- atom/browser/native_window_views.cc | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/atom/browser/native_window_views.cc b/atom/browser/native_window_views.cc index 93ff0f3855..4153ae1a41 100644 --- a/atom/browser/native_window_views.cc +++ b/atom/browser/native_window_views.cc @@ -39,6 +39,8 @@ #if defined(USE_X11) #include "atom/browser/ui/views/global_menu_bar_x11.h" #include "atom/browser/ui/views/frameless_view.h" +#include "base/environment.h" +#include "base/nix/xdg_util.h" #include "chrome/browser/ui/libgtk2ui/unity_service.h" #include "ui/gfx/x/x11_types.h" #include "ui/views/window/native_frame_view.h" @@ -59,6 +61,16 @@ const int kMenuBarHeight = 20; const int kMenuBarHeight = 25; #endif +#if defined(USE_X11) +bool ShouldUseGlobalMenuBar() { + // Some DE would pretend to be Unity but don't have global application menu, + // so we can not trust unity::IsRunning(). + scoped_ptr env(base::Environment::Create()); + return unity::IsRunning() && (base::nix::GetDesktopEnvironment(env.get()) == + base::nix::DESKTOP_ENVIRONMENT_UNITY); +} +#endif + class NativeWindowClientView : public views::ClientView { public: NativeWindowClientView(views::Widget* widget, @@ -355,7 +367,7 @@ void NativeWindowViews::SetMenu(ui::MenuModel* menu_model) { RegisterAccelerators(menu_model); #if defined(USE_X11) - if (unity::IsRunning() && !global_menu_bar_) + if (!global_menu_bar_ && ShouldUseGlobalMenuBar()) global_menu_bar_.reset(new GlobalMenuBarX11(this)); // Use global application menu bar when possible.