2005-04-23 19:34:06 -04:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
2005-04-24 00:27:07 -04:00
|
|
|
IN: assembler
|
2005-05-24 01:26:45 -04:00
|
|
|
USING: alien compiler compiler-backend inference kernel
|
|
|
|
kernel-internals lists math memory namespaces words ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %alien-invoke generate-node ( vop -- )
|
2005-05-30 03:37:22 -04:00
|
|
|
vop-in-1 uncons load-library compile-c-call ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-04-30 00:43:39 -04:00
|
|
|
: stack-size 8 + 16 align ;
|
|
|
|
: stack@ 3 + cell * ;
|
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %parameters generate-node ( vop -- )
|
2005-06-09 19:49:31 -04:00
|
|
|
vop-in-1 dup 0 = [ drop ] [ stack-size 1 1 rot SUBI ] ifte ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %unbox generate-node ( vop -- )
|
2005-05-30 03:37:22 -04:00
|
|
|
vop-in-1 uncons f compile-c-call 3 1 rot stack@ STW ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %parameter generate-node ( vop -- )
|
2005-05-30 03:37:22 -04:00
|
|
|
vop-in-1 dup 3 + 1 rot stack@ LWZ ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %box generate-node ( vop -- )
|
2005-05-30 03:37:22 -04:00
|
|
|
vop-in-1 f compile-c-call ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %cleanup generate-node ( vop -- )
|
2005-05-30 03:37:22 -04:00
|
|
|
vop-in-1 dup 0 = [ drop ] [ stack-size 1 1 rot ADDI ] ifte ;
|