-
Notifications
You must be signed in to change notification settings - Fork 4
GitHub Forking Notes
Bob Lee edited this page Apr 25, 2019
·
1 revision
Clone the fork to your machine.
(base) user@linux:~/osp$ git clone https://github.com/bleeeeee/twabler.git
Cloning into 'twabler'...
remote: Enumerating objects: 70, done.
remote: Counting objects: 100% (70/70), done.
remote: Compressing objects: 100% (54/54), done.
remote: Total 70 (delta 7), reused 58 (delta 4), pack-reused 0
Unpacking objects: 100% (70/70), done.
Checking connectivity... done.
List currently configured remote repo for the fork.
(base) user@linux:~/osp$ cd twabler/
(base) user@linux:~/osp/twabler$ git remote -v
origin https://github.com/bleeeeee/twabler.git (fetch)
origin https://github.com/bleeeeee/twabler.git (push)
Add the upstream repo to the configuration and verify.
(base) user@linux:~/osp/twabler$ git remote add upstream https://github.com/sfbrigade/twabler.git
(base) user@linux:~/osp/twabler$ git remote -v
origin https://github.com/bleeeeee/twabler.git (fetch)
origin https://github.com/bleeeeee/twabler.git (push)
upstream https://github.com/sfbrigade/twabler.git (fetch)
upstream https://github.com/sfbrigade/twabler.git (push)
Configure your credentials for persistent storage. With an unmodified local copy of your fork, do a push. This will trigger git to ask for credentials and store them in ~/.git-credentials
(base) user@linux:~/osp/twabler$ git config credential.helper store
(base) user@linux:~/osp/twabler$ git push
warning: push.default is unset; its implicit value has changed in
Git 2.0 from 'matching' to 'simple'. To squelch this message
and maintain the traditional behavior, use:
git config --global push.default matching
To squelch this message and adopt the new behavior now, use:
git config --global push.default simple
When push.default is set to 'matching', git will push local branches
to the remote branches that already exist with the same name.
Since Git 2.0, Git defaults to the more conservative 'simple'
behavior, which only pushes the current branch to the corresponding
remote branch that 'git pull' uses to update the current branch.
See 'git help config' and search for 'push.default' for further information.
(the 'simple' mode was introduced in Git 1.7.11. Use the similar mode
'current' instead of 'simple' if you sometimes use older versions of Git)
Username for 'https://github.com': bleeeeee
Password for 'https://bleeeeee@github.com':
Everything up-to-date
At this point all of your configuration is complete. Code as you need to. In this case, we'll make a branch on our fork and make changes there.
(base) user@linux:~/osp/twabler$ cd mobile/
android/ ios/
(base) user@linux:~/osp/twabler$ cd mobile/android/
(base) user@linux:~/osp/twabler/mobile/android$ ls
README.md
(base) user@linux:~/osp/twabler/mobile/android$ git checkout -b tine
Switched to a new branch 'tine'
(base) user@linux:~/osp/twabler/mobile/android$ vi README.md
Show changes made in branch 'tine'
(base) user@linux:~/osp/twabler/mobile/android$ git diff
diff --git a/mobile/android/README.md b/mobile/android/README.md
index 04893da..30b8708 100644
--- a/mobile/android/README.md
+++ b/mobile/android/README.md
@@ -1 +1 @@
-# Android Version
\ No newline at end of file
+# Android Version!
(base) user@linux:~/osp/twabler/mobile/android$ git status
On branch tine
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: README.md
no changes added to commit (use "git add" and/or "git commit -a")
Add the changed file to the index and record changes to the repo.
(base) user@linux:~/osp/twabler/mobile/android$ git add README.md
(base) user@linux:~/osp/twabler/mobile/android$ git commit -m "added exclamation point"
[tine 3db90b2] added exclamation point
1 file changed, 1 insertion(+), 1 deletion(-)
(base) user@linux:~/osp/twabler/mobile/android$ git push origin tine
Counting objects: 5, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (3/3), done.
Writing objects: 100% (5/5), 401 bytes | 0 bytes/s, done.
Total 5 (delta 1), reused 0 (delta 0)
remote: Resolving deltas: 100% (1/1), completed with 1 local object.
To https://github.com/bleeeeee/twabler.git
5058803..3db90b2 tine -> tine
(base) user@linux:~/osp/twabler/mobile/android$
The changes are pushed. You can
- Leave it as it is
- Have someone with merge rights in the upstream repo merge it
- Make a pull request