gluon: initial linux support
This commit is contained in:
parent
a841844a78
commit
36ef5b7c66
@ -1,7 +1,7 @@
|
|||||||
const rgb = (r, g, b, msg) => `\x1b[38;2;${r};${g};${b}m${msg}\x1b[0m`;
|
const rgb = (r, g, b, msg) => `\x1b[38;2;${r};${g};${b}m${msg}\x1b[0m`;
|
||||||
global.log = (...args) => console.log(`[${rgb(88, 101, 242, 'Gluon')}]`, ...args);
|
global.log = (...args) => console.log(`[${rgb(88, 101, 242, 'Gluon')}]`, ...args);
|
||||||
|
|
||||||
process.versions.gluon = '5.0-dev';
|
process.versions.gluon = '5.1-dev';
|
||||||
|
|
||||||
import { join, dirname } from 'path';
|
import { join, dirname } from 'path';
|
||||||
import { access } from 'fs/promises';
|
import { access } from 'fs/promises';
|
||||||
@ -13,24 +13,30 @@ import Firefox from './browser/firefox.js';
|
|||||||
const __filename = fileURLToPath(import.meta.url);
|
const __filename = fileURLToPath(import.meta.url);
|
||||||
const __dirname = dirname(__filename);
|
const __dirname = dirname(__filename);
|
||||||
|
|
||||||
const browserPathsWin = {
|
const browserPaths = ({
|
||||||
chrome_stable: join(process.env.PROGRAMFILES, 'Google', 'Chrome', 'Application', 'chrome.exe'),
|
win32: {
|
||||||
chrome_canary: join(process.env.LOCALAPPDATA, 'Google', 'Chrome SxS', 'Application', 'chrome.exe'),
|
chrome_stable: join(process.env.PROGRAMFILES, 'Google', 'Chrome', 'Application', 'chrome.exe'),
|
||||||
edge: join(process.env['PROGRAMFILES(x86)'], 'Microsoft', 'Edge', 'Application', 'msedge.exe'),
|
chrome_canary: join(process.env.LOCALAPPDATA, 'Google', 'Chrome SxS', 'Application', 'chrome.exe'),
|
||||||
|
edge: join(process.env['PROGRAMFILES(x86)'], 'Microsoft', 'Edge', 'Application', 'msedge.exe'),
|
||||||
|
|
||||||
firefox: join(process.env.PROGRAMFILES, 'Mozilla Firefox', 'firefox.exe'),
|
firefox: join(process.env.PROGRAMFILES, 'Mozilla Firefox', 'firefox.exe'),
|
||||||
firefox_nightly: join(process.env.PROGRAMFILES, 'Firefox Nightly', 'firefox.exe'),
|
firefox_nightly: join(process.env.PROGRAMFILES, 'Firefox Nightly', 'firefox.exe'),
|
||||||
// todo: add more common good paths/browsers here
|
},
|
||||||
};
|
|
||||||
|
linux: {
|
||||||
|
chromium: 'chromium',
|
||||||
|
firefox: 'firefox',
|
||||||
|
}
|
||||||
|
})[process.platform];
|
||||||
|
|
||||||
const exists = path => access(path).then(() => true).catch(() => false);
|
const exists = path => access(path).then(() => true).catch(() => false);
|
||||||
|
|
||||||
const findBrowserPath = async (forceBrowser) => {
|
const findBrowserPath = async (forceBrowser) => {
|
||||||
if (forceBrowser) return [ browserPathsWin[forceBrowser], forceBrowser ];
|
if (forceBrowser) return [ browserPaths[forceBrowser], forceBrowser ];
|
||||||
|
|
||||||
let whichBrowser = '';
|
let whichBrowser = '';
|
||||||
|
|
||||||
for (const x of Object.keys(browserPathsWin)) {
|
for (const x of Object.keys(browserPaths)) {
|
||||||
if (process.argv.includes('--' + x) || process.argv.includes('--' + x.split('_')[0])) {
|
if (process.argv.includes('--' + x) || process.argv.includes('--' + x.split('_')[0])) {
|
||||||
whichBrowser = x;
|
whichBrowser = x;
|
||||||
break;
|
break;
|
||||||
@ -38,10 +44,10 @@ const findBrowserPath = async (forceBrowser) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!whichBrowser) {
|
if (!whichBrowser) {
|
||||||
for (const x in browserPathsWin) {
|
for (const x in browserPaths) {
|
||||||
log('checking if ' + x + ' exists:', browserPathsWin[x], await exists(browserPathsWin[x]));
|
log('checking if ' + x + ' exists:', browserPaths[x], await exists(browserPaths[x]));
|
||||||
|
|
||||||
if (await exists(browserPathsWin[x])) {
|
if (await exists(browserPaths[x])) {
|
||||||
whichBrowser = x;
|
whichBrowser = x;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -50,7 +56,7 @@ const findBrowserPath = async (forceBrowser) => {
|
|||||||
|
|
||||||
if (!whichBrowser) return null;
|
if (!whichBrowser) return null;
|
||||||
|
|
||||||
return [ browserPathsWin[whichBrowser], whichBrowser ];
|
return [ browserPaths[whichBrowser], whichBrowser ];
|
||||||
};
|
};
|
||||||
|
|
||||||
const getFriendlyName = whichBrowser => whichBrowser[0].toUpperCase() + whichBrowser.slice(1).replace(/[a-z]_[a-z]/g, _ => _[0] + ' ' + _[2].toUpperCase()).replace(' Stable', '');
|
const getFriendlyName = whichBrowser => whichBrowser[0].toUpperCase() + whichBrowser.slice(1).replace(/[a-z]_[a-z]/g, _ => _[0] + ' ' + _[2].toUpperCase()).replace(' Stable', '');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user