app: quit other instance when starting

This commit is contained in:
Jeffrey Morgan 2023-07-27 00:02:13 -04:00
parent 8ba0f328af
commit 31673d26d0

View file

@ -1,15 +1,5 @@
import { spawn } from 'child_process' import { spawn, ChildProcess } from 'child_process'
import { import { app, autoUpdater, dialog, Tray, Menu, BrowserWindow, MenuItemConstructorOptions } from 'electron'
app,
autoUpdater,
dialog,
Tray,
Menu,
BrowserWindow,
MenuItemConstructorOptions,
nativeTheme,
systemPreferences,
} from 'electron'
import Store from 'electron-store' import Store from 'electron-store'
import winston from 'winston' import winston from 'winston'
import 'winston-daily-rotate-file' import 'winston-daily-rotate-file'
@ -17,10 +7,13 @@ import * as path from 'path'
import { analytics, id } from './telemetry' import { analytics, id } from './telemetry'
import { installed } from './install' import { installed } from './install'
import { MenuItem } from '@electron/remote'
require('@electron/remote/main').initialize() require('@electron/remote/main').initialize()
if (require('electron-squirrel-startup')) {
app.quit()
}
const store = new Store() const store = new Store()
let welcomeWindow: BrowserWindow | null = null let welcomeWindow: BrowserWindow | null = null
@ -39,9 +32,32 @@ const logger = winston.createLogger({
format: winston.format.printf(info => info.message), format: winston.format.printf(info => info.message),
}) })
const SingleInstanceLock = app.requestSingleInstanceLock() app.on('ready', () => {
if (!SingleInstanceLock) { const gotTheLock = app.requestSingleInstanceLock()
app.quit() if (!gotTheLock) {
app.exit(0)
}
app.on('second-instance', () => {
if (app.hasSingleInstanceLock()) {
app.releaseSingleInstanceLock()
}
if (proc) {
proc.off('exit', restart)
proc.kill()
}
app.exit(0)
})
app.focus({ steal: true })
init()
})
if (process.platform === 'darwin') {
app.dock.hide()
} }
function firstRunWindow() { function firstRunWindow() {
@ -63,13 +79,8 @@ function firstRunWindow() {
require('@electron/remote/main').enable(welcomeWindow.webContents) require('@electron/remote/main').enable(welcomeWindow.webContents)
// and load the index.html of the app.
welcomeWindow.loadURL(MAIN_WINDOW_WEBPACK_ENTRY) welcomeWindow.loadURL(MAIN_WINDOW_WEBPACK_ENTRY)
welcomeWindow.on('ready-to-show', () => welcomeWindow.show()) welcomeWindow.on('ready-to-show', () => welcomeWindow.show())
if (process.platform === 'darwin') {
app.dock.hide()
}
} }
let tray: Tray | null = null let tray: Tray | null = null
@ -106,16 +117,14 @@ function setTray(updateAvailable: boolean) {
tray.setImage(iconPath) tray.setImage(iconPath)
} }
if (require('electron-squirrel-startup')) { let proc: ChildProcess = null
app.quit()
}
function server() { function server() {
const binary = app.isPackaged const binary = app.isPackaged
? path.join(process.resourcesPath, 'ollama') ? path.join(process.resourcesPath, 'ollama')
: path.resolve(process.cwd(), '..', 'ollama') : path.resolve(process.cwd(), '..', 'ollama')
const proc = spawn(binary, ['serve']) proc = spawn(binary, ['serve'])
proc.stdout.on('data', data => { proc.stdout.on('data', data => {
logger.info(data.toString().trim()) logger.info(data.toString().trim())
@ -125,23 +134,21 @@ function server() {
logger.error(data.toString().trim()) logger.error(data.toString().trim())
}) })
function restart() { proc.on('exit', restart)
setTimeout(server, 3000)
} }
proc.on('exit', restart) function restart() {
setTimeout(server, 1000)
}
app.on('before-quit', () => { app.on('before-quit', () => {
if (proc) {
proc.off('exit', restart) proc.off('exit', restart)
proc.kill() proc.kill()
}
}) })
}
if (process.platform === 'darwin') { function init() {
app.dock.hide()
}
app.on('ready', () => {
if (app.isPackaged) { if (app.isPackaged) {
heartbeat() heartbeat()
autoUpdater.checkForUpdates() autoUpdater.checkForUpdates()
@ -198,7 +205,7 @@ app.on('ready', () => {
// This is the first run or the CLI is no longer installed // This is the first run or the CLI is no longer installed
app.setLoginItemSettings({ openAtLogin: true }) app.setLoginItemSettings({ openAtLogin: true })
firstRunWindow() firstRunWindow()
}) }
// Quit when all windows are closed, except on macOS. There, it's common // Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits // for applications and their menu bar to stay active until the user quits