diff options
| author | Stephen Blott | 2015-09-17 06:43:16 +0100 | 
|---|---|---|
| committer | Stephen Blott | 2015-09-17 06:43:16 +0100 | 
| commit | 9ab3f42533c0ec30decac8fd84c9decc690e3afd (patch) | |
| tree | c4e1da05cec67d49a130a76e58cc8e2ac51ced11 /background_scripts | |
| parent | 00f7fcdb2dedcaef34c498c862c403b28fdf9c88 (diff) | |
| download | vimium-9ab3f42533c0ec30decac8fd84c9decc690e3afd.tar.bz2 | |
Add <count> prefix for g0 and g$.
`2g0` takes you to the second tab.
`2g$` takes you to the second last tab.
This gives us `gt`/`gT` for relative tab selection and `g0`/`g$` for absolute tab selection.
`<count>` previously had no special meaning for `g0` and `g$`, and it's not clear it could have any other meaning than that implemented here.
Fixes #1298 (kind of).
Diffstat (limited to 'background_scripts')
| -rw-r--r-- | background_scripts/commands.coffee | 4 | ||||
| -rw-r--r-- | background_scripts/main.coffee | 14 | 
2 files changed, 8 insertions, 10 deletions
| diff --git a/background_scripts/commands.coffee b/background_scripts/commands.coffee index 64ec36be..a0b17ebc 100644 --- a/background_scripts/commands.coffee +++ b/background_scripts/commands.coffee @@ -309,8 +309,8 @@ commandDescriptions =    # Manipulating tabs    nextTab: ["Go one tab right", { background: true, passCountToFunction: true }]    previousTab: ["Go one tab left", { background: true, passCountToFunction: true }] -  firstTab: ["Go to the first tab", { background: true }] -  lastTab: ["Go to the last tab", { background: true }] +  firstTab: ["Go to the first tab", { background: true, passCountToFunction: true }] +  lastTab: ["Go to the last tab", { background: true, passCountToFunction: true }]    createTab: ["Create new tab", { background: true, repeatLimit: 20 }]    duplicateTab: ["Duplicate current tab", { background: true, repeatLimit: 20 }] diff --git a/background_scripts/main.coffee b/background_scripts/main.coffee index 1a49c3cb..511d24ac 100644 --- a/background_scripts/main.coffee +++ b/background_scripts/main.coffee @@ -267,8 +267,8 @@ BackgroundCommands =        chrome.windows.create {tabId: tab.id, incognito: tab.incognito}    nextTab: (count) -> selectTab "next", count    previousTab: (count) -> selectTab "previous", count -  firstTab: -> selectTab "first" -  lastTab: -> selectTab "last" +  firstTab: (count) -> selectTab "first", count +  lastTab: (count) -> selectTab "last", count    removeTab: (callback) ->      chrome.tabs.getSelected(null, (tab) ->        chrome.tabs.remove(tab.id) @@ -349,15 +349,13 @@ selectTab = (direction, count = 1) ->        toSelect =          switch direction            when "next" -            currentTab.index + count +            Math.min tabs.length - 1, currentTab.index + count            when "previous" -            currentTab.index - count +            Math.max 0, currentTab.index - count            when "first" -            0 +            Math.min tabs.length - 1, count - 1            when "last" -            tabs.length - 1 -      # Bring toSelect into the range [0,tabs.length). -      toSelect = (toSelect + tabs.length * Math.abs count) % tabs.length +            Math.max 0, tabs.length - count        chrome.tabs.update tabs[toSelect].id, selected: true  updateOpenTabs = (tab, deleteFrames = false) -> | 
