summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Stefan Fuchs <sfuchs@gmx.de>2017-03-31 08:14:36 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-04-06 18:29:11 -0700
commitc9c9b1b39951500829febd49adf9ead0d9426b59 (patch)
treeaaca1a3969bd94f427ab97c262d76b58c831ae66
parent385816be2ee120850415ae79a2187bf0cdbce593 (diff)
downloadsubsurface-c9c9b1b39951500829febd49adf9ead0d9426b59.tar.gz
Add creation date and Subsurface version to planner output
Signed-off-by: Stefan Fuchs <sfuchs@gmx.de>
-rw-r--r--core/planner.c9
-rw-r--r--core/qthelper.cpp10
-rw-r--r--core/qthelper.h1
3 files changed, 19 insertions, 1 deletions
diff --git a/core/planner.c b/core/planner.c
index 614634f20..fdda64940 100644
--- a/core/planner.c
+++ b/core/planner.c
@@ -15,6 +15,7 @@
#include "gettext.h"
#include "libdivecomputer/parser.h"
#include "qthelperfromc.h"
+#include "version.h"
#define TIMESTEP 2 /* second */
#define DECOTIMESTEP 60 /* seconds. Unit of deco stop times */
@@ -67,6 +68,9 @@ void dump_plan(struct diveplan *diveplan)
}
#endif
+/* this is in qthelper.cpp, so including the .h file is a pain */
+extern const char *get_current_date();
+
bool diveplan_empty(struct diveplan *diveplan)
{
struct divedatapoint *dp;
@@ -837,11 +841,14 @@ static void add_plan_to_notes(struct diveplan *diveplan, struct dive *dive, bool
const char *depth_unit;
int altitude = (int) get_depth_units((int) (log(1013.0 / diveplan->surface_pressure) * 7800000), NULL, &depth_unit);
- len += snprintf(buffer + len, sz_buffer - len, translate("gettextFromC", "ATM pressure: %dmbar (%d%s)<br></div>"),
+ len += snprintf(buffer + len, sz_buffer - len, translate("gettextFromC", "ATM pressure: %dmbar (%d%s)<br>"),
diveplan->surface_pressure,
altitude,
depth_unit);
+ len += snprintf(buffer + len, sz_buffer - len, translate("gettextFromC", "Plan creation date and version: %s, %s<br></div>"),
+ get_current_date(), subsurface_canonical_version());
+
/* Get SAC values and units for printing it in gas consumption */
double bottomsacvalue, decosacvalue;
int sacdecimals;
diff --git a/core/qthelper.cpp b/core/qthelper.cpp
index 943ad00b6..126792d52 100644
--- a/core/qthelper.cpp
+++ b/core/qthelper.cpp
@@ -959,6 +959,16 @@ const char *get_dive_date_c_string(timestamp_t when)
return strdup(text.toUtf8().data());
}
+extern "C" const char *get_current_date()
+{
+ QDateTime ts(QDateTime::currentDateTime());;
+ QString current_date;
+
+ current_date = loc.toString(ts, QString(prefs.date_format_short));
+
+ return strdup(current_date.toUtf8().data());
+}
+
bool is_same_day(timestamp_t trip_when, timestamp_t dive_when)
{
static timestamp_t twhen = (timestamp_t) 0;
diff --git a/core/qthelper.h b/core/qthelper.h
index 24215d43f..bc1268456 100644
--- a/core/qthelper.h
+++ b/core/qthelper.h
@@ -16,6 +16,7 @@ QString weight_string(int weight_in_grams);
QString distance_string(int distanceInMeters);
bool gpsHasChanged(struct dive *dive, struct dive *master, const QString &gps_text, bool *parsed_out = 0);
extern "C" const char *printGPSCoords(int lat, int lon);
+extern "C" const char *get_current_date();
QList<int> getDivesInTrip(dive_trip_t *trip);
QString get_gas_string(struct gasmix gas);
QString get_divepoint_gas_string(struct dive *d, const divedatapoint& dp);