summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tcanabrava@kde.org>2013-08-26 17:02:34 -0300
committerGravatar Tomaz Canabrava <tcanabrava@kde.org>2013-08-26 17:02:34 -0300
commit3323fecea86fdf3434d54ebfb88ae37b9812f5c5 (patch)
tree92da59b316ac374b52495c2c44289b691bc0600b
parent760c14ac0cb225ac391b9b9e04a1e9d5f7b3aa3c (diff)
downloadsubsurface-3323fecea86fdf3434d54ebfb88ae37b9812f5c5.tar.gz
Made possible to add a divepoint between two others.
Made possible to add a divepoint between two others, this also implemented the last patch in the correct way. Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org>
-rw-r--r--qt-ui/diveplanner.cpp10
1 files changed, 8 insertions, 2 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
index 61f39bc31..4752a9f2b 100644
--- a/qt-ui/diveplanner.cpp
+++ b/qt-ui/diveplanner.cpp
@@ -956,13 +956,18 @@ void DivePlannerPointsModel::setStartTime(const QTime& t)
diveplan.when = t.msec();
}
+bool divePointsLessThan(const divedatapoint& p1, const divedatapoint& p2){
+ return p1.time <= p2.time;
+}
int DivePlannerPointsModel::addStop(int meters, int minutes, const QString& gas, int ccpoint)
{
int row = divepoints.count();
// check if there's already a new stop before this one:
- Q_FOREACH(const divedatapoint& dp, divepoints){
+ for(int i = 0; i < divepoints.count(); i++){
+ const divedatapoint& dp = divepoints.at(i);
if (dp.time > minutes ){
- return -1;
+ row = i;
+ break;
}
}
@@ -975,6 +980,7 @@ int DivePlannerPointsModel::addStop(int meters, int minutes, const QString& gas,
point.he = 0;
point.po2 = 0;
divepoints.append( point );
+ std::sort(divepoints.begin(), divepoints.end(), divePointsLessThan);
endInsertRows();
return row;
}