aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2018-05-12 09:47:21 +0900
committerShin'ya Ueoka <ueokande@i-beam.org>2018-05-12 10:54:38 +0900
commita8ac7415f8b5e9e9dc36318a04b7da7775796a88 (patch)
treebeaca04a06f6f02f9222af0e73b3768f994f6acd /src
parent4116d0864213e30a6157edb6e573b0c880a4ec66 (diff)
Fix tab completions
Diffstat (limited to 'src')
-rw-r--r--src/background/actions/command.js1
-rw-r--r--src/background/shared/completions/index.js46
-rw-r--r--src/background/shared/completions/tabs.js4
-rw-r--r--src/background/shared/tabs.js5
4 files changed, 31 insertions, 25 deletions
diff --git a/src/background/actions/command.js b/src/background/actions/command.js
index 888b46f..39e880d 100644
--- a/src/background/actions/command.js
+++ b/src/background/actions/command.js
@@ -68,6 +68,7 @@ const setCommand = (args) => {
};
};
+// eslint-disable-next-line complexity
const exec = (tab, line, settings) => {
let [name, args] = parsers.parseCommandLine(line);
diff --git a/src/background/shared/completions/index.js b/src/background/shared/completions/index.js
index 21c3dd2..728cee7 100644
--- a/src/background/shared/completions/index.js
+++ b/src/background/shared/completions/index.js
@@ -65,6 +65,25 @@ const getOpenCompletions = (command, keywords, searchConfig) => {
});
};
+const getBufferCompletions = (command, keywords, excludePinned) => {
+ return tabs.getCompletions(keywords, excludePinned).then((got) => {
+ let items = got.map((tab) => {
+ return {
+ caption: tab.title,
+ content: command + ' ' + tab.title,
+ url: tab.url,
+ icon: tab.favIconUrl
+ };
+ });
+ return [
+ {
+ name: 'Buffers',
+ items: items
+ }
+ ];
+ });
+};
+
const getCompletions = (line, settings) => {
let typedWords = line.trim().split(/ +/);
let typing = '';
@@ -88,30 +107,17 @@ const getCompletions = (line, settings) => {
return getOpenCompletions(name, keywords, settings.search);
case 'b':
case 'buffer':
- case 'bd':
- case 'bdel':
- case 'bdelete':
+ return getBufferCompletions(name, keywords, false);
case 'bd!':
case 'bdel!':
case 'bdelete!':
- case 'bdeletes':
case 'bdeletes!':
- return tabs.getCompletions(keywords).then((gotTabs) => {
- let items = gotTabs.map((tab) => {
- return {
- caption: tab.title,
- content: name + ' ' + tab.title,
- url: tab.url,
- icon: tab.favIconUrl
- };
- });
- return [
- {
- name: 'Buffers',
- items: items
- }
- ];
- });
+ return getBufferCompletions(name, keywords, false);
+ case 'bd':
+ case 'bdel':
+ case 'bdelete':
+ case 'bdeletes':
+ return getBufferCompletions(name, keywords, true);
}
return Promise.resolve([]);
};
diff --git a/src/background/shared/completions/tabs.js b/src/background/shared/completions/tabs.js
index 5edddca..8c0f1f9 100644
--- a/src/background/shared/completions/tabs.js
+++ b/src/background/shared/completions/tabs.js
@@ -1,7 +1,9 @@
-const getCompletions = (keyword) => {
+const getCompletions = (keyword, excludePinned) => {
return browser.tabs.query({ currentWindow: true }).then((tabs) => {
let matched = tabs.filter((t) => {
return t.url.includes(keyword) || t.title && t.title.includes(keyword);
+ }).filter((t) => {
+ return !(excludePinned && t.pinned);
});
return matched;
});
diff --git a/src/background/shared/tabs.js b/src/background/shared/tabs.js
index a9a677a..d09f676 100644
--- a/src/background/shared/tabs.js
+++ b/src/background/shared/tabs.js
@@ -16,16 +16,13 @@ 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);
- });
+ }).filter(t => !t.pinned);
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);
});
};