Just set the environment variable FW_CONFIG_DIR
. This is also
honored by fw setup
and fw org-import
so you can create more than
one configuration this way and switch at will.
Initial setup is done with
fw setup DIR
This will look through DIR
(flat structure!) and inspect all git
repositories, then write the configuration in your home. You can
edit the configuration manually to add stuff. If you have
repositories elsewhere you will need to add them manually and set
the override_path
property. The configuration is portable as long
as you change the workspace
attribute, so you can share the file
with your colleagues (projects with override_path
set won’t be
portable obviously. You can also add shell code to the after_clone
and after_workon
fields on a per-project basis. after_clone
will be
executed after cloning the project (interpreter is sh
) and
after_workon
will be executed each time you workon
into the project.
If you want to pull in all projects from a GitHub organization
there’s fw org-import <NAME>
for that (note that you need a minimal
config first).
From now on you can
fw sync # Make sure your ssh agent has your key otherwise this command will just hang because it waits for your password (you can't enter it!).
which will clone all missing projects that are described by the configuration but not present in your workspace. Existing projects will be synced with the remote. That means a fast-forward is executed if possible.
There is also
fw foreach 'git remote update --prune'
which will run the command in all your projects using sh
.
Instead of cloning new projects you want to work on, I suggest adding a new project to your configuration. This can be done using the tool with
fw add [email protected]:brocode/fw.git
(you should run fw
sync afterwards! If you don’t want to sync
everything use fw sync -n
) In case you don’t like the computed
project name (the above case would be fw
) you can override this
(like with git clone
semantics):
fw add [email protected]:brocode/fw.git my-fw-clone
If you’re an emacs user you should always run
fw projectile
after a sync
. This will overwrite your projectile bookmarks so that
all your fw
managed projects are known. Be careful: Anything that is
not managed by fw will be lost.
Just
workon
It will open a fuzzy finder which you can use to select a project. Press <enter> on a selection and it will drop you into the project folder and execute all the hooks.
If you’re in a pinch and just want to check something real quick, then you can use
nworkon
as that will no execute any post-workon hooks and simply drop you into the project folder.
In case you’re not using fzf
integration (see above) you will need to pass an argument to workon
/ nworkon
(the project name).
It comes with simple prefix-based autocompletion.