diff options
author | Gehad elrobey <gehadelrobey@gmail.com> | 2015-08-05 22:31:27 +0200 |
---|---|---|
committer | Lubomir I. Ivanov <neolit123@gmail.com> | 2015-08-15 15:02:20 +0300 |
commit | f05e9c5c79aa6be153759837cc67fdf3c9980021 (patch) | |
tree | 51b2c229e48a7cbc7ffe996e119ffc2ee57ba916 /templatelayout.cpp | |
parent | e2dcee55a38b86e48daad8a890ca2b4e6b122e37 (diff) | |
download | subsurface-f05e9c5c79aa6be153759837cc67fdf3c9980021.tar.gz |
Printing: export more dive details with Grantlee backend
Add SAC, tags, used gas and dive rating to dive data fields exported
with Grantlee backend.
Signed-off-by: Lubomir I. Ivanov <neolit123@gmail.com>
Signed-off-by: Gehad elrobey <gehadelrobey@gmail.com>
Diffstat (limited to 'templatelayout.cpp')
-rw-r--r-- | templatelayout.cpp | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/templatelayout.cpp b/templatelayout.cpp index 1da88249b..437a6aea6 100644 --- a/templatelayout.cpp +++ b/templatelayout.cpp @@ -188,6 +188,26 @@ QString Dive::notes() const return m_notes; } +QString Dive::tags() const +{ + return m_tags; +} + +QString Dive::gas() const +{ + return m_gas; +} + +QString Dive::sac() const +{ + return m_sac; +} + +int Dive::rating() const +{ + return m_rating; +} + void Dive::put_divemaster() { if (!dive->divemaster) @@ -237,3 +257,40 @@ void Dive::put_notes() { m_notes = QString::fromUtf8(dive->notes); } + +void Dive::put_tags() +{ + char buffer[256]; + taglist_get_tagstring(dive->tag_list, buffer, 256); + m_tags = QString(buffer); +} + +void Dive::put_gas() +{ + int added = 0; + QString gas, gases; + for (int i = 0; i < MAX_CYLINDERS; i++) { + if (!is_cylinder_used(dive, i)) + continue; + gas = dive->cylinder[i].type.description; + gas += QString(!gas.isEmpty() ? " " : "") + gasname(&dive->cylinder[i].gasmix); + // if has a description and if such gas is not already present + if (!gas.isEmpty() && gases.indexOf(gas) == -1) { + if (added > 0) + gases += QString(" / "); + gases += gas; + added++; + } + } + m_gas = gases; +} + +void Dive::put_sac() +{ + if (dive->sac) { + const char *unit; + int decimal; + double value = get_volume_units(dive->sac, &decimal, &unit); + m_sac = QString::number(value, 'f', decimal).append(unit); + } +} |