diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-12-14 23:21:58 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-12-17 13:03:56 -0800 |
commit | d9942269a9b61bc35bd939b23858a7cb4a2515c3 (patch) | |
tree | 92a60687efdfbd89df1aa29d7a105487c3db16d3 /desktop-widgets/templatelayout.cpp | |
parent | bf8261c0014253634eaddf7c0a9cf79d3a8b4123 (diff) | |
download | subsurface-d9942269a9b61bc35bd939b23858a7cb4a2515c3.tar.gz |
printing: remove DiveObjectHelperGrantlee
This was a weird helper object, needed for grantlee. Instead
of storing this object, loop over cylinders and dives directly.
The actual accessor function is unchanged and now generates
a DiveObjectHelper or DiveCylinderHelper for every variable
access. Obviously, this is very inefficient. However, this
will be replaced in future commits by direct calls to formatting
functions.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'desktop-widgets/templatelayout.cpp')
-rw-r--r-- | desktop-widgets/templatelayout.cpp | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/desktop-widgets/templatelayout.cpp b/desktop-widgets/templatelayout.cpp index b7da29294..db095081a 100644 --- a/desktop-widgets/templatelayout.cpp +++ b/desktop-widgets/templatelayout.cpp @@ -9,6 +9,7 @@ #include "core/divelist.h" #include "core/selection.h" #include "core/qthelper.h" +#include "core/string-format.h" #include "core/subsurface-qt/diveobjecthelper.h" #include "core/subsurface-qt/cylinderobjecthelper.h" // TODO: remove once grantlee supports Q_GADGET objects @@ -115,7 +116,7 @@ QString TemplateLayout::generate() struct dive *dive; if (in_planner()) { - state.dives.append(DiveObjectHelperGrantlee(&displayed_dive)); + state.dives.append(&displayed_dive); emit progressUpdated(100.0); } else { int i; @@ -123,7 +124,7 @@ QString TemplateLayout::generate() //TODO check for exporting selected dives only if (!dive->selected && printOptions.print_selected) continue; - state.dives.append(DiveObjectHelperGrantlee(dive)); + state.dives.append(dive); progress++; emit progressUpdated(lrint(progress * 100.0 / totalWork)); } @@ -320,6 +321,15 @@ static int findEnd(const QList<token> &tokenList, int from, int to, token_t star return -1; } +static std::vector<const cylinder_t *> cylinderList(const dive *d) +{ + std::vector<const cylinder_t *> res; + res.reserve(d->cylinders.nr); + for (int i = 0; i < d->cylinders.nr; ++i) + res.push_back(&d->cylinders.cylinders[i]); + return res; +} + void TemplateLayout::parser(QList<token> tokenList, int from, int to, QTextStream &out, State &state) { for (int pos = from; pos < to; ++pos) { @@ -352,12 +362,12 @@ void TemplateLayout::parser(QList<token> tokenList, int from, int to, QTextStrea parser_for(tokenList, pos, loop_end, capture, state, state.dives, state.currentDive); } else if (listname == "cylinders") { if (state.currentDive) - parser_for(tokenList, pos, loop_end, capture, state, state.currentDive->cylinders, state.currentCylinder); + parser_for(tokenList, pos, loop_end, capture, state, formatCylinders(*state.currentDive), state.currentCylinder); else qWarning("cylinders loop outside of dive"); } else if (listname == "cylinderObjects") { if (state.currentDive) - parser_for(tokenList, pos, loop_end, capture, state, state.currentDive->cylinderObjects, state.currentCylinderObject); + parser_for(tokenList, pos, loop_end, capture, state, cylinderList(*state.currentDive), state.currentCylinderObject); else qWarning("cylinderObjects loop outside of dive"); } else { @@ -490,7 +500,7 @@ QVariant TemplateLayout::getValue(QString list, QString property, const State &s } else if (list == "cylinderObjects") { if (!state.currentCylinderObject) return QVariant(); - const CylinderObjectHelper &object = *state.currentCylinderObject; + const CylinderObjectHelper object(*state.currentCylinderObject); if (property == "description") { return object.description; } else if (property == "size") { @@ -507,7 +517,7 @@ QVariant TemplateLayout::getValue(QString list, QString property, const State &s } else if (list == "dives") { if (!state.currentDive) return QVariant(); - const DiveObjectHelperGrantlee &object = *state.currentDive; + const DiveObjectHelper object(*state.currentDive); if (property == "number") { return object.number; } else if (property == "id") { @@ -572,8 +582,6 @@ QVariant TemplateLayout::getValue(QString list, QString property, const State &s return object.cylinderList(); } else if (property == "cylinders") { return object.cylinders; - } else if (property == "cylinderObjects") { - return QVariant::fromValue(object.cylinderObjects); } else if (property == "maxcns") { return object.maxcns; } else if (property == "otu") { |