File: memall.c

package info (click to toggle)
yforth 0.1beta-7
  • links: PTS
  • area: main
  • in suites: hamm
  • size: 352 kB
  • ctags: 787
  • sloc: ansic: 4,414; makefile: 60
file content (40 lines) | stat: -rw-r--r-- 1,204 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/* yForth? - Written by Luca Padovani (C) 1996/97
 * ------------------------------------------------------------------------
 * This software is FreeWare as long as it comes with this header in each
 * source file, anyway you can use it or any part of it whatever
 * you want. It comes without any warranty, so use it at your own risk.
 * ------------------------------------------------------------------------
 * Module name: memall.c
 * Abstract:    Memory allocation word set
 */

#include <string.h>
#include <malloc.h>
#include "yforth.h"
#include "core.h"
#include "coree.h"

/**************************************************************************/
/* WORDS ******************************************************************/
/**************************************************************************/

void _allocate() {
    register void *addr = malloc(*sp);
    if (addr == NULL) *sp = 0;
    else *sp = (Cell) addr;
    *--sp = FFLAG(addr == NULL);
}

void _free() {
    free((void *) *sp);
    *sp = FFLAG(0);
}

void _resize() {
    register void *addr = realloc((void *) sp[1], sp[0]);
    if (addr == NULL) sp[1] = 0;
    else sp[1] = (Cell) addr;
    *sp = FFLAG(addr == NULL);
}