mercurial/commands.py
changeset 4276 cb6107f78b92
parent 4274 f38f90a177dc
parent 4262 ad33eeeeb50a
child 4306 d4f0405fadac
--- a/mercurial/commands.py
+++ b/mercurial/commands.py
@@ -2255,7 +2255,8 @@ def revert(ui, repo, *pats, **opts):
         def handle(xlist, dobackup):
             xlist[0].append(abs)
             update[abs] = 1
-            if dobackup and not opts['no_backup'] and os.path.exists(rel):
+            if (dobackup and not opts['no_backup'] and
+                (os.path.islink(rel) or os.path.exists(rel))):
                 bakname = "%s.orig" % rel
                 ui.note(_('saving current version of %s as %s\n') %
                         (rel, bakname))