aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/math.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/nvim/math.c')
-rw-r--r--src/nvim/math.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/nvim/math.c b/src/nvim/math.c
index 79e0be691b..9a0825823c 100644
--- a/src/nvim/math.c
+++ b/src/nvim/math.c
@@ -40,3 +40,29 @@ int xisnan(double d)
{
return FP_NAN == xfpclassify(d);
}
+
+/// Count trailing zeroes at the end of bit field.
+int xctz(uint64_t x)
+{
+ // If x == 0, that means all bits are zeroes.
+ if (x == 0) {
+ return 8 * sizeof(x);
+ }
+
+ // Use compiler builtin if possible.
+#if defined(__clang__) || (defined(__GNUC__) && (__GNUC__ >= 4))
+ return __builtin_ctzll(x);
+#else
+ int count = 0;
+ // Set x's trailing zeroes to ones and zero the rest.
+ x = (x ^ (x - 1)) >> 1;
+
+ // Increment count until there are just zero bits remaining.
+ while (x) {
+ count++;
+ x >>= 1;
+ }
+
+ return count;
+#endif
+}