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.
# update.py - Update dialog for TortoiseHg## Copyright 2007 TK Soh <teekaysoh@gmail.com># Copyright 2007 Steve Borho <steve@borho.org># 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.frommercurialimporterrorfromtortoisehg.utilimporthglib,pathsfromtortoisehg.hgqt.i18nimport_fromtortoisehg.hgqtimportcmdui,csinfo,qtlib,thgrepo,resolvefromPyQt4.QtCoreimport*fromPyQt4.QtGuiimport*classUpdateDialog(QDialog):output=pyqtSignal(QString,QString)progress=pyqtSignal(QString,object,QString,QString,object)makeLogVisible=pyqtSignal(bool)def__init__(self,repo,rev=None,parent=None,opts={}):super(UpdateDialog,self).__init__(parent)self.setWindowFlags(self.windowFlags()& \
~Qt.WindowContextHelpButtonHint)self._finished=Falseself.repo=repo# base layout boxbox=QVBoxLayout()box.setSpacing(6)## main layout gridgrid=QGridLayout()grid.setSpacing(6)box.addLayout(grid)### target revision comboself.rev_combo=combo=QComboBox()combo.setEditable(True)grid.addWidget(QLabel(_('Update to:')),0,0)grid.addWidget(combo,0,1)ifrevisNone:rev=self.repo.dirstate.branch()else:rev=str(rev)combo.addItem(hglib.tounicode(rev))combo.setCurrentIndex(0)fornameinrepo.namedbranches:combo.addItem(name)tags=list(self.repo.tags())+repo._bookmarks.keys()tags.sort(reverse=True)fortagintags:combo.addItem(hglib.tounicode(tag))### target revision infoitems=('%(rev)s',' %(branch)s',' %(tags)s','<br />%(summary)s')style=csinfo.labelstyle(contents=items,width=350,selectable=True)factory=csinfo.factory(self.repo,style=style)self.target_info=factory()grid.addWidget(QLabel(_('Target:')),1,0,Qt.AlignLeft|Qt.AlignTop)grid.addWidget(self.target_info,1,1)### parent revision infoself.ctxs=self.repo[None].parents()iflen(self.ctxs)==2:self.p1_info=factory()grid.addWidget(QLabel(_('Parent 1:')),2,0,Qt.AlignLeft|Qt.AlignTop)grid.addWidget(self.p1_info,2,1)self.p2_info=factory()grid.addWidget(QLabel(_('Parent 2:')),3,0,Qt.AlignLeft|Qt.AlignTop)grid.addWidget(self.p2_info,3,1)else:self.p1_info=factory()grid.addWidget(QLabel(_('Parent:')),2,0,Qt.AlignLeft|Qt.AlignTop)grid.addWidget(self.p1_info,2,1)### optionsoptbox=QVBoxLayout()optbox.setSpacing(6)expander=qtlib.ExpanderLabel(_('Options:'),False)expander.expanded.connect(self.show_options)row=grid.rowCount()grid.addWidget(expander,row,0,Qt.AlignLeft|Qt.AlignTop)grid.addLayout(optbox,row,1)self.discard_chk=QCheckBox(_('Discard local changes, no backup ''(-C/--clean)'))self.merge_chk=QCheckBox(_('Always merge (when possible)'))self.autoresolve_chk=QCheckBox(_('Automatically resolve merge conflicts ''where possible'))self.showlog_chk=QCheckBox(_('Always show command log'))optbox.addWidget(self.discard_chk)optbox.addWidget(self.merge_chk)optbox.addWidget(self.autoresolve_chk) optbox.addWidget(self.showlog_chk)
self.discard_chk.setChecked(bool(opts.get('clean')))
++ #### Persisted Options+ self.merge_chk.setChecked(+ QSettings().value('update/merge', False).toBool())+ self.autoresolve_chk.setChecked(
- repo.ui.configbool('tortoisehg', 'autoresolve', False))
+ repo.ui.configbool('tortoisehg', 'autoresolve', False) or+ QSettings().value('update/autoresolve', False).toBool())
++ self.showlog_chk.setChecked(+ QSettings().value('update/showlog', False).toBool()) ## command widget
self.cmd = cmdui.Widget(True, True, self)
self.cmd.commandStarted.connect(self.command_started)self.cmd.commandFinished.connect(self.command_finished)self.cmd.commandCanceling.connect(self.command_canceling)self.cmd.output.connect(self.output)self.cmd.makeLogVisible.connect(self.makeLogVisible)self.cmd.progress.connect(self.progress)box.addWidget(self.cmd)## bottom buttonsbuttons=QDialogButtonBox()self.cancel_btn=buttons.addButton(QDialogButtonBox.Cancel)self.cancel_btn.clicked.connect(self.cancel_clicked)self.close_btn=buttons.addButton(QDialogButtonBox.Close)self.close_btn.clicked.connect(self.reject)self.close_btn.setAutoDefault(False)self.update_btn=buttons.addButton(_('&Update'),QDialogButtonBox.ActionRole)self.update_btn.clicked.connect(self.update)self.detail_btn=buttons.addButton(_('Detail'),QDialogButtonBox.ResetRole)self.detail_btn.setAutoDefault(False)self.detail_btn.setCheckable(True)self.detail_btn.toggled.connect(self.detail_toggled)box.addWidget(buttons)# signal handlersself.rev_combo.editTextChanged.connect(lambda*a:self.update_info())self.discard_chk.toggled.connect(lambda*a:self.update_info())# dialog settingself.setLayout(box)self.layout().setSizeConstraint(QLayout.SetFixedSize)self.setWindowTitle(_('Update - %s')%self.repo.displayname)self.setWindowIcon(qtlib.geticon('hg-update'))# prepare to showself.cmd.setHidden(True)self.cancel_btn.setHidden(True)self.detail_btn.setHidden(True)self.merge_chk.setHidden(True)self.autoresolve_chk.setHidden(True)self.showlog_chk.setHidden(True)self.update_info() if not self.update_btn.isEnabled():
self.rev_combo.lineEdit().selectAll() # need to change rev
+ # expand options if a hidden one is checked+ self.show_options(self.hiddenSettingIsChecked())+ ### Private Methods ###
+ def hiddenSettingIsChecked(self):+ if self.merge_chk.isChecked() or self.autoresolve_chk.isChecked() or self.showlog_chk.isChecked():+ return True+ else:+ return False++ def saveSettings(self):+ QSettings().setValue('update/merge', self.merge_chk.isChecked())+ QSettings().setValue('update/autoresolve', self.autoresolve_chk.isChecked())+ QSettings().setValue('update/showlog', self.showlog_chk.isChecked()) def update_info(self):
self.p1_info.update(self.ctxs[0].node())
merge=len(self.ctxs)==2ifmerge:self.p2_info.update(self.ctxs[1])new_rev=hglib.fromunicode(self.rev_combo.currentText())ifnew_rev.lower()=='null':self.update_btn.setEnabled(True)returntry:new_ctx=self.repo[new_rev]ifnotmergeandnew_ctx.rev()==self.ctxs[0].rev():self.target_info.setText(_('(same as parent)'))clean=self.discard_chk.isChecked()self.update_btn.setEnabled(clean)else:self.target_info.update(self.repo[new_rev])self.update_btn.setEnabled(True)except(error.LookupError,error.RepoLookupError,error.RepoError):self.target_info.setText(_('unknown revision!')) self.update_btn.setDisabled(True)
def update(self):
+ self.saveSettings() cmdline = ['update', '--repository', self.repo.root, '--verbose']
cmdline += ['--config', 'ui.merge=internal:' +
(self.autoresolve_chk.isChecked() and 'merge' or 'fail')]
rev=hglib.fromunicode(self.rev_combo.currentText())cmdline.append('--rev')cmdline.append(rev)ifself.discard_chk.isChecked():cmdline.append('--clean')else:cur=self.repo['.']try:node=self.repo[rev]except(error.LookupError,error.RepoLookupError,error.RepoError):returndefisclean():'''whether WD is changed'''wc=self.repo[None]ifwc.modified()orwc.added()orwc.removed():returnFalseforsinwc.substate:ifwc.sub(s).dirty():returnFalsereturnTruedefismergedchange():'''whether the local changes are merged (have 2 parents)'''wc=self.repo[None]returnlen(wc.parents())==2defiscrossbranch(p1,p2):'''whether p1 -> p2 crosses branch'''pa=p1.ancestor(p2)returnp1.branch()!=p2.branch()or(p1!=paandp2!=pa)defislocalmerge(p1,p2,clean=None):ifcleanisNone:clean=isclean()pa=p1.ancestor(p2)returnnotcleanand(p1==paorp2==pa)defconfirmupdate(clean=None):ifcleanisNone:clean=isclean()msg=_('Detected uncommitted local changes in working tree.\n''Please select to continue:\n\n')data={'discard':(_('&Discard'),_('Discard - discard local changes, no backup')),'shelve':(_('&Shelve'),_('Shelve - move local changes to a patch')),'merge':(_('&Merge'),_('Merge - allow to merge with local changes')),}opts=[data['discard']]ifnotismergedchange():opts.append(data['shelve'])ifislocalmerge(cur,node,clean):opts.append(data['merge'])msg+='\n'.join([descforlabel,descinoptsifdesc])dlg=QMessageBox(QMessageBox.Question,_('Confirm Update'),msg,QMessageBox.Cancel,self)buttons={}fornamein('discard','shelve','merge'):label,desc=data[name]buttons[name]=dlg.addButton(label,QMessageBox.ActionRole)dlg.exec_()returnbuttons,dlg.clickedButton()# If merge-by-default, we want to merge whenever possible,# without prompting user (similar to command-line behavior)defaultmerge=self.merge_chk.isChecked()clean=isclean()ifclean:cmdline.append('--check')elifnot(defaultmergeandislocalmerge(cur,node,clean)):buttons,clicked=confirmupdate(clean)ifbuttons['discard']==clicked:cmdline.append('--clean')elifbuttons['shelve']==clicked:fromtortoisehg.hgqtimportshelvedlg=shelve.ShelveDialog(self.repo,self)dlg.finished.connect(dlg.deleteLater)dlg.exec_()returnelifbuttons['merge']==clicked:pass# no argselse:return# start updatingself.repo.incrementBusyCount()self.cmd.run(cmdline)### Signal Handlers ###defcancel_clicked(self):self.cmd.cancel()self.reject()defdetail_toggled(self,checked):self.cmd.setShowOutput(checked)defshow_options(self,visible):self.merge_chk.setShown(visible)self.autoresolve_chk.setShown(visible)self.showlog_chk.setShown(visible)defcommand_started(self):self.cmd.setShown(True)ifself.showlog_chk.isChecked():self.detail_btn.setChecked(True)self.update_btn.setHidden(True)self.close_btn.setHidden(True)self.cancel_btn.setShown(True)self.detail_btn.setShown(True)defcommand_finished(self,ret):self.repo.decrementBusyCount()ifretnotin(0,1)orself.cmd.outputShown():self.detail_btn.setChecked(True)self.close_btn.setShown(True)self.close_btn.setAutoDefault(True)self.close_btn.setFocus()self.cancel_btn.setHidden(True)else:self.accept()defaccept(self):forroot,path,statusinthgrepo.recursiveMergeStatus(self.repo):ifstatus=='u':qtlib.InfoMsgBox(_('Merge caused file conflicts'),_('File conflicts need to be resolved'))dlg=resolve.ResolveDialog(self.repo,self)dlg.finished.connect(dlg.deleteLater)dlg.exec_()breaksuper(UpdateDialog,self).accept()defcommand_canceling(self):self.cancel_btn.setDisabled(True)defrun(ui,*pats,**opts):repo=thgrepo.repository(ui,path=paths.find_root())rev=Noneifopts.get('rev'):rev=opts.get('rev')eliflen(pats)==1:rev=pats[0]returnUpdateDialog(repo,rev,None,opts)
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.