diff options
author | Timothy Pearson <[email protected]> | 2014-10-04 18:27:03 -0500 |
---|---|---|
committer | Timothy Pearson <[email protected]> | 2014-10-04 18:27:03 -0500 |
commit | dc94a41a15af93d28310c04e224419fb033b7a7e (patch) | |
tree | c45d19adb00df0cd9c4df1142404fcaab723fdfa /konqueror | |
parent | f3becf2104c8a615807ca62ce7c170624aab9ea5 (diff) | |
download | tdebase-dc94a41a15af93d28310c04e224419fb033b7a7e.tar.gz tdebase-dc94a41a15af93d28310c04e224419fb033b7a7e.zip |
Fix rare Konqueror crash in tree view mode
This relates to Bug 1820
Diffstat (limited to 'konqueror')
-rw-r--r-- | konqueror/listview/konq_listviewitems.cc | 2 | ||||
-rw-r--r-- | konqueror/listview/konq_listviewitems.h | 5 | ||||
-rw-r--r-- | konqueror/listview/konq_treeviewitem.cc | 7 | ||||
-rw-r--r-- | konqueror/listview/konq_treeviewitem.h | 5 | ||||
-rw-r--r-- | konqueror/listview/konq_treeviewwidget.cc | 4 |
5 files changed, 19 insertions, 4 deletions
diff --git a/konqueror/listview/konq_listviewitems.cc b/konqueror/listview/konq_listviewitems.cc index d5665313f..45ff99c1c 100644 --- a/konqueror/listview/konq_listviewitems.cc +++ b/konqueror/listview/konq_listviewitems.cc @@ -404,6 +404,7 @@ KonqBaseListViewItem::KonqBaseListViewItem(KonqBaseListViewWidget *_listViewWidg ,m_bDisabled(false) ,m_bActive(false) ,m_fileitem(_fileitem) +,m_fileitemURL(_fileitem->url()) ,m_pListViewWidget(_listViewWidget) {} @@ -413,6 +414,7 @@ KonqBaseListViewItem::KonqBaseListViewItem(KonqBaseListViewWidget *_listViewWidg ,m_bDisabled(false) ,m_bActive(false) ,m_fileitem(_fileitem) +,m_fileitemURL(_fileitem->url()) ,m_pListViewWidget(_listViewWidget) {} diff --git a/konqueror/listview/konq_listviewitems.h b/konqueror/listview/konq_listviewitems.h index f374daf1b..2e2827519 100644 --- a/konqueror/listview/konq_listviewitems.h +++ b/konqueror/listview/konq_listviewitems.h @@ -71,8 +71,11 @@ class KonqBaseListViewItem : public TDEListViewItem bool m_bDisabled; bool m_bActive; - /** Pointer to the file item in KDirLister's list */ + /** Pointer to the file item in KDirLister's list + * Don't use this unless you absolutely have to! */ KFileItem* m_fileitem; + /** URL of file item */ + KURL m_fileitemURL; /** Parent tree view */ KonqBaseListViewWidget* m_pListViewWidget; diff --git a/konqueror/listview/konq_treeviewitem.cc b/konqueror/listview/konq_treeviewitem.cc index 32baf1c41..12953c401 100644 --- a/konqueror/listview/konq_treeviewitem.cc +++ b/konqueror/listview/konq_treeviewitem.cc @@ -89,8 +89,13 @@ void KonqListViewDir::open( bool _open, bool _reload ) } } +KURL KonqListViewDir::kurl() +{ + return m_fileitemURL; +} + TQString KonqListViewDir::url( int _trailing ) { - return item()->url().url( _trailing ); + return m_fileitemURL.url( _trailing ); } diff --git a/konqueror/listview/konq_treeviewitem.h b/konqueror/listview/konq_treeviewitem.h index b17adacaf..6dcc1bb79 100644 --- a/konqueror/listview/konq_treeviewitem.h +++ b/konqueror/listview/konq_treeviewitem.h @@ -68,6 +68,11 @@ public: /** * URL of this directory + */ + KURL kurl(); + + /** + * URL of this directory * @param _trailing set to true for a trailing slash (see KURL) */ TQString url( int _trailing ); diff --git a/konqueror/listview/konq_treeviewwidget.cc b/konqueror/listview/konq_treeviewwidget.cc index 4d04f2fa4..77adc4b61 100644 --- a/konqueror/listview/konq_treeviewwidget.cc +++ b/konqueror/listview/konq_treeviewwidget.cc @@ -294,13 +294,13 @@ void KonqTreeViewWidget::slotDeleteItem( KFileItem *_fileItem ) void KonqTreeViewWidget::openSubFolder( KonqListViewDir* _dir, bool _reload ) { - m_dirLister->openURL( _dir->item()->url(), true /* keep existing data */, _reload ); + m_dirLister->openURL( _dir->kurl(), true /* keep existing data */, _reload ); slotUpdateBackground(); } void KonqTreeViewWidget::stopListingSubFolder( KonqListViewDir* _dir ) { - m_dirLister->stop( _dir->item()->url() ); + m_dirLister->stop( _dir->kurl() ); slotUpdateBackground(); } |