aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-06-06 01:58:42 +0200
committerXavier Del Campo Romero <xavi.dcr@tutanota.com>2023-07-20 23:52:55 +0200
commit0759122e4c7dd17af9f981040e44c747579478b6 (patch)
tree0c3519520c70819a70b8962e59a722825fb3bd16
parent3f642351232e51963c980a46260ce59076588c55 (diff)
downloadlibweb-0759122e4c7dd17af9f981040e44c747579478b6.tar.gz
Split wildcard_cmp into its own component
Future commits will make use of this function outside handler.c.
-rw-r--r--Makefile3
-rw-r--r--handler.c43
-rw-r--r--wildcard_cmp.c44
-rw-r--r--wildcard_cmp.h6
4 files changed, 53 insertions, 43 deletions
diff --git a/Makefile b/Makefile
index 5e330be..09f3cb2 100644
--- a/Makefile
+++ b/Makefile
@@ -20,7 +20,8 @@ OBJECTS = \
jwt.o \
main.o \
page.o \
- server.o
+ server.o \
+ wildcard_cmp.o \
all: $(PROJECT)
diff --git a/handler.c b/handler.c
index 795d503..9103db0 100644
--- a/handler.c
+++ b/handler.c
@@ -3,6 +3,7 @@
#include "handler.h"
#include "http.h"
#include "server.h"
+#include "wildcard_cmp.h"
#include <errno.h>
#include <stdbool.h>
#include <stddef.h>
@@ -47,48 +48,6 @@ static int on_write(const void *const buf, const size_t n, void *const user)
return server_write(buf, n, c->c);
}
-static int wildcard_cmp(const char *s, const char *p)
-{
- while (*p && *s)
- {
- const char *const wc = strchr(p, '*');
-
- if (!wc)
- return strcmp(s, p);
-
- const size_t n = wc - p;
-
- if (n)
- {
- const int r = strncmp(s, p, n);
-
- if (r)
- return r;
-
- p += n;
- s += n;
- }
- else if (*(wc + 1) == *s)
- {
- p = wc + 1;
- s += n;
- }
- else if (*(wc + 1) == '*')
- p++;
- else
- {
- s++;
- p += n;
- }
- }
-
- while (*p)
- if (*p++ != '*')
- return -1;
-
- return 0;
-}
-
static int on_payload(const struct http_payload *const p,
struct http_response *const r, void *const user)
{
diff --git a/wildcard_cmp.c b/wildcard_cmp.c
new file mode 100644
index 0000000..8f7c7c1
--- /dev/null
+++ b/wildcard_cmp.c
@@ -0,0 +1,44 @@
+#include "wildcard_cmp.h"
+#include <string.h>
+
+static int wildcard_cmp(const char *s, const char *p)
+{
+ while (*p && *s)
+ {
+ const char *const wc = strchr(p, '*');
+
+ if (!wc)
+ return strcmp(s, p);
+
+ const size_t n = wc - p;
+
+ if (n)
+ {
+ const int r = strncmp(s, p, n);
+
+ if (r)
+ return r;
+
+ p += n;
+ s += n;
+ }
+ else if (*(wc + 1) == *s)
+ {
+ p = wc + 1;
+ s += n;
+ }
+ else if (*(wc + 1) == '*')
+ p++;
+ else
+ {
+ s++;
+ p += n;
+ }
+ }
+
+ while (*p)
+ if (*p++ != '*')
+ return -1;
+
+ return 0;
+}
diff --git a/wildcard_cmp.h b/wildcard_cmp.h
new file mode 100644
index 0000000..9024dbc
--- /dev/null
+++ b/wildcard_cmp.h
@@ -0,0 +1,6 @@
+#ifndef WILDCARD_CMP_H
+#define WILDCARD_CMP_H
+
+int wildcard_cmp(const char *s, const char *p);
+
+#endif /* WILDCARD_CMP_H */