Convert to ObjC++
FossilOrigin-Name: 7c2704b3d77d6e63d960e315bfb601fddbf6fce538b7c5db6da664e04fbce4c2
This commit is contained in:
parent
04fa50a332
commit
133382170f
34 changed files with 87 additions and 79 deletions
148
src/tools.mm
Normal file
148
src/tools.mm
Normal file
|
@ -0,0 +1,148 @@
|
|||
// implementation of generic tools
|
||||
|
||||
#include "tools.h"
|
||||
#include <new>
|
||||
|
||||
//////////////////////////// pool ///////////////////////////
|
||||
|
||||
pool::pool()
|
||||
{
|
||||
blocks = 0;
|
||||
allocnext(POOLSIZE);
|
||||
for (int i = 0; i < MAXBUCKETS; i++)
|
||||
reuse[i] = NULL;
|
||||
};
|
||||
|
||||
void *
|
||||
pool::alloc(size_t size)
|
||||
{
|
||||
if (size > MAXREUSESIZE) {
|
||||
return malloc(size);
|
||||
} else {
|
||||
size = bucket(size);
|
||||
void **r = (void **)reuse[size];
|
||||
if (r) {
|
||||
reuse[size] = *r;
|
||||
return (void *)r;
|
||||
} else {
|
||||
size <<= PTRBITS;
|
||||
if (left < size)
|
||||
allocnext(POOLSIZE);
|
||||
char *r = p;
|
||||
p += size;
|
||||
left -= size;
|
||||
return r;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
void
|
||||
pool::dealloc(void *p, size_t size)
|
||||
{
|
||||
if (size > MAXREUSESIZE) {
|
||||
free(p);
|
||||
} else {
|
||||
size = bucket(size);
|
||||
if (size) // only needed for 0-size free, are there any?
|
||||
{
|
||||
*((void **)p) = reuse[size];
|
||||
reuse[size] = p;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
void *
|
||||
pool::realloc(void *p, size_t oldsize, size_t newsize)
|
||||
{
|
||||
void *np = alloc(newsize);
|
||||
if (!oldsize)
|
||||
return np;
|
||||
memcpy(np, p, newsize > oldsize ? oldsize : newsize);
|
||||
dealloc(p, oldsize);
|
||||
return np;
|
||||
};
|
||||
|
||||
void
|
||||
pool::dealloc_block(void *b)
|
||||
{
|
||||
if (b) {
|
||||
dealloc_block(*((char **)b));
|
||||
free(b);
|
||||
};
|
||||
}
|
||||
|
||||
void
|
||||
pool::allocnext(size_t allocsize)
|
||||
{
|
||||
char *b = (char *)malloc(allocsize + PTRSIZE);
|
||||
*((char **)b) = blocks;
|
||||
blocks = b;
|
||||
p = b + PTRSIZE;
|
||||
left = allocsize;
|
||||
};
|
||||
|
||||
char *
|
||||
pool::string(char *s, size_t l)
|
||||
{
|
||||
char *b = (char *)alloc(l + 1);
|
||||
strncpy(b, s, l);
|
||||
b[l] = 0;
|
||||
return b;
|
||||
};
|
||||
|
||||
pool *
|
||||
gp() // useful for global buffers that need to be initialisation order
|
||||
// independant
|
||||
{
|
||||
static pool *p = NULL;
|
||||
return p ? p : (p = new pool());
|
||||
};
|
||||
|
||||
///////////////////////// misc tools ///////////////////////
|
||||
|
||||
char *
|
||||
path(char *s)
|
||||
{
|
||||
for (char *t = s; t = strpbrk(t, "/\\"); *t++ = PATHDIV)
|
||||
;
|
||||
return s;
|
||||
};
|
||||
|
||||
char *
|
||||
loadfile(char *fn, int *size)
|
||||
{
|
||||
FILE *f = fopen(fn, "rb");
|
||||
if (!f)
|
||||
return NULL;
|
||||
fseek(f, 0, SEEK_END);
|
||||
int len = ftell(f);
|
||||
fseek(f, 0, SEEK_SET);
|
||||
char *buf = (char *)malloc(len + 1);
|
||||
if (!buf)
|
||||
return NULL;
|
||||
buf[len] = 0;
|
||||
size_t rlen = fread(buf, 1, len, f);
|
||||
fclose(f);
|
||||
if (len != rlen || len <= 0) {
|
||||
free(buf);
|
||||
return NULL;
|
||||
};
|
||||
if (size != NULL)
|
||||
*size = len;
|
||||
return buf;
|
||||
};
|
||||
|
||||
void
|
||||
endianswap(
|
||||
void *memory, int stride, int length) // little indians as storage format
|
||||
{
|
||||
if (*((char *)&stride))
|
||||
return;
|
||||
loop(w, length) loop(i, stride / 2)
|
||||
{
|
||||
uchar *p = (uchar *)memory + w * stride;
|
||||
uchar t = p[i];
|
||||
p[i] = p[stride - i - 1];
|
||||
p[stride - i - 1] = t;
|
||||
};
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue