Merge branch 'master' of https://github.com/Agorise/c-libp2p
This commit is contained in:
commit
f0513713cb
2 changed files with 55 additions and 0 deletions
4
include/libp2p/utils/urlencode.h
Normal file
4
include/libp2p/utils/urlencode.h
Normal file
|
@ -0,0 +1,4 @@
|
|||
#pragma once
|
||||
|
||||
char *libp2p_utils_url_encode(char *src);
|
||||
char *libp2p_utils_url_decode(char *src);
|
51
utils/urlencode.c
Normal file
51
utils/urlencode.c
Normal file
|
@ -0,0 +1,51 @@
|
|||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <ctype.h>
|
||||
|
||||
char *libp2p_utils_url_encode(char *src)
|
||||
{
|
||||
const char *hex = "0123456789abcdef";
|
||||
char *p, *dst = malloc (strlen(src) * 3);
|
||||
|
||||
if (!dst) return NULL;
|
||||
|
||||
for(p = dst ; *src ; src++ ) {
|
||||
if( isalnum(*src)){
|
||||
*p++ = *src;
|
||||
} else {
|
||||
*p++ = '%';
|
||||
*p++ = hex[*src >> 4];
|
||||
*p++ = hex[*src & 15];
|
||||
}
|
||||
}
|
||||
*p++ = '\0';
|
||||
return realloc(dst, (size_t) (p - dst));
|
||||
}
|
||||
|
||||
int h2b(int c)
|
||||
{
|
||||
if (c >= '0' && c <= '9') {
|
||||
return c - '0';
|
||||
} else if (c >= 'a' && c <= 'f') {
|
||||
return c - 'a' + 10;
|
||||
} else if (c >= 'A' && c <= 'F') {
|
||||
return c - 'A' + 10;
|
||||
}
|
||||
return 0; // ?
|
||||
}
|
||||
|
||||
char *libp2p_utils_url_decode(char *src)
|
||||
{
|
||||
char *p, *dst = malloc (strlen(src));
|
||||
|
||||
for(p = dst ; *src ; src++ ) {
|
||||
if(*src != '%'){
|
||||
*p++ = *src;
|
||||
} else {
|
||||
*p = h2b(*(++src)) << 4;
|
||||
*p++ |= h2b(*(++src)) & 15;
|
||||
}
|
||||
}
|
||||
*p++ = '\0';
|
||||
return realloc(dst, (size_t) (p - dst));
|
||||
}
|
Loading…
Reference in a new issue