mirror of
				https://github.com/arsenetar/dupeguru.git
				synced 2025-09-11 17:58:17 +00:00 
			
		
		
		
	Fix crash when recreating Results window/tab
* We need to set the Details Dialog's previous instance to None when recreating a new Results window otherwise Qt crashes since we are probably dereferencing a dangling reference. * Also fixes Results tab not showing up when selecting it from the View menu.
This commit is contained in:
		
							parent
							
								
									9f223f3964
								
							
						
					
					
						commit
						3382bd5e5b
					
				
							
								
								
									
										24
									
								
								qt/app.py
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								qt/app.py
									
									
									
									
									
								
							| @ -87,7 +87,6 @@ class DupeGuru(QObject): | |||||||
|                 "IgnoreListDialog", |                 "IgnoreListDialog", | ||||||
|                 parent=self.main_window, |                 parent=self.main_window, | ||||||
|                 model=self.model.ignore_list_dialog) |                 model=self.model.ignore_list_dialog) | ||||||
|             self.ignoreListDialog.accepted.connect(self.main_window.onDialogAccepted) |  | ||||||
| 
 | 
 | ||||||
|             self.excludeListDialog = self.main_window.createPage( |             self.excludeListDialog = self.main_window.createPage( | ||||||
|                 "ExcludeListDialog", |                 "ExcludeListDialog", | ||||||
| @ -97,7 +96,8 @@ class DupeGuru(QObject): | |||||||
|         else: |         else: | ||||||
|             self.ignoreListDialog = IgnoreListDialog( |             self.ignoreListDialog = IgnoreListDialog( | ||||||
|                 parent=parent_window, model=self.model.ignore_list_dialog) |                 parent=parent_window, model=self.model.ignore_list_dialog) | ||||||
|             self.excludeDialog = ExcludeListDialog(parent=parent_window) |             self.excludeDialog = ExcludeListDialog( | ||||||
|  |                 app=self, parent=parent_window, model=self.model.exclude_list_dialog) | ||||||
| 
 | 
 | ||||||
|         self.deletionOptions = DeletionOptions( |         self.deletionOptions = DeletionOptions( | ||||||
|             parent=parent_window, |             parent=parent_window, | ||||||
| @ -231,6 +231,10 @@ class DupeGuru(QObject): | |||||||
|     def showResultsWindow(self): |     def showResultsWindow(self): | ||||||
|         if self.resultWindow is not None: |         if self.resultWindow is not None: | ||||||
|             if self.use_tabs: |             if self.use_tabs: | ||||||
|  |                 if self.main_window.indexOfWidget(self.resultWindow) < 0: | ||||||
|  |                     self.main_window.addTab( | ||||||
|  |                         self.resultWindow, "Results", switch=True) | ||||||
|  |                     return | ||||||
|                 self.main_window.showTab(self.resultWindow) |                 self.main_window.showTab(self.resultWindow) | ||||||
|             else: |             else: | ||||||
|                 self.resultWindow.show() |                 self.resultWindow.show() | ||||||
| @ -281,18 +285,25 @@ class DupeGuru(QObject): | |||||||
|                 # we have not instantiated and populated it in their internal list yet |                 # we have not instantiated and populated it in their internal list yet | ||||||
|                 index = self.main_window.addTab( |                 index = self.main_window.addTab( | ||||||
|                     self.ignoreListDialog, "Ignore List", switch=True) |                     self.ignoreListDialog, "Ignore List", switch=True) | ||||||
|             # if not self.main_window.tabWidget.isTabVisible(index): |             elif not self.ignoreListDialog.isVisible() and not self.main_window.isTabVisible(index): | ||||||
|  |                 index = self.main_window.addTab( | ||||||
|  |                     self.ignoreListDialog, "Ignore List", switch=True) | ||||||
|  |                 # self.main_window.showTab(self.ignoreListDialog) | ||||||
|             self.main_window.setTabVisible(index, True) |             self.main_window.setTabVisible(index, True) | ||||||
|             self.main_window.setCurrentIndex(index) |             self.main_window.setCurrentIndex(index) | ||||||
|         else: |         else: | ||||||
|             self.model.ignore_list_dialog.show() |             self.model.ignore_list_dialog.show() | ||||||
| 
 | 
 | ||||||
|     def excludeListTriggered(self): |     def excludeListTriggered(self): | ||||||
|         if self.main_window: |         if self.use_tabs: | ||||||
|             index = self.main_window.indexOfWidget(self.excludeListDialog) |             index = self.main_window.indexOfWidget(self.excludeListDialog) | ||||||
|             if index < 0: |             if index < 0: | ||||||
|                 index = self.main_window.addTab( |                 index = self.main_window.addTab( | ||||||
|                     self.excludeListDialog, "Exclude List", switch=True) |                     self.excludeListDialog, "Exclude List", switch=True) | ||||||
|  |             elif not self.excludeListDialog.isVisible() and not self.main_window.isTabVisible(index): | ||||||
|  |                 index = self.main_window.addTab( | ||||||
|  |                     self.excludeListDialog, "Exclude List", switch=True) | ||||||
|  |                 # self.main_window.showTab(self.excludeListDialog) | ||||||
|             self.main_window.setTabVisible(index, True) |             self.main_window.setTabVisible(index, True) | ||||||
|             self.main_window.setCurrentIndex(index) |             self.main_window.setCurrentIndex(index) | ||||||
|         else: |         else: | ||||||
| @ -362,15 +373,14 @@ class DupeGuru(QObject): | |||||||
|             # or simply delete it on close which is probably cleaner: |             # or simply delete it on close which is probably cleaner: | ||||||
|             self.details_dialog.setAttribute(Qt.WA_DeleteOnClose) |             self.details_dialog.setAttribute(Qt.WA_DeleteOnClose) | ||||||
|             self.details_dialog.close() |             self.details_dialog.close() | ||||||
|             # self.details_dialog.setParent(None)  # seems unnecessary |             # if we don't do the following, Qt will crash when we recreate the Results dialog | ||||||
|  |             self.details_dialog.setParent(None) | ||||||
|         if self.resultWindow is not None: |         if self.resultWindow is not None: | ||||||
|             self.resultWindow.close() |             self.resultWindow.close() | ||||||
|             self.resultWindow.setParent(None) |             self.resultWindow.setParent(None) | ||||||
|         if self.use_tabs: |         if self.use_tabs: | ||||||
|             self.resultWindow = self.main_window.createPage( |             self.resultWindow = self.main_window.createPage( | ||||||
|                 "ResultWindow", parent=self.main_window, app=self) |                 "ResultWindow", parent=self.main_window, app=self) | ||||||
|             self.main_window.addTab( |  | ||||||
|                 self.resultWindow, "Results", switch=False) |  | ||||||
|         else:  # We don't use a tab widget, regular floating QMainWindow |         else:  # We don't use a tab widget, regular floating QMainWindow | ||||||
|             self.resultWindow = ResultWindow(self.directories_dialog, self) |             self.resultWindow = ResultWindow(self.directories_dialog, self) | ||||||
|             self.directories_dialog._updateActionsState() |             self.directories_dialog._updateActionsState() | ||||||
|  | |||||||
| @ -26,7 +26,7 @@ class TabWindow(QMainWindow): | |||||||
|     def __init__(self, app, **kwargs): |     def __init__(self, app, **kwargs): | ||||||
|         super().__init__(None, **kwargs) |         super().__init__(None, **kwargs) | ||||||
|         self.app = app |         self.app = app | ||||||
|         self.pages = {} |         self.pages = {}  # This is currently not used anywhere | ||||||
|         self.menubar = None |         self.menubar = None | ||||||
|         self.menuList = set() |         self.menuList = set() | ||||||
|         self.last_index = -1 |         self.last_index = -1 | ||||||
| @ -142,6 +142,7 @@ class TabWindow(QMainWindow): | |||||||
|             and not page_type == "IgnoreListDialog" else False) |             and not page_type == "IgnoreListDialog" else False) | ||||||
|         self.app.actionDirectoriesWindow.setEnabled( |         self.app.actionDirectoriesWindow.setEnabled( | ||||||
|             False if page_type == "DirectoriesDialog" else True) |             False if page_type == "DirectoriesDialog" else True) | ||||||
|  |         # FIXME add ExcludeListDialog here too | ||||||
| 
 | 
 | ||||||
|         self.previous_widget_actions = active_widget.specific_actions |         self.previous_widget_actions = active_widget.specific_actions | ||||||
|         self.last_index = current_index |         self.last_index = current_index | ||||||
| @ -158,12 +159,14 @@ class TabWindow(QMainWindow): | |||||||
|             parent = kwargs.get("parent", self) |             parent = kwargs.get("parent", self) | ||||||
|             model = kwargs.get("model") |             model = kwargs.get("model") | ||||||
|             page = IgnoreListDialog(parent, model) |             page = IgnoreListDialog(parent, model) | ||||||
|  |             page.accepted.connect(self.onDialogAccepted) | ||||||
|         elif cls == "ExcludeListDialog": |         elif cls == "ExcludeListDialog": | ||||||
|             app = kwargs.get("app", app) |             app = kwargs.get("app", app) | ||||||
|             parent = kwargs.get("parent", self) |             parent = kwargs.get("parent", self) | ||||||
|             model = kwargs.get("model") |             model = kwargs.get("model") | ||||||
|             page = ExcludeListDialog(app, parent, model) |             page = ExcludeListDialog(app, parent, model) | ||||||
|         self.pages[cls] = page |             page.accepted.connect(self.onDialogAccepted) | ||||||
|  |         self.pages[cls] = page  # Not used, might remove | ||||||
|         return page |         return page | ||||||
| 
 | 
 | ||||||
|     def addTab(self, page, title, switch=False): |     def addTab(self, page, title, switch=False): | ||||||
| @ -208,7 +211,7 @@ class TabWindow(QMainWindow): | |||||||
| 
 | 
 | ||||||
|     # --- Events |     # --- Events | ||||||
|     def appWillSavePrefs(self): |     def appWillSavePrefs(self): | ||||||
|         # Right now this is useless since the first spawn dialog inside the |         # Right now this is useless since the first spawned dialog inside the | ||||||
|         # QTabWidget will assign its geometry after restoring it |         # QTabWidget will assign its geometry after restoring it | ||||||
|         prefs = self.app.prefs |         prefs = self.app.prefs | ||||||
|         prefs.mainWindowIsMaximized = self.isMaximized() |         prefs.mainWindowIsMaximized = self.isMaximized() | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user