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.
# backout.py - Backout dialog for TortoiseHg## Copyright 2010 Yuki KODAMA <endflow.net@gmail.com>## This software may be used and distributed according to the terms of the# GNU General Public License version 2, incorporated herein by reference.fromPyQt4.QtCoreimport*fromPyQt4.QtGuiimport*frommercurialimportmergeasmergemodfromtortoisehg.utilimporthglibfromtortoisehg.hgqt.i18nimport_fromtortoisehg.hgqtimportqtlib,csinfo,i18n,cmdui,status,resolvefromtortoisehg.hgqtimportcommit,qscilib,thgrepokeep=i18n.keepgettext()classBackoutDialog(QDialog):def__init__(self,repo,rev='tip',parent=None,opts={}):super(BackoutDialog,self).__init__(parent)f=self.windowFlags()self.setWindowFlags(f&~Qt.WindowContextHelpButtonHint)self.setWindowIcon(qtlib.geticon('hg-revert'))self.repo=repo# main layout boxbox=QVBoxLayout()box.setSpacing(8)box.setContentsMargins(*(6,)*4)## target revisiontarget_sep=qtlib.LabeledSeparator(_('Target changeset'))box.addWidget(target_sep)style=csinfo.panelstyle(selectable=True)self.targetinfo=csinfo.create(self.repo,rev,style,withupdate=True)box.addWidget(self.targetinfo)## backout messagemsg_sep=qtlib.LabeledSeparator(_('Backout commit message'))box.addWidget(msg_sep)revhex=self.targetinfo.get_data('revid')self.msgset=keep._('Backed out changeset: ')self.msgset['id']+=revhexself.msgset['str']+=revhexself.msgTextEdit=commit.MessageEntry(self)self.msgTextEdit.installEventFilter(qscilib.KeyPressInterceptor(self))self.msgTextEdit.refresh(repo)self.msgTextEdit.loadSettings(QSettings(),'backout/message')self.msgTextEdit.setText(self.msgset['str'])box.addWidget(self.msgTextEdit,2)## optionsopt_sep=qtlib.LabeledSeparator(_('Options'))box.addWidget(opt_sep)obox=QVBoxLayout()obox.setSpacing(3)box.addLayout(obox)self.engChk=QCheckBox(_('Use English backout message'))self.engChk.toggled.connect(self.eng_toggled)engmsg=self.repo.ui.configbool('tortoisehg','engmsg',False)self.engChk.setChecked(engmsg)obox.addWidget(self.engChk)self.mergeChk=QCheckBox(_('Commit backout before merging with ''current working parent'))self.mergeChk.toggled.connect(self.merge_toggled)self.mergeChk.setChecked(bool(opts.get('merge')))self.msgTextEdit.setEnabled(False)obox.addWidget(self.mergeChk)self.autoresolve_chk=QCheckBox(_('Automatically resolve merge conflicts ''where possible'))self.autoresolve_chk.setChecked(repo.ui.configbool('tortoisehg','autoresolve',False))obox.addWidget(self.autoresolve_chk)ifrepo[revhex]==repo.parents()[0]:# backing out the working parent is a one-step processself.msgTextEdit.setEnabled(True)self.mergeChk.setVisible(False)self.autoresolve_chk.setVisible(False)self.backoutParent=Trueelse:self.backoutParent=Falseself.reslabel=QLabel()self.reslabel.linkActivated.connect(self.link_activated)box.addWidget(self.reslabel)## command widgetself.cmd=cmdui.Widget(True,False,self)self.cmd.commandStarted.connect(self.command_started)self.cmd.commandFinished.connect(self.command_finished)self.cmd.commandCanceling.connect(self.command_canceling)box.addWidget(self.cmd,1)## bottom buttonsbuttons=QDialogButtonBox()self.cancelBtn=buttons.addButton(QDialogButtonBox.Cancel)self.cancelBtn.clicked.connect(self.cancel_clicked)self.closeBtn=buttons.addButton(QDialogButtonBox.Close)self.closeBtn.clicked.connect(self.reject)self.backoutBtn=buttons.addButton(_('&Backout'),QDialogButtonBox.ActionRole)self.backoutBtn.clicked.connect(self.backout)self.detailBtn=buttons.addButton(_('Detail'),QDialogButtonBox.ResetRole)self.detailBtn.setAutoDefault(False)self.detailBtn.setCheckable(True)self.detailBtn.toggled.connect(self.detail_toggled)box.addWidget(buttons)# dialog settingself.setLayout(box)self.setMinimumWidth(480)self.setMaximumHeight(800)self.resize(0,340)self.setWindowTitle(_("Backout '%s' - %s")%(revhex,self.repo.displayname))# prepare to showself.cmd.setHidden(True)self.cancelBtn.setHidden(True)self.detailBtn.setHidden(True)self.msgTextEdit.setFocus()self.msgTextEdit.moveCursorToEnd()### Private Methods ###defmerge_toggled(self,checked):self.msgTextEdit.setEnabled(checked)defeng_toggled(self,checked):msg=self.msgTextEdit.text()origmsg=(checkedandself.msgset['str']orself.msgset['id'])ifmsg!=origmsg:ifnotqtlib.QuestionMsgBox(_('Confirm Discard Message'),_('Discard current backout message?'),parent=self):self.engChk.blockSignals(True)self.engChk.setChecked(notchecked)self.engChk.blockSignals(False)returnnewmsg=(checkedandself.msgset['id']orself.msgset['str'])self.msgTextEdit.setText(newmsg)defbackout(self):# prepare command linerevhex=self.targetinfo.get_data('revid')cmdline=['backout','--rev',revhex,'--repository',self.repo.root]cmdline+=['--tool=internal:'+(self.autoresolve_chk.isChecked()and'merge'or'fail')]ifself.backoutParent:msg=self.msgTextEdit.text()cmdline+=['--message='+hglib.fromunicode(msg)]commandlines=[cmdline]pushafter=self.repo.ui.config('tortoisehg','cipushafter')ifpushafter:cmd=['push','--repository',self.repo.root,pushafter]commandlines.append(cmd)elifself.mergeChk.isChecked():cmdline+=['--merge'] msg = self.msgTextEdit.text()
cmdline += ['--message', hglib.fromunicode(msg)]
commandlines = [cmdline]
+ else:+ commandlines = [cmdline] # start backing out
self.cmdline = cmdline
self.repo.incrementBusyCount()self.cmd.run(*commandlines)defcommit(self):cmdline=['commit','--repository',self.repo.root]msg=self.msgTextEdit.text()cmdline+=['--message='+hglib.fromunicode(msg)]self.cmdline=cmdlinecommandlines=[cmdline]pushafter=self.repo.ui.config('tortoisehg','cipushafter')ifpushafter:cmd=['push','--repository',self.repo.root,pushafter]commandlines.append(cmd)self.repo.incrementBusyCount()self.cmd.run(*commandlines)### Signal Handlers ###defcancel_clicked(self):self.cmd.cancel()defdetail_toggled(self,checked):self.cmd.setShowOutput(checked)defcommand_started(self):self.cmd.setShown(True)self.mergeChk.setVisible(False)self.closeBtn.setHidden(True)self.cancelBtn.setShown(True)self.detailBtn.setShown(True)self.backoutBtn.setEnabled(False)defcommand_canceling(self):self.cancelBtn.setDisabled(True)defcommand_finished(self,ret):self.repo.decrementBusyCount()self.cancelBtn.setHidden(True)# If the action wasn't successful, display the output and we're doneifretnotin(0,1):self.detailBtn.setChecked(True)self.closeBtn.setShown(True)self.closeBtn.setAutoDefault(True)self.closeBtn.setFocus()else:finished=True#If we backed out our parent, there is no second commit stepifself.cmdline[0]=='backout'andnotself.backoutParent:finished=Falseself.msgTextEdit.setEnabled(True)self.backoutBtn.setEnabled(True)self.backoutBtn.setText(_('Commit','action button'))self.backoutBtn.clicked.disconnect(self.backout)self.backoutBtn.clicked.connect(self.commit)self.checkResolve()iffinished:ifnotself.cmd.outputShown():self.accept()else:self.closeBtn.clicked.disconnect(self.reject)self.closeBtn.clicked.connect(self.accept)self.closeBtn.setHidden(False)defcheckResolve(self):forroot,path,statusinthgrepo.recursiveMergeStatus(self.repo):ifstatus=='u':txt=_('Backout generated merge <b>conflicts</b> that must ''be <a href="resolve"><b>resolved</b></a>')self.backoutBtn.setEnabled(False)breakelse:self.backoutBtn.setEnabled(True)txt=_('You may commit the backed out changes after ''<a href="status"><b>verifying</b></a> them')self.reslabel.setText(txt)@pyqtSlot(QString)deflink_activated(self,cmd):ifcmd=='resolve':dlg=resolve.ResolveDialog(self.repo,self)dlg.finished.connect(dlg.deleteLater)dlg.exec_()self.checkResolve()elifcmd=='status':dlg=status.StatusDialog([],{},self.repo.root,self)dlg.finished.connect(dlg.deleteLater)dlg.exec_()self.checkResolve()defaccept(self):self.msgTextEdit.saveSettings(QSettings(),'backout/message')super(BackoutDialog,self).accept()defrun(ui,*pats,**opts):fromtortoisehg.utilimportpathsrepo=thgrepo.repository(ui,path=paths.find_root())kargs={'opts':opts}ifopts.get('rev'):kargs['rev']=opts.get('rev')eliflen(pats)==1:kargs['rev']=pats[0]returnBackoutDialog(repo,**kargs)
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.