|
@@ -34,68 +34,84 @@
|
|
#include "../mem/mem.h"
|
|
#include "../mem/mem.h"
|
|
|
|
|
|
|
|
|
|
-enum {
|
|
|
|
- START_TO, DISPLAY_QUOTED, E_DISPLAY_QUOTED, DISPLAY_TOKEN,
|
|
|
|
- DISPLAY_TOKEN_SP, S_URI_ENCLOSED, URI_ENCLOSED, E_URI_ENCLOSED,
|
|
|
|
- URI_OR_TOKEN, MAYBE_URI_END, END, F_CR, F_LF, F_CRLF
|
|
|
|
|
|
+enum
|
|
|
|
+{
|
|
|
|
+ START_TO,
|
|
|
|
+ DISPLAY_QUOTED,
|
|
|
|
+ E_DISPLAY_QUOTED,
|
|
|
|
+ DISPLAY_TOKEN,
|
|
|
|
+ DISPLAY_TOKEN_SP,
|
|
|
|
+ S_URI_ENCLOSED,
|
|
|
|
+ URI_ENCLOSED,
|
|
|
|
+ E_URI_ENCLOSED,
|
|
|
|
+ URI_OR_TOKEN,
|
|
|
|
+ MAYBE_URI_END,
|
|
|
|
+ END,
|
|
|
|
+ F_CR,
|
|
|
|
+ F_LF,
|
|
|
|
+ F_CRLF
|
|
};
|
|
};
|
|
|
|
|
|
|
|
|
|
-enum {
|
|
|
|
- S_PARA_NAME=20, PARA_NAME, S_EQUAL, S_PARA_VALUE, TAG1, TAG2,
|
|
|
|
- TAG3, PARA_VALUE_TOKEN , PARA_VALUE_QUOTED, E_PARA_VALUE
|
|
|
|
|
|
+enum
|
|
|
|
+{
|
|
|
|
+ S_PARA_NAME = 20,
|
|
|
|
+ PARA_NAME,
|
|
|
|
+ S_EQUAL,
|
|
|
|
+ S_PARA_VALUE,
|
|
|
|
+ TAG1,
|
|
|
|
+ TAG2,
|
|
|
|
+ TAG3,
|
|
|
|
+ PARA_VALUE_TOKEN,
|
|
|
|
+ PARA_VALUE_QUOTED,
|
|
|
|
+ E_PARA_VALUE
|
|
};
|
|
};
|
|
|
|
|
|
|
|
|
|
-
|
|
|
|
-#define add_param( _param , _body , _newparam ) \
|
|
|
|
- do{\
|
|
|
|
- DBG("DEBUG: add_param: %.*s=%.*s\n",param->name.len,ZSW(param->name.s),\
|
|
|
|
- param->value.len,ZSW(param->value.s));\
|
|
|
|
- if (!(_body)->param_lst) (_body)->param_lst=(_param);\
|
|
|
|
- else (_body)->last_param->next=(_param);\
|
|
|
|
- (_body)->last_param =(_param);\
|
|
|
|
- if ((_param)->type==TAG_PARAM)\
|
|
|
|
- memcpy(&((_body)->tag_value),&((_param)->value),sizeof(str));\
|
|
|
|
- _newparam = 0;\
|
|
|
|
- }while(0);
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-static char* parse_to_param(char* const buffer, const char* const end,
|
|
|
|
- struct to_body* const to_b, const int allow_comma_sep,
|
|
|
|
- int* const returned_status)
|
|
|
|
|
|
+#define add_param(_param, _body, _newparam) \
|
|
|
|
+ do { \
|
|
|
|
+ LM_DBG("add param: %.*s=%.*s\n", param->name.len, ZSW(param->name.s), \
|
|
|
|
+ param->value.len, ZSW(param->value.s)); \
|
|
|
|
+ if(!(_body)->param_lst) \
|
|
|
|
+ (_body)->param_lst = (_param); \
|
|
|
|
+ else \
|
|
|
|
+ (_body)->last_param->next = (_param); \
|
|
|
|
+ (_body)->last_param = (_param); \
|
|
|
|
+ if((_param)->type == TAG_PARAM) \
|
|
|
|
+ memcpy(&((_body)->tag_value), &((_param)->value), sizeof(str)); \
|
|
|
|
+ _newparam = 0; \
|
|
|
|
+ } while(0);
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+static char *parse_to_param(char *const buffer, const char *const end,
|
|
|
|
+ struct to_body *const to_b, const int allow_comma_sep,
|
|
|
|
+ int *const returned_status)
|
|
{
|
|
{
|
|
struct to_param *param;
|
|
struct to_param *param;
|
|
struct to_param *newparam;
|
|
struct to_param *newparam;
|
|
int status;
|
|
int status;
|
|
int saved_status;
|
|
int saved_status;
|
|
- char *tmp;
|
|
|
|
-
|
|
|
|
- param=0;
|
|
|
|
- newparam=0;
|
|
|
|
- status=E_PARA_VALUE;
|
|
|
|
- saved_status=E_PARA_VALUE;
|
|
|
|
- for( tmp=buffer; tmp<end; tmp++)
|
|
|
|
- {
|
|
|
|
- switch(*tmp)
|
|
|
|
- {
|
|
|
|
|
|
+ char *tmp;
|
|
|
|
+
|
|
|
|
+ param = 0;
|
|
|
|
+ newparam = 0;
|
|
|
|
+ status = E_PARA_VALUE;
|
|
|
|
+ saved_status = E_PARA_VALUE;
|
|
|
|
+ for(tmp = buffer; tmp < end; tmp++) {
|
|
|
|
+ switch(*tmp) {
|
|
case ' ':
|
|
case ' ':
|
|
case '\t':
|
|
case '\t':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case TAG3:
|
|
case TAG3:
|
|
- param->type=TAG_PARAM;
|
|
|
|
|
|
+ param->type = TAG_PARAM;
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
status = S_EQUAL;
|
|
status = S_EQUAL;
|
|
break;
|
|
break;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
- param->value.len = tmp-param->value.s;
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
status = E_PARA_VALUE;
|
|
status = E_PARA_VALUE;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
break;
|
|
break;
|
|
@@ -103,69 +119,67 @@ static char* parse_to_param(char* const buffer, const char* const end,
|
|
case F_LF:
|
|
case F_LF:
|
|
case F_CR:
|
|
case F_CR:
|
|
/*previous=crlf and now =' '*/
|
|
/*previous=crlf and now =' '*/
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '\n':
|
|
case '\n':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case S_PARA_NAME:
|
|
case S_PARA_NAME:
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
- saved_status=status;
|
|
|
|
- status=F_LF;
|
|
|
|
|
|
+ saved_status = status;
|
|
|
|
+ status = F_LF;
|
|
break;
|
|
break;
|
|
case TAG3:
|
|
case TAG3:
|
|
- param->type=TAG_PARAM;
|
|
|
|
|
|
+ param->type = TAG_PARAM;
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
saved_status = S_EQUAL;
|
|
saved_status = S_EQUAL;
|
|
status = F_LF;
|
|
status = F_LF;
|
|
break;
|
|
break;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
- param->value.len = tmp-param->value.s;
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
saved_status = E_PARA_VALUE;
|
|
saved_status = E_PARA_VALUE;
|
|
status = F_LF;
|
|
status = F_LF;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
break;
|
|
break;
|
|
case F_CR:
|
|
case F_CR:
|
|
- status=F_CRLF;
|
|
|
|
|
|
+ status = F_CRLF;
|
|
break;
|
|
break;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_LF:
|
|
case F_LF:
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '\r':
|
|
case '\r':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case S_PARA_NAME:
|
|
case S_PARA_NAME:
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
- saved_status=status;
|
|
|
|
- status=F_CR;
|
|
|
|
|
|
+ saved_status = status;
|
|
|
|
+ status = F_CR;
|
|
break;
|
|
break;
|
|
case TAG3:
|
|
case TAG3:
|
|
- param->type=TAG_PARAM;
|
|
|
|
|
|
+ param->type = TAG_PARAM;
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
saved_status = S_EQUAL;
|
|
saved_status = S_EQUAL;
|
|
status = F_CR;
|
|
status = F_CR;
|
|
break;
|
|
break;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
- param->value.len = tmp-param->value.s;
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
saved_status = E_PARA_VALUE;
|
|
saved_status = E_PARA_VALUE;
|
|
status = F_CR;
|
|
status = F_CR;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
@@ -173,48 +187,45 @@ static char* parse_to_param(char* const buffer, const char* const end,
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_CR:
|
|
case F_CR:
|
|
case F_LF:
|
|
case F_LF:
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case 0:
|
|
case 0:
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case TAG3:
|
|
case TAG3:
|
|
param->type = TAG_PARAM;
|
|
param->type = TAG_PARAM;
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
status = S_EQUAL;
|
|
status = S_EQUAL;
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
- saved_status=status;
|
|
|
|
|
|
+ saved_status = status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
status = E_PARA_VALUE;
|
|
status = E_PARA_VALUE;
|
|
- param->value.len = tmp-param->value.s;
|
|
|
|
- add_param(param , to_b, newparam);
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
|
|
+ add_param(param, to_b, newparam);
|
|
case E_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
saved_status = status;
|
|
saved_status = status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '\\':
|
|
case '\\':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
- switch (*(tmp+1))
|
|
|
|
- {
|
|
|
|
|
|
+ switch(*(tmp + 1)) {
|
|
case '\r':
|
|
case '\r':
|
|
case '\n':
|
|
case '\n':
|
|
break;
|
|
break;
|
|
@@ -223,19 +234,18 @@ static char* parse_to_param(char* const buffer, const char* const end,
|
|
}
|
|
}
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '"':
|
|
case '"':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
- param->value.s = tmp+1;
|
|
|
|
|
|
+ param->value.s = tmp + 1;
|
|
status = PARA_VALUE_QUOTED;
|
|
status = PARA_VALUE_QUOTED;
|
|
break;
|
|
break;
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
- param->value.len=tmp-param->value.s;
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
status = E_PARA_VALUE;
|
|
status = E_PARA_VALUE;
|
|
break;
|
|
break;
|
|
@@ -246,13 +256,12 @@ static char* parse_to_param(char* const buffer, const char* const end,
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status,(int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
- case ';' :
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ case ';':
|
|
|
|
+ switch(status) {
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
break;
|
|
break;
|
|
case TAG3:
|
|
case TAG3:
|
|
@@ -260,7 +269,7 @@ static char* parse_to_param(char* const buffer, const char* const end,
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
param->value.s = 0;
|
|
param->value.s = 0;
|
|
param->value.len = 0;
|
|
param->value.len = 0;
|
|
@@ -268,18 +277,18 @@ static char* parse_to_param(char* const buffer, const char* const end,
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
param->value.s = tmp;
|
|
param->value.s = tmp;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
- param->value.len=tmp-param->value.s;
|
|
|
|
-semicolon_add_param:
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
|
|
+ semicolon_add_param:
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
case E_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
- param = (struct to_param*)
|
|
|
|
- pkg_malloc(sizeof(struct to_param));
|
|
|
|
- if (!param){
|
|
|
|
|
|
+ param = (struct to_param *)pkg_malloc(
|
|
|
|
+ sizeof(struct to_param));
|
|
|
|
+ if(!param) {
|
|
LM_ERR("out of memory\n");
|
|
LM_ERR("out of memory\n");
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
- memset(param,0,sizeof(struct to_param));
|
|
|
|
- param->type=GENERAL_PARAM;
|
|
|
|
|
|
+ memset(param, 0, sizeof(struct to_param));
|
|
|
|
+ param->type = GENERAL_PARAM;
|
|
status = S_PARA_NAME;
|
|
status = S_PARA_NAME;
|
|
/* link to free mem if not added in to_body list */
|
|
/* link to free mem if not added in to_body list */
|
|
newparam = param;
|
|
newparam = param;
|
|
@@ -291,14 +300,13 @@ semicolon_add_param:
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case 'T':
|
|
case 'T':
|
|
- case 't' :
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ case 't':
|
|
|
|
+ switch(status) {
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
@@ -323,14 +331,13 @@ semicolon_add_param:
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case 'A':
|
|
case 'A':
|
|
- case 'a' :
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ case 'a':
|
|
|
|
+ switch(status) {
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
@@ -357,14 +364,13 @@ semicolon_add_param:
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case 'G':
|
|
case 'G':
|
|
- case 'g' :
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ case 'g':
|
|
|
|
+ switch(status) {
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
@@ -391,21 +397,20 @@ semicolon_add_param:
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '=':
|
|
case '=':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case PARA_VALUE_QUOTED:
|
|
case PARA_VALUE_QUOTED:
|
|
break;
|
|
break;
|
|
case TAG3:
|
|
case TAG3:
|
|
- param->type=TAG_PARAM;
|
|
|
|
|
|
+ param->type = TAG_PARAM;
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
status = S_PARA_VALUE;
|
|
status = S_PARA_VALUE;
|
|
break;
|
|
break;
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
@@ -418,37 +423,35 @@ semicolon_add_param:
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case ',':
|
|
case ',':
|
|
- if(status==PARA_VALUE_QUOTED) {
|
|
|
|
|
|
+ if(status == PARA_VALUE_QUOTED) {
|
|
/* comma is allowed inside quoted values */
|
|
/* comma is allowed inside quoted values */
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
- if (allow_comma_sep)
|
|
|
|
- {
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ if(allow_comma_sep) {
|
|
|
|
+ switch(status) {
|
|
case S_PARA_NAME:
|
|
case S_PARA_NAME:
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
- saved_status=status;
|
|
|
|
- status=E_PARA_VALUE;
|
|
|
|
|
|
+ saved_status = status;
|
|
|
|
+ status = E_PARA_VALUE;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
case TAG3:
|
|
case TAG3:
|
|
- param->type=TAG_PARAM;
|
|
|
|
|
|
+ param->type = TAG_PARAM;
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
saved_status = S_EQUAL;
|
|
saved_status = S_EQUAL;
|
|
status = E_PARA_VALUE;
|
|
status = E_PARA_VALUE;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
- param->value.len = tmp-param->value.s;
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
saved_status = E_PARA_VALUE;
|
|
saved_status = E_PARA_VALUE;
|
|
status = E_PARA_VALUE;
|
|
status = E_PARA_VALUE;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
@@ -456,27 +459,28 @@ semicolon_add_param:
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_CR:
|
|
case F_CR:
|
|
case F_LF:
|
|
case F_LF:
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
- LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ LM_ERR("unexpected char [%c] in status %d: [%.*s] "
|
|
|
|
+ ".\n",
|
|
|
|
+ *tmp, status, (int)(tmp - buffer),
|
|
|
|
+ ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
} else {
|
|
} else {
|
|
- if((status==S_PARA_VALUE || status==PARA_VALUE_TOKEN)
|
|
|
|
- && param->type==TAG_PARAM) {
|
|
|
|
|
|
+ if((status == S_PARA_VALUE || status == PARA_VALUE_TOKEN)
|
|
|
|
+ && param->type == TAG_PARAM) {
|
|
/* if comma is not separator, allow it as part of value
|
|
/* if comma is not separator, allow it as part of value
|
|
* - some user agents use it */
|
|
* - some user agents use it */
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
LM_ERR("invalid character ',' in status %d: [%.*s]\n",
|
|
LM_ERR("invalid character ',' in status %d: [%.*s]\n",
|
|
- status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ status, (int)(tmp - buffer), ZSW(buffer));
|
|
}
|
|
}
|
|
default:
|
|
default:
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
case TAG3:
|
|
case TAG3:
|
|
@@ -500,94 +504,92 @@ semicolon_add_param:
|
|
/*previous=crlf and now !=' '*/
|
|
/*previous=crlf and now !=' '*/
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
- LM_ERR("spitting out [%c] in status %d\n",*tmp,status);
|
|
|
|
|
|
+ LM_ERR("spitting out [%c] in status %d\n", *tmp,
|
|
|
|
+ status);
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
- }/*switch*/
|
|
|
|
- }/*for*/
|
|
|
|
- if (!(status==F_CR || status==F_LF || status==F_CRLF))
|
|
|
|
- saved_status=status;
|
|
|
|
|
|
+ } /*switch*/
|
|
|
|
+ } /*for*/
|
|
|
|
+ if(!(status == F_CR || status == F_LF || status == F_CRLF))
|
|
|
|
+ saved_status = status;
|
|
|
|
|
|
|
|
|
|
endofheader:
|
|
endofheader:
|
|
- switch(saved_status){
|
|
|
|
|
|
+ switch(saved_status) {
|
|
case TAG3:
|
|
case TAG3:
|
|
- param->type = TAG_PARAM; /* tag at the end */
|
|
|
|
- /* no break */
|
|
|
|
|
|
+ param->type = TAG_PARAM; /* tag at the end */
|
|
|
|
+ /* no break */
|
|
case PARA_NAME:
|
|
case PARA_NAME:
|
|
case TAG1:
|
|
case TAG1:
|
|
case TAG2:
|
|
case TAG2:
|
|
- param->name.len = tmp-param->name.s;
|
|
|
|
- /* no break */
|
|
|
|
|
|
+ param->name.len = tmp - param->name.s;
|
|
|
|
+ /* no break */
|
|
case S_EQUAL:
|
|
case S_EQUAL:
|
|
/* parameter without '=', e.g. foo */
|
|
/* parameter without '=', e.g. foo */
|
|
- param->value.s=0;
|
|
|
|
- param->value.len=0;
|
|
|
|
|
|
+ param->value.s = 0;
|
|
|
|
+ param->value.len = 0;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
- saved_status=E_PARA_VALUE;
|
|
|
|
|
|
+ saved_status = E_PARA_VALUE;
|
|
break;
|
|
break;
|
|
case S_PARA_VALUE:
|
|
case S_PARA_VALUE:
|
|
/* parameter with null value, e.g. foo= */
|
|
/* parameter with null value, e.g. foo= */
|
|
- if ( status==F_CRLF )
|
|
|
|
- param->value.s=tmp-2;
|
|
|
|
- else if ( status==F_CR || status==F_LF )
|
|
|
|
- param->value.s=tmp-1;
|
|
|
|
|
|
+ if(status == F_CRLF)
|
|
|
|
+ param->value.s = tmp - 2;
|
|
|
|
+ else if(status == F_CR || status == F_LF)
|
|
|
|
+ param->value.s = tmp - 1;
|
|
else
|
|
else
|
|
- param->value.s=tmp;
|
|
|
|
- param->value.len=0;
|
|
|
|
|
|
+ param->value.s = tmp;
|
|
|
|
+ param->value.len = 0;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
- saved_status=E_PARA_VALUE;
|
|
|
|
|
|
+ saved_status = E_PARA_VALUE;
|
|
break;
|
|
break;
|
|
case PARA_VALUE_TOKEN:
|
|
case PARA_VALUE_TOKEN:
|
|
- param->value.len=tmp-param->value.s;
|
|
|
|
|
|
+ param->value.len = tmp - param->value.s;
|
|
add_param(param, to_b, newparam);
|
|
add_param(param, to_b, newparam);
|
|
- saved_status=E_PARA_VALUE;
|
|
|
|
|
|
+ saved_status = E_PARA_VALUE;
|
|
break;
|
|
break;
|
|
case E_PARA_VALUE:
|
|
case E_PARA_VALUE:
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected end of header, status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected end of header, status %d: [%.*s] .\n",
|
|
- saved_status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ saved_status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
- *returned_status=saved_status;
|
|
|
|
|
|
+ *returned_status = saved_status;
|
|
return tmp;
|
|
return tmp;
|
|
|
|
|
|
error:
|
|
error:
|
|
- if (newparam) pkg_free(newparam);
|
|
|
|
- to_b->error=PARSE_ERROR;
|
|
|
|
|
|
+ if(newparam)
|
|
|
|
+ pkg_free(newparam);
|
|
|
|
+ to_b->error = PARSE_ERROR;
|
|
*returned_status = status;
|
|
*returned_status = status;
|
|
return tmp;
|
|
return tmp;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-
|
|
|
|
-char* parse_addr_spec(char* const buffer, const char* const end,
|
|
|
|
- struct to_body* const to_b, const int allow_comma_sep)
|
|
|
|
|
|
+char *parse_addr_spec(char *const buffer, const char *const end,
|
|
|
|
+ struct to_body *const to_b, const int allow_comma_sep)
|
|
{
|
|
{
|
|
int status;
|
|
int status;
|
|
int saved_status;
|
|
int saved_status;
|
|
- char *tmp,*foo;
|
|
|
|
|
|
+ char *tmp, *foo;
|
|
|
|
|
|
- saved_status=START_TO; /* fixes gcc 4.x warning */
|
|
|
|
- status=START_TO;
|
|
|
|
|
|
+ saved_status = START_TO; /* fixes gcc 4.x warning */
|
|
|
|
+ status = START_TO;
|
|
memset(to_b, 0, sizeof(struct to_body));
|
|
memset(to_b, 0, sizeof(struct to_body));
|
|
- to_b->error=PARSE_OK;
|
|
|
|
- foo=0;
|
|
|
|
|
|
+ to_b->error = PARSE_OK;
|
|
|
|
+ foo = 0;
|
|
|
|
|
|
- for( tmp=buffer; tmp<end; tmp++)
|
|
|
|
- {
|
|
|
|
- switch(*tmp)
|
|
|
|
- {
|
|
|
|
|
|
+ for(tmp = buffer; tmp < end; tmp++) {
|
|
|
|
+ switch(*tmp) {
|
|
case ' ':
|
|
case ' ':
|
|
case '\t':
|
|
case '\t':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_LF:
|
|
case F_LF:
|
|
case F_CR:
|
|
case F_CR:
|
|
/*previous=crlf and now =' '*/
|
|
/*previous=crlf and now =' '*/
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
break;
|
|
break;
|
|
case URI_ENCLOSED:
|
|
case URI_ENCLOSED:
|
|
to_b->uri.len = tmp - to_b->uri.s;
|
|
to_b->uri.len = tmp - to_b->uri.s;
|
|
@@ -604,8 +606,7 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '\n':
|
|
case '\n':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case URI_OR_TOKEN:
|
|
case URI_OR_TOKEN:
|
|
foo = tmp;
|
|
foo = tmp;
|
|
status = MAYBE_URI_END;
|
|
status = MAYBE_URI_END;
|
|
@@ -613,30 +614,29 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
case DISPLAY_TOKEN_SP:
|
|
case DISPLAY_TOKEN_SP:
|
|
case E_DISPLAY_QUOTED:
|
|
case E_DISPLAY_QUOTED:
|
|
case END:
|
|
case END:
|
|
- saved_status=status;
|
|
|
|
- status=F_LF;
|
|
|
|
|
|
+ saved_status = status;
|
|
|
|
+ status = F_LF;
|
|
break;
|
|
break;
|
|
case DISPLAY_TOKEN:
|
|
case DISPLAY_TOKEN:
|
|
- foo=tmp;
|
|
|
|
- saved_status=DISPLAY_TOKEN_SP;
|
|
|
|
- status=F_LF;
|
|
|
|
|
|
+ foo = tmp;
|
|
|
|
+ saved_status = DISPLAY_TOKEN_SP;
|
|
|
|
+ status = F_LF;
|
|
break;
|
|
break;
|
|
case F_CR:
|
|
case F_CR:
|
|
- status=F_CRLF;
|
|
|
|
|
|
+ status = F_CRLF;
|
|
break;
|
|
break;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_LF:
|
|
case F_LF:
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '\r':
|
|
case '\r':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case URI_OR_TOKEN:
|
|
case URI_OR_TOKEN:
|
|
foo = tmp;
|
|
foo = tmp;
|
|
status = MAYBE_URI_END;
|
|
status = MAYBE_URI_END;
|
|
@@ -644,28 +644,27 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
case DISPLAY_TOKEN_SP:
|
|
case DISPLAY_TOKEN_SP:
|
|
case E_DISPLAY_QUOTED:
|
|
case E_DISPLAY_QUOTED:
|
|
case END:
|
|
case END:
|
|
- saved_status=status;
|
|
|
|
- status=F_CR;
|
|
|
|
|
|
+ saved_status = status;
|
|
|
|
+ status = F_CR;
|
|
break;
|
|
break;
|
|
case DISPLAY_TOKEN:
|
|
case DISPLAY_TOKEN:
|
|
- foo=tmp;
|
|
|
|
- saved_status=DISPLAY_TOKEN_SP;
|
|
|
|
- status=F_CR;
|
|
|
|
|
|
+ foo = tmp;
|
|
|
|
+ saved_status = DISPLAY_TOKEN_SP;
|
|
|
|
+ status = F_CR;
|
|
break;
|
|
break;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_CR:
|
|
case F_CR:
|
|
case F_LF:
|
|
case F_LF:
|
|
- status=saved_status;
|
|
|
|
|
|
+ status = saved_status;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case 0:
|
|
case 0:
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case URI_OR_TOKEN:
|
|
case URI_OR_TOKEN:
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
to_b->uri.len = tmp - to_b->uri.s;
|
|
to_b->uri.len = tmp - to_b->uri.s;
|
|
@@ -674,27 +673,25 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '\\':
|
|
case '\\':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case DISPLAY_QUOTED:
|
|
case DISPLAY_QUOTED:
|
|
tmp++; /* jump over next char */
|
|
tmp++; /* jump over next char */
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '<':
|
|
case '<':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case START_TO:
|
|
case START_TO:
|
|
- to_b->body.s=tmp;
|
|
|
|
|
|
+ to_b->body.s = tmp;
|
|
status = S_URI_ENCLOSED;
|
|
status = S_URI_ENCLOSED;
|
|
break;
|
|
break;
|
|
case DISPLAY_QUOTED:
|
|
case DISPLAY_QUOTED:
|
|
@@ -704,12 +701,12 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
break;
|
|
break;
|
|
case URI_OR_TOKEN:
|
|
case URI_OR_TOKEN:
|
|
case DISPLAY_TOKEN:
|
|
case DISPLAY_TOKEN:
|
|
- to_b->display.len=tmp-to_b->display.s;
|
|
|
|
|
|
+ to_b->display.len = tmp - to_b->display.s;
|
|
status = S_URI_ENCLOSED;
|
|
status = S_URI_ENCLOSED;
|
|
break;
|
|
break;
|
|
case DISPLAY_TOKEN_SP:
|
|
case DISPLAY_TOKEN_SP:
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
- to_b->display.len=foo-to_b->display.s;
|
|
|
|
|
|
+ to_b->display.len = foo - to_b->display.s;
|
|
status = S_URI_ENCLOSED;
|
|
status = S_URI_ENCLOSED;
|
|
break;
|
|
break;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
@@ -719,13 +716,12 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '>':
|
|
case '>':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case DISPLAY_QUOTED:
|
|
case DISPLAY_QUOTED:
|
|
break;
|
|
break;
|
|
case URI_ENCLOSED:
|
|
case URI_ENCLOSED:
|
|
@@ -741,13 +737,12 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), ZSW(buffer));
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), ZSW(buffer));
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
case '"':
|
|
case '"':
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case START_TO:
|
|
case START_TO:
|
|
to_b->body.s = tmp;
|
|
to_b->body.s = tmp;
|
|
to_b->display.s = tmp;
|
|
to_b->display.s = tmp;
|
|
@@ -755,7 +750,7 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
break;
|
|
break;
|
|
case DISPLAY_QUOTED:
|
|
case DISPLAY_QUOTED:
|
|
status = E_DISPLAY_QUOTED;
|
|
status = E_DISPLAY_QUOTED;
|
|
- to_b->display.len = tmp-to_b->display.s+1;
|
|
|
|
|
|
+ to_b->display.len = tmp - to_b->display.s + 1;
|
|
break;
|
|
break;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_LF:
|
|
case F_LF:
|
|
@@ -764,13 +759,12 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), buffer);
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), buffer);
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
- case ';' :
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ case ';':
|
|
|
|
+ switch(status) {
|
|
case DISPLAY_QUOTED:
|
|
case DISPLAY_QUOTED:
|
|
case URI_ENCLOSED:
|
|
case URI_ENCLOSED:
|
|
break;
|
|
break;
|
|
@@ -779,8 +773,9 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
to_b->uri.len = foo - to_b->uri.s;
|
|
to_b->uri.len = foo - to_b->uri.s;
|
|
case END:
|
|
case END:
|
|
- to_b->body.len = tmp-to_b->body.s;
|
|
|
|
- tmp = parse_to_param(tmp,end,to_b,allow_comma_sep,&saved_status);
|
|
|
|
|
|
+ to_b->body.len = tmp - to_b->body.s;
|
|
|
|
+ tmp = parse_to_param(
|
|
|
|
+ tmp, end, to_b, allow_comma_sep, &saved_status);
|
|
goto endofheader;
|
|
goto endofheader;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
case F_LF:
|
|
case F_LF:
|
|
@@ -789,15 +784,13 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
- *tmp,status, (int)(tmp-buffer), buffer);
|
|
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), buffer);
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
- case ',' :
|
|
|
|
- if (allow_comma_sep)
|
|
|
|
- {
|
|
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ case ',':
|
|
|
|
+ if(allow_comma_sep) {
|
|
|
|
+ switch(status) {
|
|
case DISPLAY_QUOTED:
|
|
case DISPLAY_QUOTED:
|
|
case URI_ENCLOSED:
|
|
case URI_ENCLOSED:
|
|
break;
|
|
break;
|
|
@@ -806,7 +799,7 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
to_b->uri.len = foo - to_b->uri.s;
|
|
to_b->uri.len = foo - to_b->uri.s;
|
|
case END:
|
|
case END:
|
|
- to_b->body.len = tmp-to_b->body.s;
|
|
|
|
|
|
+ to_b->body.len = tmp - to_b->body.s;
|
|
saved_status = END;
|
|
saved_status = END;
|
|
goto endofheader;
|
|
goto endofheader;
|
|
case F_CRLF:
|
|
case F_CRLF:
|
|
@@ -815,24 +808,24 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
/*previous=crlf and now !=' '*/
|
|
/*previous=crlf and now !=' '*/
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
- LM_ERR("unexpected char [%c] in status %d: [%.*s] .\n",
|
|
|
|
- *tmp,status, (int)(tmp-buffer), buffer);
|
|
|
|
|
|
+ LM_ERR("unexpected char [%c] in status %d: [%.*s] "
|
|
|
|
+ ".\n",
|
|
|
|
+ *tmp, status, (int)(tmp - buffer), buffer);
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
- /* If commas not allowed treat as a default character */
|
|
|
|
|
|
+ /* If commas not allowed treat as a default character */
|
|
default:
|
|
default:
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case START_TO:
|
|
case START_TO:
|
|
to_b->uri.s = to_b->body.s = tmp;
|
|
to_b->uri.s = to_b->body.s = tmp;
|
|
status = URI_OR_TOKEN;
|
|
status = URI_OR_TOKEN;
|
|
- to_b->display.s=tmp;
|
|
|
|
|
|
+ to_b->display.s = tmp;
|
|
break;
|
|
break;
|
|
case S_URI_ENCLOSED:
|
|
case S_URI_ENCLOSED:
|
|
- to_b->uri.s=tmp;
|
|
|
|
- status=URI_ENCLOSED;
|
|
|
|
|
|
+ to_b->uri.s = tmp;
|
|
|
|
+ status = URI_ENCLOSED;
|
|
break;
|
|
break;
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
case DISPLAY_TOKEN_SP:
|
|
case DISPLAY_TOKEN_SP:
|
|
@@ -848,16 +841,15 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
/*previous=crlf and now !=' '*/
|
|
/*previous=crlf and now !=' '*/
|
|
goto endofheader;
|
|
goto endofheader;
|
|
default:
|
|
default:
|
|
- LM_DBG("spitting out [%c] in status %d\n",
|
|
|
|
- *tmp,status );
|
|
|
|
|
|
+ LM_DBG("spitting out [%c] in status %d\n", *tmp,
|
|
|
|
+ status);
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
- }/*char switch*/
|
|
|
|
- }/*for*/
|
|
|
|
|
|
+ } /*char switch*/
|
|
|
|
+ } /*for*/
|
|
|
|
|
|
/* Reached end of buffer */
|
|
/* Reached end of buffer */
|
|
- switch (status)
|
|
|
|
- {
|
|
|
|
|
|
+ switch(status) {
|
|
case URI_OR_TOKEN:
|
|
case URI_OR_TOKEN:
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
case END:
|
|
case END:
|
|
@@ -866,11 +858,12 @@ char* parse_addr_spec(char* const buffer, const char* const end,
|
|
}
|
|
}
|
|
|
|
|
|
endofheader:
|
|
endofheader:
|
|
- if (to_b->display.len==0) to_b->display.s=0;
|
|
|
|
- status=saved_status;
|
|
|
|
|
|
+ if(to_b->display.len == 0)
|
|
|
|
+ to_b->display.s = 0;
|
|
|
|
+ status = saved_status;
|
|
LM_DBG("end of header reached, state=%d\n", status);
|
|
LM_DBG("end of header reached, state=%d\n", status);
|
|
/* check if error*/
|
|
/* check if error*/
|
|
- switch(status){
|
|
|
|
|
|
+ switch(status) {
|
|
case URI_OR_TOKEN:
|
|
case URI_OR_TOKEN:
|
|
case MAYBE_URI_END:
|
|
case MAYBE_URI_END:
|
|
to_b->uri.len = foo - to_b->uri.s;
|
|
to_b->uri.len = foo - to_b->uri.s;
|
|
@@ -880,35 +873,34 @@ endofheader:
|
|
break;
|
|
break;
|
|
default:
|
|
default:
|
|
LM_ERR("invalid To - unexpected "
|
|
LM_ERR("invalid To - unexpected "
|
|
- "end of header in state %d\n", status);
|
|
|
|
|
|
+ "end of header in state %d\n",
|
|
|
|
+ status);
|
|
goto error;
|
|
goto error;
|
|
}
|
|
}
|
|
return tmp;
|
|
return tmp;
|
|
|
|
|
|
error:
|
|
error:
|
|
free_to_params(to_b);
|
|
free_to_params(to_b);
|
|
- to_b->error=PARSE_ERROR;
|
|
|
|
|
|
+ to_b->error = PARSE_ERROR;
|
|
return tmp;
|
|
return tmp;
|
|
-
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-void free_to_params(struct to_body* const tb)
|
|
|
|
|
|
+void free_to_params(struct to_body *const tb)
|
|
{
|
|
{
|
|
- struct to_param *tp=tb->param_lst;
|
|
|
|
|
|
+ struct to_param *tp = tb->param_lst;
|
|
struct to_param *foo;
|
|
struct to_param *foo;
|
|
- while (tp){
|
|
|
|
|
|
+ while(tp) {
|
|
foo = tp->next;
|
|
foo = tp->next;
|
|
pkg_free(tp);
|
|
pkg_free(tp);
|
|
- tp=foo;
|
|
|
|
|
|
+ tp = foo;
|
|
}
|
|
}
|
|
tb->param_lst = NULL;
|
|
tb->param_lst = NULL;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-void free_to(struct to_body* const tb)
|
|
|
|
|
|
+void free_to(struct to_body *const tb)
|
|
{
|
|
{
|
|
free_to_params(tb);
|
|
free_to_params(tb);
|
|
pkg_free(tb);
|
|
pkg_free(tb);
|
|
}
|
|
}
|
|
-
|
|
|