slight refactor and lin cleanup
This commit is contained in:
parent
f8f21815eb
commit
c9da806c84
1 changed files with 46 additions and 56 deletions
|
@ -4,14 +4,14 @@
|
||||||
|
|
||||||
#include "atom/browser/browser.h"
|
#include "atom/browser/browser.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include "atom/browser/native_window.h"
|
#include "atom/browser/native_window.h"
|
||||||
#include "atom/browser/window_list.h"
|
#include "atom/browser/window_list.h"
|
||||||
#include "atom/common/atom_version.h"
|
#include "atom/common/atom_version.h"
|
||||||
#include "base/environment.h"
|
|
||||||
#include "base/command_line.h"
|
#include "base/command_line.h"
|
||||||
|
#include "base/environment.h"
|
||||||
#include "base/process/launch.h"
|
#include "base/process/launch.h"
|
||||||
#include "brightray/common/application_info.h"
|
#include "brightray/common/application_info.h"
|
||||||
|
|
||||||
|
@ -22,7 +22,48 @@
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
bool SetDefaultWebClient(const std::string& protocol);
|
const char kXdgSettings[] = "xdg-settings";
|
||||||
|
const char kXdgSettingsDefaultBrowser[] = "default-web-browser";
|
||||||
|
const char kXdgSettingsDefaultSchemeHandler[] = "default-url-scheme-handler";
|
||||||
|
|
||||||
|
bool LaunchXdgUtility(const std::vector<std::string>& argv, int* exit_code) {
|
||||||
|
*exit_code = EXIT_FAILURE;
|
||||||
|
int devnull = open("/dev/null", O_RDONLY);
|
||||||
|
if (devnull < 0) return false;
|
||||||
|
|
||||||
|
base::LaunchOptions options;
|
||||||
|
|
||||||
|
base::FileHandleMappingVector remap;
|
||||||
|
remap.push_back(std::make_pair(devnull, STDIN_FILENO));
|
||||||
|
options.fds_to_remap = &remap;
|
||||||
|
|
||||||
|
base::Process process = base::LaunchProcess(argv, options);
|
||||||
|
close(devnull);
|
||||||
|
|
||||||
|
if (!process.IsValid())return false;
|
||||||
|
return process.WaitForExit(exit_code);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool SetDefaultWebClient(const std::string& protocol) {
|
||||||
|
#if defined(OS_CHROMEOS)
|
||||||
|
return true;
|
||||||
|
#else
|
||||||
|
std::unique_ptr<base::Environment> env(base::Environment::Create());
|
||||||
|
|
||||||
|
std::vector<std::string> argv;
|
||||||
|
argv.push_back(kXdgSettings);
|
||||||
|
argv.push_back("set");
|
||||||
|
if (!protocol.empty()) {
|
||||||
|
argv.push_back(kXdgSettingsDefaultSchemeHandler);
|
||||||
|
argv.push_back(protocol);
|
||||||
|
}
|
||||||
|
argv.push_back(libgtkui::GetDesktopName(env.get()));
|
||||||
|
|
||||||
|
int exit_code;
|
||||||
|
bool ran_ok = LaunchXdgUtility(argv, &exit_code);
|
||||||
|
return ran_ok && exit_code == EXIT_SUCCESS;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void Browser::Focus() {
|
void Browser::Focus() {
|
||||||
// Focus on the first visible window.
|
// Focus on the first visible window.
|
||||||
|
@ -43,18 +84,11 @@ void Browser::ClearRecentDocuments() {
|
||||||
void Browser::SetAppUserModelID(const base::string16& name) {
|
void Browser::SetAppUserModelID(const base::string16& name) {
|
||||||
}
|
}
|
||||||
|
|
||||||
const char kXdgSettings[] = "xdg-settings";
|
|
||||||
const char kXdgSettingsDefaultBrowser[] = "default-web-browser";
|
|
||||||
const char kXdgSettingsDefaultSchemeHandler[] = "default-url-scheme-handler";
|
|
||||||
|
|
||||||
bool Browser::SetAsDefaultProtocolClient(const std::string& protocol,
|
bool Browser::SetAsDefaultProtocolClient(const std::string& protocol,
|
||||||
mate::Arguments* args) {
|
mate::Arguments* args) {
|
||||||
return SetDefaultWebClient(protocol);
|
return SetDefaultWebClient(protocol);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(codebytere): handle/replace GetChromeVersionOfScript
|
|
||||||
// https://portland.freedesktop.org/doc/xdg-settings.html
|
|
||||||
// https://cs.chromium.org/chromium/src/chrome/browser/shell_integration_linux.cc?sq=package:chromium&l=78
|
|
||||||
bool Browser::IsDefaultProtocolClient(const std::string& protocol,
|
bool Browser::IsDefaultProtocolClient(const std::string& protocol,
|
||||||
mate::Arguments* args) {
|
mate::Arguments* args) {
|
||||||
#if defined(OS_CHROMEOS)
|
#if defined(OS_CHROMEOS)
|
||||||
|
@ -67,9 +101,7 @@ bool Browser::IsDefaultProtocolClient(const std::string& protocol,
|
||||||
std::vector<std::string> argv;
|
std::vector<std::string> argv;
|
||||||
argv.push_back(kXdgSettings);
|
argv.push_back(kXdgSettings);
|
||||||
argv.push_back("check");
|
argv.push_back("check");
|
||||||
if (protocol.empty()) {
|
if (!protocol.empty()) {
|
||||||
argv.push_back(kXdgSettingsDefaultBrowser);
|
|
||||||
} else {
|
|
||||||
argv.push_back(kXdgSettingsDefaultSchemeHandler);
|
argv.push_back(kXdgSettingsDefaultSchemeHandler);
|
||||||
argv.push_back(protocol);
|
argv.push_back(protocol);
|
||||||
}
|
}
|
||||||
|
@ -89,7 +121,7 @@ bool Browser::IsDefaultProtocolClient(const std::string& protocol,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(codebytere): implement method with xdgsettings
|
// Todo implement
|
||||||
bool Browser::RemoveAsDefaultProtocolClient(const std::string& protocol,
|
bool Browser::RemoveAsDefaultProtocolClient(const std::string& protocol,
|
||||||
mate::Arguments* args) {
|
mate::Arguments* args) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -125,46 +157,4 @@ bool Browser::IsUnityRunning() {
|
||||||
return unity::IsRunning();
|
return unity::IsRunning();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Helper Functions */
|
|
||||||
|
|
||||||
bool LaunchXdgUtility(const std::vector<std::string>& argv, int* exit_code) {
|
|
||||||
*exit_code = EXIT_FAILURE;
|
|
||||||
int devnull = open("/dev/null", O_RDONLY);
|
|
||||||
if (devnull < 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
base::LaunchOptions options;
|
|
||||||
base::FileHandleMappingVector remap = *(options.fds_to_remap);
|
|
||||||
remap.push_back(std::make_pair(devnull, STDIN_FILENO));
|
|
||||||
base::Process process = base::LaunchProcess(argv, options);
|
|
||||||
close(devnull);
|
|
||||||
if (!process.IsValid())
|
|
||||||
return false;
|
|
||||||
return process.WaitForExit(exit_code);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool SetDefaultWebClient(const std::string& protocol) {
|
|
||||||
#if defined(OS_CHROMEOS)
|
|
||||||
return true;
|
|
||||||
#else
|
|
||||||
std::unique_ptr<base::Environment> env(base::Environment::Create());
|
|
||||||
|
|
||||||
std::vector<std::string> argv;
|
|
||||||
argv.push_back(kXdgSettings);
|
|
||||||
argv.push_back("set");
|
|
||||||
if (protocol.empty()) {
|
|
||||||
argv.push_back(kXdgSettingsDefaultBrowser);
|
|
||||||
} else {
|
|
||||||
argv.push_back(kXdgSettingsDefaultSchemeHandler);
|
|
||||||
argv.push_back(protocol);
|
|
||||||
}
|
|
||||||
argv.push_back(libgtkui::GetDesktopName(env.get()));
|
|
||||||
|
|
||||||
int exit_code;
|
|
||||||
bool ran_ok = LaunchXdgUtility(argv, &exit_code);
|
|
||||||
|
|
||||||
return ran_ok && exit_code == EXIT_SUCCESS;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue