aboutsummaryrefslogtreecommitdiff
path: root/src/types.c
diff options
context:
space:
mode:
authorXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-11-26 22:43:30 +0100
committerXavier Del Campo Romero <xavi.dcr@tutanota.com>2024-04-21 01:51:24 +0200
commitf25b015e5b668028c34974bbb22faa4105c26690 (patch)
tree28f2b08c17b3585d06694ad74004d0617eadb785 /src/types.c
downloadnanowasm-sync-f25b015e5b668028c34974bbb22faa4105c26690.tar.gz
First commit
Diffstat (limited to 'src/types.c')
-rw-r--r--src/types.c89
1 files changed, 89 insertions, 0 deletions
diff --git a/src/types.c b/src/types.c
new file mode 100644
index 0000000..88c883e
--- /dev/null
+++ b/src/types.c
@@ -0,0 +1,89 @@
+/*
+ * nanowasm, a tiny WebAssembly/Wasm interpreter
+ * Copyright (C) 2023-2024 Xavier Del Campo Romero
+ *
+ * This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/.
+ */
+
+#include <nw/leb128.h>
+#include <nw/types.h>
+#include <stdio.h>
+
+int varuint1_read(FILE *const f, varuint1 *const out)
+{
+ unsigned long long value;
+
+ if (leb128_read_unsigned(f, 1, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}
+
+int varint7_read(FILE *const f, varint7 *const out)
+{
+ long long value;
+
+ if (leb128_read_signed(f, 7, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}
+
+int varuint7_read(FILE *const f, varuint7 *const out)
+{
+ unsigned long long value;
+
+ if (leb128_read_unsigned(f, 7, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}
+
+int varuint32_read(FILE *const f, varuint32 *out)
+{
+ unsigned long long value;
+
+ if (leb128_read_unsigned(f, 32, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}
+
+int varint32_read(FILE *const f, varint32 *const out)
+{
+ long long value;
+
+ if (leb128_read_signed(f, 32, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}
+
+int varuint64_read(FILE *const f, varuint64 *const out)
+{
+ unsigned long long value;
+
+ if (leb128_read_unsigned(f, 64, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}
+
+int varint64_read(FILE *const f, varint64 *const out)
+{
+ long long value;
+
+ if (leb128_read_signed(f, 64, &value))
+ return -1;
+
+ *out = value;
+ return 0;
+}