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.
# merge.py - TortoiseHg's dialog for merging revisions## Copyright 2007 TK Soh <teekaysoh@gmail.com># Copyright 2007 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.importosimportgtkimportgobjectfrommercurialimporthg,uifromtortoisehg.util.i18nimport_fromtortoisehg.utilimporthglib,pathsfromtortoisehg.hgtkimportchangesetinfo,gtklib,commit,gdialog,hgcmdRESPONSE_MERGE=1RESPONSE_COMMIT=2RESPONSE_UNDO=3MODE_NORMAL='normal'MODE_WORKING='working'classMergeDialog(gtk.Dialog):""" Dialog to merge revisions of a Mercurial repo """def__init__(self,rev=None):""" Initialize the Dialog """gtk.Dialog.__init__(self)gtklib.set_tortoise_icon(self,'menumerge.ico')gtklib.set_tortoise_keys(self)self.set_has_separator(False)self.set_resizable(False)self.connect('response',self.dialog_response)self.notify_func=Noneifnotrev:gdialog.Prompt(_('Unable to merge'),_('Must supply a target revision'),self).run()gobject.idle_add(self.destroy)returntry:repo=hg.repository(ui.ui(),path=paths.find_root())excepthglib.RepoError:gobject.idle_add(self.destroy)returnself.set_title(_('Merging in %s')%hglib.get_reponame(repo))frame=gtk.Frame(_('Merge target (other)'))self.otherrev,desc=changesetinfo.changesetinfo(repo,rev,True)frame.add(desc)frame.set_border_width(5)self.vbox.pack_start(frame,False,False)self.otherframe=frameframe=gtk.Frame(_('Current revision (local)'))self.localrev,desc=changesetinfo.changesetinfo(repo,'.',True)frame.add(desc)frame.set_border_width(5)self.vbox.pack_start(frame,False,False)self.localframe=frameself.mergebtn=self.add_button(_('Merge'),RESPONSE_MERGE)self.commitbtn=self.add_button(_('Commit'),RESPONSE_COMMIT)self.undobtn=self.add_button(_('Undo'),RESPONSE_UNDO)self.closebtn=self.add_button(gtk.STOCK_CLOSE,gtk.RESPONSE_CLOSE)vlist=gtk.ListStore(str,# tool namebool)# separatorcombo=gtk.ComboBoxEntry(vlist,0)self.mergetool=combocombo.set_row_separator_func(lambdamodel,path:model[path][1])combo.child.set_width_chars(8)lbl=gtk.Label(_('Merge tools:'))lbl.set_alignment(1,0.5) self.mergelabel = lbl
self.action_area.add(lbl)
self.action_area.add(combo)
+ prev = False for tool in hglib.mergetools(repo.ui):
- vlist.append((hglib.toutf(tool), False))
+ cur = tool.startswith('internal:')+ vlist.append((hglib.toutf(tool), prev != cur))
+ prev = cur mtool = repo.ui.config('ui', 'merge', None)
if mtool:
combo.child.set_text(hglib.toutf(mtool))
else:combo.child.set_text('')# prepare to showself.mergebtn.grab_focus()self.commitbtn.set_sensitive(False)self.undobtn.set_sensitive(False)gobject.idle_add(self.after_init)defafter_init(self):# CmdWidgetself.cmd=hgcmd.CmdWidget()self.cmd.show_all()self.cmd.hide()self.vbox.pack_start(self.cmd,True,True,6)# abort buttonself.abortbtn=self.add_button(_('Abort'),gtk.RESPONSE_CANCEL)self.abortbtn.hide()defdialog_response(self,dialog,response_id):defabort():self.cmd.stop()self.cmd.show_log()self.switch_to(MODE_NORMAL,cmd=False)# Merge buttonifresponse_id==RESPONSE_MERGE:self.domerge()# Commit buttonelifresponse_id==RESPONSE_COMMIT:self.docommit()# Undo buttonelifresponse_id==RESPONSE_UNDO:self.doundo()# Close button or dialog closing by the userelifresponse_idin(gtk.RESPONSE_CLOSE,gtk.RESPONSE_DELETE_EVENT):ifself.cmd.is_alive():ret=gdialog.Confirm(_('Confirm Abort'),[],self,_('Do you want to abort?')).run()ifret==gtk.RESPONSE_YES:abort()else:repo=hg.repository(ui.ui(),path=paths.find_root())iflen(repo.parents())==2:ret=gdialog.Confirm(_('Confirm Exit'),[],self,_('To complete merging, you need to commit'' merged files in working directory.\n\n''Do you want to exit?')).run()ifret==gtk.RESPONSE_YES:self.destroy()return# close dialogelse:self.destroy()return# close dialog# Abort buttonelifresponse_id==gtk.RESPONSE_CANCEL:abort()else:raise_('unexpected response id: %s')%response_idself.run()# don't close dialogdefset_notify_func(self,func,*args):self.notify_func=funcself.notify_args=list(args)defswitch_to(self,mode,cmd=True):ifmode==MODE_NORMAL:normal=Trueelifmode==MODE_WORKING:normal=Falseself.abortbtn.grab_focus()else:raise_('unknown mode name: %s')%modeworking=notnormalself.otherframe.set_sensitive(normal)self.localframe.set_sensitive(normal)self.mergetool.set_property('visible',normal)self.mergelabel.set_property('visible',normal)self.mergebtn.set_property('visible',normal)self.commitbtn.set_property('visible',normal)self.undobtn.set_property('visible',normal)self.closebtn.set_property('visible',normal)ifcmd:self.cmd.set_property('visible',working)self.abortbtn.set_property('visible',working)defcmd_done(self,returncode):self.switch_to(MODE_NORMAL,cmd=False)ifreturncode==0andnotself.cmd.is_show_log():self.response(gtk.RESPONSE_CLOSE)defdomerge(self):cmdline=['hg','merge','--rev',self.otherrev]tool=hglib.fromutf(self.mergetool.child.get_text())iftool:oldmergeenv=os.environ.get('HGMERGE')os.environ['HGMERGE']=tooldefcmd_done(returncode):self.switch_to(MODE_NORMAL,cmd=False)repo=hg.repository(ui.ui(),path=paths.find_root())iflen(repo.parents())==1:returniftool:ifoldmergeenv:os.environ['HGMERGE']=oldmergeenvelse:delos.environ['HGMERGE']ifself.notify_func:self.notify_func(self.notify_args)self.mergetool.set_sensitive(False)self.mergelabel.set_sensitive(False)self.mergebtn.set_sensitive(False)self.undobtn.set_sensitive(True)self.commitbtn.set_sensitive(True)self.commitbtn.grab_focus()self.switch_to(MODE_WORKING)self.cmd.execute(cmdline,cmd_done)defdocommit(self):dlg=commit.run(ui.ui())dlg.set_transient_for(self)dlg.set_modal(True)dlg.set_notify_func(self.commit_notify,dlg)dlg.display()defcommit_notify(self,dlg):# refresh the log toolifself.notify_func:self.notify_func(self.notify_args)# hide merge dialogself.hide()# hide commit tooldlg.ready=False# disables refreshdlg.hide()gobject.timeout_add(50,self.destroy)defdoundo(self):res=gdialog.Confirm(_('Confirm undo merge'),[],self,_('Clean checkout of original revision?')).run()ifres!=gtk.RESPONSE_YES:returncmdline=['hg','update','--rev',self.localrev,'--clean']defcmd_done(returncode):self.switch_to(MODE_NORMAL,cmd=False)ifself.notify_func:self.notify_func(self.notify_args)self.mergetool.set_sensitive(True)self.mergelabel.set_sensitive(True)self.mergebtn.set_sensitive(True)self.mergebtn.grab_focus()self.undobtn.set_sensitive(False)self.commitbtn.set_sensitive(False)self.switch_to(MODE_WORKING)self.cmd.execute(cmdline,cmd_done)defrun(ui,*pats,**opts):returnMergeDialog(opts.get('rev'))
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.