Skip to content

Instantly share code, notes, and snippets.

@btutal
Forked from 0xjac/private_fork.md
Last active March 24, 2020 16:17
Show Gist options
  • Save btutal/0673c502e24d38b48e919a6e12f47f10 to your computer and use it in GitHub Desktop.
Save btutal/0673c502e24d38b48e919a6e12f47f10 to your computer and use it in GitHub Desktop.

Revisions

  1. btutal revised this gist Mar 24, 2020. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions directus_private_fork.md
    Original file line number Diff line number Diff line change
    @@ -28,9 +28,9 @@ For this assignment the commands are:
    rm -rf app.git
    ```

    5. You can now clone your `app` repository on your machine (in my case in the `code` folder).
    5. You can now clone your `app` repository on your machine (in my case in the `Developer` folder).
    ```bash
    cd ~/code
    cd ~/Developer
    git clone [email protected]:<your_username>/app.git
    ```

  2. btutal revised this gist Mar 24, 2020. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion directus_private_fork.md
    Original file line number Diff line number Diff line change
    @@ -7,7 +7,7 @@ For this assignment the commands are:
    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:directus/appe.git
    git clone --bare [email protected]:directus/app.git
    ```

    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
  3. btutal revised this gist Mar 24, 2020. 2 changed files with 57 additions and 71 deletions.
    57 changes: 57 additions & 0 deletions directus_private_fork.md
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,57 @@
    The [repository](https://github.com/directus/app) for the assignment is public and Github does not allow the creation of private forks for public repositories.

    The correct way of creating a private frok by duplicating the repo is documented [here](https://help.github.com/articles/duplicating-a-repository/).

    For this assignment the commands are:

    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:directus/appe.git
    ```

    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.

    3. Mirror-push your bare clone to your new `app` repository.
    > Replace `<your_username>` with your actual Github username in the url below.

    ```bash
    cd app.git
    git push --mirror [email protected]:<your_username>/app.git
    ```

    4. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf app.git
    ```

    5. You can now clone your `app` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/app.git
    ```

    6. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add directus-repo [email protected]:directus/app.git
    git remote set-url --push directus-repo DISABLE
    ```
    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:<your_username>/app.git (fetch)
    origin [email protected]:<your_username>/app.git (push)
    directus-repo [email protected]:directus/app (fetch)
    directus-repo DISABLE (push)
    ```
    > When you push, do so on `origin` with `git push origin`.

    > When you want to pull changes from `directus-repo` you can just fetch the remote and rebase on top of your work.
    ```bash
    git fetch directus-repo
    git rebase directus-repo/master
    ```
    And solve the conflicts if any
    71 changes: 0 additions & 71 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -1,71 +0,0 @@
    The [repository](https://github.com/usi-systems/easytrace) for the assignment is public and Github does not allow the creation of private forks for public repositories.

    The correct way of creating a private frok by duplicating the repo is documented [here](https://help.github.com/articles/duplicating-a-repository/).

    For this assignment the commands are:

    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.

    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.

    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```

    4. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf easytrace.git
    ```

    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```

    6. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    git remote set-url --push upstream DISABLE
    ```
    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:<your_username>/easytrace.git (fetch)
    origin [email protected]:<your_username>/easytrace.git (push)
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```
    > When you push, do so on `origin` with `git push origin`.

    > When you want to pull changes from `upstream` you can just fetch the remote and rebase on top of your work.
    ```bash
    git fetch upstream
    git rebase upstream/master
    ```
    And solve the conflicts if any

    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.

    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```

    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```

    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
  4. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -56,7 +56,7 @@ For this assignment the commands are:
    ```
    And solve the conflicts if any

    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.

    ```
  5. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -49,7 +49,7 @@ For this assignment the commands are:
    ```
    > When you push, do so on `origin` with `git push origin`.

    When you want to pull changes from `upstream` you can just fetch the remote and rebase on top of your work.
    > When you want to pull changes from `upstream` you can just fetch the remote and rebase on top of your work.
    ```bash
    git fetch upstream
    git rebase upstream/master
  6. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 0 deletions.
    1 change: 1 addition & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -48,6 +48,7 @@ For this assignment the commands are:
    upstream DISABLE (push)
    ```
    > When you push, do so on `origin` with `git push origin`.

    When you want to pull changes from `upstream` you can just fetch the remote and rebase on top of your work.
    ```bash
    git fetch upstream
  7. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 3 deletions.
    5 changes: 2 additions & 3 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -48,9 +48,8 @@ For this assignment the commands are:
    upstream DISABLE (push)
    ```
    > When you push, do so on `origin` with `git push origin`.
    >
    > To pull changes from `upstream`:
    > ```bash
    When you want to pull changes from `upstream` you can just fetch the remote and rebase on top of your work.
    ```bash
    git fetch upstream
    git rebase upstream/master
    ```
  8. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 1 deletion.
    3 changes: 2 additions & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -55,7 +55,8 @@ For this assignment the commands are:
    git rebase upstream/master
    ```
    And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile

    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.

    ```
  9. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 6 deletions.
    7 changes: 1 addition & 6 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -40,15 +40,13 @@ For this assignment the commands are:
    git remote add upstream [email protected]:usi-systems/easytrace.git
    git remote set-url --push upstream DISABLE
    ```

    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:<your_username>/easytrace.git (fetch)
    origin [email protected]:<your_username>/easytrace.git (push)
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```

    > When you push, do so on `origin` with `git push origin`.
    >
    > To pull changes from `upstream`:
    @@ -57,9 +55,6 @@ For this assignment the commands are:
    git rebase upstream/master
    ```
    And solve the conflicts if any



    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.

    @@ -72,4 +67,4 @@ For this assignment the commands are:
    vagrant reload
    ```

    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
  10. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 55 additions and 55 deletions.
    110 changes: 55 additions & 55 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -5,71 +5,71 @@ The correct way of creating a private frok by duplicating the repo is documented
    For this assignment the commands are:

    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.

    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```

    4. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf easytrace.git
    ```

    ```bash
    cd ..
    rm -rf easytrace.git
    ```
    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```

    6. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    git remote set-url --push upstream DISABLE
    ```

    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:<your_username>/easytrace.git (fetch)
    origin [email protected]:<your_username>/easytrace.git (push)
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```

    > When you push, do so on `origin` with `git push origin`.
    >
    > To pull changes from `upstream`:
    > ```bash
    git fetch upstream
    git rebase upstream/master
    ```
    And solve the conflicts if any
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    git remote set-url --push upstream DISABLE
    ```

    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:<your_username>/easytrace.git (fetch)
    origin [email protected]:<your_username>/easytrace.git (push)
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```

    > When you push, do so on `origin` with `git push origin`.
    >
    > To pull changes from `upstream`:
    > ```bash
    git fetch upstream
    git rebase upstream/master
    ```
    And solve the conflicts if any



    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```
    ```bash
    vagrant reload
    ```
    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
  11. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 0 deletions.
    1 change: 1 addition & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -59,6 +59,7 @@ For this assignment the commands are:
    And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
  12. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 0 deletions.
    1 change: 1 addition & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -58,6 +58,7 @@ For this assignment the commands are:
    ```
    And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
  13. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 10 additions and 10 deletions.
    20 changes: 10 additions & 10 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -4,37 +4,37 @@ The correct way of creating a private frok by duplicating the repo is documented

    For this assignment the commands are:

    1. Create a bare clone of the repository.
    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.
    3. Mirror-push your bare clone to your new `easytrace` repository.
    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```

    4. Remove the temporary local repository you created in step 1.
    4. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf easytrace.git
    ```

    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```

    6. If you want, add the original repo as remote to fetch (potential) future changes.
    6. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    @@ -43,8 +43,8 @@ For this assignment the commands are:

    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:jacquesd/easytrace.git (fetch)
    origin [email protected]:jacquesd/easytrace.git (push)
    origin [email protected]:<your_username>/easytrace.git (fetch)
    origin [email protected]:<your_username>/easytrace.git (push)
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```
    @@ -58,14 +58,14 @@ For this assignment the commands are:
    ```
    And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```
  14. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 10 additions and 11 deletions.
    21 changes: 10 additions & 11 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -4,42 +4,43 @@ The correct way of creating a private frok by duplicating the repo is documented

    For this assignment the commands are:

    #. Create a bare clone of the repository.
    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    #. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.
    #. Mirror-push your bare clone to your new `easytrace` repository.
    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```

    #. Remove the temporary local repository you created in step 1.
    4. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf easytrace.git
    ```

    #. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```

    #. If you want, add the original repo as remote to fetch (potential) future changes.
    6. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    git remote set-url --push upstream DISABLE
    ```

    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:jacquesd/easytrace.git (fetch)
    @@ -57,18 +58,16 @@ For this assignment the commands are:
    ```
    And solve the conflicts if any
    #. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    #. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```
    #. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
  15. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 9 additions and 9 deletions.
    18 changes: 9 additions & 9 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -4,37 +4,37 @@ The correct way of creating a private frok by duplicating the repo is documented

    For this assignment the commands are:

    1. Create a bare clone of the repository.
    #. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    #. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.
    3. Mirror-push your bare clone to your new `easytrace` repository.
    #. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```

    4. Remove the temporary local repository you created in step 1.
    #. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf easytrace.git
    ```

    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    #. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```

    6. If you want, add the original repo as remote to fetch (potential) future changes.
    #. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    @@ -57,18 +57,18 @@ For this assignment the commands are:
    ```
    And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    #. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    #. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```
    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
    #. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
  16. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 1 deletion.
    3 changes: 2 additions & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -47,14 +47,15 @@ For this assignment the commands are:
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```

    > When you push, do so on `origin` with `git push origin`.
    >
    > To pull changes from `upstream`:
    > ```bash
    git fetch upstream
    git rebase upstream/master
    ```
    > And solve the conflicts if any
    And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
  17. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 0 additions and 1 deletion.
    1 change: 0 additions & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -56,7 +56,6 @@ For this assignment the commands are:
    ```
    > And solve the conflicts if any
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
  18. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 3 additions and 3 deletions.
    6 changes: 3 additions & 3 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -57,18 +57,18 @@ For this assignment the commands are:
    > And solve the conflicts if any
    6. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    7. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    7. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    8. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```
    8. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
    9. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.
  19. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 23 additions and 0 deletions.
    23 changes: 23 additions & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -34,6 +34,29 @@ For this assignment the commands are:
    git clone [email protected]:<your_username>/easytrace.git
    ```

    6. If you want, add the original repo as remote to fetch (potential) future changes.
    Make sure you also disable push on the remote (as you are not allowed to push to it anyway).
    ```bash
    git remote add upstream [email protected]:usi-systems/easytrace.git
    git remote set-url --push upstream DISABLE
    ```
    You can list all your remotes with `git remote -v`. You should see:
    ```
    origin [email protected]:jacquesd/easytrace.git (fetch)
    origin [email protected]:jacquesd/easytrace.git (push)
    upstream [email protected]:usi-systems/easytrace.git (fetch)
    upstream DISABLE (push)
    ```
    > When you push, do so on `origin` with `git push origin`.
    >
    > To pull changes from `upstream`:
    > ```bash
    git fetch upstream
    git rebase upstream/master
    ```
    > And solve the conflicts if any
    6. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
  20. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 3 additions and 1 deletion.
    4 changes: 3 additions & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -10,7 +10,9 @@ For this assignment the commands are:
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    2. Create a new repository on Github and name it `easytrace`.
    2. [Create a new private repository on Github](https://help.github.com/articles/creating-a-new-repository/) and name it `easytrace`.
    > If you are unable to create a private repo, you can request unlimited private repos as a studant by getting
    > the [student pack](https://education.github.com/pack) from Github.
    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
  21. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 2 deletions.
    4 changes: 2 additions & 2 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -1,11 +1,11 @@
    The [repository](https://github.com/usi-systems/easytrace) for the assignment is public and Github does not allow the creation of private forks for public repositories.

    The correct way of creating a private frok by duplicating the repo is documented [here](https://help.github.com/articles/duplicating-a-repository/)
    The correct way of creating a private frok by duplicating the repo is documented [here](https://help.github.com/articles/duplicating-a-repository/).

    For this assignment the commands are:

    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever)
    (This is temporary and will be removed so just do it wherever.)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```
  22. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 0 deletions.
    2 changes: 2 additions & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -38,10 +38,12 @@ For this assignment the commands are:
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```

    7. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```

    8. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.


  23. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 0 deletions.
    2 changes: 2 additions & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -25,11 +25,13 @@ For this assignment the commands are:
    cd ..
    rm -rf easytrace.git
    ```

    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```

    6. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
  24. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 1 addition and 1 deletion.
    2 changes: 1 addition & 1 deletion private_fork.md
    Original file line number Diff line number Diff line change
    @@ -1,4 +1,4 @@
    The [repository]() for the assignment is public and Github does not allow the creation of private forks for public repositories.
    The [repository](https://github.com/usi-systems/easytrace) for the assignment is public and Github does not allow the creation of private forks for public repositories.

    The correct way of creating a private frok by duplicating the repo is documented [here](https://help.github.com/articles/duplicating-a-repository/)

  25. @0xjac 0xjac revised this gist Dec 7, 2016. 1 changed file with 2 additions and 0 deletions.
    2 changes: 2 additions & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -14,6 +14,7 @@ For this assignment the commands are:

    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    @@ -31,6 +32,7 @@ For this assignment the commands are:
    ```
    6. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
  26. @0xjac 0xjac created this gist Dec 7, 2016.
    43 changes: 43 additions & 0 deletions private_fork.md
    Original file line number Diff line number Diff line change
    @@ -0,0 +1,43 @@
    The [repository]() for the assignment is public and Github does not allow the creation of private forks for public repositories.

    The correct way of creating a private frok by duplicating the repo is documented [here](https://help.github.com/articles/duplicating-a-repository/)

    For this assignment the commands are:

    1. Create a bare clone of the repository.
    (This is temporary and will be removed so just do it wherever)
    ```bash
    git clone --bare [email protected]:usi-systems/easytrace.git
    ```

    2. Create a new repository on Github and name it `easytrace`.

    3. Mirror-push your bare clone to your new `easytrace` repository.
    > Replace `<your_username>` with your actual Github username in the url below.
    ```bash
    cd easytrace.git
    git push --mirror [email protected]:<your_username>/easytrace.git
    ```

    4. Remove the temporary local repository you created in step 1.
    ```bash
    cd ..
    rm -rf easytrace.git
    ```
    5. You can now clone your `easytrace` repository on your machine (in my case in the `code` folder).
    ```bash
    cd ~/code
    git clone [email protected]:<your_username>/easytrace.git
    ```
    6. Make your `easytrace` repo available in your Vagrant VM by adding the following to your Vagrantfile
    > Replace `"~/code/easytrace"` with your local path to the `easytrace` repo.
    ```
    config.vm.synced_folder "~/code/easytrace", "/easytrace"
    ```
    7. Reload your VM to enable the synced folder (in the folder containing your Vagrant file).
    ```bash
    vagrant reload
    ```
    8. The `easytrace` repo is available at `/easytrace` once you ssh into the machine.