A Scalable, User-Friendly Source Control System.
Go to file
2009-01-02 15:54:05 -06:00
notes utility_commands: Implement rebuildmeta so that metadata can be rebuilt. 2008-12-23 22:19:26 -06:00
svnwrap Support svn:externals changes via .hgsvnexternals updates 2009-01-02 15:54:05 -06:00
tests Support svn:externals changes via .hgsvnexternals updates 2009-01-02 15:54:05 -06:00
__init__.py fetch: Add support for an authormap which can rename authors, intended for 2008-12-30 20:13:32 -06:00
.hgignore .hgignore: ignore nose coverage html. 2008-12-11 19:21:05 -06:00
diff_cmd.py push: Fix the bad implementation that required modifying the dirstate to push. 2008-12-22 21:22:11 -06:00
fetch_command.py Convert svn:externals properties into a .hgsvnexternals file 2009-01-02 15:54:05 -06:00
hg_delta_editor.py Convert svn:externals properties into a .hgsvnexternals file 2009-01-02 15:54:05 -06:00
push_cmd.py Support svn:externals changes via .hgsvnexternals updates 2009-01-02 15:54:05 -06:00
README Wrapped long lines in README. 2008-12-30 19:24:16 -06:00
rebuildmeta.py utility_commands: Implement rebuildmeta so that metadata can be rebuilt. 2008-12-23 22:19:26 -06:00
svncommand.py utility_commands: Implement rebuildmeta so that metadata can be rebuilt. 2008-12-23 22:19:26 -06:00
svnexternals.py Support svn:externals changes via .hgsvnexternals updates 2009-01-02 15:54:05 -06:00
tag_repo.py Import cleanup thanks to pyflakes. 2008-12-24 11:17:50 -06:00
util.py parse_revmap: Stop supporting pickled revmaps. I've made enough major changes 2008-12-24 11:23:19 -06:00
utility_commands.py Fix "hg svn outgoing" help text. 2008-12-30 19:24:16 -06:00

-*-restructuredtext-*-

About
-----
hgsubversion is an extension for Mercurial that allows using Mercurial
as a Subversion client.

Right now it is *not* ready for production use. You should only be
using this if you're ready to hack on it, and go diving into the
internals of Mercurial and/or Subversion.

Installation
------------
You need to have Subversion installed with the SWIG Python bindings
from Subversion 1.5 or later. You need Mercurial 1.1.1 or later.

.. _mercurial: http://selenic.com/repo/hg
.. _mercurial-stable: http://selenic.com/repo/hg-stable
.. _crew: http://hg.intevation.org/mercurial/crew
.. _crew-stable: http://hg.intevation.org/mercurial/crew-stable

If you are unfamiliar with installing Mercurial extensions, please see
the UsingExtensions_ page in the Mercurial wiki. Look at the example
for specifying an absolute path near the bottom of the page. You want
to give the path to the top level of your clone of this repository.

.. _UsingExtensions: http://www.selenic.com/mercurial/wiki/index.cgi/
                     UsingExtensions

Before using hgsubversion, I *strongly* encourage you to run the
automated tests. Just use nose_ if you have it (or ``easy_install
nose`` if you want it), or use ``python tests/run.py`` to run the
suite with the conventional test runner. Note that because I use nose,
there's a lot of stdout spew in the tests right now. The important
part is that all the tests pass.

.. _nose: http://code.google.com/p/python-nose/

Basic Use
-----------
Get a new clone of an svn server::

 $ hg svnclone <svn URI> [destination]

Real example::

 $ hg svnclone http://python-nose.googlecode.com/svn nose-hg

Note, you should pull from the root subversion directory, not specific
folders (such as trunk).

Pull new revisions into an already-converted repo::

 $ hg svn pull

For more information, see 'hg help svn' while in a converted repo.