mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Since the sorted_owning_table depends on the fact that different elements never compare as equal, make the comparison function safer in that respect. If all failes, compare the pointers. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| #include "tripselectiondialog.h"
 | |
| #include "core/divelog.h"
 | |
| #include "core/string-format.h"
 | |
| #include "core/trip.h"
 | |
| #include <QShortcut>
 | |
| #include <QPushButton>
 | |
| 
 | |
| TripSelectionDialog::TripSelectionDialog(QWidget *parent) : QDialog(parent)
 | |
| {
 | |
| 	ui.setupUi(this);
 | |
| 	connect(ui.trips, &QListWidget::itemSelectionChanged, this, &TripSelectionDialog::selectionChanged);
 | |
| 
 | |
| 	QShortcut *close = new QShortcut(QKeySequence(Qt::CTRL | Qt::Key_W), this);
 | |
| 	connect(close, &QShortcut::activated, this, &QDialog::close);
 | |
| 	QShortcut *quit = new QShortcut(QKeySequence(Qt::CTRL | Qt::Key_Q), this);
 | |
| 	connect(quit, &QShortcut::activated, parent, &QWidget::close);
 | |
| 
 | |
| 	// We could use a model, but it seems barely worth the hassle.
 | |
| 	QStringList list;
 | |
| 	list.reserve(divelog.trips->size());
 | |
| 	for (auto &trip: *divelog.trips)
 | |
| 		list.push_back(formatTripTitleWithDives(*trip));
 | |
| 	ui.trips->addItems(list);
 | |
| }
 | |
| 
 | |
| void TripSelectionDialog::selectionChanged()
 | |
| {
 | |
| 	ui.buttonBox->button(QDialogButtonBox::Ok)->setEnabled(selectedTrip() != nullptr);
 | |
| }
 | |
| 
 | |
| dive_trip *TripSelectionDialog::selectedTrip() const
 | |
| {
 | |
| 	// Accessing the selected index of a QListWidget is ridiculously cumbersome.
 | |
| 	// Note that "currentItem" is a different beast.
 | |
| 	QModelIndexList rows = ui.trips->selectionModel()->selectedRows();
 | |
| 	if (rows.size() != 1)
 | |
| 		return nullptr;
 | |
| 	int idx = rows[0].row();
 | |
| 	if (idx < 0 || static_cast<size_t>(idx) >= divelog.trips->size())
 | |
| 		return nullptr;
 | |
| 	return (*divelog.trips)[idx].get();
 | |
| }
 | |
| 
 | |
| dive_trip *TripSelectionDialog::getTrip()
 | |
| {
 | |
| 	return exec() ? selectedTrip() : nullptr;
 | |
| }
 |