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.
# hgignore.py - TortoiseHg's dialog for editing .hgignore## Copyright 2008 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.importosimportgtkimportrefrommercurialimporthg,ui,match,util,errorfromtortoisehg.util.i18nimport_fromtortoisehg.utilimportshlib,hglib,pathsfromtortoisehg.hgtkimportgtklib,gdialog,dialogclassHgIgnoreDialog(gtk.Window):'Edit a reposiory .hgignore file'def__init__(self,fileglob='',*pats):'Initialize the Dialog'gtk.Window.__init__(self,gtk.WINDOW_TOPLEVEL)gtklib.set_tortoise_icon(self,'ignore.ico')gtklib.set_tortoise_keys(self)self.set_default_size(630,400)try:repo=hg.repository(ui.ui(),path=paths.find_root())excepterror.RepoError:gtklib.idle_add_single_call(self.destroy)returnself.repo=repoself.set_title(_('Ignore filter - %s')%hglib.get_reponame(repo))self.notify_func=None# vbox for dialog mainmainvbox=gtk.VBox()self.add(mainvbox)mainvbox.set_border_width(2)## layout table for toptable=gtklib.LayoutTable()mainvbox.pack_start(table,False,False)### hbox for glob entryself.glob_entry=gtk.Entry()self.glob_entry.set_text(hglib.toutf(fileglob))self.glob_entry.connect('activate',self.add_glob)glob_button=gtk.Button(_('Add'))glob_button.connect('clicked',self.add_glob)table.add_row(_('Glob:'),self.glob_entry,0,glob_button,expand=0)### hbox for regexp entryself.regexp_entry=gtk.Entry()self.regexp_entry.connect('activate',self.add_regexp)regexp_button=gtk.Button(_('Add'))regexp_button.connect('clicked',self.add_regexp)table.add_row(_('Regexp:'),self.regexp_entry,0,regexp_button,expand=0)ignorefiles=[repo.wjoin('.hgignore')]forname,valueinrepo.ui.configitems('ui'):ifname=='ignore'orname.startswith('ignore.'):ignorefiles.append(os.path.expanduser(value))### ignore file combo if needsiflen(ignorefiles)>1:# file selectorcombo=gtk.combo_box_new_text()forfinignorefiles:combo.append_text(hglib.toutf(f))combo.set_active(0)combo.connect('changed',self.file_selected)# edit buttonedit=gtk.Button(_('Edit File'))edit.connect('clicked',self.edit_clicked)table.add_row(_('Apply to:'),combo,0,edit,padding=False,expand=0)self.ignorefile=ignorefiles[0]## hbox for filter & unknown listhbox=gtk.HBox()mainvbox.pack_start(hbox,True,True)### frame for filter list & buttonframe=gtk.Frame(_('Filters'))hbox.pack_start(frame,True,True,4)vbox=gtk.VBox()frame.add(vbox)vbox.set_border_width(2)#### filter listscrolledwindow=gtk.ScrolledWindow()vbox.pack_start(scrolledwindow,True,True,2)scrolledwindow.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC)scrolledwindow.set_border_width(4)pattree=gtk.TreeView()scrolledwindow.add(pattree)pattree.set_enable_search(False)pattree.set_reorderable(False)pattree.get_selection().set_mode(gtk.SELECTION_SINGLE)col=gtk.TreeViewColumn(_('Patterns'),gtk.CellRendererText(),text=0)pattree.append_column(col)pattree.set_headers_visible(False)self.pattree=pattree#### remove buttonbhbox=gtk.HBox()vbox.pack_start(bhbox,False,False,2)self.removebtn=gtk.Button(_('Remove Selected'))bhbox.pack_start(self.removebtn,False,False,2)self.removebtn.connect('clicked',self.remove_clicked)self.removebtn.set_sensitive(False)### frame for unknown file list & buttonframe=gtk.Frame(_('Unknown Files'))hbox.pack_start(frame,True,True,4)vbox=gtk.VBox()frame.add(vbox)vbox.set_border_width(2)#### unknown file listscrolledwindow=gtk.ScrolledWindow()vbox.pack_start(scrolledwindow,True,True,2)scrolledwindow.set_policy(gtk.POLICY_AUTOMATIC,gtk.POLICY_AUTOMATIC)scrolledwindow.set_border_width(4)unktree=gtk.TreeView()scrolledwindow.add(unktree)unktree.set_search_equal_func(self.unknown_search)col=gtk.TreeViewColumn(_('Files'),gtk.CellRendererText(),text=0)unktree.append_column(col)model=gtk.ListStore(str,str)unktree.set_model(model)unktree.set_headers_visible(False)self.unkmodel=model#### refresh buttonbhbox=gtk.HBox()vbox.pack_start(bhbox,False,False,2)refresh=gtk.Button(_('Refresh'))bhbox.pack_start(refresh,False,False,2)refresh.connect('pressed',lambdab:self.refresh())self.connect('thg-refresh',lambdaw:self.refresh())# register signal handlerspattree.get_selection().connect('changed',self.pattree_rowchanged)unktree.get_selection().connect('changed',self.unknown_rowchanged)# prepare to showself.glob_entry.grab_focus()gtklib.idle_add_single_call(self.refresh)deffile_selected(self,combo):'select another ignore file'self.ignorefile=hglib.fromutf(combo.get_active_text())self.refresh()defedit_clicked(self,button):gtklib.open_with_editor(self.repo.ui,self.ignorefile,self)defunknown_search(self,model,column,key,iter):'case insensitive filename search'key=key.lower()ifkeyinmodel.get_value(iter,0).lower():returnFalsereturnTruedefremove_clicked(self,button):sel=self.pattree.get_selection()model,rows=sel.get_selected_rows()delmodel[rows[0]]delself.ignorelines[rows[0][0]]self.write_ignore_lines()self.refresh()defpattree_rowchanged(self,sel):model,ppaths=sel.get_selected()sensitive=ppathsandTrueorFalseself.removebtn.set_sensitive(sensitive)defunknown_rowchanged(self,sel):model,upaths=sel.get_selected()ifnotupaths:returnself.glob_entry.set_text(model[upaths][0])defadd_glob(self,widget):newglob=hglib.fromutf(self.glob_entry.get_text())ifnewglob=='':returnnewglob='glob:'+newglobtry:match.match(self.repo.root,'',[],[newglob])exceptutil.Abort,inst:gdialog.Prompt(_('Invalid glob expression'),str(inst),self).run()returnself.ignorelines.append(newglob)self.write_ignore_lines()self.glob_entry.set_text('')self.refresh()defadd_regexp(self,widget):newregexp=hglib.fromutf(self.regexp_entry.get_text())ifnewregexp=='':returntry:match.match(self.repo.root,'',[],['relre:'+newregexp])re.compile(newregexp)except(util.Abort,re.error),inst:gdialog.Prompt(_('Invalid regexp expression'),str(inst),self).run()returnself.ignorelines.append('relre:'+newregexp)self.write_ignore_lines()self.regexp_entry.set_text('')self.refresh()defset_notify_func(self,func):self.notify_func=func def refresh(self):
hglib.invalidaterepo(self.repo)
matcher = match.always(self.repo.root, self.repo.root)
- unknown = self.repo.status(match=matcher, unknown=True)[4]
+ try:+ unknown = self.repo.status(match=matcher, unknown=True)[4]
+ except (EnvironmentError, util.Abort), inst:+ gdialog.Prompt(_('Error while reading status'),+ hglib.toutf(str(inst)), self).run()+ return self.unkmodel.clear()
for u in unknown:
self.unkmodel.append([hglib.toutf(u), u])
try:l=open(self.ignorefile,'rb').readlines()self.doseoln=l[0].endswith('\r\n')except(IOError,ValueError,IndexError):self.doseoln=os.name=='nt'l=[]model=gtk.ListStore(str)self.ignorelines=[]forlineinl:model.append([hglib.toutf(line.strip())])self.ignorelines.append(line.strip())self.pattree.set_model(model)defwrite_ignore_lines(self):ifself.doseoln:out=[line+'\r\n'forlineinself.ignorelines]else:out=[line+'\n'forlineinself.ignorelines]try:f=util.atomictempfile(self.ignorefile,'wb',createmode=None)f.writelines(out)f.rename()exceptIOError,e:dialog.error_dialog(self,_('Unable to write .hgignore file'),hglib.tounicode(str(e)))shlib.shell_notify([self.ignorefile])ifself.notify_func:self.notify_func()defrun(_ui,*pats,**opts):ifpatsandpats[0].endswith('.hgignore'):pats=[]returnHgIgnoreDialog(*pats)
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.