Mercurial and Git clients can push and pull from this alias URL to interact with this repository. You can change to which repository an alias points by going to the Aliases link on the project page.
# wctxactions.py - menu and responses for working copy files## Copyright 2010 Steve Borho <steve@borho.org>## This software may be used and distributed according to the terms of the# GNU General Public License version 2, incorporated herein by reference.importosimport subprocess
from mercurial import util, cmdutil, error, merge, commands
-from tortoisehg.hgqt import qtlib, htmlui
+from tortoisehg.hgqt import qtlib, htmlui, visdifffrom tortoisehg.util import hglib, shlib
from tortoisehg.util.i18n import _
fromPyQt4.QtCoreimportQt,SIGNALfromPyQt4.QtGuiimportQAction,QMenu,QMessageBox,QFileDialogdefwctxactions(parent,point,repo,selrows):ifnotselrows:returnalltypes=set()fort,pathinselrows:alltypes|=tdefmake(text,func,types,icon=None):files=[ffort,finselrowsift&types]ifnotfiles:returnNoneaction=menu.addAction(text)ificon:action.setIcon(icon)action.wrapper=lambdafiles=files:run(func,parent,files,repo)parent.connect(action,SIGNAL('triggered()'),action.wrapper)returnactionmenu=QMenu(parent)make(_('&Visual Diff'),vdiff,frozenset('MAR!'))make(_('Edit'),edit,frozenset('MACI?'))make(_('View missing'),viewmissing,frozenset('R!'))iflen(repo.parents())>1:make(_('View other'),other,frozenset('MA'))menu.addSeparator()make(_('&Revert'),revert,frozenset('MAR!'))menu.addSeparator()make(_('L&og'),log,frozenset('MARC!'))menu.addSeparator()make(_('&Forget'),forget,frozenset('MAC!'))make(_('&Add'),add,frozenset('I?'))make(_('&Guess Rename...'),guessRename,frozenset('?!'))make(_('&Ignore'),ignore,frozenset('?'))make(_('Remove versioned'),remove,frozenset('C'))make(_('&Delete unversioned'),delete,frozenset('?I'))iflen(selrows)==1:menu.addSeparator()make(_('&Copy...'),copy,frozenset('MC'))make(_('Rename...'),rename,frozenset('MC'))menu.addSeparator()make(_('Mark unresolved'),unmark,frozenset('r'))make(_('Mark resolved'),mark,frozenset('u'))f=make(_('Restart Merge...'),resolve,frozenset('u'))iff:files=[ffort,finselrowsif'u'int]rmenu=QMenu(_('Restart merge with'))fortoolinhglib.mergetools(repo.ui):action=rmenu.addAction(tool)action.wrapper=lambdatool=tool:resolve_with(tool,repo,files)parent.connect(action,SIGNAL('triggered()'),action.wrapper)menu.addMenu(rmenu)returnmenu.exec_(point)defrun(func,parent,files,repo):'run wrapper for all action methods'hu=htmlui.htmlui()name=func.__name__.title()notify=Falsecwd=os.getcwd()os.chdir(repo.root)try:# All operations should quietly succeed. Any error should# result in a message boxnotify=func(parent,hu,repo,files)o,e=hu.getdata()ife:QMessageBox.warning(parent,name+_(' reported errors'),str(e))elifo:QMessageBox.information(parent,name+_(' output'),str(o))elifnotify:wfiles=[repo.wjoin(x)forxinfiles]shlib.shell_notify(wfiles)except(util.Abort,IOError,OSError),e:QMessageBox.critical(parent,name+_(' Aborted'),str(e))except(error.LookupError),e:QMessageBox.critical(parent,name+_(' Aborted'),str(e))exceptNotImplementedError:QMessageBox.critical(parent,name+_(' not implemented'),'Please add it :)')os.chdir(cwd) return notify
def vdiff(parent, ui, repo, files):
-from tortoisehg.hgqt.visdiff import visualdiff-visualdiff(ui, repo, files, {})
+visdiff.visualdiff(ui, repo, files, {})
def edit(parent, ui, repo, files):
editor = (ui.config('tortoisehg', 'editor') or
ui.config('gtools','editor')oros.environ.get('HGEDITOR')orui.config('ui','editor')oros.environ.get('EDITOR','vi'))ifos.path.basename(editor)in('vi','vim','hgeditor'):res=QtGui.QMessageBox.critical(parent,_('No visual editor configured'),_('Please configure a visual editor.'))#dlg = thgconfig.ConfigDialog(False, focus='tortoisehg.editor')#dlg.exec_()return cmdline = ' '.join([editor] + [util.localpath(f) for f in files])
cmdline = util.quotecommand(cmdline)
try:
- from tortoisehg.hgqt.visdiff import openflags- subprocess.Popen(cmdline, shell=True, creationflags=openflags,
+ subprocess.Popen(cmdline, shell=True, creationflags=visdiff.openflags,
stderr=None, stdout=None, stdin=None)
except (OSError, EnvironmentError), e:
QtGui.QMessageBox.warning(parent,
_('Editor launch failure'), _('%s : %s') % (cmd, str(e)))
return False
+def viewmissing(parent, ui, repo, files):
-raiseNotImplementedError()
+base,_ = visdiff.snapshot(repo, files, repo['.'])
+ edit(parent, ui, repo, [os.path.join(base, f) for f in files])def other(parent, ui, repo, files):
-raiseNotImplementedError()
+wctx= repo[None]+ assert bool(wctx.p2())+ base, _ = visdiff.snapshot(repo, files, wctx.p2())+ edit(parent, ui, repo, [os.path.join(base, f) for f in files])def revert(parent, ui, repo, files):
revertopts = {'date': None, 'rev': '.'}
iflen(repo.parents())>1:res=qtlib.CustomPrompt(_('Uncommited merge - please select a parent revision'),_('Revert files to local or other parent?'),parent,(_('&Local'),_('&Other'),('&Cancel')),0,2,files).run()ifres==0:revertopts['rev']=repo[None].p1().rev()elifres==1:revertopts['rev']=repo[None].p2().rev()else:returncommands.revert(ui,repo,*files,**revertopts)else:res=qtlib.CustomPrompt(_('Confirm Revert'),_('Revert changes to files?'),parent,(_('&Yes (backup changes)'),_('Yes (&discard changes)'),_('&Cancel')),2,2,files).run()ifres==2:returnFalseifres==1:revertopts['no_backup']=Truecommands.revert(ui,repo,*files,**revertopts)returnTruedeflog(parent,ui,repo,files):raiseNotImplementedError()defforget(parent,ui,repo,files):commands.forget(ui,repo,*files)returnTruedefadd(parent,ui,repo,files):commands.add(ui,repo,*files)returnTruedefguessRename(parent,ui,repo,files):raiseNotImplementedError()defignore(parent,ui,repo,files):raiseNotImplementedError()defremove(parent,ui,repo,files):commands.remove(ui,repo,*files)returnTruedefdelete(parent,ui,repo,files):res=qtlib.CustomPrompt(_('Confirm Delete Unrevisioned'),_('Delete the following unrevisioned files?'),parent,(_('&Delete'),_('&Cancel')),1,1,files).run()ifres==1:returnforwfileinfiles:os.unlink(wfile)returnTruedefcopy(parent,ui,repo,files):assertlen(files)==1wfile=repo.wjoin(files[0])fd=QFileDialog(parent)fname=fd.getSaveFileName(parent,_('Copy file to'),wfile)ifnotfname:returnfname=hglib.fromunicode(fname)wfiles=[wfile,fname]commands.copy(ui,repo,*wfiles)returnTruedefrename(parent,ui,repo,files):# needs rename dialograiseNotImplementedError()defresolve(parent,ui,repo,files):wctx=repo[None]mctx=wctx.parents()[-1]ms=merge.mergestate(repo)forwfileinfiles:ms.resolve(wfile,wctx,mctx)returnTruedefunmark(parent,ui,repo,files):ms=merge.mergestate(repo)forwfileinfiles:ms.mark(wfile,'u')returnTruedefmark(parent,ui,repo,files):ms=merge.mergestate(repo)forwfileinfiles:ms.mark(wfile,'r')returnTruedefresolve_with(tool,repo,files):oldmergeenv=os.environ.get('HGMERGE')os.environ['HGMERGE']=toolresolve(None,None,repo,files)ifoldmergeenv:os.environ['HGMERGE']=oldmergeenvelse:delos.environ['HGMERGE']returnTrue
Attach a Trello Card
Add a tag
Your session has expired
You are no longer logged in. Please log in and try your request again.
Filter RSS Feed
This RSS feed URL allows you to see the contents of your current filter using any feed reader.
This link includes a special authentication token. If you share the URL with anyone else, they can see this RSS feed's activity. You can disable these tokens when needed.
Your current filter is unsaved; changing it won't affect this RSS feed.