This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| git [2022/11/01 14:39] dblume | git [2023/03/21 09:54] (current) dblume | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| ====== git ====== | ====== git ====== | ||
| - | Make the clone at the remote repository. | + | Make the clone of the remote repository. | 
| < | < | ||
| Line 11: | Line 11: | ||
| </ | </ | ||
| - | Double checking the remote names... | + | If it's a huge repo, [[https:// | 
| < | < | ||
| - | $ git remote | + | git clone \ | 
| - | origin | + |  | 
| - | origin | + | -b main \ | 
| - | upstream | + | --single-branch \ | 
| - | upstream | + | --no-tags \ | 
| + |  | ||
| + | --recurse-submodules=os/components/toolchain \ | ||
| + |  | ||
| + | git@fake.github.com:project/project.git | ||
| </ | </ | ||
| Line 48: | Line 52: | ||
| <code bash> | <code bash> | ||
| - | $ git fetch --all # TODO investigate why fetch | + | $ git fetch --all # Bring your copy of the remote up-to-date | 
| $ git remote prune origin | $ git remote prune origin | ||
| </ | </ | ||
| Line 64: | Line 68: | ||
| $ git push --set-upstream origin new_branch | $ git push --set-upstream origin new_branch | ||
| + | ==== Creating a local branch from an existing remote ==== | ||
| + | |||
| + | After doing a fetch, and suppose " | ||
| + | |||
| + | $ git switch remote-branch | ||
| ==== Changing a local branch to a new remote branch ==== | ==== Changing a local branch to a new remote branch ==== | ||
| Line 93: | Line 102: | ||
| # If main is getting updated, rebase like so: | # If main is getting updated, rebase like so: | ||
| - | # | + | # | 
| # git pull | # git pull | ||
| - | # | + | # | 
| - | # git rebase main | + | # git rebase main # --dry-run to test first | 
| # Consider whether you want to squash commits before pushing | # Consider whether you want to squash commits before pushing | ||
| - | # git reset --soft HEAD~3 | + | #   git reset --soft HEAD~3 | 
| git commit -m "fixed bug" | git commit -m "fixed bug" | ||
| git push --set-upstream origin bugfix/ | git push --set-upstream origin bugfix/ | ||
| - | (do a merge/pull request | + | # Do a MR/PR that deletes the original branch at the remote | 
| - | git checkout | + | git switch | 
| git branch -d bugfix/ | git branch -d bugfix/ | ||
| git pull | git pull | ||
| Line 113: | Line 122: | ||
| **[[https:// | **[[https:// | ||
| - | > I attempted to rebase my branch to main and end up pulling in all of the intermediate commits on main into my branch, | + | > I attempted to rebase my branch to main and end up pulling in all of the intermediate commits on main into my branch, and the merge request suddenly requires approval from unrelated code owners. | 
| **Workaround**: | **Workaround**: | ||
| Line 121: | Line 130: | ||
| <code bash> | <code bash> | ||
| git stash push -m "hold for pull" | git stash push -m "hold for pull" | ||
| - | git branch --set-upstream-to origin/main | + | git switch | 
| git pull | git pull | ||
| - | git stash pop (restores stash on top of main) | + | git stash pop  # | 
| git add/commit | git add/commit | ||
| git push -f origin < | git push -f origin < | ||
| + | </ | ||
| + | |||
| + | If others have made changes in the branch you're working on, you can try to rebase directly onto the latest from the remote: | ||
| + | |||
| + | <code bash> | ||
| + | git pull --rebase | ||
| + | </ | ||
| + | |||
| + | ====== Applying changes in a stash to a changed file ===== | ||
| + | |||
| + | When '' | ||
| + | |||
| + | < | ||
| + | git stash show -p | patch -p0 | ||
| </ | </ | ||
| Line 171: | Line 194: | ||
| I could' | I could' | ||
| + | |||
| + | ====== Limit scope of huge repos ====== | ||
| + | |||
| + | Create a .gitconfig file at the base of your repo: | ||
| + | <file git .gitconfig> | ||
| + | [remote " | ||
| + | fetch = +refs/ | ||
| + | fetch = +refs/ | ||
| + | tagopt = --no-tags | ||
| + | </ | ||
| + | |||
| + | Or explicitly specify your flags: | ||
| + | <code bash> | ||
| + | git fetch --no-tags origin main | ||
| + | git pull --no-tags origin main | ||
| + | git submodule foreach git pull --no-tags origin main | ||
| + | </ | ||
| + | |||
| + | The submodule one is an optimization for the more general: | ||
| + | <code bash> | ||
| + | git submodule update --recursive | ||
| + | </ | ||
| + | |||
| + | ====== git vim mergetool on macOS ====== | ||
| + | |||
| + | File / | ||
| + | |||
| + | <file bash / | ||
| + | FINAL_CMD=" | ||
| + | </ | ||
| + | But vim has a problem with " | ||