Idris2/support/refc/buffer.c

119 lines
3.1 KiB
C
Raw Normal View History

#include "buffer.h"
#include "refc_util.h"
2020-05-18 16:51:10 +03:00
#include <sys/stat.h>
#include <string.h>
void* newBuffer(int bytes) {
2020-05-18 16:51:10 +03:00
size_t size = sizeof(Buffer) + bytes*sizeof(uint8_t);
Buffer* buf = malloc(size);
if (buf == NULL) {
return NULL;
}
buf->size = bytes;
memset(buf->data, 0, bytes);
2020-05-18 16:51:10 +03:00
return (void*)buf;
}
static void assert_valid_range(Buffer* buf, int64_t offset, int64_t len) {
IDRIS2_REFC_VERIFY(offset >= 0, "offset (%lld) < 0", (long long) offset);
IDRIS2_REFC_VERIFY(len >= 0, "len (%lld) < 0", (long long) offset);
IDRIS2_REFC_VERIFY(offset + len <= buf->size,
"offset (%lld) + len (%lld) > buf.size (%lld)",
(long long) offset, (long long) len, (long long) buf->size);
}
void copyBuffer(void* from, int from_offset, int len,
void* to, int to_offset) {
2020-05-18 16:51:10 +03:00
Buffer* bfrom = from;
Buffer* bto = to;
assert_valid_range(bfrom, from_offset, len);
assert_valid_range(bto, to_offset, len);
memcpy(bto->data + to_offset, bfrom->data + from_offset, len);
2020-05-18 16:51:10 +03:00
}
int getBufferSize(void* buffer) {
2020-05-18 16:51:10 +03:00
return ((Buffer*)buffer)->size;
}
void setBufferByte(void* buffer, int loc, int byte) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(buffer, loc, 1);
b->data[loc] = byte;
2020-05-18 16:51:10 +03:00
}
void setBufferInt(void* buffer, int loc, int64_t val) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(b, loc, 8);
b->data[loc ] = val & 0xff;
b->data[loc+1] = (val >> 8) & 0xff;
b->data[loc+2] = (val >> 16) & 0xff;
b->data[loc+3] = (val >> 24) & 0xff;
b->data[loc+4] = (val >> 32) & 0xff;
b->data[loc+5] = (val >> 40) & 0xff;
b->data[loc+6] = (val >> 48) & 0xff;
b->data[loc+7] = (val >> 56) & 0xff;
2020-05-18 16:51:10 +03:00
}
void setBufferDouble(void* buffer, int loc, double val) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(b, loc, sizeof(double));
unsigned char* c = (unsigned char*)(& val);
int i;
for (i = 0; i < sizeof(double); ++i) {
b->data[loc+i] = c[i];
2020-05-18 16:51:10 +03:00
}
}
void setBufferString(void* buffer, int loc, char* str) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
size_t len = strlen(str);
assert_valid_range(b, loc, len);
memcpy((b->data)+loc, str, len);
2020-05-18 16:51:10 +03:00
}
uint8_t getBufferByte(void* buffer, int loc) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(b, loc, 1);
return b->data[loc];
2020-05-18 16:51:10 +03:00
}
int64_t getBufferInt(void* buffer, int loc) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(b, loc, 8);
int64_t result = 0;
for (size_t i=0; i<8; i++) {
result |= (uint64_t)(uint8_t)b->data[loc + i] << (8 * i);
2020-05-18 16:51:10 +03:00
}
return result;
2020-05-18 16:51:10 +03:00
}
double getBufferDouble(void* buffer, int loc) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(b, loc, sizeof(double));
2020-05-18 16:51:10 +03:00
double d;
// I am even less proud of this
unsigned char *c = (unsigned char*)(& d);
int i;
for (i = 0; i < sizeof(double); ++i) {
c[i] = b->data[loc+i];
2020-05-18 16:51:10 +03:00
}
return d;
2020-05-18 16:51:10 +03:00
}
char* getBufferString(void* buffer, int loc, int len) {
2020-05-18 16:51:10 +03:00
Buffer* b = buffer;
assert_valid_range(b, loc, len);
2020-05-18 16:51:10 +03:00
char * s = (char*)(b->data + loc);
char * rs = malloc(len + 1);
strncpy(rs, s, len);
rs[len] = '\0';
return rs;
}