diff options
| author | ame <[email protected]> | 2024-08-26 22:33:07 -0500 |
|---|---|---|
| committer | ame <[email protected]> | 2024-08-26 22:33:07 -0500 |
| commit | d0c7c5b0dd9d20bfc323dc10c67f9de12d58c343 (patch) | |
| tree | 893fe45044ce5869246328f82eca2e7b78f02dd6 /src/net | |
| parent | fda120441cabfefc511786d7a6af40eec9f181fa (diff) | |
initial param matching
Diffstat (limited to 'src/net')
| -rw-r--r-- | src/net/util.c | 48 | ||||
| -rw-r--r-- | src/net/util.h | 2 |
2 files changed, 50 insertions, 0 deletions
diff --git a/src/net/util.c b/src/net/util.c index 213be9f..bc2c6bb 100644 --- a/src/net/util.c +++ b/src/net/util.c @@ -239,3 +239,51 @@ int content_disposition(str* src, parray_t** _dest){ return 1; } + +int match_param(char* path, char* match){ + int pi, mi = pi = 0; + int step = 0; + //0 increment both + //1 move match to find '/' or '\0' + //2 move path to find '}' + for(; path[pi] != '\0' && match[mi] != '\0';){ + if(step == 0){ + if(path[pi] == '{'){ + step = 1; + } else { + pi++; + mi++; + } + } else if (step == 1){ + if(match[mi] == '/'){ + printf("\n"); + step = 2; + } else { + printf("%c",match[mi]); + mi++; + } + } else if (step == 2){ + if(path[pi] == '}'){ + step = 0; + } else { + pi++; + } + } + } + return 0; +} + +parray_t* route_match(parray_t* paths, char* request){ + parray_t* out = parray_initl(paths->len); + out->len = 0; + + for(int i = 0; i != paths->len; i++){ + match_param(paths->P[i].key->c, request); + if(strcmp(request, paths->P[i].key->c) == 0){ + out->P[out->len] = paths->P[i]; + out->len++; + + } + } + return out; +} diff --git a/src/net/util.h b/src/net/util.h index d723b6f..ea7c294 100644 --- a/src/net/util.h +++ b/src/net/util.h @@ -45,3 +45,5 @@ void http_code(int code, char* code_det); void client_fd_errors(int client_fd); int content_disposition(str* src, parray_t** _dest); + +parray_t* route_match(parray_t* paths, char* path); |
