Use GetDesktopEnvironment to determien desktop env

Which can get a much more precise result for us.
This commit is contained in:
Cheng Zhao 2017-03-29 16:21:38 +09:00
parent f9dbdf4522
commit 6db827cc9a

View file

@ -7,7 +7,9 @@
#include <stdio.h> #include <stdio.h>
#include "base/cancelable_callback.h" #include "base/cancelable_callback.h"
#include "base/environment.h"
#include "base/files/file_util.h" #include "base/files/file_util.h"
#include "base/nix/xdg_util.h"
#include "base/process/kill.h" #include "base/process/kill.h"
#include "base/process/launch.h" #include "base/process/launch.h"
#include "url/gurl.h" #include "url/gurl.h"
@ -98,19 +100,22 @@ void OpenExternal(const GURL& url, bool activate,
bool MoveItemToTrash(const base::FilePath& full_path) { bool MoveItemToTrash(const base::FilePath& full_path) {
std::string trash; std::string trash;
if (getenv(ELECTRON_TRASH) != NULL) { if (getenv(ELECTRON_TRASH) != NULL) {
trash = getenv(ELECTRON_TRASH); trash = getenv(ELECTRON_TRASH);
} else { } else {
// Determine desktop environment and set accordingly. // Determine desktop environment and set accordingly.
std::string desktopEnv = getenv(DESKTOP_SESSION); std::unique_ptr<base::Environment> env(base::Environment::Create());
if (desktopEnv.find("plasma") != std::string::npos) { base::nix::DesktopEnvironment desktop_env(
base::nix::GetDesktopEnvironment(env.get()));
if (desktop_env == base::nix::DESKTOP_ENVIRONMENT_KDE4 ||
desktop_env == base::nix::DESKTOP_ENVIRONMENT_KDE5) {
trash = "kioclient5"; trash = "kioclient5";
} else if (desktopEnv.find("kde") != std::string::npos) { } else if (desktop_env == base::nix::DESKTOP_ENVIRONMENT_KDE3) {
trash = "kioclient"; trash = "kioclient";
} else { } else {
trash = ELECTRON_DEFAULT_TRASH; trash = ELECTRON_DEFAULT_TRASH;
} }
} }
std::vector<std::string> argv; std::vector<std::string> argv;
if (trash.compare("kioclient5") == 0 || trash.compare("kioclient") == 0) { if (trash.compare("kioclient5") == 0 || trash.compare("kioclient") == 0) {