summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Miika Turkia <miika.turkia@gmail.com>2012-11-24 12:12:17 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2012-11-24 09:00:56 -0800
commit27f7e58493ca16266f32363f55fbe3d979348af0 (patch)
tree97cf42ba8bea28f80604a22defae92af0575bc93
parent2feaf1e815d6f3b39d338a8ba3970157e482bd37 (diff)
downloadsubsurface-27f7e58493ca16266f32363f55fbe3d979348af0.tar.gz
Improvements on JDiveLog import
If dive computer does not record the sample interval, but records time stamps on the samples, we use those. A couple of corner cases fixed that were noticed in new log samples. Also fixes when importing dives logged in imperial units. Signed-off-by: Miika Turkia <miika.turkia@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--xslt/jdivelog2subsurface.xslt142
1 files changed, 110 insertions, 32 deletions
diff --git a/xslt/jdivelog2subsurface.xslt b/xslt/jdivelog2subsurface.xslt
index 4e900f59b..42cbec01e 100644
--- a/xslt/jdivelog2subsurface.xslt
+++ b/xslt/jdivelog2subsurface.xslt
@@ -68,13 +68,19 @@
<suit>
<xsl:value-of select="Equipment/Suit"/>
</suit>
- <xsl:value-of select="Equipment/Suit"/>
</xsl:if>
<xsl:if test="Equipment/Weight != ''">
<weightsystem>
<xsl:attribute name="weight">
- <xsl:value-of select="Equipment/Weight"/>
+ <xsl:choose>
+ <xsl:when test="Equipment/Weight = 'none'">
+ <xsl:value-of select="0" />
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="Equipment/Weight"/>
+ </xsl:otherwise>
+ </xsl:choose>
</xsl:attribute>
</weightsystem>
</xsl:if>
@@ -178,10 +184,20 @@ Comment: <xsl:value-of select="Comment"/>
</xsl:choose>
</xsl:attribute>
<xsl:attribute name="time">
- <xsl:call-template name="timeConvert">
- <xsl:with-param name="timeSec" select="count(preceding-sibling::D) * $delta"/>
- <xsl:with-param name="units" select="'si'"/>
- </xsl:call-template>
+ <xsl:choose>
+ <xsl:when test="$delta != '0'">
+ <xsl:call-template name="timeConvert">
+ <xsl:with-param name="timeSec" select="count(preceding-sibling::D) * $delta"/>
+ <xsl:with-param name="units" select="'si'"/>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:call-template name="timeConvert">
+ <xsl:with-param name="timeSec" select="preceding-sibling::T[1]"/>
+ <xsl:with-param name="units" select="$units"/>
+ </xsl:call-template>
+ </xsl:otherwise>
+ </xsl:choose>
</xsl:attribute>
</event>
</xsl:if>
@@ -192,10 +208,29 @@ Comment: <xsl:value-of select="Comment"/>
<xsl:for-each select="DIVE/SAMPLES/SWITCH">
<event name="gaschange">
<xsl:attribute name="time">
- <xsl:call-template name="timeConvert">
- <xsl:with-param name="timeSec" select="count(preceding-sibling::D) * $delta"/>
- <xsl:with-param name="units" select="'si'"/>
- </xsl:call-template>
+ <xsl:choose>
+ <xsl:when test="$delta != '0'">
+ <xsl:call-template name="timeConvert">
+ <xsl:with-param name="timeSec" select="count(preceding-sibling::D) * $delta"/>
+ <xsl:with-param name="units" select="'si'"/>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:call-template name="timeConvert">
+ <xsl:with-param name="timeSec">
+ <xsl:choose>
+ <xsl:when test="preceding-sibling::T[1] != ''">
+ <xsl:value-of select="preceding-sibling::T[1]"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="'0'"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:with-param>
+ <xsl:with-param name="units" select="$units"/>
+ </xsl:call-template>
+ </xsl:otherwise>
+ </xsl:choose>
</xsl:attribute>
<xsl:attribute name="value">
<xsl:value-of select="ancestor::DIVE/GASES/MIX[MIXNAME=current()]/O2 * 100" />
@@ -205,20 +240,61 @@ Comment: <xsl:value-of select="Comment"/>
<!-- end gas change -->
<!-- dive sample - all the depth and temp readings -->
- <xsl:for-each select="DIVE/SAMPLES/D">
- <xsl:variable name="timeSec" select="(position() - 1) * $delta"/>
- <xsl:variable name="time" select="concat(floor($timeSec div 60), ':',
- format-number(floor($timeSec mod 60), '00'), ' min')"/>
- <xsl:choose>
- <xsl:when test="name(following-sibling::*[1]) = 'TEMPERATURE'">
- <sample time="{$time}" depth="{concat(., ' m')}"
- temp="{following-sibling::TEMPERATURE}"/>
- </xsl:when>
- <xsl:otherwise>
- <sample time="{$time}" depth="{concat(., ' m')}"/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:for-each>
+ <xsl:choose>
+ <xsl:when test="$delta != '0'">
+ <xsl:for-each select="DIVE/SAMPLES/D">
+ <xsl:variable name="timeSec" select="(position() - 1) * $delta"/>
+ <xsl:variable name="time" select="concat(floor($timeSec div 60), ':',
+ format-number(floor($timeSec mod 60), '00'), ' min')"/>
+ <xsl:choose>
+ <xsl:when test="name(following-sibling::*[1]) = 'TEMPERATURE'">
+ <sample time="{$time}" depth="{concat(., ' m')}">
+ <xsl:attribute name="temp">
+ <xsl:choose>
+ <xsl:when test="$units = 'si'">
+ <xsl:value-of select="concat(format-number(following-sibling::TEMPERATURE - 273.15, '00.0'), ' C')"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="concat(following-sibling::TEMPERATURE, ' C')"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </sample>
+ </xsl:when>
+ <xsl:otherwise>
+ <sample time="{$time}" depth="{concat(., ' m')}"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:for-each>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:for-each select="DIVE/SAMPLES/D">
+ <sample>
+ <xsl:attribute name="time">
+ <xsl:call-template name="timeConvert">
+ <xsl:with-param name="timeSec" select="preceding-sibling::T[1]"/>
+ <xsl:with-param name="units" select="$units"/>
+ </xsl:call-template>
+ </xsl:attribute>
+ <xsl:if test="name(following-sibling::*[1]) = 'TEMPERATURE'">
+ <xsl:attribute name="temp">
+ <xsl:choose>
+ <xsl:when test="$units = 'si'">
+ <xsl:value-of select="concat(format-number(following-sibling::TEMPERATURE - 273.15, '00.0'), ' C')"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="concat(following-sibling::TEMPERATURE, ' C')"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:if>
+ <xsl:attribute name="depth">
+ <xsl:value-of select="concat(., ' m')"/>
+ </xsl:attribute>
+ </sample>
+ </xsl:for-each>
+ </xsl:otherwise>
+ </xsl:choose>
<!-- dive sample -->
</dive>
@@ -266,14 +342,16 @@ Comment: <xsl:value-of select="Comment"/>
<xsl:param name="timeSec"/>
<xsl:param name="units"/>
- <xsl:choose>
- <xsl:when test="$units = 'si'">
- <xsl:value-of select="concat(floor(number($timeSec) div 60), ':', format-number(floor(number($timeSec) mod 60), '00'), ' min')"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:value-of select="concat(substring-before($timeSec, '.'), ':', format-number(substring-after($timeSec, '.'), '00'), ' min')"/>
- </xsl:otherwise>
- </xsl:choose>
+ <xsl:if test="$timeSec != ''">
+ <xsl:choose>
+ <xsl:when test="$units = 'si'">
+ <xsl:value-of select="concat(floor(number($timeSec) div 60), ':', format-number(floor(number($timeSec) mod 60), '00'), ' min')"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="concat(substring-before($timeSec, '.'), ':', format-number(substring-after($timeSec, '.'), '00'), ' min')"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:if>
</xsl:template>
<!-- end convert time -->