more alloca fixes
This commit is contained in:
parent
60d00ede11
commit
f52aa87441
1
CHANGES
1
CHANGES
@ -19,6 +19,7 @@
|
|||||||
head -1 -> head -n 1
|
head -1 -> head -n 1
|
||||||
apending 0 bytes to an empty array would fail it
|
apending 0 bytes to an empty array would fail it
|
||||||
remove socket_sendfile now that we have io_sendfile
|
remove socket_sendfile now that we have io_sendfile
|
||||||
|
break out alloca #include dependency into havealloca.h
|
||||||
|
|
||||||
0.16:
|
0.16:
|
||||||
add buffer_fromsa (make buffer from stralloc)
|
add buffer_fromsa (make buffer from stralloc)
|
||||||
|
@ -141,7 +141,7 @@ libepoll havesigio.h havebsdsf.h havescope.h havedevpoll.h Makefile dep
|
|||||||
|
|
||||||
INCLUDES=buffer.h byte.h fmt.h ip4.h ip6.h mmap.h scan.h socket.h str.h stralloc.h \
|
INCLUDES=buffer.h byte.h fmt.h ip4.h ip6.h mmap.h scan.h socket.h str.h stralloc.h \
|
||||||
uint16.h uint32.h uint64.h open.h textcode.h tai.h taia.h dns.h iopause.h case.h \
|
uint16.h uint32.h uint64.h open.h textcode.h tai.h taia.h dns.h iopause.h case.h \
|
||||||
openreadclose.h readclose.h ndelay.h array.h io.h safemult.h iob.h havealloca.h
|
openreadclose.h readclose.h ndelay.h array.h io.h safemult.h iob.h
|
||||||
|
|
||||||
install: libowfat.a
|
install: libowfat.a
|
||||||
install -d $(INCLUDEDIR) $(MAN3DIR) $(LIBDIR)
|
install -d $(INCLUDEDIR) $(MAN3DIR) $(LIBDIR)
|
||||||
|
@ -6,5 +6,5 @@ void array_cat(array* to,const array* const from) {
|
|||||||
array_fail(to);
|
array_fail(to);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
return array_catb(to,from->p,from->initialized);
|
array_catb(to,from->p,from->initialized);
|
||||||
}
|
}
|
||||||
|
3
havealloca.h
Normal file
3
havealloca.h
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
#if defined(__linux__) || defined(_SGI_SOURCE)
|
||||||
|
#include <alloca.h>
|
||||||
|
#endif
|
@ -20,7 +20,7 @@ int64 iob_send(int64 s,io_batch* b) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (b->bytesleft==0) return 0;
|
if (b->bytesleft==0) return 0;
|
||||||
last=(iob_entry*)(((char*)array_start(&b->b))+array_bytes(&b->b));
|
last=((char*)array_start(&b->b))+array_bytes(&b->b);
|
||||||
v=alloca(b->bufs*sizeof(struct iovec));
|
v=alloca(b->bufs*sizeof(struct iovec));
|
||||||
total=0;
|
total=0;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
@ -2,9 +2,10 @@
|
|||||||
|
|
||||||
int imult16(int16 a,int16 b,int16* c) {
|
int imult16(int16 a,int16 b,int16* c) {
|
||||||
int neg=(a<0);
|
int neg=(a<0);
|
||||||
|
uint16 d;
|
||||||
if (neg) a=-a;
|
if (neg) a=-a;
|
||||||
if (b<0) { neg^=1; b=-b; }
|
if (b<0) { neg^=1; b=-b; }
|
||||||
if (umult16(a,b,c)) return 0;
|
if (umult16(a,b,&d)) return 0;
|
||||||
if (neg) *c=-*c;
|
*c=(neg?-d:d);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -2,9 +2,10 @@
|
|||||||
|
|
||||||
int imult32(int32 a,int32 b,int32* c) {
|
int imult32(int32 a,int32 b,int32* c) {
|
||||||
int neg=(a<0);
|
int neg=(a<0);
|
||||||
|
uint32 d;
|
||||||
if (neg) a=-a;
|
if (neg) a=-a;
|
||||||
if (b<0) { neg^=1; b=-b; }
|
if (b<0) { neg^=1; b=-b; }
|
||||||
if (umult32(a,b,c)) return 0;
|
if (umult32(a,b,&d)) return 0;
|
||||||
if (neg) *c=-*c;
|
*c=(neg?-d:d);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -2,10 +2,11 @@
|
|||||||
|
|
||||||
int imult64(int64 a,int64 b,int64* c) {
|
int imult64(int64 a,int64 b,int64* c) {
|
||||||
int neg=(a<0);
|
int neg=(a<0);
|
||||||
|
uint64 d;
|
||||||
if (neg) a=-a;
|
if (neg) a=-a;
|
||||||
if (b<0) { neg^=1; b=-b; }
|
if (b<0) { neg^=1; b=-b; }
|
||||||
if (umult64(a,b,c)) return 0;
|
if (umult64(a,b,&d)) return 0;
|
||||||
if (neg) *c=-*c;
|
*c=(neg?-d:d);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,9 +2,7 @@
|
|||||||
#include "byte.h"
|
#include "byte.h"
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include "socket.h"
|
#include "socket.h"
|
||||||
#if defined(__linux__) || defined(_SGI_SOURCE)
|
#include "havealloca.h"
|
||||||
#include <alloca.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
unsigned int scan_ip6if(const char* src,char* ip,uint32* scope_id) {
|
unsigned int scan_ip6if(const char* src,char* ip,uint32* scope_id) {
|
||||||
int i=scan_ip6(src,ip);
|
int i=scan_ip6(src,ip);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "textcode.h"
|
#include "textcode.h"
|
||||||
|
#include "havealloca.h"
|
||||||
|
|
||||||
void b64encode(const char* c) {
|
void b64encode(const char* c) {
|
||||||
char* buf=alloca(strlen(c)*2+4);
|
char* buf=alloca(strlen(c)*2+4);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "textcode.h"
|
#include "textcode.h"
|
||||||
|
#include "havealloca.h"
|
||||||
|
|
||||||
void b64encode(const char* c) {
|
void b64encode(const char* c) {
|
||||||
char* buf=alloca(strlen(c)*2+4);
|
char* buf=alloca(strlen(c)*2+4);
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "textcode.h"
|
#include "textcode.h"
|
||||||
|
#include "havealloca.h"
|
||||||
|
|
||||||
void cescape(const char* c) {
|
void cescape(const char* c) {
|
||||||
char* buf=alloca(strlen(c)*5+1);
|
char* buf=alloca(strlen(c)*5+1);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "textcode.h"
|
#include "textcode.h"
|
||||||
|
#include "havealloca.h"
|
||||||
|
|
||||||
void unurl(const char* s) {
|
void unurl(const char* s) {
|
||||||
char* buf;
|
char* buf;
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "buffer.h"
|
#include "buffer.h"
|
||||||
#include "textcode.h"
|
#include "textcode.h"
|
||||||
|
#include "havealloca.h"
|
||||||
|
|
||||||
void urlencode(const char* c) {
|
void urlencode(const char* c) {
|
||||||
char* buf=alloca(strlen(c)*3+1);
|
char* buf=alloca(strlen(c)*3+1);
|
||||||
|
@ -10,7 +10,7 @@ unsigned long scan_tofrom_array(unsigned long (*func)(const char*,char*,unsigned
|
|||||||
array_cat0(src);
|
array_cat0(src);
|
||||||
if (array_failed(src) || array_failed(dest)) return 0;
|
if (array_failed(src) || array_failed(dest)) return 0;
|
||||||
needed=array_bytes(src);
|
needed=array_bytes(src);
|
||||||
x=array_start(dest)+array_bytes(dest);
|
x=((char*)array_start(dest))+array_bytes(dest);
|
||||||
if (!array_allocate(dest,1,array_bytes(dest)+needed-1)) return 0;
|
if (!array_allocate(dest,1,array_bytes(dest)+needed-1)) return 0;
|
||||||
needed=func(array_start(src),x,&scanned);
|
needed=func(array_start(src),x,&scanned);
|
||||||
array_truncate(src,1,array_bytes(src)-1);
|
array_truncate(src,1,array_bytes(src)-1);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user