xxxxxxxxxx
git checkout -b <new-branch>
// This will leave your current branch as it is, create and checkout a new branch and keep all your changes. You can then stage changes in files to commit with:
git add <files>
//and commit to your new branch with:
git commit -m "<Brief description of this commit>"
xxxxxxxxxx
git checkout -b newfeat master
git rebase --onto working-branch origin/master newfeat
git checkout master
git reset --hard origin/master
At this point you have:
*master pointing to the last pushed commit (origin/master)
*working-branch never changed
*a new newfeat branch that contains all the new commits and is ahead of working-branch.
xxxxxxxxxx
#i want to wark on branch A (existing branch), i did clone , i worked on branch B, now i want to push my work to branch A
# if i did add and commit i need to do this step ⬇️
git reset HEAD~
#THEN
git stash
git checkout A
git stash pop
# then add and push