mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
core: replace divesite_table_t by a vector of std::unique_ptr<>s
This is a long commit, because it introduces a new abstraction: a general std::vector<> of std::unique_ptrs<>. Moreover, it replaces a number of pointers by C++ references, when the callee does not suppoert null objects. This simplifies memory management and makes ownership more explicit. It is a proof-of-concept and a test-bed for the other core data structrures. Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
This commit is contained in:
parent
411188728d
commit
e39dea3d68
41 changed files with 451 additions and 426 deletions
|
@ -1069,7 +1069,7 @@ bool QMLManager::checkLocation(DiveSiteChange &res, struct dive *d, QString loca
|
|||
bool changed = false;
|
||||
QString oldLocation = QString::fromStdString(get_dive_location(d));
|
||||
if (oldLocation != location) {
|
||||
ds = get_dive_site_by_name(location.toStdString(), divelog.sites);
|
||||
ds = get_dive_site_by_name(location.toStdString(), *divelog.sites);
|
||||
if (!ds && !location.isEmpty()) {
|
||||
res.createdDs = std::make_unique<dive_site>(qPrintable(location));
|
||||
res.changed = true;
|
||||
|
@ -1816,7 +1816,7 @@ QString QMLManager::getVersion() const
|
|||
|
||||
QString QMLManager::getGpsFromSiteName(const QString &siteName)
|
||||
{
|
||||
struct dive_site *ds = get_dive_site_by_name(siteName.toStdString(), divelog.sites);
|
||||
struct dive_site *ds = get_dive_site_by_name(siteName.toStdString(), *divelog.sites);
|
||||
if (!ds)
|
||||
return QString();
|
||||
return printGPSCoords(&ds->location);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue