Kiln » TortoiseHg » TortoiseHg
Clone URL:  
Pushed to one repository · View In Graph Contained in 0.9, 0.9.1, and 0.9.1.1

stable gdialog: add some methods for command widgets

Changeset c56578291760

Parent 3325644ced94

by Yuki KODAMA

Changes to one file · Browse files at c56578291760 Showing diff from parent 3325644ced94 Diff from another changeset...

 
340
341
342
 
 
 
 
 
 
343
344
345
346
347
 
348
349
350
351
352
353
354
355
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
356
357
 
 
 
 
 
 
358
359
360
 
340
341
342
343
344
345
346
347
348
349
 
 
 
 
350
351
352
353
354
 
 
 
 
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
 
372
373
374
375
376
377
378
379
380
@@ -340,21 +340,41 @@
  def get_menuitem(self, name):   return self.menuitems[name]   + def get_widgets(self, name): + widgets = [] + widgets.append(self.toolbuttons.get(name)) + widgets.append(self.menuitems.get(name)) + return widgets +   def cmd_set_sensitive(self, name, sensitive): - ws = [] - ws.append(self.toolbuttons.get(name)) - ws.append(self.menuitems.get(name)) - for w in ws: + for w in self.get_widgets(name):   if w:   w.set_sensitive(sensitive)     def cmd_set_active(self, name, active): - ws = [] - ws.append(self.toolbuttons.get(name)) - ws.append(self.menuitems.get(name)) - for w in ws: + for w in self.get_widgets(name): + if w and hasattr(w, 'set_active'): + w.set_active(active) + + def cmd_get_active(self, name, fallback=None): + prev = None + for w in self.get_widgets(name): + if w and hasattr(w, 'set_active'): + active = w.get_active() + if prev is not None and prev != active: + return fallback + prev = active + return prev + + def cmd_handler_block_by_func(self, name, func): + for w in self.get_widgets(name):   if w: - w.set_active(active) + w.handler_block_by_func(func) + + def cmd_handler_unblock_by_func(self, name, func): + for w in self.get_widgets(name): + if w: + w.handler_unblock_by_func(func)     def get_reponame(self):   return hglib.get_reponame(self.repo)