diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2020-10-25 18:14:23 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2020-10-25 13:59:52 -0700 |
commit | f728923c79873cf9a182e3b37e5c79e6ecc9fe8d (patch) | |
tree | 01d08f85f8f5e887866b4ffe7673afa2f912317f /core | |
parent | f9c3227975e02a576c039e55a2d775dd9d691e03 (diff) | |
download | subsurface-f728923c79873cf9a182e3b37e5c79e6ecc9fe8d.tar.gz |
cleanup: move interpolate inline function to its own header file
This is not really related to struct dive, so let's move it.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'core')
-rw-r--r-- | core/CMakeLists.txt | 1 | ||||
-rw-r--r-- | core/dive.c | 1 | ||||
-rw-r--r-- | core/dive.h | 11 | ||||
-rw-r--r-- | core/divelist.c | 1 | ||||
-rw-r--r-- | core/interpolate.h | 16 | ||||
-rw-r--r-- | core/planner.c | 1 | ||||
-rw-r--r-- | core/profile.c | 1 |
7 files changed, 21 insertions, 11 deletions
diff --git a/core/CMakeLists.txt b/core/CMakeLists.txt index 276185fff..1ed24019c 100644 --- a/core/CMakeLists.txt +++ b/core/CMakeLists.txt @@ -119,6 +119,7 @@ set(SUBSURFACE_CORE_LIB_SRCS import-shearwater.c import-suunto.c import-seac.c + interpolate.h libdivecomputer.c libdivecomputer.h liquivision.c diff --git a/core/dive.c b/core/dive.c index 1fe0d44f2..177c91990 100644 --- a/core/dive.c +++ b/core/dive.c @@ -15,6 +15,7 @@ #include "errorhelper.h" #include "event.h" #include "extradata.h" +#include "interpolate.h" #include "qthelper.h" #include "membuffer.h" #include "picture.h" diff --git a/core/dive.h b/core/dive.h index 0b0597477..3e30ff521 100644 --- a/core/dive.h +++ b/core/dive.h @@ -21,17 +21,6 @@ extern const char *cylinderuse_text[NUM_GAS_USE]; extern const char *divemode_text_ui[]; extern const char *divemode_text[]; -/* Linear interpolation between 'a' and 'b', when we are 'part'way into the 'whole' distance from a to b */ -static inline int interpolate(int a, int b, int part, int whole) -{ - /* It is doubtful that we actually need floating point for this, but whatever */ - if (whole) { - double x = (double)a * (whole - part) + (double)b * part; - return (int)lrint(x / whole); - } - return (a+b)/2; -} - struct dive_site; struct dive_site_table; struct dive_table; diff --git a/core/divelist.c b/core/divelist.c index 7cbb5535c..5d87ccbcb 100644 --- a/core/divelist.c +++ b/core/divelist.c @@ -10,6 +10,7 @@ #include "event.h" #include "filterpreset.h" #include "fulltext.h" +#include "interpolate.h" #include "planner.h" #include "qthelper.h" #include "gettext.h" diff --git a/core/interpolate.h b/core/interpolate.h new file mode 100644 index 000000000..acb213acd --- /dev/null +++ b/core/interpolate.h @@ -0,0 +1,16 @@ +// SPDX-License-Identifier: GPL-2.0 +#ifndef INTERPOLATE_H +#define INTERPOLATE_H + +/* Linear interpolation between 'a' and 'b', when we are 'part'way into the 'whole' distance from a to b */ +static inline int interpolate(int a, int b, int part, int whole) +{ + /* It is doubtful that we actually need floating point for this, but whatever */ + if (whole) { + double x = (double)a * (whole - part) + (double)b * part; + return (int)lrint(x / whole); + } + return (a+b)/2; +} + +#endif diff --git a/core/planner.c b/core/planner.c index bfadf4b7f..341fa6dad 100644 --- a/core/planner.c +++ b/core/planner.c @@ -17,6 +17,7 @@ #include "deco.h" #include "errorhelper.h" #include "event.h" +#include "interpolate.h" #include "planner.h" #include "subsurface-time.h" #include "gettext.h" diff --git a/core/profile.c b/core/profile.c index 05aae3b64..48be68309 100644 --- a/core/profile.c +++ b/core/profile.c @@ -12,6 +12,7 @@ #include "display.h" #include "divelist.h" #include "event.h" +#include "interpolate.h" #include "sample.h" #include "subsurface-string.h" |