From b91e53e5feff66c1744faa930f4a79f493f91875 Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Thu, 10 May 2018 22:16:38 +0900 Subject: [PATCH] Add bdlete/bdelete! commands --- src/background/actions/command.js | 8 +++++ src/background/shared/completions/index.js | 6 ++++ src/background/shared/tabs.js | 37 +++++++++++++++++++++- 3 files changed, 50 insertions(+), 1 deletion(-) diff --git a/src/background/actions/command.js b/src/background/actions/command.js index fa040ff..888b46f 100644 --- a/src/background/actions/command.js +++ b/src/background/actions/command.js @@ -84,6 +84,14 @@ const exec = (tab, line, settings) => { case 'b': case 'buffer': return bufferCommand(args); + case 'bd': + case 'bdel': + case 'bdelete': + return tabs.closeTabByKeywords(args.join(' ')); + case 'bd!': + case 'bdel!': + case 'bdelete!': + return tabs.closeTabByKeywordsForce(args.join(' ')); case 'bdeletes': return tabs.closeTabsByKeywords(args.join(' ')); case 'bdeletes!': diff --git a/src/background/shared/completions/index.js b/src/background/shared/completions/index.js index 77394bc..21c3dd2 100644 --- a/src/background/shared/completions/index.js +++ b/src/background/shared/completions/index.js @@ -88,6 +88,12 @@ const getCompletions = (line, settings) => { return getOpenCompletions(name, keywords, settings.search); case 'b': case 'buffer': + case 'bd': + case 'bdel': + case 'bdelete': + case 'bd!': + case 'bdel!': + case 'bdelete!': case 'bdeletes': case 'bdeletes!': return tabs.getCompletions(keywords).then((gotTabs) => { diff --git a/src/background/shared/tabs.js b/src/background/shared/tabs.js index c90ac4b..a9a677a 100644 --- a/src/background/shared/tabs.js +++ b/src/background/shared/tabs.js @@ -12,6 +12,40 @@ const closeTabForce = (id) => { return browser.tabs.remove(id); }; +const closeTabByKeywords = (keyword) => { + return browser.tabs.query({ currentWindow: true }).then((tabs) => { + let matched = tabs.filter((t) => { + return t.url.includes(keyword) || t.title.includes(keyword); + }); + + if (matched.length === 0) { + throw new Error('No matching buffer for ' + keyword); + } else if (matched.length > 1) { + throw new Error('More than one match for ' + keyword); + } + if (matched[0].pinned) { + throw new Error('Cannot close a pinned tab (add ! to override)'); + } + browser.tabs.remove(matched[0].id); + }); +}; + +const closeTabByKeywordsForce = (keyword) => { + return browser.tabs.query({ currentWindow: true }).then((tabs) => { + let matched = tabs.filter((t) => { + return t.url.includes(keyword) || t.title.includes(keyword); + }); + + if (matched.length === 0) { + throw new Error('No matching buffer for ' + keyword); + } else if (matched.length > 1) { + throw new Error('More than one match for ' + keyword); + } + browser.tabs.remove(matched[0].id); + }); +}; + + const closeTabsByKeywords = (keyword) => { tabCompletions.getCompletions(keyword).then((tabs) => { let tabs2 = tabs.filter(tab => !tab.pinned); @@ -134,7 +168,8 @@ const duplicate = (id) => { }; export { - closeTab, closeTabForce, closeTabsByKeywords, closeTabsByKeywordsForce, + closeTab, closeTabForce, closeTabByKeywords, closeTabByKeywordsForce, + closeTabsByKeywords, closeTabsByKeywordsForce, reopenTab, selectAt, selectByKeyword, selectPrevTab, selectNextTab, selectFirstTab, selectLastTab, selectTab, reload, updateTabPinned,