mirror of
https://github.com/zen-browser/surfer.git
synced 2025-07-07 17:05:33 +02:00
🐛 Don't delete the engine directory every download
The primary justification for this is adding/updating extensions. Ideally, you should just be able to run `download` again to get the new extensions, which the current implementation does not allow for.
This commit is contained in:
parent
c5db3d7b6a
commit
97a87f5eb4
3 changed files with 18 additions and 6 deletions
|
@ -19,6 +19,7 @@ import {
|
|||
unpackAddon,
|
||||
} from './addon'
|
||||
import { configPath } from '../../utils'
|
||||
import { readdir } from 'node:fs/promises'
|
||||
|
||||
export function shouldSetupFirefoxSource() {
|
||||
return !(
|
||||
|
@ -111,7 +112,7 @@ async function downloadFirefoxSource(version: string) {
|
|||
}
|
||||
|
||||
export async function downloadInternals(version: string) {
|
||||
// If gFFVersion isn't specified, provide legible error
|
||||
// Provide a legible error if there is no version specified
|
||||
if (!version) {
|
||||
log.error(
|
||||
'You have not specified a version of firefox in your config file. This is required to build a firefox fork.'
|
||||
|
@ -119,9 +120,15 @@ export async function downloadInternals(version: string) {
|
|||
process.exit(1)
|
||||
}
|
||||
|
||||
if (existsSync(ENGINE_DIR)) {
|
||||
log.info("Deleting engine/")
|
||||
rmSync(ENGINE_DIR)
|
||||
// If the engine directory is empty, we should delete its contents
|
||||
const engineIsEmpty = await readdir(ENGINE_DIR).then((files) => files.length === 0)
|
||||
if (existsSync(ENGINE_DIR) && engineIsEmpty) {
|
||||
log.info("'engine/' is empty, deleting contents...")
|
||||
rmSync(ENGINE_DIR, { recursive: true })
|
||||
|
||||
}
|
||||
|
||||
if (!existsSync(ENGINE_DIR)) {
|
||||
await setupFirefoxSource(version)
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue