GitPedia

Finicky

A macOS app for customizing which browser to start

From johnste·Updated June 23, 2026·View on GitHub·

Finicky is a macOS application that allows you to set up rules that decide which browser is opened for every url. With Finicky as your default browser, you can tell it to open Bluesky or Reddit in one browser, and LinkedIn or Google Meet in another. The project is written primarily in Go, distributed under the MIT License license, first published in 2015. It has gained significant community traction with 4,917 stars and 199 forks on GitHub. Key topics include: browser, go, handler, macos, menu.

Latest release: v4.4.0-alpha4.4.0-alpha — Rules UI, Firefox profiles & window-aware routing
April 26, 2026View Changelog →
<div align="center"><picture> <source media="(prefers-color-scheme: dark)" srcset="https://github.com/user-attachments/assets/ab66e6cc-25d1-4f5f-9c98-c742ecb2261f"> <img alt="Finicky Logo" height="110" src="https://github.com/user-attachments/assets/067d7619-a2be-49dd-8a4f-5e9a46fa632a"> </picture> <br/><br/> <strong>Always open the right browser</strong><br> <br/> </div>

Finicky is a macOS application that allows you to set up rules that decide which browser is opened for every url. With Finicky as your default browser, you can tell it to open Bluesky or Reddit in one browser, and LinkedIn or Google Meet in another.

  • Route any URL to your preferred browser with powerful matching rules
  • Automatically edit URLs before opening them (e.g., force HTTPS, remove tracking parameters)
  • Write rules in JavaScript or TypeScript for complete control
  • Create complex routing logic with regular expressions and custom functions
  • Handle multiple browsers and apps with a single configuration
  • Keep your workflow organized by separating work and personal browsing

GitHub prerelease MIT License Finicky v4 release

Table of Contents

Installation

  • Download from releases
  • Or install via homebrew: brew install --cask finicky
  • Create a JavaScript or TypeScript configuration file at ~/.finicky.js. Have a look at the example configuration below, or in the example-config folder.
  • Start Finicky (in Applications, or through Spotlight/Alfred/Raycast) and allow it to be set as the default browser. Starting Finicky manually opens the configuration/troubleshooting window.

Basic configuration

Here's a short example configuration that can help you get started

js
// ~/.finicky.js export default { defaultBrowser: "Google Chrome", rewrite: [ { // Redirect all x.com urls to use xcancel.com match: "x.com/*", url: (url) => { url.host = "xcancel.com"; return url; }, }, ], handlers: [ { // Open all bsky.app urls in Firefox match: "bsky.app/*", browser: "Firefox", }, { // Open google.com and *.google.com urls in Google Chrome match: [ "google.com/*", // match google.com urls "*.google.com*", // also match google.com subdomains ], browser: "Google Chrome", }, ], };

See the configuration for all the features Finicky supports.

Configuration

Finicky has extensive support for matching, rewriting and starting browsers or other application that handle urls. See the wiki for the full configuration documentation explaining available, APIs and options as well as detail information on how to match on urls.

Migrating from Finicky 3

Please see the wiki page for updating info and migrating your configuration

Other

Browser extensions

Finicky has browser extensions for Chrome and Firefox. They add an "open with Finicky" on links, and alt-clicking links opens them in Finicky directly.

Building Finicky from source

See Building Finicky from source

Works well with

If you are looking for something that lets you pick the browser to activate in a graphical interface, check out Browserosaurus by Will Stone, an open source browser prompter for macOS. It works really well together with Finicky!

Questions

Have any other questions or need help? Please feel free to reach out to me on Bluesky or post an issue here

License

MIT

Icon designed by @uetchy

Contributors

Showing top 12 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from johnste/finicky via the GitHub API.Last fetched: 6/23/2026