2017-04-27 18:24:53 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2016-01-07 18:01:24 +00:00
|
|
|
#include "DiveObjectHelper.h"
|
|
|
|
|
|
|
|
#include <QDateTime>
|
|
|
|
#include <QTextDocument>
|
|
|
|
|
2018-05-11 15:25:41 +00:00
|
|
|
#include "core/qthelper.h"
|
|
|
|
#include "core/subsurface-string.h"
|
|
|
|
#include "qt-models/tankinfomodel.h"
|
2016-01-07 18:01:24 +00:00
|
|
|
|
2016-04-15 11:44:12 +00:00
|
|
|
static QString EMPTY_DIVE_STRING = QStringLiteral("");
|
2016-02-09 16:19:06 +00:00
|
|
|
enum returnPressureSelector {START_PRESSURE, END_PRESSURE};
|
2016-01-07 18:01:24 +00:00
|
|
|
|
|
|
|
static QString getFormattedWeight(struct dive *dive, unsigned int idx)
|
|
|
|
{
|
2016-01-11 14:14:45 +00:00
|
|
|
weightsystem_t *weight = &dive->weightsystem[idx];
|
|
|
|
if (!weight->description)
|
|
|
|
return QString(EMPTY_DIVE_STRING);
|
|
|
|
QString fmt = QString(weight->description);
|
|
|
|
fmt += ", " + get_weight_string(weight->weight, true);
|
|
|
|
return fmt;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static QString getFormattedCylinder(struct dive *dive, unsigned int idx)
|
|
|
|
{
|
2016-01-11 14:14:45 +00:00
|
|
|
cylinder_t *cyl = &dive->cylinder[idx];
|
|
|
|
const char *desc = cyl->type.description;
|
|
|
|
if (!desc && idx > 0)
|
|
|
|
return QString(EMPTY_DIVE_STRING);
|
2018-07-03 14:52:20 +00:00
|
|
|
QString fmt = desc ? QString(desc) : gettextFromC::tr("unknown");
|
Don't use "get_volume_string()" for cylinder size string
We had two totally different usage cases for "get_volume_string()": one
that did the obvious "show this volume as a string", and one that tried
to show a cylinder size.
The function used a magic third argument (the working pressure of the
cylinder) to distinguish between the two cases, but it still got it
wrong.
A metric cylinder doesn't necessarily have a working pressure at all,
and the size is a wet size in liters. We'd pass in zero as the working
pressure, and if the volume units were set to cubic feet, the logic in
"get_volume_string()" would happily convert the metric wet size into the
wet size in cubic feet.
But that's completely wrong. An imperial cylinder size simply isn't a
wet size. If you don't have a working pressure, you cannot convert the
cylinder size to cubic feet. End of story.
So instead of having "get_volume_string()" have magical behavior
depending on working pressure, and getting it wrong anyway, just make
get_volume_string do a pure volume conversion, and create a whole new
function for showing the size of a cylinder.
Now, if the cylinder doesn't have a working pressure, we just show the
metric size, even if the user had asked for cubic feet.
[Dirk Hohndel: added call to translation functions for the units]
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
2016-02-24 22:42:56 +00:00
|
|
|
fmt += ", " + get_volume_string(cyl->type.size, true);
|
2016-01-11 14:14:45 +00:00
|
|
|
fmt += ", " + get_pressure_string(cyl->type.workingpressure, true);
|
|
|
|
fmt += ", " + get_pressure_string(cyl->start, false) + " - " + get_pressure_string(cyl->end, true);
|
|
|
|
fmt += ", " + get_gas_string(cyl->gasmix);
|
|
|
|
return fmt;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2018-07-17 09:49:42 +00:00
|
|
|
static QString getPressures(struct dive *dive, int i, enum returnPressureSelector ret)
|
2016-02-09 16:19:06 +00:00
|
|
|
{
|
2018-07-17 09:49:42 +00:00
|
|
|
cylinder_t *cyl = &dive->cylinder[i];
|
2016-02-09 16:19:06 +00:00
|
|
|
QString fmt;
|
2016-03-03 21:16:12 +00:00
|
|
|
if (ret == START_PRESSURE) {
|
2016-02-14 15:33:18 +00:00
|
|
|
if (cyl->start.mbar)
|
|
|
|
fmt = get_pressure_string(cyl->start, true);
|
|
|
|
else if (cyl->sample_start.mbar)
|
|
|
|
fmt = get_pressure_string(cyl->sample_start, true);
|
2016-03-03 21:16:12 +00:00
|
|
|
}
|
|
|
|
if (ret == END_PRESSURE) {
|
2016-02-14 15:33:18 +00:00
|
|
|
if (cyl->end.mbar)
|
|
|
|
fmt = get_pressure_string(cyl->end, true);
|
|
|
|
else if(cyl->sample_end.mbar)
|
|
|
|
fmt = get_pressure_string(cyl->sample_end, true);
|
2016-03-03 21:16:12 +00:00
|
|
|
}
|
2016-02-09 16:19:06 +00:00
|
|
|
return fmt;
|
|
|
|
}
|
|
|
|
|
2016-01-11 17:02:13 +00:00
|
|
|
DiveObjectHelper::DiveObjectHelper(struct dive *d) :
|
2016-01-07 18:01:24 +00:00
|
|
|
m_dive(d)
|
|
|
|
{
|
2016-07-31 21:27:07 +00:00
|
|
|
m_cyls.clear();
|
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
|
|
|
//Don't add blank cylinders, only those that have been defined.
|
|
|
|
if (m_dive->cylinder[i].type.description)
|
|
|
|
m_cyls.append(new CylinderObjectHelper(&m_dive->cylinder[i]));
|
|
|
|
}
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
DiveObjectHelper::~DiveObjectHelper()
|
|
|
|
{
|
2016-07-31 21:27:07 +00:00
|
|
|
while (!m_cyls.isEmpty())
|
2016-09-04 17:27:56 +00:00
|
|
|
delete m_cyls.takeFirst();
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int DiveObjectHelper::number() const
|
|
|
|
{
|
2016-01-11 17:02:13 +00:00
|
|
|
return m_dive->number;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int DiveObjectHelper::id() const
|
|
|
|
{
|
2016-01-11 17:04:21 +00:00
|
|
|
return m_dive->id;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2018-10-24 20:14:33 +00:00
|
|
|
struct dive *DiveObjectHelper::getDive() const
|
|
|
|
{
|
|
|
|
return m_dive;
|
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QString DiveObjectHelper::date() const
|
|
|
|
{
|
2016-04-28 23:31:37 +00:00
|
|
|
QDateTime localTime = QDateTime::fromMSecsSinceEpoch(1000*m_dive->when, Qt::UTC);
|
2016-01-11 18:40:10 +00:00
|
|
|
localTime.setTimeSpec(Qt::UTC);
|
2017-06-19 00:48:04 +00:00
|
|
|
return localTime.date().toString(prefs.date_format_short);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
timestamp_t DiveObjectHelper::timestamp() const
|
|
|
|
{
|
2016-01-11 17:34:53 +00:00
|
|
|
return m_dive->when;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::time() const
|
|
|
|
{
|
2016-04-28 23:31:37 +00:00
|
|
|
QDateTime localTime = QDateTime::fromMSecsSinceEpoch(1000*m_dive->when, Qt::UTC);
|
2016-01-11 18:40:10 +00:00
|
|
|
localTime.setTimeSpec(Qt::UTC);
|
|
|
|
return localTime.time().toString(prefs.time_format);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::location() const
|
|
|
|
{
|
2016-01-11 17:35:21 +00:00
|
|
|
return get_dive_location(m_dive) ? QString::fromUtf8(get_dive_location(m_dive)) : EMPTY_DIVE_STRING;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::gps() const
|
|
|
|
{
|
2018-10-26 15:03:54 +00:00
|
|
|
struct dive_site *ds = m_dive->dive_site;
|
2018-10-20 18:12:15 +00:00
|
|
|
return ds ? QString(printGPSCoords(&ds->location)) : QString();
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
2017-03-21 16:52:29 +00:00
|
|
|
|
|
|
|
QString DiveObjectHelper::gps_decimal() const
|
|
|
|
{
|
|
|
|
bool savep = prefs.coordinates_traditional;
|
|
|
|
QString val;
|
|
|
|
|
|
|
|
prefs.coordinates_traditional = false;
|
|
|
|
val = gps();
|
|
|
|
prefs.coordinates_traditional = savep;
|
2018-02-17 20:21:16 +00:00
|
|
|
return val;
|
2017-03-21 16:52:29 +00:00
|
|
|
}
|
|
|
|
|
2018-10-25 18:46:12 +00:00
|
|
|
QVariant DiveObjectHelper::dive_site() const
|
2018-03-08 19:18:31 +00:00
|
|
|
{
|
2018-10-28 21:19:17 +00:00
|
|
|
return QVariant::fromValue(m_dive->dive_site);
|
2018-03-08 19:18:31 +00:00
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QString DiveObjectHelper::duration() const
|
|
|
|
{
|
2018-07-03 14:52:20 +00:00
|
|
|
return get_dive_duration_string(m_dive->duration.seconds, gettextFromC::tr("h"), gettextFromC::tr("min"));
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-02-15 00:26:37 +00:00
|
|
|
bool DiveObjectHelper::noDive() const
|
|
|
|
{
|
|
|
|
return m_dive->duration.seconds == 0 && m_dive->dc.duration.seconds == 0;
|
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QString DiveObjectHelper::depth() const
|
|
|
|
{
|
2016-01-11 17:36:12 +00:00
|
|
|
return get_depth_string(m_dive->dc.maxdepth.mm, true, true);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::divemaster() const
|
|
|
|
{
|
2016-01-11 17:39:04 +00:00
|
|
|
return m_dive->divemaster ? m_dive->divemaster : EMPTY_DIVE_STRING;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::buddy() const
|
|
|
|
{
|
2016-01-11 17:40:10 +00:00
|
|
|
return m_dive->buddy ? m_dive->buddy : EMPTY_DIVE_STRING;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::airTemp() const
|
|
|
|
{
|
2016-01-11 17:40:10 +00:00
|
|
|
QString temp = get_temperature_string(m_dive->airtemp, true);
|
|
|
|
if (temp.isEmpty()) {
|
|
|
|
temp = EMPTY_DIVE_STRING;
|
|
|
|
}
|
|
|
|
return temp;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::waterTemp() const
|
|
|
|
{
|
2016-01-11 17:46:30 +00:00
|
|
|
QString temp = get_temperature_string(m_dive->watertemp, true);
|
|
|
|
if (temp.isEmpty()) {
|
|
|
|
temp = EMPTY_DIVE_STRING;
|
|
|
|
}
|
|
|
|
return temp;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::notes() const
|
|
|
|
{
|
2016-01-11 18:04:46 +00:00
|
|
|
QString tmp = m_dive->notes ? QString::fromUtf8(m_dive->notes) : EMPTY_DIVE_STRING;
|
|
|
|
if (same_string(m_dive->dc.model, "planned dive")) {
|
|
|
|
QTextDocument notes;
|
|
|
|
#define _NOTES_BR "\n"
|
|
|
|
tmp.replace("<thead>", "<thead>" _NOTES_BR)
|
|
|
|
.replace("<br>", "<br>" _NOTES_BR)
|
|
|
|
.replace("<tr>", "<tr>" _NOTES_BR)
|
|
|
|
.replace("</tr>", "</tr>" _NOTES_BR);
|
|
|
|
notes.setHtml(tmp);
|
|
|
|
tmp = notes.toPlainText();
|
|
|
|
tmp.replace(_NOTES_BR, "<br>");
|
|
|
|
#undef _NOTES_BR
|
|
|
|
} else {
|
|
|
|
tmp.replace("\n", "<br>");
|
|
|
|
}
|
|
|
|
return tmp;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::tags() const
|
|
|
|
{
|
2018-04-09 08:09:34 +00:00
|
|
|
return get_taglist_string(m_dive->tag_list);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::gas() const
|
|
|
|
{
|
2016-01-11 18:37:10 +00:00
|
|
|
/*WARNING: here should be the gastlist, returned
|
|
|
|
* from the get_gas_string function or this is correct?
|
|
|
|
*/
|
|
|
|
QString gas, gases;
|
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
2017-02-03 15:31:03 +00:00
|
|
|
if (!is_cylinder_used(m_dive, i))
|
2016-01-11 18:37:10 +00:00
|
|
|
continue;
|
|
|
|
gas = m_dive->cylinder[i].type.description;
|
|
|
|
if (!gas.isEmpty())
|
|
|
|
gas += QChar(' ');
|
2018-08-16 17:10:10 +00:00
|
|
|
gas += gasname(m_dive->cylinder[i].gasmix);
|
2016-01-11 18:37:10 +00:00
|
|
|
// if has a description and if such gas is not already present
|
|
|
|
if (!gas.isEmpty() && gases.indexOf(gas) == -1) {
|
|
|
|
if (!gases.isEmpty())
|
|
|
|
gases += QString(" / ");
|
|
|
|
gases += gas;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return gases;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::sac() const
|
|
|
|
{
|
2016-01-11 18:16:48 +00:00
|
|
|
if (!m_dive->sac)
|
|
|
|
return QString();
|
|
|
|
const char *unit;
|
|
|
|
int decimal;
|
|
|
|
double value = get_volume_units(m_dive->sac, &decimal, &unit);
|
2016-01-21 20:41:40 +00:00
|
|
|
return QString::number(value, 'f', decimal).append(unit);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-02-29 14:42:07 +00:00
|
|
|
QString DiveObjectHelper::weightList() const
|
|
|
|
{
|
|
|
|
QString weights;
|
|
|
|
for (int i = 0; i < MAX_WEIGHTSYSTEMS; i++) {
|
|
|
|
QString w = getFormattedWeight(m_dive, i);
|
|
|
|
if (w == EMPTY_DIVE_STRING)
|
|
|
|
continue;
|
|
|
|
weights += w + "; ";
|
|
|
|
}
|
|
|
|
return weights;
|
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QStringList DiveObjectHelper::weights() const
|
|
|
|
{
|
2016-01-11 18:48:46 +00:00
|
|
|
QStringList weights;
|
2016-07-19 05:55:21 +00:00
|
|
|
for (int i = 0; i < MAX_WEIGHTSYSTEMS; i++) {
|
|
|
|
QString w = getFormattedWeight(m_dive, i);
|
|
|
|
if (w == EMPTY_DIVE_STRING)
|
|
|
|
continue;
|
|
|
|
weights << w;
|
|
|
|
}
|
2016-01-11 18:48:46 +00:00
|
|
|
return weights;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-02-06 06:53:12 +00:00
|
|
|
bool DiveObjectHelper::singleWeight() const
|
|
|
|
{
|
|
|
|
return weightsystem_none(&m_dive->weightsystem[1]);
|
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QString DiveObjectHelper::weight(int idx) const
|
|
|
|
{
|
2016-01-11 18:48:46 +00:00
|
|
|
if ( (idx < 0) || idx > MAX_WEIGHTSYSTEMS )
|
2016-01-07 18:01:24 +00:00
|
|
|
return QString(EMPTY_DIVE_STRING);
|
2016-01-11 18:48:46 +00:00
|
|
|
return getFormattedWeight(m_dive, idx);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::suit() const
|
|
|
|
{
|
2016-01-11 17:49:06 +00:00
|
|
|
return m_dive->suit ? m_dive->suit : EMPTY_DIVE_STRING;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-08-30 14:24:19 +00:00
|
|
|
QStringList DiveObjectHelper::cylinderList() const
|
2016-02-29 14:42:07 +00:00
|
|
|
{
|
2016-08-30 14:24:19 +00:00
|
|
|
QStringList cylinders;
|
|
|
|
struct dive *d;
|
|
|
|
int i = 0;
|
|
|
|
for_each_dive (i, d) {
|
|
|
|
for (int j = 0; j < MAX_CYLINDERS; j++) {
|
|
|
|
QString cyl = d->cylinder[j].type.description;
|
|
|
|
if (cyl == EMPTY_DIVE_STRING)
|
|
|
|
continue;
|
|
|
|
cylinders << cyl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-27 00:05:26 +00:00
|
|
|
for (unsigned long ti = 0; ti < MAX_TANK_INFO && tank_info[ti].name != NULL; ti++) {
|
2016-09-04 17:27:56 +00:00
|
|
|
QString cyl = tank_info[ti].name;
|
2016-02-29 14:42:07 +00:00
|
|
|
if (cyl == EMPTY_DIVE_STRING)
|
|
|
|
continue;
|
2016-08-30 14:24:19 +00:00
|
|
|
cylinders << cyl;
|
2016-02-29 14:42:07 +00:00
|
|
|
}
|
2016-08-30 14:24:19 +00:00
|
|
|
|
|
|
|
cylinders.removeDuplicates();
|
|
|
|
cylinders.sort();
|
2016-02-29 14:42:07 +00:00
|
|
|
return cylinders;
|
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QStringList DiveObjectHelper::cylinders() const
|
|
|
|
{
|
2016-01-11 18:48:46 +00:00
|
|
|
QStringList cylinders;
|
2016-07-18 23:06:10 +00:00
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
|
|
|
QString cyl = getFormattedCylinder(m_dive, i);
|
|
|
|
if (cyl == EMPTY_DIVE_STRING)
|
|
|
|
continue;
|
|
|
|
cylinders << cyl;
|
|
|
|
}
|
2016-01-11 18:48:46 +00:00
|
|
|
return cylinders;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::cylinder(int idx) const
|
|
|
|
{
|
2016-01-11 18:48:46 +00:00
|
|
|
if ( (idx < 0) || idx > MAX_CYLINDERS)
|
2016-01-07 18:01:24 +00:00
|
|
|
return QString(EMPTY_DIVE_STRING);
|
2016-01-11 18:48:46 +00:00
|
|
|
return getFormattedCylinder(m_dive, idx);
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-07-31 21:27:07 +00:00
|
|
|
QList<CylinderObjectHelper*> DiveObjectHelper::cylinderObjects() const
|
|
|
|
{
|
|
|
|
return m_cyls;
|
|
|
|
}
|
|
|
|
|
2016-01-07 18:01:24 +00:00
|
|
|
QString DiveObjectHelper::trip() const
|
|
|
|
{
|
2016-01-11 17:49:06 +00:00
|
|
|
return m_dive->divetrip ? m_dive->divetrip->location : EMPTY_DIVE_STRING;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-04-05 19:27:51 +00:00
|
|
|
// combine the pointer address with the trip title so that
|
|
|
|
// we detect multiple, destinct trips with the same title
|
|
|
|
// the trip title is designed to be
|
|
|
|
// location (# dives)
|
|
|
|
// or, if there is no location name
|
|
|
|
// date range (# dives)
|
|
|
|
// where the date range is given as "month year" or "month-month year" or "month year - month year"
|
2016-01-27 04:06:30 +00:00
|
|
|
QString DiveObjectHelper::tripMeta() const
|
|
|
|
{
|
|
|
|
QString ret = EMPTY_DIVE_STRING;
|
2016-04-05 19:27:51 +00:00
|
|
|
struct dive_trip *dt = m_dive->divetrip;
|
|
|
|
if (dt) {
|
2018-10-24 20:18:31 +00:00
|
|
|
QString numDives = tr("(%n dive(s))", "", dt->showndives);
|
2016-04-05 19:27:51 +00:00
|
|
|
QString title(dt->location);
|
2018-11-11 12:09:51 +00:00
|
|
|
QDateTime firstTime = QDateTime::fromMSecsSinceEpoch(1000*trip_date(dt), Qt::UTC);
|
2017-06-24 20:13:04 +00:00
|
|
|
QString firstMonth = firstTime.toString("MMM");
|
|
|
|
QString tripDate = QStringLiteral("%1@%2").arg(firstMonth,firstTime.toString("yy"));
|
2018-11-07 22:30:14 +00:00
|
|
|
|
2016-04-05 19:27:51 +00:00
|
|
|
if (title.isEmpty()) {
|
|
|
|
// so use the date range
|
2016-04-28 23:31:37 +00:00
|
|
|
QString firstYear = firstTime.toString("yyyy");
|
2018-11-08 15:58:33 +00:00
|
|
|
QDateTime lastTime = QDateTime::fromMSecsSinceEpoch(1000*dt->dives.dives[0]->when, Qt::UTC);
|
2016-04-28 23:31:37 +00:00
|
|
|
QString lastMonth = lastTime.toString("MMM");
|
|
|
|
QString lastYear = lastTime.toString("yyyy");
|
2016-04-05 19:27:51 +00:00
|
|
|
if (lastMonth == firstMonth && lastYear == firstYear)
|
|
|
|
title = firstMonth + " " + firstYear;
|
|
|
|
else if (lastMonth != firstMonth && lastYear == firstYear)
|
|
|
|
title = firstMonth + "-" + lastMonth + " " + firstYear;
|
|
|
|
else
|
|
|
|
title = firstMonth + " " + firstYear + " - " + lastMonth + " " + lastYear;
|
|
|
|
}
|
2017-06-24 20:13:04 +00:00
|
|
|
ret = QString::number((quint64)m_dive->divetrip, 16) + QLatin1Literal("++") + tripDate + QLatin1Literal("::") + QStringLiteral("%1 %2").arg(title, numDives);
|
2016-04-05 19:27:51 +00:00
|
|
|
}
|
2016-01-27 04:06:30 +00:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2018-04-15 00:34:33 +00:00
|
|
|
int DiveObjectHelper::tripNrDives() const
|
|
|
|
{
|
|
|
|
struct dive_trip *dt = m_dive->divetrip;
|
2018-11-08 15:58:33 +00:00
|
|
|
return dt ? dt->dives.nr : 0;
|
2018-04-15 00:34:33 +00:00
|
|
|
}
|
|
|
|
|
2016-07-18 22:08:27 +00:00
|
|
|
int DiveObjectHelper::maxcns() const
|
2016-01-07 18:01:24 +00:00
|
|
|
{
|
2016-07-18 22:08:27 +00:00
|
|
|
return m_dive->maxcns;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
2016-07-18 22:08:27 +00:00
|
|
|
int DiveObjectHelper::otu() const
|
2016-01-07 18:01:24 +00:00
|
|
|
{
|
2016-07-18 22:08:27 +00:00
|
|
|
return m_dive->otu;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int DiveObjectHelper::rating() const
|
|
|
|
{
|
2016-01-11 17:05:07 +00:00
|
|
|
return m_dive->rating;
|
2016-01-07 18:01:24 +00:00
|
|
|
}
|
2016-01-27 17:34:34 +00:00
|
|
|
|
2016-07-16 08:59:05 +00:00
|
|
|
int DiveObjectHelper::visibility() const
|
|
|
|
{
|
|
|
|
return m_dive->visibility;
|
|
|
|
}
|
|
|
|
|
2016-01-27 17:34:34 +00:00
|
|
|
QString DiveObjectHelper::sumWeight() const
|
|
|
|
{
|
2016-02-06 06:52:30 +00:00
|
|
|
weight_t sum = { 0 };
|
2016-01-27 17:34:34 +00:00
|
|
|
for (int i = 0; i < MAX_WEIGHTSYSTEMS; i++){
|
2016-02-06 06:52:30 +00:00
|
|
|
sum.grams += m_dive->weightsystem[i].weight.grams;
|
2016-01-27 17:34:34 +00:00
|
|
|
}
|
2016-02-06 06:52:30 +00:00
|
|
|
return get_weight_string(sum, true);
|
2016-01-27 17:34:34 +00:00
|
|
|
}
|
|
|
|
|
2018-07-12 09:57:21 +00:00
|
|
|
QStringList DiveObjectHelper::getCylinder() const
|
2016-01-27 17:34:34 +00:00
|
|
|
{
|
2018-07-12 09:57:21 +00:00
|
|
|
QStringList getCylinder;
|
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
|
|
|
if (is_cylinder_used(m_dive, i))
|
|
|
|
getCylinder << m_dive->cylinder[i].type.description;
|
|
|
|
}
|
2016-01-27 17:34:34 +00:00
|
|
|
return getCylinder;
|
|
|
|
}
|
2016-02-09 16:19:06 +00:00
|
|
|
|
2018-07-17 09:49:42 +00:00
|
|
|
QStringList DiveObjectHelper::startPressure() const
|
2016-02-09 16:19:06 +00:00
|
|
|
{
|
2018-07-17 09:49:42 +00:00
|
|
|
QStringList startPressure;
|
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
|
|
|
if (is_cylinder_used(m_dive, i))
|
|
|
|
startPressure << getPressures(m_dive, i, START_PRESSURE);
|
|
|
|
}
|
2016-02-09 16:19:06 +00:00
|
|
|
return startPressure;
|
|
|
|
}
|
|
|
|
|
2018-07-17 09:49:42 +00:00
|
|
|
QStringList DiveObjectHelper::endPressure() const
|
2016-02-09 16:19:06 +00:00
|
|
|
{
|
2018-07-17 09:49:42 +00:00
|
|
|
QStringList endPressure;
|
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
|
|
|
if (is_cylinder_used(m_dive, i))
|
|
|
|
endPressure << getPressures(m_dive, i, END_PRESSURE);
|
|
|
|
}
|
2016-02-09 16:19:06 +00:00
|
|
|
return endPressure;
|
|
|
|
}
|
2016-02-13 17:34:29 +00:00
|
|
|
|
2018-07-16 16:25:21 +00:00
|
|
|
QStringList DiveObjectHelper::firstGas() const
|
2016-02-13 17:34:29 +00:00
|
|
|
{
|
2018-07-16 16:25:21 +00:00
|
|
|
QStringList gas;
|
|
|
|
for (int i = 0; i < MAX_CYLINDERS; i++) {
|
|
|
|
if (is_cylinder_used(m_dive, i))
|
|
|
|
gas << get_gas_string(m_dive->cylinder[i].gasmix);
|
|
|
|
}
|
2016-02-13 17:34:29 +00:00
|
|
|
return gas;
|
|
|
|
}
|
2018-10-16 11:56:41 +00:00
|
|
|
|
|
|
|
// for a full text search / filter function
|
|
|
|
QString DiveObjectHelper::fullText() const
|
|
|
|
{
|
2018-10-20 01:15:56 +00:00
|
|
|
return fullTextNoNotes() + ":-:" + notes();
|
|
|
|
}
|
|
|
|
|
|
|
|
QString DiveObjectHelper::fullTextNoNotes() const
|
|
|
|
{
|
|
|
|
return trip() + ":-:" + location() + ":-:" + buddy() + ":-:" + divemaster() + ":-:" + suit() + ":-:" + tags();
|
2018-10-16 11:56:41 +00:00
|
|
|
}
|