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.importosimportrefrommercurialimportutil,error,merge,commands,extensions,matchfromtortoisehg.hgqtimportqtlib,htmlui,visdifffromtortoisehg.utilimporthglib,shlibfromtortoisehg.hgqt.i18nimport_fromPyQt4.QtCoreimportQt,QObject,QDirfromPyQt4.QtGuiimport*classWctxActions(QObject):'container class for working context actions'def__init__(self,repo,parent):super(WctxActions,self).__init__(parent)self.menu=QMenu(parent)self.repo=repoallactions=[]defmake(text,func,types,icon=None,keys=None):action=QAction(text,parent)action._filetypes=typesaction._runfunc=funcificon:action.setIcon(qtlib.getmenuicon(icon))ifkeys:action.setShortcut(QKeySequence(keys))action.triggered.connect(self.runAction)parent.addAction(action)allactions.append(action)make(_('&Visual Diff'),vdiff,frozenset('MAR!'),'visualdiff','CTRL+D')make(_('Copy patch'),copyPatch,frozenset('MAR!'),'copy-patch')make(_('Edit'),edit,frozenset('MACI?'),'edit-file','SHIFT+CTRL+E')make(_('Copy path'),copyPath,frozenset('MARC?!I'),'')make(_('View missing'),viewmissing,frozenset('R!'))allactions.append(None)make(_('&Revert...'),revert,frozenset('MAR!'),'hg-revert')make(_('&Add'),add,frozenset('R'),'fileadd')allactions.append(None)make(_('File History'),log,frozenset('MARC!'),'hg-log')make(_('&Annotate'),annotate,frozenset('MARC!'),'hg-annotate')allactions.append(None)make(_('&Forget'),forget,frozenset('MAC!'),'filedelete')make(_('&Add'),add,frozenset('I?'),'fileadd')if'kbfiles'inself.repo.extensions():make(_('Add &Bfiles'),addbf,frozenset('I?'))make(_('&Detect Renames...'),guessRename,frozenset('A?!'),'detect_rename')make(_('&Ignore...'),ignore,frozenset('?'),'ignore')make(_('Remove versioned'),remove,frozenset('C'),'remove')make(_('&Delete unversioned...'),delete,frozenset('?I'),'hg-purge')allactions.append(None)make(_('Mark unresolved'),unmark,frozenset('r'))make(_('Mark resolved'),mark,frozenset('u'))self.allactions=allactionsdefupdateActionSensitivity(self,selrows):'Enable/Disable permanent actions based on current selection'self.selrows=selrowsalltypes=set()fortypes,wfileinselrows:alltypes|=typesforactioninself.allactions:ifactionisnotNone:action.setEnabled(bool(action._filetypes&alltypes))defmakeMenu(self,selrows):self.selrows=selrowsrepo,menu=self.repo,self.menualltypes=set()fortypes,wfileinselrows:alltypes|=typesmenu.clear()addedActions=Falseforactioninself.allactions:ifactionisNone:ifaddedActions:menu.addSeparator()addedActions=Falseelifaction._filetypes&alltypes:menu.addAction(action)addedActions=Truedefmake(text,func,types,icon=None):ifnottypes&alltypes:returnaction=menu.addAction(text)action._filetypes=typesaction._runfunc=funcificon:action.setIcon(qtlib.getmenuicon(icon))action.triggered.connect(self.runAction)iflen(repo.parents())>1:make(_('View other'),viewother,frozenset('MA'))iflen(selrows)==1:menu.addSeparator()make(_('&Copy...'),copy,frozenset('MC'),'edit-copy')make(_('Rename...'),rename,frozenset('MC'),'hg-rename')# Add 'was renamed from' actions for unknown filest,path=selrows[0]wctx=self.repo[None]ift&frozenset('?')andwctx.deleted():rmenu=QMenu(_('Was renamed from'),self.parent())fordinwctx.deleted()[:15]:defmkaction(deleted):a=rmenu.addAction(hglib.tounicode(deleted))a.triggered.connect(lambda:renamefromto(repo,deleted,path))mkaction(d)menu.addSeparator()menu.addMenu(rmenu)# Add restart merge actions for resolved filesifalltypes&frozenset('u'):f=make(_('Restart Merge...'),resolve,frozenset('u'))files=[ffort,finselrowsif'u'int]rmenu=QMenu(_('Restart merge with'),self.parent())fortoolinhglib.mergetools(repo.ui):defmkaction(rtool):a=rmenu.addAction(hglib.tounicode(rtool))a.triggered.connect(lambda:resolve_with(rtool,repo,files))mkaction(tool)menu.addSeparator()menu.addMenu(rmenu)returnmenudefrunAction(self):'run wrapper for all action methods'repo,action,parent=self.repo,self.sender(),self.parent()func=action._runfuncfiles=[wfilefort,wfileinself.selrowsift&action._filetypes]hu=htmlui.htmlui()name=func.__name__.title()notify=Falsecwd=os.getcwd()try: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+_(' errors'),hglib.tounicode(str(e)))elifo:QMessageBox.information(parent,name+_(' output'),hglib.tounicode(str(o)))elifnotify:wfiles=[repo.wjoin(x)forxinfiles]shlib.shell_notify(wfiles)except(IOError,OSError),e:err=hglib.tounicode(str(e))QMessageBox.critical(parent,name+_(' Aborted'),err)exceptutil.Abort,e:ife.hint:err=_('%s (hint: %s)')%(hglib.tounicode(str(e)),hglib.tounicode(e.hint))else:err=hglib.tounicode(str(e))QMessageBox.critical(parent,name+_(' Aborted'),err)except(error.LookupError),e:err=hglib.tounicode(str(e))QMessageBox.critical(parent,name+_(' Aborted'),err)finally:os.chdir(cwd)returnnotifydefrenamefromto(repo,deleted,unknown):repo[None].copy(deleted,unknown)repo[None].forget([deleted])# !->RdefcopyPatch(parent,ui,repo,files):ui.pushbuffer()try:commands.diff(ui,repo,*files)exceptException,e:ui.popbuffer()if'THGDEBUG'inos.environ:importtracebacktraceback.print_exc()returnoutput=ui.popbuffer()QApplication.clipboard().setText(hglib.tounicode(output))defcopyPath(parent,ui,repo,files):clip=QApplication.clipboard()absfiles=[hglib.fromunicode(QDir.toNativeSeparators(repo.wjoin(fname)))forfnameinfiles]clip.setText(os.linesep.join(absfiles))defvdiff(parent,ui,repo,files):dlg=visdiff.visualdiff(ui,repo,files,{})ifdlg:dlg.exec_()defedit(parent,ui,repo,files,lineno=None,search=None):qtlib.editfiles(repo,files,lineno,search,parent)defviewmissing(parent,ui,repo,files):base,_=visdiff.snapshot(repo,files,repo['.'])edit(parent,ui,repo,[os.path.join(base,f)forfinfiles])defviewother(parent,ui,repo,files):wctx=repo[None]assertbool(wctx.p2())base,_=visdiff.snapshot(repo,files,wctx.p2())edit(parent,ui,repo,[os.path.join(base,f)forfinfiles])defrevert(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 local file changes?'),parent,(_('&Revert with backup'),_('&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):fromtortoisehg.hgqt.workbenchimportrunfromtortoisehg.hgqt.runimportqtrunopts={'root':repo.root}qtrun(run,repo.ui,*files,**opts)returnFalsedefannotate(parent,ui,repo,files):fromtortoisehg.hgqt.manifestdialogimportrunfromtortoisehg.hgqt.runimportqtrunopts={'repo':repo,'canonpath':files[0],'rev':repo['.'].rev()}qtrun(run,repo.ui,**opts)returnFalsedefforget(parent,ui,repo,files):commands.forget(ui,repo,*files)returnTruedef add(parent, ui, repo, files):
if 'kbfiles' in repo.extensions():
bfiles = []
- minsize = int(ui.config('kilnbfiles', 'size', default=10))
+ usekbf = os.path.exists(repo.wjoin('.kbf'))+ minsize = int(ui.config('kilnbfiles', 'size', default='10'))
patterns = ui.config('kilnbfiles', 'patterns', default=())
if patterns:
patterns = patterns.split(' ')
matcher = match.match(repo.root, '', list(patterns))
else:
matcher = None
- if minsize == 0 or minsize >= 10:- for wfile in files:
-if not matcher or not matcher(wfile):
- filesize = os.path.getsize(repo.wjoin(wfile))
-if filesize >= 10*1024*1024 and filesize < minsize*1024*1024:
- bfiles.append(wfile)
+ for wfile in files:
+ if not matcher or not matcher(wfile) or not usekbf:
+ filesize = os.path.getsize(repo.wjoin(wfile))
+ if filesize >= 10*1024*1024 and (filesize < minsize*1024*1024 or not usekbf):
+ bfiles.append(wfile)
if bfiles:
ret = qtlib.BfilesPrompt(parent, files).run()
if ret == 0:
# add as bfilesforbfileinbfiles:files.remove(bfile)elifret==1:# add as normal filesbfiles=[]elifret==2:returnFalseforname,moduleinextensions.extensions():ifname=='kbfiles':override_add=module.bfsetup.override_addiffiles:override_add(commands.add,ui,repo,*files)ifbfiles:override_add(commands.add,ui,repo,*bfiles,bf=1)returnTruecommands.add(ui,repo,*files)returnTruedefaddbf(parent,ui,repo,files):forname,moduleinextensions.extensions():ifname=='kbfiles':override_add=module.bfsetup.override_addoverride_add(commands.add,ui,repo,*files,bf=True)returnTruereturnFalsedefguessRename(parent,ui,repo,files):fromtortoisehg.hgqt.guessimportDetectRenameDialogdlg=DetectRenameDialog(repo,parent,*files)defmatched():ret=Trueret=Falsedlg.matchAccepted.connect(matched)dlg.finished.connect(dlg.deleteLater)dlg.exec_()returnretdefignore(parent,ui,repo,files):fromtortoisehg.hgqt.hgignoreimportHgignoreDialogdlg=HgignoreDialog(repo,parent,*files)dlg.finished.connect(dlg.deleteLater)returndlg.exec_()==QDialog.Accepteddefremove(parent,ui,repo,files):commands.remove(ui,repo,*files)returnTruedefdelete(parent,ui,repo,files):res=qtlib.CustomPrompt(_('Confirm Delete Unversioned'),_('Delete the following unversioned 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):fromtortoisehg.hgqt.renameimportRenameDialogassertlen(files)==1dlg=RenameDialog(ui,files,parent)dlg.finished.connect(dlg.deleteLater)dlg.exec_()returnTruedefunmark(parent,ui,repo,files):ms=merge.mergestate(repo)forwfileinfiles:ms.mark(wfile,'u')ms.commit()returnTruedefmark(parent,ui,repo,files):ms=merge.mergestate(repo)forwfileinfiles:ms.mark(wfile,'r')ms.commit()returnTruedefresolve(parent,ui,repo,files):commands.resolve(ui,repo,*files)returnTruedefresolve_with(tool,repo,files):opts={'tool':tool}paths=[repo.wjoin(f)forfinfiles]commands.resolve(repo.ui,repo,*paths,**opts)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.