fw 1.12.0

faster workspace management
fw-1.12.0 is not a library.

[[./logo/fw_rgb.png]]

  • fw [[https://travis-ci.org/brocode/fw][file:https://travis-ci.org/brocode/fw.svg?branch=master]] [[https://crates.io/crates/fw][file:https://img.shields.io/crates/v/fw.svg]]

    [[https://asciinema.org/a/134985][https://asciinema.org/a/134985.png]]

** Why fw? With fw you have a JSON file describing your workspace. It takes care of cloning projects and can run commands across your entire workspace. You can start working on any project quickly, even if it's not in your flat structured workspace (better than CDPATH!). It also "sets up" your environment when you start working on a project (compile stuff, run make, activate virtualenv or nvm, fire up sbt shell, etc.)

[[doc/sample_config.json][Here's]] an example configuration that should be easy to grasp:

Per default projects are cloned into ${settings.workspace}/${project.name} but you can override that by setting an override_path attribute as seen above.

** What this is, and isn't fw is a tool I wrote to do my bidding. It might not work for you if your workflow differs a lot from mine or might require adjustments. Here are the assumptions:

  • only git repositories
  • only ssh clone (easily resolveable by putting more work in the git2 bindings usage)
  • ssh-agent based authentication

*** If you can live with all of the above, you get: - workspace persistence (I can rm -rf my entire workspace and have it back in a few minutes) - ZERO overhead project switching with the workon function (need to activate nvm? Run sbt? Set LCD brightness to 100%? fw will do all that for you) - zsh completions on the project names for workon - generate projectile configuration for all your project (no need to projectile-add-known-project every time you clone some shit, it will just work)

** [[doc/installation.org][Installation]] ** [[doc/usage.org][Usage]]