File the issue here.
You'd like to fix a bug or implement a feature? Great! Before getting started, understand Vimium's design principles and the goals of the maintainers.
When people first start using Vimium, it provides an incredibly powerful workflow improvement and it makes them feel awesome. Surprisingly, Vimium is applicable to a huge, broad population of people, not just users of Vim.
In addition to power, a secondary goal of Vimium is approachability: minimizing the barriers which prevent a new user from feeling awesome. Many of Vimium's users haven't used Vim before -- about 1 in 5 Chrome Store reviews say this -- and most people have strong web browsing habits forged from years of browsing. Given that, it's a great experience when Vimium feels like a natural addition to Chrome which augments, but doesn't break, the user's current browsing habits.
Principles:
- Easy to understand. Even if you're not very familiar with Vim. The Vimium video shows you all you need to know to start using Vimium and feel awesome.
- Reliable. The core feature set works on most sites on the web.
- Immediately useful. Vimium doesn't require any configuration or doc-reading before it's
useful. Just watch the video or hit
?
. You can transition into using Vimium piecemeal; you don't need to jump in whole-hog from the start. - Feels native. Vimium doesn't drastically change the way Chrome looks or behaves.
- Simple. The core feature set isn't overwhelming. This principle is particularly vulnerable as we add to Vimium, so it requires our active effort to maintain this simplicity.
- Code simplicity. Developers find the Vimium codebase relatively simple and easy to jump into. This allows more people to fix bugs and implement features.
Goals of the maintainers
The maintainers of Vimium have limited bandwidth, which influences which PRs we can review and merge.
Our goals are generally to keep Vimium small, maintainable, and really nail the broad appeal use cases. This is in contrast to adding and maintaining an increasing number of complex or niche features. We recommend those live in forked repos rather than the mainline Vimium repo.
PRs we'll likely merge:
- Reflect all of the Vimium design principles.
- Are useful for lots of Vimium users.
- Have simple implementations (straightforward code, few lines of code).
PRs we likely won't:
- Violate one or more of our design principles.
- Are niche.
- Have complex implementations -- more code than they're worth.
Tips for preparing a PR:
- If you want to check with us first before implementing something big, open an issue proposing the idea. You'll get feedback from the maintainers as to whether it's something we'll likely merge.
- Try to keep PRs around 50 LOC or less. Bigger PRs create inertia for review.
Here's the rationale behind this policy:
- Vimium is a volunteer effort. To make it possible to keep the project up-to-date as the web and browsers evolve, the codebase has to remain small and maintainable.
- If the maintainers don't use a feature, and most other users don't, then the feature will likely get neglected.
- Every feature, particularly neglected ones, increase the complexity of the codebase and makes it more difficult and less pleasant to work on.
- Adding a new feature is only part of the work. Once it's added, a feature must be maintained forever.
- Vimium is a project which suffers from the stadium model of open source: there are many users but unfortunately few maintainers. As a result, there is bandwidth to maintain only a limited number of features in the main repo.
Vimium is written in Javascript. To install Vimium from source:
On Chrome/Chromium:
- Navigate to
chrome://extensions
- Toggle into Developer Mode
- Click on "Load Unpacked Extension..."
- Select the Vimium directory you've cloned from Github.
On Firefox:
Firefox needs a modified version of the manifest.json that's used for Chrome. To generate this, run
./make.js write-firefox-manifest
After that:
- Open Firefox
- Enter "about:debugging" in the URL bar
- Click "Load Temporary Add-on"
- Open the Vimium directory you've cloned from Github, and select any file inside.
Our tests use shoulda.js and Puppeteer. To run the tests:
- Install Deno if you don't have it already.
PUPPETEER_PRODUCT=chrome deno run -A --unstable https://deno.land/x/puppeteer@16.2.0/install.ts
to install Puppeteer./make.js test
to build the code and run the tests.
- Run
deno fmt
at the root of the Vimium project to format your code. - We generally follow the recommendations from the Airbnb Javascript style guide.
- We wrap lines at 100 characters.
- When writing comments, uppercase the first letter of your sentence, and put a period at the end.
- We're currently using JavaScript language features from ES2018 or earlier. If we desire to use something introduced in a later version of JavaScript, we need to remember to update the minimum Chrome and Firefox versions required.