diff options
author | Stefan Fuchs <sfuchs@gmx.de> | 2017-10-11 21:29:47 +0200 |
---|---|---|
committer | Robert C. Helling <helling@atdotde.de> | 2017-10-16 17:14:17 +0200 |
commit | 24bd5a8dcebec886b8fbbf077fabfb2106dc7dcd (patch) | |
tree | 35c03fc280dab0a09ccb2f59939f0a1d93595aaf /qt-models/cylindermodel.cpp | |
parent | 73d2ab8099ce08ab20f119a126334463ffd41b1e (diff) | |
download | subsurface-24bd5a8dcebec886b8fbbf077fabfb2106dc7dcd.tar.gz |
Planner: Autom. move first datapoint gas to first gaslist position
In the planner it is best practise to start the dive with the first
gas in the gaslist. Otherwise one would get a gaschange event at the
very beginning of a dive.
This change implements the following feature:
Automatically move a gas to position 0 in the gaslist if the user selects
this gas for the first dive data point.
Signed-off-by: Stefan Fuchs <sfuchs@gmx.de>
Diffstat (limited to 'qt-models/cylindermodel.cpp')
-rw-r--r-- | qt-models/cylindermodel.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/qt-models/cylindermodel.cpp b/qt-models/cylindermodel.cpp index 6408342bc..ca5e74cff 100644 --- a/qt-models/cylindermodel.cpp +++ b/qt-models/cylindermodel.cpp @@ -581,6 +581,27 @@ void CylindersModel::remove(const QModelIndex &index) dataChanged(index, index); } +void CylindersModel::moveAtFirst(int cylid) +{ + int mapping[MAX_CYLINDERS]; + cylinder_t temp_cyl; + + beginMoveRows(QModelIndex(), cylid, cylid, QModelIndex(), 0); + memmove(&temp_cyl, &displayed_dive.cylinder[cylid], sizeof(temp_cyl)); + for (int i = cylid - 1; i >= 0; i--) { + memmove(&displayed_dive.cylinder[i + 1], &displayed_dive.cylinder[i], sizeof(temp_cyl)); + mapping[i] = i + 1; + } + memmove(&displayed_dive.cylinder[0], &temp_cyl, sizeof(temp_cyl)); + mapping[cylid] = 0; + for (int i = cylid + 1; i < MAX_CYLINDERS; i++) + mapping[i] = i; + changed = true; + endMoveRows(); + cylinder_renumber(&displayed_dive, mapping); + DivePlannerPointsModel::instance()->cylinderRenumber(mapping); +} + void CylindersModel::updateDecoDepths(pressure_t olddecopo2) { pressure_t decopo2; |