Level Up Your Git Game: 10 Little-Known Features You’ll Love

  Рет қаралды 29,294

ArjanCodes

ArjanCodes

Күн бұрын

Пікірлер: 58
@ArjanCodes
@ArjanCodes 3 ай бұрын
My favorite one by far is git worktree. It saves me a lot of time switching between branches. What's yours?
@KrishnaKantMishra-mv4tf
@KrishnaKantMishra-mv4tf 3 ай бұрын
Mine too, as I have to do it a lot stash or commit and then move to other repo
@iSJ9y217
@iSJ9y217 3 ай бұрын
It's "git notes" for sure, because my science supervisor often forgets why did we decide to change something, and notes are very convenient to refresh the memory
@SugarBeetMC
@SugarBeetMC 3 ай бұрын
The -p (patch) flag for git-stash and git-add, helps me avoid monster commits.
@davidgromling4455
@davidgromling4455 3 ай бұрын
Agreed with worktrees. For complied languages, it can actually save complain time as well, since no files need to be changed when switching branches.
@schwaboy
@schwaboy 3 ай бұрын
One of the things I find myself using way too often is `git stash`. Sometimes I will make a bunch of changes, and then when I go to commit, I realize that I'm still in the main branch. But I want them to be in a feature branch. So I will use `git stash` to store my changes, switch to the feature branch, and use `git stash pop` to bring those changes into that feature branch instead.
@etiennelebard4899
@etiennelebard4899 3 ай бұрын
If the feature branch doesn't exist yet, you should be able to just 'git checkout -b feature_branch'. Or at least that's how I remember it, I have to admit I've been switching and creating branches with GitHub Desktop for the last year or so.
@ntorneri
@ntorneri 3 ай бұрын
I think that if the files you've changed in the main branch have not been modified in the feature branch, you don't even have to do a "git stash" and just switch branches.
@Tresorthas
@Tresorthas 3 ай бұрын
Incidentally, that's what JetBrains IDEs do. I always get annoyed with VS Code when it says "oh, I can't pull/rebase this branch, because you have uncommitted changes!"... "Then do a stash before, and a stash pop after, you dummy!"
@kompot4277
@kompot4277 3 ай бұрын
I just git checkout a new branch
@christucker9566
@christucker9566 3 ай бұрын
You don’t need to stash in this case! Just create the new branch.
@danielhjertholm
@danielhjertholm 3 ай бұрын
I think being comfortable with interactive rebase, reflog and understanding how to use git reset --mixed and --soft pretty useful. For example if you've accidentally amended your changes to the last commit, but wanted to make a separate commit, just find the SHA from before the ammend with reflog, mixed-reset to that, and your changes are staged to be committed again.
@etiennelebard4899
@etiennelebard4899 3 ай бұрын
Yeah I still haven't wrapped my head around what "--mixed" does when using git reset 😅
@traal
@traal 3 ай бұрын
There are two other great lectures in this format that I can strongly recommend - ”So you think you know Git” and part 2 by Scott Chacon. It’s a bunch of random stuff just like this, some of it very useful or interesting. 🧐😁
@traal
@traal 3 ай бұрын
kzbin.info/www/bejne/l6DPepKIr5WNp7s
@ondskabenselv
@ondskabenselv 3 ай бұрын
Yes, those are really good!
@dmitryutkin9864
@dmitryutkin9864 3 ай бұрын
Could you please make a follow along dev video using git best practices - what to commit, when to switch and so on, how merge, rebase - and why . just kind a real life workflow.
@_DRMR_
@_DRMR_ 3 ай бұрын
First time I used `git bisect` was to track a bug in the Linux kernel .. took like 7-8 iterations (and kernel builds .. and reboots) to find the culprit. Very satisfying when successful! One command I use a lot to get the current commit hash: `git rev-parse HEAD`
@danielhjertholm
@danielhjertholm 3 ай бұрын
My whole workflow is built around worktrees. I do a "bare" clone to keep that base directory relatively clean, and the keep all worktrees in that base.
@iSJ9y217
@iSJ9y217 3 ай бұрын
Hi Arjan! Please, read till the end ✌ Long-long-long time ago when the magic of KZbin algorithms recommended me one of your videos, I actually didn't like it at all, in any possible way it was the opposite of what I'd consider a good tech video, because I had an impression, you are just another tech-blogger, a little bit too much pretentious, and the content itself is not that much useful, but... BUT! But for some reason I subscribed and kept watching (don't know why, maybe click bates work haha), and I didn't notice how my perception of your channel changed gradually. Today I believe you are an awesome person, and when I saw that this really cool video only has 37 comments I felt it's not fair. Honestly, I was expecting at least 1-2 thousand of comments. I'd like to say what I like about your channel and your videos specifically: 1. So nice, cozy and comfy! It's almost like a Christmas evening but, it's about coding, and you are Santa. 2. I like the little humor you add, it's exactly enough to make watching interesting, yet not turn into a comedy. The kind of intellectual humor which's so rare these days. 3. It's obvious for every one: you sir, are a 100% pro in this field, not a person, who just pretends to be one. And even I don't need 75% of what you are talking about for my work, I like to know more about it, because it looks so easy when you explain things. 4. The setting, the light, the sound - just perfect without any shouting, music or anything else! Honestly, I started to watch your videos not for education purposes, but just to listen to something smart during coffee breaks. Your channel gives the same feeling as the famous LockPickinLawyer: calm intellectual retreat. I sincerely wish your channel to grow and prosper! 🖖 If one day you are traveling in Hong Kong or Shenzhen (or just South China in general), I owe you a cup of coffee! Cheers!
@ArjanCodes
@ArjanCodes 3 ай бұрын
Thanks so much! It’s awesome to know the hard work doesn’t go unnoticed. There’s so much more behind a single video than people realize, all the behind-the-scenes hustle. Would love to grab that cup of coffee one day!
@Flankymanga
@Flankymanga 3 ай бұрын
Amending is certainly one feature not mentioned that is very important to know - fixing existing commits.
@user-kricks
@user-kricks 3 ай бұрын
Could you consolidate all the concepts of git in a course like structure. Could be pretty usefull
@ramimashalfontenla1312
@ramimashalfontenla1312 3 ай бұрын
Awesome video!
@ArjanCodes
@ArjanCodes 3 ай бұрын
Thank you! Glad you liked it.
@klmcwhirter
@klmcwhirter 3 ай бұрын
I really expected to see git ls-files / git cat-file in the list. Learning about those two will help dispel the mystery in the git db. I echo the comments about interactive rebase - git rebase -i - that command has saved my bacon more than once. Also this is a standard alias I setup on any new system to get a one line, colorized log per commit: alias.lg=log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cd) %C(bold blue)%Creset' --abbrev-commit Aliases are a powerful feature such as this one to save typing: alias.stashu=stash --include-untracked But I guess git worktree might be even more useful now a days ... Thanks again for a great video!
@Megamorf
@Megamorf 27 күн бұрын
You left out one important detail about "git bisect" - If you have many commits to go through to figure out where a bug was introduced it becomes quite tedious to manually mark every commit as good or bad. You can pass a script to "git bisect" that based on its exit code will mark a commit as good or bad and can automate the search for the oldest bad commit. That script could take care of the heavy lifting such as pulling dependencies and then building and testing your application.
@wexwexexort
@wexwexexort 3 ай бұрын
I like interactive rebase the most and force push to master.
@franktewierikholscher
@franktewierikholscher 3 ай бұрын
@ArjanCodes I always wonder why you don't pronounce the "i" in repository. You always say: repostory
@MichaelFJ1969
@MichaelFJ1969 3 ай бұрын
I like "git blame". The name says it all!
@kellymoses8566
@kellymoses8566 3 ай бұрын
learning git really well honestly is harder than learning Python.
@radiofuture6911
@radiofuture6911 3 ай бұрын
My favourite: "git gud".
@ArjanCodes
@ArjanCodes 3 ай бұрын
Haha, right on!
@rbalfanz
@rbalfanz 3 ай бұрын
Since .gitkeep is a convention and not a first class feature, I prefer a .gitignore file that ignores all files except itself. If that is confusing, a documentation file e.g. README that explains the purpose of the kept empty directory might be preferred. I think both those are slightly better than a .gitkeep, IMHO.
@digiryde
@digiryde 3 ай бұрын
IIRC, Linus said GIT sucks, but sucks less than all the others.
@TarikAmar
@TarikAmar 3 ай бұрын
`git co -p` or `git reset -p` or `git add -p`, `git co main; git pull; git co -; git rebase -`
@AndyWallWasWeak
@AndyWallWasWeak 3 ай бұрын
if git was really good then every writer would be using it but no it's a distraction from the artistic process
@EduardAlexandru
@EduardAlexandru 3 ай бұрын
Not really, is just a skill, like regex, once you're confident with it you'll kick yourself for not learning it years ago.
@iSJ9y217
@iSJ9y217 3 ай бұрын
It's because every day we stray further from the beauty of punched card coding
@EduardAlexandru
@EduardAlexandru 3 ай бұрын
@@iSJ9y217 😂
When to (Not) Use Dunder Methods?
20:37
ArjanCodes
Рет қаралды 30 М.
小丑教训坏蛋 #小丑 #天使 #shorts
00:49
好人小丑
Рет қаралды 54 МЛН
Quando A Diferença De Altura É Muito Grande 😲😂
00:12
Mari Maria
Рет қаралды 45 МЛН
So You Think You Know Git - FOSDEM 2024
47:00
GitButler
Рет қаралды 1,3 МЛН
7 Functional Programming Techniques EVERY Developer Should Know
21:35
How GIT works under the HOOD?
16:01
Tech With Nikola
Рет қаралды 211 М.
Neovim and Git: SOLVED
8:03
typecraft
Рет қаралды 82 М.
7 Powerful Databases Python Developers Should Know
23:55
ArjanCodes
Рет қаралды 46 М.
git rebase - Why, When & How to fix conflicts
9:45
Philomatics
Рет қаралды 71 М.
Avoid These BAD Practices in Python OOP
24:42
ArjanCodes
Рет қаралды 84 М.
How GitHub's Database Self-Destructed in 43 Seconds
12:04
Kevin Fang
Рет қаралды 1 МЛН
UV for Python… (Almost) All Batteries Included
17:35
ArjanCodes
Рет қаралды 93 М.
Git Tutorial For Dummies
19:25
Nick White
Рет қаралды 1,3 МЛН
小丑教训坏蛋 #小丑 #天使 #shorts
00:49
好人小丑
Рет қаралды 54 МЛН