Dictionary allocation is a stack-oriented allocation scheme, i.e., if you want to deallocate X, you also deallocate everything allocated after X.
The allocations using the words below are contiguous and grow the region
towards increasing addresses. Other words that allocate dictionary
memory of any kind (i.e., defining words including :noname
) end
the contiguous region and start a new one.
In Standard Forth only create
d words are guaranteed to produce an
address that is the start of the following contiguous region. In
particular, the cell allocated by variable
is not guaranteed to
be contiguous with following allot
ed memory.
You can deallocate memory by using allot
with a negative argument
(with some restrictions, see allot
). For larger deallocations use
marker
.
here
( – addr ) core “here”
Return the address of the next free location in data space.
unused
( – u ) core-ext “unused”
Return the amount of free space remaining (in address units) in
the region addressed by here
.
allot
( n – ) core “allot”
Reserve n address units of data space without initialization. n is a signed number, passing a negative n releases memory. In ANS Forth you can only deallocate memory from the current contiguous region in this way. In Gforth you can deallocate anything in this way but named words. The system does not check this restriction.
->here
( addr – ) gforth-1.0 “to-here”
Change the value of here
to addr.
c,
( c – ) core “c-comma”
Reserve data space for one char and store c in the space.
f,
( f – ) gforth-0.2 “f,”
Reserve data space for one floating-point number and store f in the space.
,
( w – ) core “comma”
Reserve data space for one cell and store w in the space.
2,
( w1 w2 – ) gforth-0.2 “2,”
Reserve data space for two cells and store the double w1 w2 there, w2 first (lower address).
w,
( w – ) gforth-1.0 “w-comma”
l,
( l – ) gforth-1.0 “l-comma”
x,
( x – ) gforth-1.0 “x-comma”
xd,
( xd – ) gforth-1.0 “x-d-comma”
A,
( addr – ) gforth-0.2 “A,”
Reserve data space for one cell, and store addr there. For our
cross-compiler this provides the type information necessary for a
relocatable image; normally, though, this is equivalent to
,
.
mem,
( addr u – ) gforth-0.6 “mem,”
save-mem-dict
( addr1 u – addr2 u ) gforth-0.7 “save-mem-dict”
Copy the memory block addr1 u to a newly allot
ed
memory block of size u; the target memory block starts at
addr2.
Memory accesses have to be aligned (see Address arithmetic). So of
course you should allocate memory in an aligned way, too. I.e., before
allocating allocating a cell, here
must be cell-aligned, etc.
The words below align here
if it is not already. Basically it is
only already aligned for a type, if the last allocation was a multiple
of the size of this type and if here
was aligned for this type
before.
After freshly create
ing a word, here
is align
ed in
Standard Forth (maxalign
ed in Gforth).
align
( – ) core “align”
If the data-space pointer is not aligned, reserve enough space to align it.
falign
( – ) floating “f-align”
If the data-space pointer is not float-aligned, reserve enough space to align it.
sfalign
( – ) floating-ext “s-f-align”
If the data-space pointer is not single-float-aligned, reserve enough space to align it.
dfalign
( – ) floating-ext “d-f-align”
If the data-space pointer is not double-float-aligned, reserve enough space to align it.
maxalign
( – ) gforth-0.2 “maxalign”
Align data-space pointer for all alignment requirements.
cfalign
( – ) gforth-0.2 “cfalign”
Align data-space pointer for code field requirements (i.e., such that the corresponding body is maxaligned).