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.fromPyQt4.QtCoreimportQtfromPyQt4.QtGuiimportQDialog,QDialogButtonBox,QVBoxLayout,QGridLayoutfromPyQt4.QtGuiimportQComboBox,QLabel,QLayout,QCheckBox,QMessageBoxfrommercurialimporthg,ui,errorfromtortoisehg.utilimporthglib,pathsfromtortoisehg.hgqt.i18nimport_fromtortoisehg.hgqtimportcmdui,csinfoclassUpdateDialog(QDialog):def__init__(self,rev=None,repo=None,parent=None,opts=None):super(UpdateDialog,self).__init__(parent,Qt.WindowTitleHintorQt.WindowSystemMenuHint)self.ui=ui.ui()ifrepo:self.repo=repoelse:root=paths.find_root()ifroot:self.repo=hg.repository(self.ui,path=root)else:raise'not repository'# 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)fornameinhglib.getlivebranch(self.repo):combo.addItem(hglib.tounicode(name))tags=list(self.repo.tags())tags.sort()tags.reverse()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)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)grid.addWidget(QLabel(_('Options:')),3,0,Qt.AlignLeft|Qt.AlignTop)grid.addLayout(optbox,3,1)self.discard_chk=QCheckBox(_('Discard local changes, no backup (-C/--clean)'))self.merge_chk=QCheckBox(_('Always merge (when possible)'))self.showlog_chk=QCheckBox(_('Always show command log'))optbox.addWidget(self.discard_chk)optbox.addWidget(self.merge_chk)optbox.addWidget(self.showlog_chk)self.discard_chk.setChecked(bool(opts.get('clean',False)))## command widgetself.cmd=cmdui.Widget()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)## 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.rev_combo.lineEdit().returnPressed.connect(self.update)self.discard_chk.toggled.connect(lambda*a:self.update_info())# dialog settingself.setLayout(box)self.layout().setSizeConstraint(QLayout.SetFixedSize)reponame=hglib.get_reponame(self.repo)self.setWindowTitle(_('Update - %s')%hglib.tounicode(reponame))# prepare to showself.rev_combo.lineEdit().selectAll()self.cmd.setHidden(True)self.cancel_btn.setHidden(True)self.detail_btn.setHidden(True)self.update_info()### Private Methods ###defupdate_info(self):self.p1_info.update(self.ctxs[0])merge=len(self.ctxs)==2ifmerge:self.p2_info.update(self.ctxs[1])new_rev=hglib.fromunicode(self.rev_combo.currentText())try:new_ctx=self.repo[new_rev]ifnotmergeandnew_ctx.rev()==self.ctxs[0].rev():self.target_info.setPlainText(_('(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.setPlainText(_('unknown revision!'))self.update_btn.setDisabled(True)defupdate(self):cmdline=['update','--verbose']rev=hglib.fromunicode(self.rev_combo.currentText())cmdline.append('--rev')cmdline.append(rev)ifself.discard_chk.isChecked(): cmdline.append('--clean')
else:
cur = self.repo['.']
- node = self.repo[rev]
+ try:+ node = self.repo[rev]
+ except (error.LookupError, error.RepoLookupError, error.RepoError):+ return def isclean():
'''whether WD is changed'''
wc = self.repo[None]
returnnot(wc.modified()orwc.added()orwc.removed())defismergedchange():'''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')),'patch':(_('&Patch'),_('Patch - move local changes to MQ patch')),'merge':(_('&Merge'),_('Merge - allow to merge with local changes')),}opts=[data['discard']]ifnotismergedchange():opts.append(data['patch'])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','patch','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['patch']==clicked:return# TODO: not implemented yetelifbuttons['merge']==clicked:pass# no argselse:return# start updatingself.cmd.run(cmdline)### Signal Handlers ###defcancel_clicked(self):self.cmd.cancel()defdetail_toggled(self,checked):self.cmd.show_output(checked)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,wrapper):ifwrapper.dataisnot0orself.cmd.is_show_output():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.reject()defcommand_canceling(self):self.cancel_btn.setDisabled(True)defrun(ui,*pats,**opts):rev=Noneifopts.get('rev'):rev=opts.get('rev')eliflen(pats)==1:rev=pats[0]returnUpdateDialog(rev,opts=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.