mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Dive list: seriously simplify the "add to trip" code
The existing code seemed way complicated, made way too many assumptions and apparently was broken in certain cases. This code seems very simple, looks correct and should fail gracefully (i.e. simply do nothing) if things get confused. Fixes #706 (I hope) Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
		
							parent
							
								
									b940f078b5
								
							
						
					
					
						commit
						512c42e38a
					
				
					 2 changed files with 15 additions and 27 deletions
				
			
		|  | @ -572,43 +572,31 @@ void DiveListView::newTripAbove() | ||||||
| 
 | 
 | ||||||
| void DiveListView::addToTripBelow() | void DiveListView::addToTripBelow() | ||||||
| { | { | ||||||
| 	addToTrip(true); | 	addToTrip(1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void DiveListView::addToTripAbove() | void DiveListView::addToTripAbove() | ||||||
| { | { | ||||||
| 	addToTrip(false); | 	addToTrip(-1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void DiveListView::addToTrip(bool below) | void DiveListView::addToTrip(int delta) | ||||||
| { | { | ||||||
| 	int delta = (currentOrder == Qt::AscendingOrder) ? -1 : +1; | 	// if there is a trip above / below, then it's a sibling at the same
 | ||||||
|  | 	// level as this dive. So let's take a look
 | ||||||
| 	struct dive *d = (struct dive *)contextMenuIndex.data(DiveTripModel::DIVE_ROLE).value<void *>(); | 	struct dive *d = (struct dive *)contextMenuIndex.data(DiveTripModel::DIVE_ROLE).value<void *>(); | ||||||
|  | 	QModelIndex t = contextMenuIndex.sibling(contextMenuIndex.row() + delta, 0); | ||||||
|  | 	dive_trip_t *trip = (dive_trip_t *)t.data(DiveTripModel::TRIP_ROLE).value<void *>(); | ||||||
|  | 
 | ||||||
|  | 	if (!trip || !d) | ||||||
|  | 		// no dive, no trip? get me out of here
 | ||||||
|  | 		return; | ||||||
|  | 
 | ||||||
| 	rememberSelection(); | 	rememberSelection(); | ||||||
| 
 | 
 | ||||||
| 	//TODO: This part should be moved to C-code.
 |  | ||||||
| 	int idx; |  | ||||||
| 	dive_trip_t *trip = NULL; |  | ||||||
| 	struct dive *pd = NULL; |  | ||||||
| 	if (below) // Should we add to the trip below instead?
 |  | ||||||
| 		delta *= -1; |  | ||||||
| 
 |  | ||||||
| 	if (d->selected) { // we are right-clicking on one of possibly many selected dive(s)
 |  | ||||||
| 		// find the top selected dive, depending on the list order
 |  | ||||||
| 		if (delta == 1) |  | ||||||
| 			d = last_selected_dive(); |  | ||||||
| 		else |  | ||||||
| 			d = first_selected_dive(); |  | ||||||
| 	} |  | ||||||
| 	// now find the trip "above" in the dive list
 |  | ||||||
| 	if ((pd = get_dive(get_divenr(d) + delta)) != NULL) { |  | ||||||
| 		trip = pd->divetrip; |  | ||||||
| 	} |  | ||||||
| 	if (!pd || !trip) |  | ||||||
| 		// previous dive wasn't in a trip, so something is wrong
 |  | ||||||
| 		return; |  | ||||||
| 	add_dive_to_trip(d, trip); | 	add_dive_to_trip(d, trip); | ||||||
| 	if (d->selected) { // there are possibly other selected dives that we should add
 | 	if (d->selected) { // there are possibly other selected dives that we should add
 | ||||||
|  | 		int idx; | ||||||
| 		for_each_dive (idx, d) { | 		for_each_dive (idx, d) { | ||||||
| 			if (d->selected) | 			if (d->selected) | ||||||
| 				add_dive_to_trip(d, trip); | 				add_dive_to_trip(d, trip); | ||||||
|  | @ -616,7 +604,7 @@ void DiveListView::addToTrip(bool below) | ||||||
| 	} | 	} | ||||||
| 	trip->expanded = 1; | 	trip->expanded = 1; | ||||||
| 	mark_divelist_changed(true); | 	mark_divelist_changed(true); | ||||||
| 	//This part stays at C++ code.
 | 
 | ||||||
| 	reload(currentLayout, false); | 	reload(currentLayout, false); | ||||||
| 	restoreSelection(); | 	restoreSelection(); | ||||||
| 	fixMessyQtModelBehaviour(); | 	fixMessyQtModelBehaviour(); | ||||||
|  |  | ||||||
|  | @ -79,7 +79,7 @@ private: | ||||||
| 	void updateLastUsedImageDir(const QString &s); | 	void updateLastUsedImageDir(const QString &s); | ||||||
| 	void updateLastImageTimeOffset(int offset); | 	void updateLastImageTimeOffset(int offset); | ||||||
| 	int lastImageTimeOffset(); | 	int lastImageTimeOffset(); | ||||||
| 	void addToTrip(bool); | 	void addToTrip(int delta); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #endif // DIVELISTVIEW_H
 | #endif // DIVELISTVIEW_H
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue