Hi all!

Recently, I’ve been thinking about how to handle my dotfiles again.

I’ve used chezmoi for a while, and while it’s good, I’ve been wanting something a little lighter.

The simplicity of having my $HOME be a git repository was attractive, but I ran into issues. Specifically, many command line tools I use such as fzf and ripgrep have a feature to automatically ignore in their search results any files which are ignored by a gitignore. This meant I had to either turn this feature off (not ideal) or they wouldn’t work any more. Also, the terminal prompt I use also showed I was within a git repository all the time, which was annoying.

Does anyone have an wisdom they’d like to share? If I can’t get the $HOME as a git repository working the way I’d like, I may check out GNU Stow, which seems to be the next most lightweight option.

Thanks!

  • DessalinesA
    link
    fedilink
    arrow-up
    6
    ·
    3 years ago

    I just use symlinks, and have a script that replaces the files in home with symlinks t my dotfiles folder.

    • timbuck2themoon
      link
      fedilink
      arrow-up
      2
      ·
      3 years ago

      I do this and can recommend. I also just keep two small scripts in the repo as well to stow and unstow all files (bash, ssh, etc).

  • Adda
    link
    fedilink
    arrow-up
    3
    ·
    3 years ago

    I have often heard of using Git bare repository instead of having $HOME as a normal Git repository itself. This approach sets your $HOME directory only as a Git repository’s work tree, not entire Git repository. That would solve the problem of your CLI tools, I believe. For further information, see for example the following.

    But GNU Stow seems to be pretty interesting way to manage dotfiles, too. It could definitely do what you need, as far as I know.

    • ssenecaOP
      link
      fedilink
      arrow-up
      2
      ·
      3 years ago

      I’ve been experimenting with the Git bare repository method and I think it solves all my problems! Thanks very much. If I run into issues again, I’ll for sure check out GNU Stow.

      • Adda
        link
        fedilink
        arrow-up
        2
        ·
        3 years ago

        Glad to hear that. Hope everything will work out for you. I have already thought about trying Git bare repository myself, but so far I am quite content with just copying dotfiles from my repository directory to $HOME myself. Might give these options a second thought someday soon.

  • ksynwa
    link
    fedilink
    arrow-up
    3
    ·
    edit-2
    3 years ago

    In my dotfile repo, all dotfiles have a comment at the top like:

    -- DOTFILE_DEST=.config/nvim/init.lua
    

    The path is relative to home.

    Then I have a shell script that goes through all the dotfiles and creates symlinks to the appropriate location.

    Honestly it’s kinda shit but I spent hours into getting this to work so I stick with it. Sunk cost fallacy. I have been interested in switching to yadm or chezmoi but having to depend on external tools is something I am reluctant to do for something so simple.

    I am yet to find a dotfile which doesn’t allow comments so this hasn’t failed me so far.

    This also allows me to rename the file to something more sensible in the context of a dotfile repo. Like I can rename init.lua to nvim.lua.

    • Helix
      link
      fedilink
      arrow-up
      1
      ·
      3 years ago

      nice idea; you could’ve done this as Ansible module and put the dotfiles in a template repository instead. That way you can separate the “what goes where” from the contents and have different target locations for different systems/distributions.

  • Anachron
    link
    fedilink
    arrow-up
    1
    ·
    3 years ago

    Specifically, many command line tools I use such as fzf and ripgrep have a feature to automatically ignore in their search results any files which are ignored by a gitignore. This meant I had to either turn this feature off (not ideal) or they wouldn’t work any more. Also, the terminal prompt I use also showed I was within a git repository all the time, which was annoying.

    I have not seen any fzf which does that. Ripgrep I dont know, but I would guess there is an easy option to disable it like you said. For the prompt: You could easily modify your prompt to only show git repos that are not residing in ~/. So I can’t follow your reasoning at all. I don’t use this system but I don’t think there will be a lot of benefit changing it all over again when the fixes are so simple.