1 ### 0.14.1 (2016-04-30)
3 - Fixed: The Find commands (such as `/`, `n` and `N`) no longer crash on some
4 sites (regression since 0.14.0).
6 ### 0.14.0 (2016-04-29)
8 - Added: [Caret mode], which lets you copy text from web pages using the
10 - Improved: The Find commands (such as `/`, `n` and `N`) now search from the top
11 of the viewport, instead of from the top of the document, which is more
12 Vim-like and less disorienting. To read more about it (or to return to the
13 Firefox default behavior) please see the [`find_from_top_of_viewport`] pref.
14 - Improved: Compatibility with the [BackTrack Tab History] add-on.
15 - Added: The `<c-enter>` Hints mode command, which creates hint markers for
17 - Fixed: `__dirname` inside config files now works on Windows. Thanks to
18 Zhong Jianxin (@azuwis)!
19 - Fixed: Unnecessary full-page hint markers on some sites, such as Hackernews,
22 [Caret mode]: https://github.com/akhodakivskiy/VimFx/blob/4ffda62560096f91244f3f7731171002ed174f05/documentation/commands.md#the-v-commands--caret-mode
23 [`find_from_top_of_viewport`]: https://github.com/akhodakivskiy/VimFx/blob/4ffda62560096f91244f3f7731171002ed174f05/documentation/options.md#find_from_top_of_viewport
24 [BackTrack Tab History]: https://addons.mozilla.org/firefox/addon/backtrack-tab-history/
26 ### 0.13.2 (2016-04-08)
28 - Improved: The “last position mark” `` ` `` now works more reliably.
29 - Improved: More video players are now recognized. Many video players lets you
30 press `<space>` while focused to toggle play/pause. VimFx tries to detect if
31 the currently focused element is a video player. If so, `<space>` is passed to
32 the video player instead of scrolling the page. (For those interested, see
33 also the [`adjustable_element_keys`] pref.)
35 [`adjustable_element_keys`]: https://github.com/akhodakivskiy/VimFx/blob/645e35d7d82019b0551534c43926bc126e7105bd/documentation/options.md#adjustable_element_keys
37 ### 0.13.1 (2016-04-01)
39 - Fixed: Blacklisting of some XUL pages.
40 - Fixed: The current mode is no longer lost when a page loads. For example, if
41 you press `zF` while a page is loading, the markers no longer disappear.
42 - Fixed: Elements that you have focused using an `f` command no longer get stuck
43 appearing as if you’d put the mouse pointer.
44 - Updated locale: zh-CN. Thanks to @mozillazg!
46 ### 0.13.0 (2016-03-19)
48 - Added: The `T` command, which opens a new tab after the current.
49 - Changed: The `gl` command now deals with _visited_ tabs only.
50 - Added: The [`gL`] command, which deals with <em>un</em>visited tabs only, in
51 oldest-first order. Use this to step through your unvisited background tabs in
52 the order you opened them (for example using the `F` command).
53 - Improved: The `gi` command no longer tries to focus the last focused text
54 input if it has been removed from the page. If so, it finds a new one instead.
55 - Fixed: You can now type in sidebar text inputs (such as in the history
56 sidebar) without having to switch to Ignore mode.
57 - Changed: If you enter Ignore mode you will now stay in Ignore mode in that tab
58 until you explicitly exit it (by pressing `<s-escape>`), even if you reload
59 the page or follow a link. If Ignore mode was entered automatically because of
60 the [blacklist][blacklist-2], though, you will be automatically returned to
62 the URL changes to a non-blacklisted page.
63 - Added: VimFx can now automatically enter and exit Ignore mode based on the
64 currently focused element. Currently, the [wasavi] extension as well as
65 [CodeMirror] in Vim mode are detected. Both of those provide Vim-style
66 editors. This allows sending `<escape>` to those editors in order to exit
67 their Insert mode, without blurring the editor.
68 - Improved: CodeMirror editors now get better hints, keeping the cursor where
70 - Improved: The [blacklist][blacklist-2] is now applied faster on some pages.
71 - Improved: Many audio and video elements are now recognized as “adjustable”,
72 allowing you to press for example `<space>` on them to toggle play/pause,
73 without scrolling the page.
74 - Improved: Scrolling by pages, such as using the `<space>` command, now takes
75 fixed heaears and footers into account, just like Firefox does.
76 - Fixed: Access keys now work correctly in context menus in the devtools and
78 - Improved: The arrow keys now Just Work in the devtools, even if you have bound
79 them to VimFx commands.
80 - Changed: The public API has been removed, and turned into the Config file API.
81 If you were already using a config file, it will no longer work. You need to
82 set up a new one, but you should be able to simply copy and paste the contents
83 of the old one into the new one. Read the [config file] documentation for more
85 - Changed: There are a few minor breaking changes to the API, though I doubt it
87 - If you use [`vimfx.on`], you probably need to adjust the arguments of the
88 your callbacks. They are now _always_ passed an object of data, instead of
89 sometimes passing the data directly.
90 - `match.focus` of [match object]s has been removed, and replaced by
91 `vim.focusType` of [vim object]s.
92 - Fixed: The toolbar button’s icon is now correctly sized when setting
93 `layout.css.devPixelsPerPx` to `2`. Thanks to Robert Ma (@Hexcles) and Dale
95 - Fixed: Find commands now work when the find bar was opened before the page had
97 - Improved: Lots of internal improvements. This should make VimFx faster, more
98 reliable and more responsive.
99 - All keyboard event handling (except `<late>` shortcuts) are now handled in
100 the UI process, instead of mostly in each tab’s web page content process.
101 This should make VimFx’s shortcuts more reliable and responsive.
102 - Removed all synchronous message passing (execpt for `<late>` keypresses).
103 Mozilla recommends using them only where absolutely necessary. Turns out
104 VimFx doesn’t need them anymore!
105 - The `f` commands are now more reliable. Before, they could crash on rare
106 occasions (on certain web pages), but that is less likely now.
107 - Less `MutationObserver`s are now used. This should improve performance.
108 - Less uncaught errors (especially on shutdown).
109 - Lots of minor improvements.
110 - Updated locale: ja. Thanks to Kaoru Esashika (@pluser)!
112 [`gL`]: https://github.com/akhodakivskiy/VimFx/blob/44b3e1bc350ceb1560176ee5b4ae97d9671a04db/documentation/commands.md#gl-1
113 [blacklist-2]: https://github.com/akhodakivskiy/VimFx/blob/44b3e1bc350ceb1560176ee5b4ae97d9671a04db/documentation/options.md#blacklist
114 [wasavi]: http://appsweets.net/wasavi/
115 [CodeMirror]: https://codemirror.net/demo/vim.html
116 [config file]: https://github.com/akhodakivskiy/VimFx/blob/44b3e1bc350ceb1560176ee5b4ae97d9671a04db/documentation/config-file.md
117 [`vimfx.on`]: https://github.com/akhodakivskiy/VimFx/blob/44b3e1bc350ceb1560176ee5b4ae97d9671a04db/documentation/api.md#vimfxoneventname-listener-and-vimfxoffeventname-listener
118 [match object]: https://github.com/akhodakivskiy/VimFx/blob/44b3e1bc350ceb1560176ee5b4ae97d9671a04db/documentation/api.md#match-object
119 [vim object]: https://github.com/akhodakivskiy/VimFx/blob/44b3e1bc350ceb1560176ee5b4ae97d9671a04db/documentation/api.md#vim-object
121 ### 0.12.0 (2016-02-03)
123 - Improved: More clickable elements are now recognized. Most notably, elements
124 with click event listeners added by JavaScript now get hints.
125 - Improved: Autofocus prevention after using the `[` and `]` commands.
126 - Added: In VimFx’s Keyboard Shortcuts help dialog (which can be opened by
127 pressing `?`) you can now click on any command to open VimFx’s settings page
128 in the Add-ons Manager and automatically select the text input for that
129 command, letting you edit its shortcuts. Tip: Use the `zF` command to click
130 without using the mouse.
131 - Changed: Autofocus is no longer prevented in Firefox internal pages, such as
132 `about:preferences`, `about:addons` and `about:config` (as well as other XUL
134 - Fixed: VimFx and the Beyond Australis extension do not conflict with each
136 - Fixed: The `gH` command no longer nags you about “No back/forward history”
137 even though there is.
138 - Added: The `gl` command now takes a [count][gl-count].
139 - Improved: Optimized CPU usage in Hints mode. (See also the [`hints_sleep`]
141 - Improved: The `H` and `L` commands should now be more reliable in Firefox 43
143 - Changed: There was a tiny breaking change to the Public API, though I doubt it
144 will affect anyone. (See [commit 0ca807605e] if you’re especially interested.)
145 - Improved: _Several_ minor things, and some really nice internal refactoring.
146 - Updated locale: de. Thanks to @just-barcodes!
148 [`hints_sleep`]: https://github.com/akhodakivskiy/VimFx/blob/92b483c4a4f6da0b2c998267e0f01d3d999f93b6/documentation/options.md#hints_sleep
149 [gl-count]: https://github.com/akhodakivskiy/VimFx/blob/92b483c4a4f6da0b2c998267e0f01d3d999f93b6/documentation/commands.md#gl
150 [commit 0ca807605e]: https://github.com/akhodakivskiy/VimFx/commit/0ca807605e8d69fdc01ef9ce5d539cf66ce7d96f
152 ### 0.11.0 (2016-01-15)
154 - Fixed: The `` ` `` command is no longer broken.
155 - Fixed: Memory leak.
156 - Added: The `gl` command, which takes you to the most recent tab.
157 - Improved: The Keyboard Shortcuts help dialog is now scrollable using VimFx’s
158 scrolling commands. To allow for this, the search field is no longer
159 autofocused. Instead, press `/` to open it.
160 - Improved: Using the `f` commands, such as `f` and `zf`, now works like
161 actually moving your mouse onto the link, making hover menus and such-like
163 - Improved: VimFx should now work better with Google Drive Documents, Etherpad
164 and a few other fancy text editors.
165 - Improved: The `]` command now works on google.com.
166 - Improved: Checkboxes and menu items on gmail.com are now given hints by the
168 - Improved: The `gi` command now also recognizes 'contenteditable' elements.
169 - Improved: Hint markers now move along together with their elements.
170 - Fixed: Hint markers should now be correctly positioned when zooming.
171 - Fixed: The toolbar button icon should now look correctly on Retina screens.
172 - Added: You may now disable counts by using toggling the [`counts_enabled`]
174 - Updated locale: de. Thanks to @just-barcodes!
175 - Improved: Several minor things.
177 [`counts_enabled`]: https://github.com/akhodakivskiy/VimFx/blob/8dae7aec9008595da31b939d5ae2d239849cf6dc/documentation/options.md#counts_enabled
179 ### 0.10.0 (2015-12-09)
181 - Added: The `zF` command, which lets you click browser elements.
182 - Improved: The scrolling commands can now scroll browser elements (in other
183 words, not only web page content), by first selecting the scollable element
185 - Added: The `gr` command, which toggles [Reader View].
186 - Added: The `gX` command, which opens the Recently Closed Tabs menu at the
187 middle of the screen.
188 - Added: The keys you’ve typed so far of a command, as well the count, are now
189 shown in a [notification]. (You may disable this using the
190 [`notify_entered_keys`] pref.)
191 - Improved: When commands don’t do anything, they show a [notification] instead,
192 letting you know that you actually pressed the right keys. For example, if you
193 press `f` but there are no markable elements visible, a notification is shown
194 telling you so, instead of silently doing nothing.
195 - Improved: `<space>` now scrolls _about a line less_ than a full page, just
196 like Firefox does by default. `d` scroll about _half_ a line less (by
197 default), so that pressing `d` twice works like pressing `<space>` once. (See
198 the [`scroll.full_page_adjustment` and `scroll.half_page_adjustment`] prefs
199 for more information.)
200 - Improved: `gi` now only selects all text in its text input if you haven’t
201 focused a text input yet (allowing you to easily replace pre-filled text),
202 instead of _always_ doing so. Otherwise, it now puts the cursor where you left
203 off typing the last time.
204 - Fixed: The `f` commands now put the cursor where you left off typing the last
205 time when focusing a text input. Previously, they accidentally selected all
206 text in the text input (use `zf` for that behavior).
207 - Fixed: Yet a scrolling fix. VimFx’s scrolling commands should now “just work”
209 - Fixed: AltGr should now work out of the box on Windows. (See the
210 [`ignore_ctrl_alt`] pref for more information.)
211 - Removed: The el-GR, hu and pl locales were sadly too out of date to be useful,
212 and nobody has shown interest in updating them, so they were removed.
213 - Updated locales: id, de and zh-CN. Thanks to Yoppy Halilintar, @just-barcodes
215 - Fixed: Several tiny bugs.
217 [Reader View]: https://support.mozilla.org/kb/firefox-reader-view-clutter-free-web-pages
218 [notification]: https://github.com/akhodakivskiy/VimFx/blob/ba9d4675e19ce315e6855b64400aae092e727975/documentation/notifications.md
219 [`notify_entered_keys`]: https://github.com/akhodakivskiy/VimFx/blob/ba9d4675e19ce315e6855b64400aae092e727975/documentation/options.md#notify_entered_keys
220 [`scroll.full_page_adjustment` and `scroll.half_page_adjustment`]: https://github.com/akhodakivskiy/VimFx/blob/ba9d4675e19ce315e6855b64400aae092e727975/documentation/options.md#scrollfull_page_adjustment-and-scrollhalf_page_adjustment
221 [`ignore_ctrl_alt`]: https://github.com/akhodakivskiy/VimFx/blob/ba9d4675e19ce315e6855b64400aae092e727975/documentation/options.md#ignore_ctrl_alt
223 ### 0.9.0 (2015-12-02)
225 - Fixed: Links with the `onclick` attribute can now be opened in new tabs again.
226 (Regression since 0.8.0.)
227 - Fixed: The text size in VimFx’s Keyboard Shortcuts help dialog is now
229 - Added: The `gH` command. It opens the back/forward button context menu in the
230 middle of the window, allowing you to choose a history entry with the arrow
233 ### 0.8.0 (2015-12-01)
235 - Fixed: VimFx now works properly in tabs moved to other windows.
236 - Fixed: An unreliable check for multi-process mode has been eliminated, fixing
237 various problems for some users.
238 - Fixed: VimFx’s toolbar button now changes color correctly when switching
239 between blacklisted and non-blacklisted tabs.
240 - Fixed: Dead keys now work out of the box on Windows.
241 - Improved: Links with the `onclick` attribute (abused as buttons) can no longer
242 get the same hint as another link.
243 - Added: The Keyboard Shortcuts help dialog (shown by pressing `?`) is now
245 - Added: The `g/` command. It’s like `/` but searches links only.
249 - Use `ma` to mark the current scroll position and `` `a `` to return to it.
250 (You may substitute `a` with any key press.)
251 - Use ``` `` ``` to return to the position before the last `gg`, `G`, `0`,
252 `$`, `/`, `n`, `N` or `` ` ``. (You can change this mark using the
253 [`last_scroll_position_mark`] pref.)
255 - Added: Window commands.
257 - `w`: Open new window.
258 - `W`: Open new private window.
259 - `gw`: Move tab to new window.
260 - `gF`: Follow link in new window.
262 [Marks]: https://github.com/akhodakivskiy/VimFx/blob/47fc699ce8217ee90af4d12e81f102f2bea09d61/documentation/commands.md#marks-m-and-
263 [`last_scroll_position_mark`]: https://github.com/akhodakivskiy/VimFx/blob/47fc699ce8217ee90af4d12e81f102f2bea09d61/documentation/options.md#last_scroll_position_mark
265 ### 0.7.3 (2015-11-22)
267 - Fixed: Scrolling now works correctly in pages in quirks mode (lacking a
268 doctype), such as Hackernews.
269 - Improved: The largest scrollable element is now detected better in frames.
270 - Fixed: Hints mode now exits correctly when focusing a text input using `af`,
273 ### 0.7.2 (2015-11-21)
275 - Fixed: The blinking text caret now always appears correctly when focusing text
278 ### 0.7.1 (2015-11-21)
280 - Fixed: The scrolling commands should now “just work” when using non-default
281 zoom or DPI settings, most notably on Google Groups.
283 ### 0.7.0 (2015-11-19)
285 - Changed: Instead of using system notifications, which turned out to be a bit
286 too intrusive, [notifications] are now similar to the “URL popup” (shown when
287 hovering or focusing links) but are placed on the opposite side,.
288 - Changed: The “Focus next element” and “Focus previous element” commands have
289 been removed. The reason they existed was to let `<tab>` and `<s-tab>` only
290 cycle between text inputs (as opposed to _all_ focusable elements) after
291 you’ve pressed `gi`. Now, `<tab>` and `<s-tab>` are handled specially instead,
292 and _only_ after pressing `gi`. The reason for this change is that the now
293 removed commands were too intrusive, breaking user habits. One of VimFx’s main
294 goal is _not_ to do that. (You can turn the special handling of `<tab>` and
295 `<s-tab>` off using the the new [`focus_previous_key` and `focus_next_key`]
297 - Fixed: The scrolling commands should now “just work” in a lot more situations,
298 most notably on Gmail and Google Groups. More scrollable elements are also
299 recognized by the `f` and `zf` commands.
300 - Improved: The right border of hint markers for scrollable elements is now
301 styled to remind of a scroll bar, making them easier to recognize among hints
303 - Improved/Changed: `J` and `gJ` now allow a count on the first tab.
304 Consequently, `K` and `gK` now allow a count on the _last_ tab.
305 - Changed: `gJ` and `gK` can no longer be used to pin or unpin tabs. They now
306 only wrap around tabs of the same pinned state. Use `gp` to toggle between
307 pinned and non-pinned.
308 - Fixed: Many elements that got a hint before VimFx 0.6.0 now do again.
309 - Improved: Comment fields on Facebook can now be focused using `f` and blurred
311 - Improved: VimFx’s toolbar button is no greyed out when you focus a text input.
312 This is to show that your key presses will be passed into the text input
313 rather than activating VimFx commands.
314 - Added: [`g0`, `g^` and `g$` now accept counts][tab-index-counts], allowing you
315 to go to tab number _count._
316 - Improved: `gi` now finds text inputs inside frames.
317 - Fixed: “gi mode” is now exited properly when blurring a text input.
318 - Fixed: `<select>` elements are no longer considered to be text inputs when
319 using `<tab>` and `<s-tab>` in “gi mode.”
320 - Fixed: Using `<force>` or `<late>` in a shortcut no longer applies to _every_
321 shortcut for the command, but only that shortcut.
322 - Fixed: The order of the Previous/Next page patterns is now respected. This
323 caused the wrong link to be picked by the `[` and `]` commands on some pages.
325 [`focus_previous_key` and `focus_next_key`]: https://github.com/akhodakivskiy/VimFx/blob/d70b5bb14be89d9ce52138b0e9abdef1b31ad337/documentation/options.md#focus_previous_key-and-focus_next_key
326 [notifications]: https://github.com/akhodakivskiy/VimFx/blob/d70b5bb14be89d9ce52138b0e9abdef1b31ad337/documentation/notifications.md
327 [tab-index-counts]: https://github.com/akhodakivskiy/VimFx/blob/d70b5bb14be89d9ce52138b0e9abdef1b31ad337/documentation/commands.md#g0-g-g
329 ### 0.6.2 (2015-11-11)
331 - Improved: If the entire page isn’t scrollable, the largest scrollable element
333 - Fixed: VimFx’s keyboard shortcuts now works on slowly loading pages.
334 - Fixed: Numbers may now be used as shortcut keys (overriding counts).
335 - Fixed: The toolbar button’s icon is now correctly sized in high DPI.
336 - Fixed: Hint markers are now correctly positioned when zooming using the “Zoom
338 - Fixed: The `P` command now works with the InstantFox add-on.
340 ### 0.6.1 (2015-11-10)
342 - Fixed: If you customized the “esc” command before VimFx 0.6.0 it should now
344 - Fixed: `<tab>` now works as expected in the location bar and in the dev tools.
345 - Fixed: Light-weight themes can no longer make VimFx’s Keyboard Shortcuts help
346 dialog and hint markers unreadable.
347 - Added: The [notifications\_enabled] option.
349 [notifications\_enabled]: https://github.com/akhodakivskiy/VimFx/blob/56c4b7c514ea8b58d2cdcecf3d2654648c48ca31/documentation/options.md#notifications_enabled
351 ### 0.6.0 (2015-11-09)
353 ##### Most important (breaking) changes
355 - VimFx now works properly with **any keyboard layout.** Users of **multiple
356 layouts** should enable the **[ignore keyboard layout] option.** #249 #259
358 - Features related to disabling VimFx, and to the [toolbar button]:
360 - **Insert Mode** has been renamed to **_Ignore_ mode.**
361 - **[Blacklisted][blacklist] sites** now **enter Ignore mode automatically,**
362 instead of being specially handled.
363 - The feature to click the toolbar button (or press `<a-V>`) to **disable
364 VimFx** has been **removed.** Use **Ignore mode** (`i`) and the
365 **[blacklist] instead.**
366 - The **toolbar button** is now **red in Ignore mode** (which also means that
367 it is red on blacklisted sites) and green otherwise (never grey anymore).
368 - The toolbar button no longer offers to (un-)blacklist the current domain.
369 (Head into VimFx’s settings page in the Add-ons Manager and add
370 `*currentdomain.com*` to the [blacklist] option yourself instead.)
372 (See [commit 3552282] for more information.)
374 - **Some default shortcuts have changed,** mostly because they conflicted with
375 standard Firefox shortcuts: #308
381 - `g^` and `gH` → `g0`
383 `g^` now selects the first _non pinned_ tab instead, while `g0`
384 selects the first tab regardless of whether it is pinned or not. #317
386 - `<c-e>` (alias for `j`) and `<c-y>` (alias for `k`) have been removed.
388 - `<c-f>` → `<space>` and `<c-b>` → `<s-space>`
392 This frees up `v` for future shortcuts (instead making `z` a
393 “namespace” key, just like in Vim).
395 - To **exit Ignore mode:** `<escape>` → `<s-escape>`. This is because Ignore
396 mode has replaced the disable feature, as well as the special blacklist
397 state (see above). Sites are likely to use `<escape>` but not `<s-escape>`.
398 (In a way, this new role of Ignore mode also means that the old (many times
399 broken) shortcut to disable VimFx (`<a-V>`) has been replaced by `i`.) #64
402 - VimFx’s Keyboard Shortcuts help dialog is now help only, and more accessible.
403 To **customize keyboard shortcuts,** go to VimFx’s settings page **in the
404 Add-ons Manager,** just like you would to customize other settings. Also,
405 **commas** between every key are **no longer needed:** Type `gJ` instead of
408 - For performance reasons, **Hint markers** are now placed vertically **centered
409 instead of at the top** of the element. Don’t be surprised if you see the same
410 hint repeated several times**—links that go to the same place now get the same
411 hint.** The “Smart hints” option has been removed—hints are _always_ smart
412 now, and a lot smarter than before. Finally, hints now also work in the new
413 tab page, the Add-ons Manager and the preferences page. If you want to, you
414 can read more about [the `f` commands]. \#51 #60 #176 #320 #325 #468 #471 #475
416 - The **`F`** command now _always_ opens tabs in new **background** tabs, while
417 **`gf`** has been added to open tabs in new **foreground** tabs. #227 #464
419 - **Autofocus prevention** is now **off by default.** One of VimFx’s core
420 philosophies is to be nice to your browser habits. Some find autofocus
421 prevention too big a change. Turn it on again if you like it! By the way,
422 autofocus prevention now works much more reliably and should not cause issues
423 with other extensions. #497 #541
425 - The **“Scroll step”** option has been **removed**. The scrolling commands that
426 used it now **work like the arrow keys instead,** and are customized just like
427 them. See [scrolling prefs] for more information.
429 - Speaking of scrolling, **which elements scrolls** when you use VimFx’s
430 scrolling commands **has changed.** See [scrolling commands] for more
437 - `gp` pins or unpins the current tab. (Also see `g^` and `g0` mentioned
439 - `yt` duplicates the current tab. #121
440 - `0` and `^` scroll to the far left, and `$` scrolls to the far right.
441 - [`gi`] has finally been implemented. #47
442 - [Ignore mode `<s-f1>`] let you run a Normal mode command without exiting
445 - In Hints mode you can now hold ctrl and alt to change behavior of the matched
446 marker. Hold shift to temporarily make the hints see-through. See [the `f`
447 commands] for more information. #220 #421 #484
449 - Some commands now accept [counts]. #374
451 - It is now possible to create shortcuts that work inside text inputs. See the
452 [`<force>`] key for more information. #258
454 - It is now possible to create shortcuts that the page can override. See the
455 [`<late>`] key for more information.
457 - A number of [advanced options] have been added. Rather than listing everything
458 regarding them here, follow that link if you’re interested. #452 #489
460 - You may now, if you want to, configure VimFx through a [config file], using
461 the new [public API]. Customizing VimFx through a config file also gives extra
462 abilities, such as [site-specific options][option-overrides] and [disabling
463 certain commands on certain sites][key-overrides]. It also allows to add
464 [custom commands] \(and other extensions to extend VimFx). #158 #235 #255 #261
465 \#300 #408 #445 #490 #515
467 - It is now easier to customize VimFx through custom [styling]. An example is
468 changing the way hint markers look. #220 #233 #424 #432 #465
470 - VimFx now has [documentation] and a [wiki].
472 - A few new locales were added:
474 - fr. Thanks to Mickaël RAYBAUD-ROIG (@m-r-r)!
475 - pt-BR. Thanks to Átila Camurça Alves (@atilacamurca)!
476 - sv-SE. Thanks to Andreas Lindhé (@lindhe)!
480 - VimFx is now multi-process/Electrolysis/e10s compatible! This means that you
481 can run VimFx on a version of Firefox with multi-process enabled without
482 issues, and that we’re future proof for the day when Firefox becomes
483 multi-process by default. Best of all, it also made VimFx more reliable in
484 non-multi-process (“regular”) Firefox. #378
486 - The `[` and `]` commands are now smarter, recognizing more links to the
487 previous/next page correctly. You may read more about [previous/next page
490 - The `n` and `N` commands now notify you when they wrap around the page, or the
491 phrase you searched for could not be found. #398
493 - _All_ shortcuts in _all modes_ can now be customized. For example, this allows
494 you to disable VimFx’s Vim-style `<enter>` behavior in the find bar. #222 #390
497 - The `p` and `P` commands are now smarter regarding whether to treat the
498 clipboard contents as a URL or a search, by working exactly like pasting in
499 the location bar. They also now read the selection clipboard, if available.
502 - VimFx’s toolbar button is now properly implemented. #303 #349 #383
504 - Most locales were updated. Thanks to our awesome [translators]!
506 ##### Minor bug fixes
508 - VimFx now works correctly in tabs dragged to other windows. #57
509 - The `p` command is no longer broken. #494
510 - Non-ASCII shortcut keys now work properly. #433
511 - The Keyboard Shortcuts help dialog can no longer be covered by page elements.
513 - Hint markers can no longer be covered by page elements.
514 - VimFx no longer causes scripts on icloud.com to get stuck in an infinite loop.
517 [advanced options]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/options.md#advanced-options
518 [blacklist]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/options.md#blacklist
519 [ignore keyboard layout]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/options.md#ignore-keyboard-layout
520 [previous/next page patterns]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/options.md#previousnext-page-patterns
521 [scrolling prefs]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/options.md#scrolling-prefs
522 [counts]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/commands.md#counts
523 [`gi`]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/commands.md#gi-1
524 [Ignore mode `<s-f1>`]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/commands.md#ignore-mode-s-f1
525 [scrolling commands]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/commands.md#scrolling-commands-1
526 [the `f` commands]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/commands.md#the-f-commands-1
527 [`<force>`]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/shortcuts.md#force
528 [`<late>`]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/shortcuts.md#late
529 [config file]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/config-file.md
530 [public api]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/api.md
531 [option-overrides]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/api.md#vimfxaddoptionoverridesrules
532 [key-overrides]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/api.md#vimfxaddkeyoverridesrules
533 [styling]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/styling.md
534 [toolbar button]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/styling.md
535 [translators]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/PEOPLE.md#translators
536 [documentation]: https://github.com/akhodakivskiy/VimFx/blob/c790b0fc1127c66bb7b33ccbaf4c0e8090e5530b/documentation/
537 [wiki]: https://github.com/akhodakivskiy/VimFx/wiki/
538 [custom commands]: https://github.com/akhodakivskiy/VimFx/wiki/Custom-Commands
539 [commit 3552282]: https://github.com/akhodakivskiy/VimFx/commit/355228217d7e7a61f5e1edbb9efbfb0f3e4ef81c
541 ### 0.5.17 (2015-01-23)
543 - Fixed: The hints generation no longer crashes on some pages (regression since
546 ### 0.5.16 (2015-01-22)
548 - Fixed: The toolbar button no longer throws errors. (This fix should have been
549 in 0.5.15 but was forgotten. Luckily an AMO reviewer found it.)
551 ### 0.5.15 (2015-01-21)
553 - Improved: This version is now forwards-compatible with the upcoming version
554 0.6.0. Downgrading from 0.6.0 to 0.5.14 or older might cause VimFx to crash,
555 but downgrading from 0.6.0 to 0.5.15 is safe.
556 - Fixed: Non-hintchars key presses in hints mode are now suppressed. They used
557 to be passed along to the browser, which could confusingly activate site
559 - Fixed: The 'f' command now always opens links in the same tab. Links used to
560 be able to force a new tab or window.
561 - Fixed: Pressing 'Esc' in the location bar now restores the URL, as is the
562 default behaviour of Firefox. You may now also close Firefox dialogs using
564 - Improved: Updated the de locale. Thanks to Alexander Haeussler!
565 - Improved: Updated the pl locale. Thanks to morethanoneanimal!
567 ### 0.5.14 (2014-08-16)
569 - Fixed: Locales should now work properly.
570 - Improved: Updated the zh-CN locale (@mozillazg).
571 - Improved: Updated the de locale (@Kambfhase).
572 - Added: Japanese locale (@pluser).
573 - Fixed: If you switched to another tab or window while an `<input>` element
574 was focused and then switched back, the `<input>` element got blurred, while
575 it should have stayed focused. This caused the auto-type feature of KeePassX
578 ### 0.5.13 (2014-08-02)
580 - Fixed: The vote button on StackExchange sites are now markable again.
581 - Improved: Detection of previous/next links. Should work better on gmail now.
582 - Fixed: It is now possible to use Enter/Return in keyboard shortcuts.
583 - Improved: The n/N commands (etc.) now work even if you didn’t open the finbar
584 using the VimFx command (such as the default key binding ctrl+f, or by
585 clicking a menu item).
586 - Improved: It is now possible to blur text inputs without sending Esc to the
587 page, which could cause dialogs etc. to annoyingly close.
588 - Improved: Updated the el-GR locale (@sirodoht).
589 - Fixed: Autofocus prevention sometimes made text inputs impossible to focus
590 until you reloaded the page.
591 - Improved: Autofocus prevention now works on more sites than before.
592 - Improved: Autofocus prevention now prevents _all_ automatic focusing (not
593 just when the page loads). This makes devdocs.io much easier to use.
594 - Added: When viewing images directly and the image has been resized to fit the
595 screen the image is now markable, allowing you to toggle zoom on it using the
597 - Fixed: It is no longer possible to add conflicting shortcuts (such as adding
598 'a' when 'af' and 'as' are already present).
600 ### 0.5.12 (2014-06-01)
602 - Fixed: Autofocus prevention got stuck sometimes, making it impossible to
605 ### 0.5.11 (2014-06-01)
607 - Fixed: The focus search bar command was broken.
608 - Fixed: Autofocus prevention was broken.
609 - Fixed: The top bar on YouTube could not be accessed by VimFx.
610 - Fixed: You can no longer add blank hotkeys.
611 - Improved: Tab Groups are supported.
612 - Improved: Matching of previous/next links should be more reliable.
613 - Improved: A few minor things.
615 ### 0.5.10 (2014-05-07)
617 - Fixed yet another bug related to the default preferences
619 ### 0.5.9 (2014-05-04)
621 - Fixed a bug with default preferences not being set
622 - Fixed gg and G to be faster
624 ### 0.5.8 (2014-04-18)
626 - AMO Preliminary Review bug fix (sorry for such long delay)
628 ### 0.5.7 (2014-03-03)
632 ### 0.5.6 (2014-02-26)
634 - Updated some translations
635 - Updated pagination patterns and logic
637 ### 0.5.5 (2014-01-03)
639 - Hotfix release to address a bug that has been introduced in 0.5.4
641 ### 0.5.4 (2014-01-03)
643 - Fix for popup passthrough mode stucking
644 - Make toolbar button click depend on current mode
645 - Higher weight markers should not be overlapped
646 - Refactor find mode to use Firefox native search bar
647 - Bump minimum required Firefox version to 25
648 - Added commands to go in the URL path
649 - Added commands to navigate previous and next links with customizable link
651 - Use Firefox 24+ native console API
652 - Update zh-CN localization
654 ### 0.5.3 (2013-10-16)
656 - Lots of refactoring
657 - Insert mode (`i` command)
658 - Follow multiple links with `af` command
659 - Hint marker rotation with `space` while in hints mode
661 ### 0.5.1 (2013-08-21)
663 - Fixed regression with stylesheets
668 - Added command to focus search bar: `O`
669 - Added commands to stop loading current page and all pages: `s` and `as`
670 - Invisible elements will not get hint markers
671 - Compatibility with Firefox 25
672 - Simple shortcut customization with UI in Help dialog
673 - Use Huffman coding algorithm for hint markers generation which results in
675 - Implemented Bloom filters to achieve shorter hints for those shortcuts that
677 - Reimplemented scrolling - now works with pages where window is not scrollable
678 - Find disabled on non HTML documents
679 - Find string is now global for all windows.
680 - Fixed logic of locale discovery. Now we rely on general.useragent.locale
681 Firefox preference for current locale
683 ### 0.4.8 (2013-06-12)
685 - `embed` and `object` tags will now have their own hints
686 - Bug fixes related to custom hint chars (@LordJZ)
687 - Fixed `t` - now it will be nice to other extensions
688 - Updated Chinese translations (@mozillazg)
689 - Reenter Normal mode on page reloads to avoid getting stuck in Hints mode
691 - Search will focus element that contains matching text
692 - Fixed hint markers for iframes
693 - Marker bug fixes (@LordJZ)
695 ### 0.4.6 (2013-03-27)
697 - Reimplemented find mode: CJK support, performance boost
698 - `a/` or `a.` to highlight all matches of the search string on the page
699 - Hint markers will now reach into iframes
700 - Key handling is disabled when a popupmenu or panel are shown
701 - `yf` will now also focus links and copy values from text/textarea element
702 - `vf` will show hit markers to focus the underlying element
704 ### 0.4.5 (2013-03-12)
706 - `:` to open Firefox Developer Toolbar, `Esc` to close it.
707 - Add Hungarian locale (@thenonameguy).
708 - Add Polish locale (@grn).
709 - Don't close pinned tabs when pressing x (@grn).
710 - Switched to Makefile for building the extension release (@carno).
711 - Mrakers CSS tweaks (@helmuthdu)
713 ### 0.4.4 (2013-01-30)
715 - Thanks to @mozillazg and @mcomella for translation contributions.
716 - Added `gh` command that will navigate to the home page.
717 - Added `o` command to focus location bar.
718 - `p` and `P` will parse the contents of the clipboard. If the string in the
719 clipboard appears to be a URL then it will navigate to this URL. Otherwise it
720 will search for the string in the clipboard using currently selected search
722 - Now hint markers for links will stay on top of all the markers for different
724 - Esc will now also close the focused default search bar.
725 - Fixed bugs related to keyboard events handling, XUL documents, and some other
727 - Bug fixed where not all the commands could be disabled via the Help dialog.
729 ### 0.4.3 (2012-12-27)
731 - Toolbar button bugfix
732 - Added an option to disable individual commands via the help dialog
734 ### 0.4.1, 0.4.2 (2012-12-12)
736 - Small tweaks of the find feature.
737 - Bugfix for keyboard handling on non-english keyboard layouts
741 - Implemented find with `/` and `n/N`
742 - Added `ar` and `aR` commands to reload pages in all open tabs.
743 - Added a preference that enables blurring from any element that has input focus
744 in the browser on Esc keydown (on by default)
745 - Fixed bug where markers and help dialog would blow up some of the pages.
746 - Marker hints are now sorted with respect to the underlying element area.
747 Elements with larger area get shorter hints
748 - Added *mail.google.com* to the default black list
749 - Various bug fixed and improvements.
751 ### 0.3.2, 0.3.2, 0.3.3 (2012-11-20)
753 - Hotfixes for the build script to include localization related files and folders
757 - Fixed [Desktop](https://addons.mozilla.org/en-us/firefox/addon/desktop/)
758 extension compatibility problem
759 - Removed c-b/c-f for now. c-f is a standard search hotkey. Will put c-f back
760 when proper Vim-like search with / is implemented
761 - Scrolling with G will now reach the bottom of the page
762 - Implemented localization, currently there is only Russian localization.
763 Community is welcome [to contribute your localizations](https://github.com/akhodakivskiy/VimFx/tree/master/extension/locale)!
764 - Implemented simple smooth scrolling
768 - document.designMode='on' is now honored. Will also provide hint markers for
770 - Bug fixed where it would completely reset the toolbar while installing the
772 - Bug fixed where it's not possible to change the text in the blacklisting
774 - Changed u/d to scroll half a page, added c-f/c-b to scroll full page
775 - Added tab movement commands: c-J and c-K.
776 - Invisible markers bug fixed.
777 - Global hotkey to disable the commands (equal to the toolbar button click):
779 - ^u and ^d are removed from the command list. ^u is commonly used to show the
781 - Opening new tab with now focuses the location bar
782 - Other small bugs nailed down.
784 ### 0.1.1 (2012-10-27)
786 - Just to deal with AMO - no changes