stk/Src/address.c

53 lines
1.2 KiB
C
Raw Normal View History

1996-09-27 06:29:02 -04:00
/*
*
* a d d r e s s . c -- Addresses management
*
*
1999-09-05 07:16:41 -04:00
* Copyright <EFBFBD> 1993-1999 Erick Gallesio - I3S-CNRS/ESSI <eg@unice.fr>
1996-09-27 06:29:02 -04:00
*
*
1999-09-05 07:16:41 -04:00
* Permission to use, copy, modify, distribute,and license this
* software and its documentation for any purpose is hereby granted,
* provided that existing copyright notices are retained in all
* copies and that this notice is included verbatim in any
* distributions. No written agreement, license, or royalty fee is
* required for any of the authorized uses.
* This software is provided ``AS IS'' without express or implied
* warranty.
1996-09-27 06:29:02 -04:00
*
* Author: Erick Gallesio [eg@kaolin.unice.fr]
* Creation date: 16-Mar-1994 10:34
1999-09-05 07:16:41 -04:00
* Last file update: 3-Sep-1999 20:18 (eg)
1996-09-27 06:29:02 -04:00
*
*
*/
#include "stk.h"
#include "gc.h"
SCM STk_address2object(char *buffer)
{
SCM address;
1998-09-30 07:11:02 -04:00
sscanf(buffer, "%lx", (unsigned long *) &address);
1996-09-27 06:29:02 -04:00
if (!STk_valid_address(address))
Err("bad address", STk_makestring(buffer));
return address;
}
PRIMITIVE STk_address_of(SCM obj)
{
SCM z;
NEWCELL(z, tc_address);
z->storage_as.env.data = obj;
return z;
}
PRIMITIVE STk_addressp(SCM address)
{
return TYPEP(address, tc_address)? Truth: Ntruth;
}