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.
# quickop.py - TortoiseHg's dialog for quick dirstate operations## Copyright 2009 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.importosimportsysfrommercurialimportutilfrom tortoisehg.util import hglib, shlib
from tortoisehg.hgqt.i18n import _
-from tortoisehg.hgqt import qtlib, status, cmdui
+from tortoisehg.hgqt import qtlib, status, cmdui, bfpromptfrom PyQt4.QtCore import *
from PyQt4.QtGui import *
LABELS={'add':(_('Checkmark files to add'),_('Add')),'forget':(_('Checkmark files to forget'),_('Forget')),'revert':(_('Checkmark files to revert'),_('Revert')),'remove':(_('Checkmark files to remove'),_('Remove')),}ICONS={'add':'fileadd','forget':'hg-remove','revert':'hg-revert','remove':'hg-remove',}classQuickOpDialog(QDialog):""" Dialog for performing quick dirstate operations """def__init__(self,repo,command,pats,parent):QDialog.__init__(self,parent)self.setWindowFlags(Qt.Window)self.pats=patsself.repo=repoos.chdir(repo.root)# Handle rm aliasifcommand=='rm':command='remove'self.command=commandself.setWindowTitle(_('%s - hg %s')%(repo.displayname,command))self.setWindowIcon(qtlib.geticon(ICONS[command]))layout=QVBoxLayout()layout.setContentsMargins(2,2,2,2)layout.setMargin(0)self.setLayout(layout)hbox=QHBoxLayout()lbl=QLabel(LABELS[command][0])slbl=QLabel()hbox.addWidget(lbl)hbox.addStretch(1)hbox.addWidget(slbl)self.status_label=slbllayout.addLayout(hbox)types={'add':'I?','forget':'MAR!C','revert':'MAR!','remove':'MAR!CI?',}filetypes=types[self.command]opts={}fors,valinstatus.statusTypes.iteritems():opts[val.name]=sinfiletypesopts['checkall']=True# pre-check all matching filesstwidget=status.StatusWidget(repo,pats,opts,self)layout.addWidget(stwidget,1)ifself.command=='revert':## no backup checkboxchk=QCheckBox(_('Do not save backup files (*.orig)'))self.chk=chklayout.addWidget(chk)self.statusbar=cmdui.ThgStatusBar(self)self.statusbar.setSizeGripEnabled(False)stwidget.showMessage.connect(self.statusbar.showMessage)self.cmd=cmd=cmdui.Runner(True,self)cmd.commandStarted.connect(self.commandStarted)cmd.commandFinished.connect(self.commandFinished)cmd.progress.connect(self.statusbar.progress)BB=QDialogButtonBoxbb=QDialogButtonBox(BB.Ok|BB.Close)bb.accepted.connect(self.accept)bb.rejected.connect(self.reject)bb.button(BB.Ok).setDefault(True)bb.button(BB.Ok).setText(LABELS[command][1])layout.addWidget(bb)self.bb=bbifself.command=='add'and'kbfiles'inself.repo.extensions():self.addBfilesButton=QPushButton(_("Add &Bfiles"))self.addBfilesButton.clicked.connect(self.addBfiles)bb.addButton(self.addBfilesButton,BB.ActionRole)hbox=QHBoxLayout()hbox.setMargin(0)hbox.setContentsMargins(*(0,)*4)hbox.addWidget(self.statusbar)hbox.addWidget(self.bb)layout.addLayout(hbox)s=QSettings()stwidget.loadSettings(s,'quickop')self.restoreGeometry(s.value('quickop/geom').toByteArray())ifhasattr(self,'chk'):self.chk.setChecked(s.value('quickop/nobackup',True).toBool())self.stwidget=stwidgetself.stwidget.refreshWctx()QShortcut(QKeySequence('Ctrl+Return'),self,self.accept)QShortcut(QKeySequence('Ctrl+Enter'),self,self.accept)QShortcut(QKeySequence.Refresh,self,self.stwidget.refreshWctx)QShortcut(QKeySequence('Escape'),self,self.reject)defcommandStarted(self):self.bb.button(QDialogButtonBox.Ok).setEnabled(False)defcommandFinished(self,ret):self.bb.button(QDialogButtonBox.Ok).setEnabled(True)ifret==0:shlib.shell_notify(self.files)self.reject()defaccept(self):cmdline=[self.command]ifhasattr(self,'chk')andself.chk.isChecked():cmdline.append('--no-backup')files=self.stwidget.getChecked()ifnotfiles:qtlib.WarningMsgBox(_('No files selected'),_('No operation to perform'),parent=self)returnifself.command=='remove':self.repo.bfstatus=Truerepostate=self.repo.status()self.repo.bfstatus=Falseunknown,ignored=repostate[4:6]forwfileinfiles:ifwfileinunknownorwfileinignored:try:util.unlink(wfile) except EnvironmentError:
pass
files.remove(wfile)
+ elif self.command == 'add' and 'kbfiles' in self.repo.extensions():+ self.addWithPrompt(files)+ return if files:
cmdline.extend(files)
self.files = files
self.cmd.run(cmdline)else:self.reject()defreject(self):ifself.cmd.core.running():self.cmd.core.cancel()elifnotself.stwidget.canExit():returnelse:s=QSettings()self.stwidget.saveSettings(s,'quickop')s.setValue('quickop/geom',self.saveGeometry())ifhasattr(self,'chk'):s.setValue('quickop/nobackup',self.chk.isChecked())QDialog.reject(self)defaddBfiles(self):cmdline=['add','--bf']files=self.stwidget.getChecked()ifnotfiles:qtlib.WarningMsgBox(_('No files selected'),_('No operation to perform'),parent=self)returncmdline.extend(files) self.files = files
self.cmd.run(cmdline)
+ def addWithPrompt(self, files):+ result = bfprompt.promptForBfiles(self, self.repo.ui, self.repo, files)+ if not result:+ return+ files, bfiles = result+ if files:+ cmdline = ['add']+ cmdline.extend(files)+ self.files = files+ self.cmd.run(cmdline)+ if bfiles:+ cmdline = ['add', '--bf']+ cmdline.extend(bfiles)+ self.files = bfiles+ self.cmd.run(cmdline)+instance = None
class HeadlessQuickop(QWidget):
def __init__(self, repo, cmdline):
QWidget.__init__(self)self.files=cmdline[1:]os.chdir(repo.root)self.cmd=cmdui.Runner(True,self)self.cmd.commandFinished.connect(self.commandFinished)self.cmd.run(cmdline)self.hide()defcommandFinished(self,ret):ifret==0:shlib.shell_notify(self.files)sys.exit(0)defrun(ui,*pats,**opts):pats=hglib.canonpaths(pats)ifopts.get('canonpats'):pats=list(pats)+opts['canonpats']fromtortoisehg.utilimportpathsfromtortoisehg.hgqtimportthgreporepo=thgrepo.repository(ui,path=paths.find_root())command=opts['alias']imm=repo.ui.config('tortoisehg','immediate','')ifcommandinimm.lower():cmdline=[command]+patsglobalinstanceinstance=HeadlessQuickop(repo,cmdline)returnNoneelse:returnQuickOpDialog(repo,command,pats,None)
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.