abouttreesummaryrefslogcommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/fixedbuffer.c43
-rw-r--r--src/fixedbuffer.h19
-rw-r--r--src/matrix.c11
-rw-r--r--src/matrix.h13
4 files changed, 63 insertions, 23 deletions
diff --git a/src/fixedbuffer.c b/src/fixedbuffer.c
new file mode 100644
index 0000000..ad99897
--- /dev/null
+++ b/src/fixedbuffer.c
@@ -0,0 +1,43 @@
+#include "fixedbuffer.h"
+
+#include <string.h>
+
+FixedBuffer
+FixedBuf(const char * str)
+{
+ int len = strlen(str);
+ FixedBuffer result;
+ result.ptr = (char *)str;
+ result.cap = len;
+ result.len = len;
+ return result;
+}
+
+bool
+FixedBufferToInt(FixedBuffer fb, int * outInt)
+{
+ bool valid = false;
+ int result = 0;
+
+ bool negative = false;
+
+ for (int i = 0; i < fb.len; i++)
+ {
+ if (i == 0 && fb.ptr[i] == '-')
+ {
+ negative = true;
+ continue;
+ }
+
+ int val = fb.ptr[i] - '0';
+ if (val < 0 || val > 9)
+ return false;
+
+ result *= 10;
+ result += val;
+ valid = true;
+ }
+
+ *outInt = result;
+ return valid;
+} \ No newline at end of file
diff --git a/src/fixedbuffer.h b/src/fixedbuffer.h
new file mode 100644
index 0000000..d8055cb
--- /dev/null
+++ b/src/fixedbuffer.h
@@ -0,0 +1,19 @@
+#ifndef FIXEDBUFFER__H
+#define FIXEDBUFFER__H
+
+#include <stdbool.h>
+
+typedef struct FixedBuffer {
+ char * ptr;
+ int cap;
+ int len;
+} FixedBuffer;
+
+FixedBuffer
+FixedBuf(const char * str);
+
+bool
+FixedBufferToInt(FixedBuffer fb, int * outInt);
+
+
+#endif \ No newline at end of file
diff --git a/src/matrix.c b/src/matrix.c
index bc0f1ca..082806a 100644
--- a/src/matrix.c
+++ b/src/matrix.c
@@ -1,16 +1,5 @@
#include "matrix.h"
-FixedBuffer
-FixedBuf(const char * str)
-{
- int len = strlen(str);
- FixedBuffer result;
- result.ptr = (char *)str;
- result.size = len;
- result.len = len;
- return result;
-}
-
bool
MatrixClientInit(
diff --git a/src/matrix.h b/src/matrix.h
index d61c59b..5f53e0e 100644
--- a/src/matrix.h
+++ b/src/matrix.h
@@ -6,18 +6,7 @@
#include <olm/olm.h>
-
-
-
-
-typedef struct FixedBuffer {
- void * ptr;
- int size;
- int len;
-} FixedBuffer;
-
-FixedBuffer
-FixedBuf(const char * str);
+#include "fixedbuffer.h"