From 10fdc938c50dbea6e6049d436cc7acdd4045b635 Mon Sep 17 00:00:00 2001 From: Andras Schmelczer Date: Fri, 28 Nov 2025 21:27:27 +0000 Subject: [PATCH] Add error on duplicate plugin load --- frontend/obsidian-plugin/src/vault-link-plugin.ts | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/frontend/obsidian-plugin/src/vault-link-plugin.ts b/frontend/obsidian-plugin/src/vault-link-plugin.ts index 4287d636..ad93ba69 100644 --- a/frontend/obsidian-plugin/src/vault-link-plugin.ts +++ b/frontend/obsidian-plugin/src/vault-link-plugin.ts @@ -43,6 +43,14 @@ export default class VaultLinkPlugin extends Plugin { public async onload(): Promise { this.app.workspace.onLayoutReady(async () => { + if ((globalThis as any).VAULT_LINK_RUNNING_INSTANCE) { + new Notice( + "Another instance of VaultLink is already running. Please disable the duplicate instance." + ); + throw new Error("VaultLink instance already running"); + } + (globalThis as any).VAULT_LINK_RUNNING_INSTANCE = this; + const client = await this.createSyncClient(); this.registerObsidianExtensions(client); @@ -188,6 +196,10 @@ export default class VaultLinkPlugin extends Plugin { this.register(() => { editorStatusDisplayManager.dispose(); }); + + this.register(() => { + (globalThis as any).VAULT_LINK_RUNNING_INSTANCE = null; + }); } private addRibbonIcons(): void {