summaryrefslogtreecommitdiff
path: root/web/web_opts.c
diff options
context:
space:
mode:
authorDavid Vazgenovich Shakaryan <dvshakaryan@gmail.com>2022-05-04 01:59:39 -0700
committerDavid Vazgenovich Shakaryan <dvshakaryan@gmail.com>2022-05-04 01:59:39 -0700
commit3492c24cc533e9088e8b12f929f5d922c8787cba (patch)
tree32565b49bd46ff1e2d2ae6954240593ac4a5427c /web/web_opts.c
parent2709b070c5fde766c0e9fe98ade169a865e6c9ad (diff)
downloaddartboat-3492c24cc533e9088e8b12f929f5d922c8787cba.tar.gz
dartboat-3492c24cc533e9088e8b12f929f5d922c8787cba.tar.xz
web: move opt logic to c
Diffstat (limited to 'web/web_opts.c')
-rw-r--r--web/web_opts.c73
1 files changed, 66 insertions, 7 deletions
diff --git a/web/web_opts.c b/web/web_opts.c
index 945909f..c156598 100644
--- a/web/web_opts.c
+++ b/web/web_opts.c
@@ -4,15 +4,67 @@
#include <math.h>
#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
#include <emscripten/emscripten.h>
+#define PREFIX "dartboat_"
+
int delay_ms = 1000;
+void set_delay(char *val)
+{
+ delay_ms = atoi(val);
+}
+
+void set_stdev(char *val)
+{
+ double stdev = strtod(val, NULL);
+ if (isfinite(stdev))
+ horizontal_stdev = vertical_stdev = stdev;
+}
+
+char *prefix_opt(char *opt)
+{
+ char len = strlen(opt);
+ char *s = malloc(len + sizeof(PREFIX));
+ memcpy(s, PREFIX, sizeof(PREFIX) - 1);
+ memcpy(s + sizeof(PREFIX) - 1, opt, len + 1);
+
+ return s;
+}
+
+char *read_opt(char *opt)
+{
+ char *s = prefix_opt(opt);
+ char *val = (char *)EM_ASM_INT({return readOpt($0)}, s);
+ free(s);
+ return val;
+}
+
+void read_delay()
+{
+ char *val = read_opt("delay");
+ if (!val) return;
+
+ set_delay(val);
+ free(val);
+}
+
+void read_stdev()
+{
+ char *val = read_opt("stdev");
+ if (!val) return;
+
+ set_stdev(val);
+ free(val);
+}
+
void opts_init()
{
- EM_ASM(readOpts());
+ read_delay();
+ read_stdev();
char buf[64];
sprintf(buf, "%d", delay_ms);
@@ -30,15 +82,22 @@ void opts_init()
EM_ASM({elemSetValue($0, $1)}, "#stdev", buf);
}
-EMSCRIPTEN_KEEPALIVE
-void set_delay(int delay)
+void store_opt(char *opt, char *val)
{
- delay_ms = delay;
+ char *s = prefix_opt(opt);
+ EM_ASM({storeOpt($0, $1)}, s, val);
+ free(s);
}
EMSCRIPTEN_KEEPALIVE
-void set_stdev(float stdev)
+void set_opt(char *opt, char *val)
{
- if (!isnan(stdev))
- horizontal_stdev = vertical_stdev = stdev;
+ if (!strcmp(opt, "delay"))
+ set_delay(val);
+ else if (!strcmp(opt, "stdev"))
+ set_stdev(val);
+ else
+ return;
+
+ store_opt(opt, val);
}