Git Bare Repository - A Better Way To Manage Dotfiles

Поділитися
Вставка
  • Опубліковано 27 січ 2025

КОМЕНТАРІ • 264

  • @AbduleeFtw
    @AbduleeFtw 4 роки тому +124

    Lmao i used to tar these files and upload then onto mega like every week xD

  • @evanstenger8590
    @evanstenger8590 Рік тому +1

    Thanks for putting together this video! I read that article, and then searched on UA-cam to see if someone could explain it better. Showing the normal repo and bare repo side by side was what I was looking for. Your explanation, and walking through actually using it made it make sense!

  • @engageintellect
    @engageintellect 4 роки тому +10

    New to github and using git to manage my dotfiles, suckless builds, etc... basically the stuff I’m tired of making from scratch each time I move to a new system. 😂
    I’ve had to watch this video a few times to really understand how this is working.. Now that I understand I just have to say this is the most elegant and clean solution I’ve seen. Much better than GNU/stow or traditional methods.
    Excited to soon be living in a world where I can git-clone a github repo on a brand new system and have everything be how I like it, from window manager to vim rc.
    Thanks for this video. Really appreciate what you’re doing @distrotube 🙏🏻
    Also- my dads side of the family all lives in West Monroe. He has a house out there on the same land as his brother and step-dad. Beautiful place. I like it much more there than So Cal.

  • @lpanebr
    @lpanebr 4 роки тому +10

    Awesome! I was just about to restart my dotfiles and was already dreading the symlinking management I would have. Thank you!!!

  • @RockTheCage55
    @RockTheCage55 Рік тому +2

    Thanks a bunch. Excellent way to manage dotfiles. I'm quite good at git but i didn't know you could use it like this so much better than symlinking everything

  • @ItsRyanStudios
    @ItsRyanStudios Рік тому +6

    My .vimrc file has become one of the most valuable and irreplaceable files on my computer and having a backup is essential.
    I've have a really inefficient git backup setup currently, but this video is exactly what I've been looking for for months.
    Excited to implement it.
    Especially now that I started using linux and I'm creating even more valuable/ irreplaceable dot files.

  • @matthewstott3493
    @matthewstott3493 4 роки тому +20

    Tip: use 'exec bash' or 'exec zsh' as it works better than just sourcing the .bashrc .zshrc or launching a new instance of the shell within a shell. Especially if you are doing it a lot as you build your dotfiles.

    • @wemusthavechannelstocommen619
      @wemusthavechannelstocommen619 11 місяців тому +1

      what's the difference?

    • @matthewstott3493
      @matthewstott3493 11 місяців тому

      3 years later… Use GNU Stow to manage dotfiles. It does most of it for you.

    • @brainstormsurge154
      @brainstormsurge154 10 місяців тому

      Or you could alias editing and sourcing such as ebash to edit and sbash to source. Very convenient.

  • @vpxc
    @vpxc 6 років тому +98

    imo you should retitle this video
    That the clone is bare isn't really important here-- all it means is that wherever you clone (or initialize) it, Git will store all the repo metadata but not check out any version of the contents of the repo in that directory.
    The real workhorse here is the git-worktree feature, and you can use it with any repo to create a working tree in another directory, and you can have as many of them as you want.

    • @cc-hc1dr
      @cc-hc1dr 4 роки тому

      can you give a link to a working example?

    • @vpxc
      @vpxc 4 роки тому +2

      @@cc-hc1dr you can use any repo you want, including one you've already cloned. Just make sure you have git worktree and see the man page. There might be a tldr page as well

    • @Neko-kun-dp1hq
      @Neko-kun-dp1hq 4 роки тому +2

      @@vpxc I think you could have put more effort to give a good example. Your example doesn't help me understand what you were talking about at all. DT's on the other hand, shows how it works very well.

    • @GeorgeSukFuk
      @GeorgeSukFuk 4 роки тому +3

      @@Neko-kun-dp1hq you should do some digging yourself which is clearly what pxc has done

    • @viktorovksy
      @viktorovksy 3 роки тому

      @pxc It's not possible to use git-worktree feature for the dotfiles because git won't allow you to create the worktree in the existing home directory (~)
      `cd /gitrepo && git worktree add --force ~`

  • @bobgrimes8618
    @bobgrimes8618 6 років тому +2

    I am always learning something new every time I watch your show! Also, congratulations on your Saints winning on Sunday!

  • @mitchelvalentino1569
    @mitchelvalentino1569 6 років тому +28

    Nice. Well-edited and informed Linux content that’s useful for both new and experienced Linux users. Surprisingly rare on UA-cam. Thank you!!

  • @gcasanas1
    @gcasanas1 3 роки тому +1

    I think this is the cleanest way to do this task. The neat part is that one can track dotfiles in root or nested folders at the same time.

  • @meowtabby5369
    @meowtabby5369 4 роки тому

    thanks a lot! I knew there would be a solution like this. For some reason, I made my dotfile repos in the same way as it were in the home directory, having each filesin their corresponding directory folders and whatnot. surprisingly, after applying what you showed in your video, cloning from my repo was a breeze, and everything just fits perfectly after cloning! and it was indeed a hassle symlinking each one of them from their corresponding folder. but then I knew this can be done, which is indeed better than my first option, which is to turn the entire home directory as a git repo, which would be a hassle. I never knew this option can be done! really helped a lot!

  • @distroverse
    @distroverse 6 років тому +7

    Yeah this method is really awesome, I use it for some time now. Can't live without it.

    • @DistroTube
      @DistroTube  6 років тому

      Yea, can't believe I hadn't heard of this before now.

  • @DDBAA24
    @DDBAA24 5 років тому +12

    DT , you should do a video on ' etckeeper ' straight from the default repos. A VCS for all of your etc config files , it keeps logs of all changes and it has its own set of commands which are actually very similar to git's. Its more automated , every time you update whether its APT or Pacman it lets you know all of the changes being logged in the output.

  • @miss-astronomikal-mcmxcvii
    @miss-astronomikal-mcmxcvii Рік тому +1

    Wow, this tutorial is very self-explanatory and very informational. Thank you sooo much! :)

  • @QazCetelic
    @QazCetelic Рік тому

    This is the most convenient method I've seen so far. Great video!

  • @johannesmariomeissner7262
    @johannesmariomeissner7262 3 роки тому

    Excellent explanation, and a big thanks for referencing back to the Atlassian article. Love your content!

  • @PoisonHeadcrab2
    @PoisonHeadcrab2 5 років тому +3

    Really cool of you to credit the author of the article you got the idea from, respect!

  • @Ggldoork
    @Ggldoork 3 роки тому +7

    Great video. Would have liked to have seen you sync a few Dev machines off the bare repo - especially with different OS (folder locations)

  • @fuseteam
    @fuseteam 4 роки тому +20

    but how would you clone in it in a fresh system?

    • @BillGarrett
      @BillGarrett 11 місяців тому +2

      git clone --bare repository-location local-dotfiles-location

    • @readmore8974
      @readmore8974 2 місяці тому +2

      @@BillGarrett Will git know to spread those out to the correct system locations or will it just put them in one place?
      Edit: For stumbling onto this now, I highly recommend a stow based approach for dotfiles. There's a great video on it by "Dreams of Autonomy". Quite a bit cleaner imo

    • @BillGarrett
      @BillGarrett 2 місяці тому

      @@readmore8974 If you're using his "config" alias at 9:19 it will put the files in whatever directory was given to --work-tree. In his example that's $HOME

  • @SantiYounger
    @SantiYounger 3 роки тому

    This video is excellent, by far this is my favorite method to manage dotfiles

  • @abucketofelves
    @abucketofelves 6 років тому +28

    It's just the, bare repository, the simple bare repository, forget about your worries and your strife

  • @hzaphry
    @hzaphry 3 роки тому

    Just had my bare dotfiles repo. DT you're awesome. Thanks man

  • @saltrocklamp199
    @saltrocklamp199 4 роки тому +2

    One downside I found with this method: you can't add a README file without having said file sitting in your home directory. Otherwise this is 100% the lowest-friction "dotfiles repo" setup I've heard of, and I can't see myself going back to another method.

  • @wvovaw3052
    @wvovaw3052 4 роки тому +5

    ⚠️ BE CAREFULL EVERYBODY WHO'S GONNA USE THAT METHOD... ⚠️ I did 'config reset --hard' to my repo and that ALMOST killed all my configs. If you have done like that you still can get back to the last commit: check 'config reflog' and then 'git reset --hard ' back to the last commit.

    • @shrikamath
      @shrikamath Рік тому +1

      This is what I was worried about. Will `git clean -fdx` remove all untracked files ?

  • @you_what319
    @you_what319 6 років тому +4

    Thanks, perhaps a little more information was needed for newbies to get their dotfiles published. I used dotfiles as my alias because "dotfiles status" makes a lot more sense than "config status"

  • @ehsanamini8501
    @ehsanamini8501 9 місяців тому

    Great explanation as always. If you got around to recording a video about etckeeper, that would be also much appreciated.

  • @SheldonHull
    @SheldonHull 2 роки тому

    Chezmoi is my go-to. Templating and ability to run scripts. Control any file by chezmoi add and begin templating or tracking in one repo, but anything directory can be controlled

  • @dimaj1
    @dimaj1 5 років тому

    that's a VERY nifty trick!
    what I've been doing with my dotfiles repo is add an init script that would create symlinks and load my submodules. What I call submodules is separate dotfiles repos (I have one for Personal, Work and OS-Specific)

  • @lawrencedoliveiro9104
    @lawrencedoliveiro9104 6 років тому +10

    Death to dotfiles! Not only do they clutter your home directory, they are also visible to other users, who can see what sort of apps you use, which is a privacy breach.
    Luckily, more and more apps are adopting the XDG Base Directory spec , which defines default directories ~/.config/, ~/.local/ and the rest of it to contain these things (and these locations can be overridden by environment variables if you wish). If you are a developer working on an app which needs to create user preference/cache files and the like, and you haven’t already adopted this spec, I urge you to do so!

    • @zacklight
      @zacklight 2 роки тому +1

      Sorry I know the reply is late. Why is the home directory accessible to others while ~/.config isn't? Does the latter have a stricter file mode by default in many distros?

  • @espehon
    @espehon 2 роки тому +1

    For those on Windows, setting an alias might not work. I found you can instead make a custom function like the following:
    function config {
    git --git-dir=$HOME/dotfiles --work-tree=$HOME $args
    }

  • @pengpleb
    @pengpleb 6 років тому +23

    I just gitignore every file with "*" and then use git add -f with each file I want to track.

    • @BlackM3sh
      @BlackM3sh 6 років тому +19

      I like this. Let me add to it. You can undo a ignored file or directory in the .gitignore file by starting the line with a '!'. So if you e.g. don't want to ignore .bashrc and the .config directory in your home directory, just add these three lines after '*'.
      !/.bashrc
      !/.config/
      !/.config/**
      So just add every file or directory you want to add with the negate pattern to .gitignore first first. I think this is a lot cleaner this way.

    • @pengpleb
      @pengpleb 6 років тому +4

      @@BlackM3sh I never knew that was a possibility, thanks I'll try it out.

    • @fuseteam
      @fuseteam 4 роки тому

      @@BlackM3sh ohw both /.config/ _and_ /.config/* is neccesary imma try this

    • @feschber
      @feschber 4 роки тому

      that would have been my first idea

  • @viniciusdufloth6015
    @viniciusdufloth6015 6 років тому +4

    Great timing for me! Yesterday I had just begun to version my dotfiles.
    The solution I had found was to create a git repositorie in my user's home directory and a .gitignore to ignore all files (*). Then, I whitelisted (!) only the config files I wanted. It worked, but it got a little complicated to mess around with .gitignore when I got into folder structures (like things inside .config, in witch there were files I wanted to version, and files I didn't, in diferent folders and diferent levels).
    And of course, anything outside of the user's home directory would be out of versioning or in a simbolic link mess.
    Glad you showed this solution, much more elegant indeed! Will be using it instead.

    • @bitnatures
      @bitnatures 6 років тому +1

      what would you need to version outside of HOME? most unix programs should respect a user config. Just curious.

    • @thierrybo6304
      @thierrybo6304 6 років тому

      @@bitnatures I have a git + stow setup for config files in home, and another separated setup for all manual changes I make to files in /etc/ (and etckeeper to track automatically all changes made to all files in /etc)

  • @GR3YS0RG4N1CS
    @GR3YS0RG4N1CS Рік тому

    I prefer using the "ba-bam+bp" workflow for adding dotfiles, essentially instead of the alias being "config" I've set it to "b" for the git bare command in the video, "ba" for "(git bare) add" to add tracking to any new files, and "bam" for "(git bare) commit -am" then "bp" for "git Bare) push"

  • @jasperzanjani
    @jasperzanjani 5 років тому +14

    the bare repository doesn't mean anything, if your existing repo was created without the `--bare` flag and is named "dotfiles" you can repeat this trick by aliasing `git --git-dir=$HOME/dotfiles/.git ...`. the real focus should be on the `--work-tree` flag which I would actually set to $PWD, that way you can add configuration files from all over the place, like in ~/.config, without adjusting the alias at all

    • @MrPolindrom
      @MrPolindrom 5 років тому +2

      That would defeat the purpose of preserving the directory structure, thereby making a new install as simple as cloning the repository (and maybe moving the work tree to $HOME).

    • @Maldito011316
      @Maldito011316 4 роки тому +1

      I agree with everything but using pwd. It wouldn't work smoothly

    • @jasperzanjani
      @jasperzanjani 4 роки тому

      @@Maldito011316 yeah I no longer use this technique, I think GNU Stow might be better

    • @Maldito011316
      @Maldito011316 4 роки тому

      @@jasperzanjani It's a very elegant solution!

    • @jasperzanjani
      @jasperzanjani 4 роки тому

      @@Maldito011316 it's a little bit of a pain when you're trying to check git status, because you will be confronted by a list of all the files you didn't add.. I used it for a while but I think using symlinks GNU Stow might be less painful, still have to try it tho

  • @norcal6181
    @norcal6181 5 років тому +2

    Thanks for this. I'd be doing mine the same as you with symlinks. I set my dotfiles up like this, and I have to say after some getting use to I really like it allot better. I like that all of the config file directory structure is preserved in the remote branch. That will make things allot less hassle when installing to another computer, or refreshing my own computer.

  • @pedro_alonso
    @pedro_alonso Рік тому

    This has blown my mind, and was posted 4 years ago. Bruhh, how I don´t have seem that before

  • @dengan699
    @dengan699 6 років тому +6

    Actually you can 'source .bashrc' instead of relaunching shell
    And at the end, just setup a ssh key and add remote, so that you can push in 1 command

    • @abaumarabahilal1189
      @abaumarabahilal1189 6 років тому +1

      But if that ssh key has passphrase, then he has to type it also.

    • @artslob
      @artslob 5 років тому +2

      @@abaumarabahilal1189 you can store password for ssh key with commands ssh-agent and ssh-add

    • @GreyDeathVaccine
      @GreyDeathVaccine 4 роки тому +1

      @@artslob Yep, gnome-keyring, kde-wallet, etc. will do heavy lifting :-)

  • @pcfreak1992
    @pcfreak1992 6 років тому +2

    UA-cam kept recommending me your videos and I enjoyed them a lot so far, so I just subscribed ;-)

  • @kraftwerk28
    @kraftwerk28 5 років тому +1

    By the way, you can create git alias instead of bash: git config --global alias.config="--git-dir=$HOME/dotfiles --work-tree=$HOME"

  • @doctorpine
    @doctorpine 2 роки тому +1

    I'm not sure if I am just missing something or what. It's probably due to me not being as familiar with git as I should be.
    When I go to run "config push" it throws the following:
    fatal: No configured push destination.
    Either specify the URL from the command-line or configure a remote repository using
    git remote add
    and then push using the remote name
    git push

  • @ShadwTrooper
    @ShadwTrooper 4 роки тому +2

    Jaw on the floor. /me Going to redo my dotfiles repo... Thanks, DT!

  • @k2a3r4l5o6
    @k2a3r4l5o6 6 років тому +1

    The drawback of this method is that you can not access the `diff` of your dotfiles locally. That is only possible after commit and push the modifications to the remote repository.

    • @maroskukan8387
      @maroskukan8387 2 роки тому +1

      Of course you can. When you make a change locally, just use config diff before you commit. If you want to compare changes between commits, you can use config diff HEAD~1 HEAD for example

  • @sasakanjuh7660
    @sasakanjuh7660 6 років тому +2

    Great, really interesting alternative! Btw, you can clean terminal with Ctrl+l, it's a bit faster :)

  • @arykleinerman6516
    @arykleinerman6516 5 років тому +6

    What do you do with the README.md file? Do you have to keep the README.md file in your home?

    • @allegoricalstatue
      @allegoricalstatue 5 років тому

      Hah I have the exact same question. currently I just have a README.md in ~/ :/

    • @LordZultair
      @LordZultair 5 років тому +2

      @@allegoricalstatue You can hide the README.md in a .github directory on ~/ (help.github.com/en/github/creating-cloning-and-archiving-repositories/about-readmes)

    • @aryklein
      @aryklein 4 роки тому

      @@LordZultair I didn't know that. Thanks

  • @anantgupta7916
    @anantgupta7916 3 роки тому

    This method is super legendary.
    Thanks DT otherwise I will have a gitignore file with tones of thing in that

  • @kriseberwein7357
    @kriseberwein7357 6 років тому +8

    Great stuff DT! I took it a step further by adding a line to my nightly cron jobs to automatically look for changes and push. Nicely done! "config commit -a -m "nightly" && config push github.com/MY_NAME/MY_REPO.git"

  • @VanStabHolme
    @VanStabHolme 3 роки тому

    Very useful and convinient. Thank you.

  • @Drazil100
    @Drazil100 4 роки тому +1

    I have taken to the symlink method however I automated it. In my "dotfiles" folder (which I actually just call "home" I replicate the folder structure for every tracked config file and I have a bash script in the root of my repo that searches through reporoot/home/ and symlinks it into place to my actual home (creating directories if they dont exist).

  • @allegoricalstatue
    @allegoricalstatue 5 років тому +4

    Damn, this is actually really cool

  • @ankushm3t
    @ankushm3t 4 роки тому +1

    Thank you very much. Amazing video!

  • @dustinmorse8497
    @dustinmorse8497 5 років тому +1

    Thanks DT! just set one of these up in my shiny new GitLab account!!!

  • @twiksify
    @twiksify Рік тому

    This is brilliant! 🎉

  • @reza.kargar
    @reza.kargar 10 місяців тому

    What a cool use case you 👌🏻, wonderful 😀 🙏🏻

  • @elocinnet
    @elocinnet 3 роки тому

    Thanks for this; it is an elegant solution like you mention.
    I don't know what I am missing, but when I move to a directory, I can commit a file added, get a message:
    "Your branch is up to date with 'origin/main
    .'nothing to commit (use -u to show untracked files)."

  • @diszydreams
    @diszydreams Рік тому

    Thanks! Still valid! works for me!

  • @bGrickD
    @bGrickD 4 роки тому +1

    how does one clone this repo onto a new machine? If I do a normal `git clone` it just has all of the files in a single directory

    • @grapesalt
      @grapesalt 4 роки тому

      i mean you could always provide a directory of where you want to put the files like git clone pathtoyour.repo/ DIR replace DIR with your desired directory like git clone example.com ./ (clone it to the current folder) or git clone example.com $HOME (clone it to your home directory)

  • @Berlm
    @Berlm 3 роки тому +1

    I gotta ask- does the laptop in the background exist only for the sole purpose of running cmatrix?

  • @KristofKorwisi
    @KristofKorwisi 4 роки тому

    Thanks for sharing your approach of storing dotfiles. I've audaciously adapted this for myself now :-)

  • @texaslinux
    @texaslinux 6 років тому

    NICE! This is so, so much easier. Thank you!

  • @laughingvampire7555
    @laughingvampire7555 4 місяці тому

    in a normal git repo you have the working directory "project/" and the "project/.git/" directory, the .git is the git repo and it is the contents of a bare repo.

  • @konscodes
    @konscodes 3 роки тому +3

    Great video but I spent hours trying to figure out how to push this to remote github repo 😄 had some issue with branch names and understanding the whole process in general

    • @exnihilonihilfit6316
      @exnihilonihilfit6316 Рік тому

      You did good, learning basic git(hub) use normally takes days to learn. 😀

  • @Ethorbit
    @Ethorbit 2 роки тому

    This is super helpful and useful, thanks!

  • @ex0stasis72
    @ex0stasis72 5 років тому +5

    I ended up calling my alias 'dgit' because it's shorter and more descriptive.

  • @Jonathan-dm3pt
    @Jonathan-dm3pt 6 років тому

    Very useful, thanks DT.

  • @koszal_
    @koszal_ 4 роки тому +1

    Thanks!!! Great solution for me.

  • @sylvershadow1247
    @sylvershadow1247 6 років тому

    Pretty handy. Saved it in a playlist for future reference.

  • @dmmeteo
    @dmmeteo 5 років тому

    It's really cool solution! Thank you man! I know want I going to do tomorrow morning;)

  • @SpittedDusk
    @SpittedDusk 6 років тому

    Thank you, I will start using this method myself.

  • @VulcanOnWheels
    @VulcanOnWheels 3 роки тому

    I tried to get this working, but I couldn't. I'll have to use the simlink method until I find out why. Although I don't know yet how I'm going to find out without trying again. It kind of feels like that song titled There's a Hole in The Bucket.

  • @VictorMartinez-vi7jx
    @VictorMartinez-vi7jx 2 роки тому

    How would you add a readme to the new dotfiles repo? It is not part of the dotfiles but also necessary to document how to setup certain dependencies

  • @mrAirsoft953
    @mrAirsoft953 6 років тому +4

    What would the process be for a fresh install, would cloning the repo put the dotfiles in the correct directories?

    • @l0n3ly_7ree
      @l0n3ly_7ree 6 років тому +2

      I would assume that yes, is like another repo, but with this one your $HOME is also the repo's working directory.

    • @135jacko
      @135jacko 5 років тому

      Just create a new 'alias config(...)' in your bashrc and try 'config checkout' command. If there were any error, remove or back up conflict files.

    • @benlennart4481
      @benlennart4481 5 років тому +1

      I had the same question in mind. The following worked for me:
      1) Create the alias:
      alias config="git --work-tree $HOME --git-dir $HOME/dotfiles"
      2) Initialize the bare-repo and add the original repo as an remote-repository:
      config init
      config remote add -t \* -f origin
      3) to put all the dotfiles into your $HOME just checkout your branch:
      config checkout master
      Hope it helps someone!

  • @max_ishere
    @max_ishere 4 роки тому

    I may have just spent a day writing a script to do all the sync... The good thing is I learned bash.

  • @CichlidVibes
    @CichlidVibes 4 роки тому +1

    why not just rsync all the dotfiles to a safe place and make backup and restore on a new system?

  • @shrikamath
    @shrikamath Рік тому

    How do I move my dotfiles to anothe machine and restore files ?

  • @matthill11
    @matthill11 3 роки тому

    I am using the fish shell and when I try to use config I get an error "fatal: not a git repository '/home/myname/dotfiles/'" what could I be doing wrong?

  • @modaryaghi
    @modaryaghi 4 роки тому +1

    Everything had worked with me exept the config push command, git didn't know where to posh the file, and it asked for something it called upstream!

    • @SupaShang
      @SupaShang 4 роки тому +2

      I had that too, I fixed it by doing this: config push --set-upstream git@gitlab.com:myusername/dotfiles.git master

  • @ramonrames
    @ramonrames 3 роки тому

    you should really also try etckeeper. BTW I tried dotbare but in the end, I just use a standard git repo in my home dir. No downfalls and better integration with existing tools

  • @devKazuto
    @devKazuto Рік тому

    I like this approach, but how would you handle scripts that install a set of applications? In a separate directory called e.g. `.setup`?

  • @kmui6022
    @kmui6022 2 роки тому

    instead of setting showUntrackedFiles to no i keep it normal and instead filter with an .gitignore file. So i automatically track files in specific subdirectories

  • @krombopuloslincler4849
    @krombopuloslincler4849 2 роки тому

    Why can't we simply hardlink files and have a cron job git-push it every week?

  • @WizardPlatypus
    @WizardPlatypus 4 роки тому

    Hi! I like this method, but come into some problems when i try to get my configs on a new machine. Things just look weird. Can somebody please give me a proper way to do it with such method?

  • @johnsonmcbig9157
    @johnsonmcbig9157 5 років тому +2

    What if you make the whole root folder a repository?

    • @jeetadityachatterjee6995
      @jeetadityachatterjee6995 5 років тому +2

      Well then when you upload it anyone can take your entire system and replace use it as well. They would also probably know every file program and image that you have on your computer unless you remove them manually. Other then that it would be unnecessary.

  • @praetorxyn
    @praetorxyn 4 роки тому

    I think I still prefer dotbot but I'll give this a look. I am not sure this solution will be as flexible as I need it to be. Using the settings.json example you provided, Iwould have no idea what that file pertained to if I didn't put it in the commit message; seems way better to just have dotfiles/config//settings.json -> ${XDG_CONFIG_HOME}//settings.json by just adding an entry for it into install.config.yaml and running dotbot-install.

  • @JS-kr7zy
    @JS-kr7zy 5 років тому

    I did this, then cloned my dotfiles repository to a new machine, but this broke my .bashrc alias. For some reason even tho the repo was cloned into $HOME/dotfiles the alias no longer recognizes it as a git repo when using the alias. Inside the $HOME/dotfiles dir it is recognized by a simple git status command, but the alias doesn't work.

  • @omenquentama6453
    @omenquentama6453 3 роки тому

    if I generate .gitignore file with everything else selected than my dotfiles, am I able to do " add ."?

  • @nonetrix3066
    @nonetrix3066 3 роки тому +1

    I just make my whole system a git repo and when ever I mess up my system I revert the last commit :gigabrain:

  • @nevdelap6735
    @nevdelap6735 6 років тому +2

    If you just clone your dotfiles repo, move the .git directory to ~, delete the clone, and do git reset --hard in ~ you can avoid the config alias. Your ~ is the working copy. Then as someone mentioned .gitignore * and use git add -f. Then you can just use git normally.

  • @jabuxas
    @jabuxas 2 роки тому

    I have a question, I backup up everything I needed and then distrohopped. How do I clone the repository so that it has the same functionalities? i.e. I can "config add x.file" and it will work perfectly. The only way I managed to do it was deleting the repo and following the tutorial again.

  • @rancidbeef582
    @rancidbeef582 Рік тому

    Use "stow" to automagically symlink to your dotfiles directory.

  • @VasanthDeveloper
    @VasanthDeveloper 6 років тому

    Greatly explained!

  • @Little-bird-told-me
    @Little-bird-told-me 2 роки тому +1

    Why can't we just "git" the entire .config folder ? Wouldn't that be a simpler way. My _.config folder /repo_ is about 250 mb. Granted you make have to symlink a few files like .bashrc which reside outside of .config but the majority of files sit inside .config.

  • @atps
    @atps 5 років тому

    That could be very useful. Thanks for the video.

  • @notchicken
    @notchicken Рік тому

    This seems like a great new thing to try out! However, I'm confused as to how one would go about setting up a new machine if they were to reuse the same dotfiles. Would they not have to do any moving / copying / symlinking?

  • @Appalling68
    @Appalling68 5 років тому +1

    I’m a Linux (Mint) newbie and am aware of what dotfiles are, but am clueless as to why you have to “manage” them. Also, is the point of this video to show us how to backup these dotfiles? Guess I’m way in over my head here.

    • @korben4340
      @korben4340 5 років тому +1

      the idea of managing them is #1 to backup all your important settings stored in dotfiles #2 if switching between different computers and virtual machines to easily reload the backup
      this obv saves a lot of setup time and also makes it simple to try out different config setups
      espc for heavily config'd uses like mail accounts and news and media feeds

  • @michalski9141
    @michalski9141 2 роки тому

    I still have to add them one by one right? I wanted to add my .config and it started adding tons of cache files for some reason

  • @Void-in2pz
    @Void-in2pz 4 роки тому +1

    Hey, DT! do you think it's possible to bring this to a bigger scale ? I mean, what if we make git bare repository for the whole system on empty , freshly installed distro and call it main, then we can create another branch and call it kde, install and configure kde afterwards , and commit changes to kde branch , and then again we go checkout our main branch, and do the same for , say , dwm, or i3 , or xfce even. See where I'm going with this ? Or how about we use another branch and call it thinkpad-x201, on a fresh arch linux install, then we configure everything we need for this machine (media keys, stylus support (if any) , fingerprint sensor, hibernation and so on) , we can then checkout main branch on another machine , say thinkpad-x61 , and do the same, now we made our selves custom distro, may i say, that can be used on any of our machines, and we can just install official distro on any machine as always , install just git and then clone our custom distro repository , and that's it , no more messing around with different distros, desktop environments (we all know how messy it becomes if you have more than one DE), you just install your favorite distro , as usual , and use your own configuration of that, suitable for current machine and god knows what else you can do with it, and more over, it's a back up system for your whole system , out of the box ! imagine installing some program that can make serious changes to your system ( not so hard to imagine having AUR under your hand , huh) , you prepare a commit -m "restore point: before installing dangerous software" , you install the software , your system crashes , as it should , but , you just boot from some live linux usb , or if it's just GUI, or graphics that failed we can do it even without live usb, chroot to your system , and roll back to your previous commit , boom this house is clear!
    Any way, why am I even writing this ? Well , I see the possibility but I'm not quite sure how to do this.
    Any chance you can get involved, or advise on this, what so ever ?

  • @surferbum618
    @surferbum618 11 місяців тому

    Hey DT, just wanted to check in and see if this is still the way you're managing your dot files?

  • @bobkoss280
    @bobkoss280 4 роки тому

    How do you diff and merge using this technique? I can't figure out a way to use vim-fugitive or any other vim/nvim diff tools because of the alias.

  • @RockingWomble
    @RockingWomble Рік тому

    How do you setup a bare repo with gitlab?