Git Bare Repository - A Better Way To Manage Dotfiles

Поделиться
HTML-код
  • Опубликовано: 21 авг 2024

Комментарии • 257

  • @AbduleeFtw
    @AbduleeFtw 4 года назад +106

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

    • @str0680
      @str0680 3 года назад +14

      NOOOOOOOOOOOOO 💀💀💀💀

    • @coompiler9029
      @coompiler9029 3 года назад +6

      Oh my god

    • @RazoBeckett.
      @RazoBeckett. 8 месяцев назад +1

      lol

    • @teesh3rt
      @teesh3rt 6 месяцев назад +1

      OH NOOOOOOOO 💀💀💀💀

  • @engageintellect
    @engageintellect 4 года назад +8

    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.

  • @vpxc
    @vpxc 5 лет назад +94

    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 3 года назад +1

      @@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 3 года назад +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 ~`

  • @tackvector
    @tackvector 8 месяцев назад +1

    I'm still coming back to this video to remember how to do this on new machines. The information presented here is invaluable. Thank you so much!

  • @matthewstott3493
    @matthewstott3493 4 года назад +18

    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 6 месяцев назад

      what's the difference?

    • @matthewstott3493
      @matthewstott3493 6 месяцев назад

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

    • @brainstormsurge154
      @brainstormsurge154 5 месяцев назад

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

  • @lpanebr
    @lpanebr 4 года назад +9

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

  • @ItsRyanStudios
    @ItsRyanStudios Год назад +4

    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.

  • @mitchelvalentino1569
    @mitchelvalentino1569 5 лет назад +27

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

  • @evanstenger8590
    @evanstenger8590 8 месяцев назад

    Thanks for putting together this video! I read that article, and then searched on RUclips 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!

  • @RockTheCage55
    @RockTheCage55 8 месяцев назад +1

    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

  • @wvovaw3052
    @wvovaw3052 4 года назад +4

    ⚠️ 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 ?

  • @DDBAA24
    @DDBAA24 4 года назад +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.

  • @fuseteam
    @fuseteam 4 года назад +18

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

    • @BillGarrett
      @BillGarrett 5 месяцев назад +1

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

  • @UNNAM3D82
    @UNNAM3D82 4 года назад +3

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

  • @Gglsucksbigballz
    @Gglsucksbigballz 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)

  • @gcasanas1
    @gcasanas1 2 года назад +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.

  • @distroverse
    @distroverse 5 лет назад +6

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

    • @DistroTube
      @DistroTube  5 лет назад

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

  • @bobgrimes8618
    @bobgrimes8618 5 лет назад +2

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

  • @abucketofelves
    @abucketofelves 5 лет назад +28

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

  • @meowtabby5369
    @meowtabby5369 3 года назад

    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!

  • @saltrocklamp199
    @saltrocklamp199 3 года назад +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.

  • @you_what319
    @you_what319 5 лет назад +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"

  • @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!

  • @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 4 года назад +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

  • @pedro_alonso
    @pedro_alonso Год назад

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

  • @pengpleb
    @pengpleb 5 лет назад +23

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

    • @BlackM3sh
      @BlackM3sh 5 лет назад +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 5 лет назад +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 5 лет назад +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 5 лет назад +1

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

    • @thierrybo6304
      @thierrybo6304 5 лет назад

      @@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)

  • @dengan699
    @dengan699 5 лет назад +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 5 лет назад +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 года назад

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

  • @ShadwTrooper
    @ShadwTrooper 3 года назад +2

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

  • @allegoricalstatue
    @allegoricalstatue 4 года назад +4

    Damn, this is actually really cool

  • @johannesmariomeissner7262
    @johannesmariomeissner7262 2 года назад

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

  • @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)

  • @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"

  • @kriseberwein7357
    @kriseberwein7357 5 лет назад +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"

  • @ex0stasis72
    @ex0stasis72 4 года назад +5

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

  • @hzaphry
    @hzaphry 2 года назад

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

  • @kraftwerk28
    @kraftwerk28 4 года назад +1

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

  • @SheldonHull
    @SheldonHull Год назад

    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

  • @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.

  • @ehsanamini8501
    @ehsanamini8501 4 месяца назад

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

  • @SantiYounger
    @SantiYounger 3 года назад

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

  • @sasakanjuh7660
    @sasakanjuh7660 5 лет назад +2

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

  • @lawrencedoliveiro9104
    @lawrencedoliveiro9104 5 лет назад +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?

  • @k2a3r4l5o6
    @k2a3r4l5o6 5 лет назад +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 Год назад +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

  • @pcfreak1992
    @pcfreak1992 5 лет назад +2

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

  • @twiksify
    @twiksify Год назад

    This is brilliant! 🎉

  • @anantgupta7916
    @anantgupta7916 3 года назад

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

  • @bendover4728
    @bendover4728 5 лет назад +9

    This is really confusing.. It would help if you actually run the freaking commands, like in another user (you may create a dummy user for testing or for tutorials like this one...).

    • @FekuEntertainmentLtd
      @FekuEntertainmentLtd 3 года назад +1

      I've been a long time subscriber to DT. He used to put effort into these videos. But nowadays, kinda feels he is becoming too lazy to just make videos and drop it in the channel.

  • @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).

  • @espehon
    @espehon Год назад

    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
    }

  • @konscodes
    @konscodes 2 года назад +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. 😀

  • @dustinmorse8497
    @dustinmorse8497 5 лет назад +1

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

  • @arykleinerman6516
    @arykleinerman6516 4 года назад +6

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

    • @allegoricalstatue
      @allegoricalstatue 4 года назад

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

    • @LordZultair
      @LordZultair 4 года назад +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

  • @diszydreams
    @diszydreams 8 месяцев назад

    Thanks! Still valid! works for me!

  • @ankushmenat
    @ankushmenat 4 года назад +1

    Thank you very much. Amazing video!

  • @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)."

  • @king_and_country
    @king_and_country 5 лет назад

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

  • @reza.kargar
    @reza.kargar 4 месяца назад

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

  • @VanStabHolme
    @VanStabHolme 2 года назад

    Very useful and convinient. Thank you.

  • @Jonathan-dm3pt
    @Jonathan-dm3pt 5 лет назад

    Very useful, thanks DT.

  • @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:

  • @sylvershadow1247
    @sylvershadow1247 5 лет назад

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

  • @rancidbeef582
    @rancidbeef582 Год назад

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

  • @max_ishere
    @max_ishere 3 года назад

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

  • @koszal_
    @koszal_ 4 года назад +1

    Thanks!!! Great solution for me.

  • @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 лет назад

      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

  • @SpittedDusk
    @SpittedDusk 5 лет назад

    Thank you, I will start using this method myself.

  • @MarcoMonteiro
    @MarcoMonteiro 4 года назад

    THIS IS A GAME CHANGER!!!!!!

  • @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.

  • @dmmeteo
    @dmmeteo 4 года назад

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

  • @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

  • @KristofKorwisi
    @KristofKorwisi 3 года назад

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

  • @bGrickD
    @bGrickD 3 года назад +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 3 года назад

      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)

  • @Ethorbit
    @Ethorbit 2 года назад

    This is super helpful and useful, thanks!

  • @trqhxrd5844
    @trqhxrd5844 2 года назад

    You can even create different branches for different rices / profiles

  • @doctorpine
    @doctorpine 2 года назад

    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

  • @ramzeslo2
    @ramzeslo2 4 года назад +1

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

  • @VasanthDeveloper
    @VasanthDeveloper 5 лет назад

    Greatly explained!

  • @nevdelap6735
    @nevdelap6735 5 лет назад +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.

  • @mrAirsoft953
    @mrAirsoft953 5 лет назад +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 5 лет назад +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 4 года назад +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!

  • @Void-in2pz
    @Void-in2pz 3 года назад +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 ?

  • @atps
    @atps 4 года назад

    That could be very useful. Thanks for the video.

  • @Little-bird-told-me
    @Little-bird-told-me Год назад +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.

  • @kendawg_mcawesome
    @kendawg_mcawesome 5 лет назад

    Very nice, great tip.

  • @VulcanOnWheels
    @VulcanOnWheels 2 года назад

    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.

  • @douglaidlaw740
    @douglaidlaw740 3 года назад

    I have a far simpler solution, one that is regarded as basic, and does not involve all this duplication. I put my Home Directory on a separate partition, which survives a reinstall!

  • @notchicken
    @notchicken 9 месяцев назад

    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?

  • @krombopuloslincler4849
    @krombopuloslincler4849 2 года назад

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

  • @modaryaghi
    @modaryaghi 3 года назад +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 3 года назад +2

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

  • @YannMetalhead
    @YannMetalhead Год назад

    Good video.

  • @example101
    @example101 3 года назад +1

    Awesome! Leveled up. Will contrib $ when cv $ rolls in. If you are new to Linux or Git start here.

  • @mjaysmileofficial
    @mjaysmileofficial Год назад

    so it's the same thing as making symlinks, it's just instead of symlinking every file, now you have to git add every file

  • @Varma414
    @Varma414 5 лет назад +1

    I am new to this channel. What distro you are using and terminal you are using to look fancy ?
    ThankX

    • @DistroTube
      @DistroTube  5 лет назад +1

      I was using Manjaro. This was the i3 window manager at the time (I used i3 for three weeks recently). The terminal might have been xterm in this video. The terminal I used for most of my earlier videos was urxvt. The terminal I use currently is st. All fine choices.

    • @Varma414
      @Varma414 5 лет назад

      DistroTube Thanks for your response. I am using Manjaro too. I will i3.

  • @johnsonmcbig9157
    @johnsonmcbig9157 5 лет назад +2

    What if you make the whole root folder a repository?

    • @jeetadityachatterjee6995
      @jeetadityachatterjee6995 4 года назад +1

      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.

  • @FredMny
    @FredMny Год назад

    hey DT
    I love your videos and am using this method since you posted about it.
    Is there a way to use the same bare repository, but use and update just specific files in different systems?
    My use case: I use Arch Linux on my personal computer, but have a Macbook for work. So, I don't need all my dotfiles from my Arch config, but just some like `.vimrc`, `.zshrc` etc.

  • @philippkrause7650
    @philippkrause7650 3 года назад

    Awesome solution, thx

  • @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.

  • @noferblatz
    @noferblatz 3 года назад

    Wouldn't it just be easier to set up a script in /etc/cron.daily to do an rsync backup of your $HOME directory to a USB drive? Backup takes seconds each day and backs up everything in your home directory.

  • @surferbum618
    @surferbum618 6 месяцев назад

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