mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-10 19:52:50 -06:00
more bugfixes in the allocator
This commit is contained in:
@@ -31,55 +31,20 @@ ref<C> vector_new(Vector<A> C::* field, size_t len)
|
||||
PGF_INTERNAL_DECL size_t
|
||||
get_next_padovan(size_t min);
|
||||
|
||||
/* Resize a vector by creating a new one and copying the old content.
|
||||
* The new vector is now also safe to update */
|
||||
template <class A> inline PGF_INTERNAL
|
||||
ref<Vector<A>> vector_copy(ref<Vector<A>> vec, size_t len)
|
||||
{
|
||||
size_t size = len*sizeof(A);
|
||||
ref<Vector<A>> res = PgfDB::malloc<Vector<A>>(size);
|
||||
res->len = len;
|
||||
memcpy(res->data, vec->data, size);
|
||||
return res;
|
||||
}
|
||||
|
||||
/* Resize a vector by changing its length. If there is no enough space
|
||||
* the implementation will create a copy, but whenever possible it will
|
||||
* return the reference of the original vector. In the later case, it
|
||||
* changes the length in-place which means that the function is safe
|
||||
* only if the vector was created during the current transaction. */
|
||||
* return the reference to the original vector. A copy is created also
|
||||
* if txn_id is different from the current transaction. In this way
|
||||
* it is safe to change the length. */
|
||||
template <class A> inline PGF_INTERNAL
|
||||
ref<Vector<A>> vector_unsafe_resize(ref<Vector<A>> vec, size_t len)
|
||||
ref<Vector<A>> vector_resize(ref<Vector<A>> vec, size_t len, txn_t txn_id)
|
||||
{
|
||||
size_t new_len = get_next_padovan(len);
|
||||
size_t old_len = get_next_padovan(vec->len);
|
||||
size_t new_len = get_next_padovan(len);
|
||||
|
||||
if (old_len == new_len)
|
||||
return vec;
|
||||
|
||||
ref<Vector<A>> res = PgfDB::realloc<Vector<A>>(vec,old_len*sizeof(A),new_len*sizeof(A)).as_object();
|
||||
res->len = len;
|
||||
return res;
|
||||
}
|
||||
|
||||
/* Resize a vector embedded in another structure, by changing its length.
|
||||
* If there is no enough space the implementation will copy the structure,
|
||||
* but whenever possible it will return a reference to
|
||||
* the original structure. In the later case, it changes
|
||||
* the vector's length in-place which means that the function is safe
|
||||
* only if the structure was created during the current transaction. */
|
||||
template <class C, class A> inline PGF_INTERNAL
|
||||
ref<C> vector_unsafe_resize(ref<C> r, Vector<A> C::* field, size_t len)
|
||||
{
|
||||
size_t old_len = get_next_padovan((r->*field).len);
|
||||
size_t new_len = get_next_padovan(len);
|
||||
|
||||
if (old_len == new_len)
|
||||
return r;
|
||||
|
||||
ref<C> res = PgfDB::realloc<C>(r,old_len*sizeof(A),new_len*sizeof(A)).as_object();
|
||||
(res->*field).len = len;
|
||||
return res;
|
||||
vec = PgfDB::realloc<Vector<A>>(vec,old_len*sizeof(A),new_len*sizeof(A),txn_id);
|
||||
vec->len = len;
|
||||
return vec;
|
||||
}
|
||||
|
||||
template <class A> inline PGF_INTERNAL
|
||||
|
||||
Reference in New Issue
Block a user