2012-06-02 15:06:22 +00:00
|
|
|
/* Copyright (c) 2012, Avian Contributors
|
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
|
|
|
#ifndef LZMA_UTIL_H
|
|
|
|
#define LZMA_UTIL_H
|
|
|
|
|
|
|
|
#include "lzma.h"
|
2012-06-02 21:43:42 +00:00
|
|
|
#include "C/Types.h"
|
2013-02-21 03:42:09 +00:00
|
|
|
#include <avian/vm/system/system.h>
|
2012-06-02 15:06:22 +00:00
|
|
|
#include "allocator.h"
|
|
|
|
|
|
|
|
namespace vm {
|
|
|
|
|
|
|
|
const unsigned Padding = 16;
|
|
|
|
|
|
|
|
class LzmaAllocator {
|
|
|
|
public:
|
|
|
|
LzmaAllocator(Allocator* a): a(a) {
|
|
|
|
allocator.Alloc = allocate;
|
|
|
|
allocator.Free = free;
|
|
|
|
}
|
|
|
|
|
|
|
|
ISzAlloc allocator;
|
|
|
|
Allocator* a;
|
|
|
|
|
|
|
|
static void* allocate(void* allocator, size_t size) {
|
|
|
|
uint8_t* p = static_cast<uint8_t*>
|
|
|
|
(static_cast<LzmaAllocator*>(allocator)->a->allocate(size + Padding));
|
|
|
|
int32_t size32 = size;
|
|
|
|
memcpy(p, &size32, 4);
|
|
|
|
return p + Padding;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void free(void* allocator, void* address) {
|
|
|
|
if (address) {
|
|
|
|
void* p = static_cast<uint8_t*>(address) - Padding;
|
|
|
|
int32_t size32;
|
|
|
|
memcpy(&size32, p, 4);
|
|
|
|
static_cast<LzmaAllocator*>(allocator)->a->free(p, size32 + Padding);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace vm
|
|
|
|
|
|
|
|
#endif // LZMA_UTIL_H
|