Shelve in TortoiseSVN?

后端 未结 7 2046
春和景丽
春和景丽 2021-01-31 13:34

I\'ve moved from TFS to SVN (TortoiseSVN) with my current company. I really miss the \"Shelve\" feature of TFS. I\'ve read various articles on how to \"Shelve\" with SVN, but I\

相关标签:
7条回答
  • 2021-01-31 14:12

    You can use a DVCS but in a way this is a kludge. 'Shelving' in a DVCS stores your changes locally only. Its useful only if you want to checkpoint your work to rollback if you break it with further work, but preferably you'd want to save your work on the server.

    One way to do this in SVN without an explicit shelve command is to switch your working copy to a different svn location and commit there instead of on your main repo. This is effectively like creating a temporary branch and working on that for the duration of your work. I don't think you'll even have to merge as SVN will do it for you when you switch, as your local modifications will be kept.

    Unfortunately, you cannot switch to a non-existent location, so the first time you do this, you'll have to create the 'branch' to shelve to. I guess the whole thing could be automated.

    0 讨论(0)
  • 2021-01-31 14:14

    If you understand how SVN branches work, emulating Shelve in SVN is a no-brainer:

    1. Create a branch in the repository (on the server)
    2. Switch your local copy to it
    3. Commit your changes to the new branch
    4. Switch your local copy back to the trunk

    When you are ready to get back to your shelved changes ("unshelve"), simply merge the shelf branch back to your local copy.

    If you don't know command-line SVN nor Tortoise SVN well enough to do the above, here's a super detailed step-by-step instruction on how to do it in Tortoise SVN:

    1. Do "SVN Update" to update your working copy to the latest version of the trunk. This way the only differences between your local copy and the trunk are your changes.
    2. From the context menu select "Branch / Tag"
    3. "HEAD version in the repository" option is selected by default. Keep that.
    4. Change the "To Url" to specify branch name, e.g. http://server/repository/project1/branches/shelf1
    5. Check the "Switch working copy to new branch/tag" box
    6. Click Ok to create the branch and switch to it
    7. Do "SVN Commit..." and commit your changes to the newly created branch
    8. From the context menu select "Switch..."
    9. Change the "To URL" to the trunk URL e.g. http://server/repository/project1/trunk
    10. Click Ok to switch back to the trunk

    See this link for even more details and the command-line equivalent of the above:
    Shelves in Subversion

    0 讨论(0)
  • 2021-01-31 14:15

    SVN have upgraded the shelving https://subversion.apache.org/docs/release-notes/1.11.html#shelving

    The kinds of change you can shelve are committable changes to files and properties, except the following kinds which are not yet supported:

    • copies and moves
    • creating and deleting directories
    0 讨论(0)
  • 2021-01-31 14:25

    I don't believe that SVN has this feature built into the server product. I also don't believe anything like this emulated in any clients that I have used, including TortoiseSVN.

    To get around this problem, I have resorted to using a DVCS such as Git or Mercurial, to allow me to branch/merge/shelve locally before pushing the content back to SVN. It's arguably a bit of a kludge, but it works really well.

    0 讨论(0)
  • 2021-01-31 14:29

    TortoiseSVN 1.10 now supports shelving: https://tortoisesvn.net/docs/nightly/TortoiseSVN_en/tsvn-dug-shelving.html

    0 讨论(0)
  • 2021-01-31 14:31

    Shelving in SVN is starting to roll out with version 1.10, see Release Notes

    0 讨论(0)
提交回复
热议问题