Can/should I fork my own github repo?

My github repo is called Programming-iOS-4-Book-Examples, because it’s the example code from my book “Programming iOS 4”. Now I’ve written a new edition of the book, retitled “Programming iOS 5”. I need to leave the old repo in place with the old name, because there are links to it all over the net and someone might need the old code. But now I also want a new repo with a new name, Programming-iOS-5-Book-Examples, containing the same examples rewritten for iOS 5 (plus some new ones).

Naturally, I saw this: How can I fork my own GitHub repository? But the advice there is to use branches. That isn’t going to work for me. I don’t want to use a branch because that defeats the purpose of giving the repo a name that I can link to. I want the public to find my iOS 4 examples in the iOS 4 repo and my iOS 5 examples in the iOS 5 repo.

This seems like a perfect use of a fork, but when I press the Fork button nothing happens; I’m apparently not allowed to fork my own repo.

Of course I could just make this a whole new repo, but that would mean uploading all the resources separately, which is unfortunate because everything is already right there in the iOS 4 repo. Do I just have to do that anyway?

  • Compilation of code on build/CI server
  • Having a hard time understanding Git and Github's place on my web server
  • Git: Remove a file from a Pull Request
  • How to properly use git with local remote
  • How to get last commit date inside a folder/directory in github repo?
  • Git linked directory (always in sync)
  • How do I do many pull requests to a project on Github and keep my master updated at the same time while waiting for reviews?
  • Delete remote branch displayed on local by 'git branch -a'
  • 4 Solutions collect form web for “Can/should I fork my own github repo?”

    You can’t have two repositories with the same name, and forking on Github automatically transfers the name, so that’s what keeps that from working. It sounds like you would be well served by adding a branch locally, then pushing to a new Github repository with the new name. You can even keep the Github repo showing master as the branch:

    git clone git://github.com/you/repo.git
    git checkout -b new_book
    [ create new repo on Github ]
    git remote add new_origin git://github.com/you/repo.git
    git push new_origin new_book:master
    

    Just use more appropriate names and you’re golden. You can merge updates to shared examples, add additional examples to the new book code, and you just push to both origin and new_origin (using the example names above) when you make changes.

    I know this is old but I faced the same issue recently. What did work for me was the following:

    1. Create a new_repo at github
    2. git clone new_repo
    3. cd new_repo
    4. git remote add upstream old_repo.git
    5. git pull upstream master
    6. git push origin master

    I got all the above from here.

    Given that you can have URL that link branches in a repo, you can still use branches, which INMHO are the natural and easy way for the case .

    For example, you can have the following URL for iOS4 example:
    https://github.com/mattneub/Programming-iOS-Book-Examples/tree/ios4

    And https://github.com/mattneub/Programming-iOS-Book-Examples/tree/ios5 for the iOS5 examples, where ios4 and ios5 are your branch names.

    In the end here’s what I did:

    1. I renamed the existing repo. This works great (thanks, github, for making that so easy). Don’t forget to edit your own git repo’s config file to keep the remote branch relationship between your own master branch and the github repo’s master branch.

    2. I created a new repo with the old repo’s name, consisting of nothing but a README.md providing the existing repo’s new URL.

    Thus, I didn’t end up separating the iOS 4 book content from the iOS 5 book content. Instead, I rearranged the structure of the original repo and gave it a more general name, not tied to iOS 4 in particular. And existing links to the old repo don’t break, because there’s a placeholder repo at that URL, pointing to the new repo.

    Git Baby is a git and github fan, let's start git clone.