move repeated temp alloca in parser into inline function to not exhaust

stack space
This commit is contained in:
leitner
2004-02-05 02:12:27 +00:00
parent 3dd5fb78b1
commit a755f3154b

View File

@@ -65,6 +65,14 @@ static int unbase64(char* buf) {
return destlen;
}
static inline int add_normalized(const char* s,long len) {
char* newdn=alloca(len+1);
long val;
if ((val=mstorage_add(&stringtable,newdn,normalize_dn(newdn,s,len)))<0) return -1;
return val;
}
static int parserec(buffer* b, struct ldaprec** l) {
char buf[8192];
int n,i,eof=0,ofs=0;
@@ -142,8 +150,7 @@ lookagain:
if (tmp==objectClass) {
if ((val=mduptab_add(&classes,payload.s,len-1))<0) goto nomem;
} else if (tmp==dn) {
char* newdn=alloca(len);
if ((val=mstorage_add(&stringtable,newdn,normalize_dn(newdn,payload.s,len)))<0) goto nomem;
if ((val=add_normalized(payload.s,len))==-1) goto nomem;
} else
if ((val=mstorage_add_bin(&stringtable,payload.s,len))<0) goto nomem;
addattribute(l,tmp,val);
@@ -181,8 +188,7 @@ lookagain:
if (tmp==objectClass) {
if ((val=mduptab_add(&classes,payload.s,len-1))<0) goto nomem;
} else if (tmp==dn) {
char* newdn=alloca(payload.len+1);
if ((val=mstorage_add(&stringtable,newdn,normalize_dn(newdn,payload.s,payload.len)))<0) goto nomem;
if ((val=add_normalized(payload.s,payload.len))==-1) goto nomem;
} else
if ((val=mstorage_add_bin(&stringtable,payload.s,payload.len))<0) goto nomem;
addattribute(l,tmp,val);