2017-07-12 22:00:23 -04:00
|
|
|
! Copyright (C) 2009 Matthew Willis, 2017 Björn Lindqvist.
|
2017-07-12 09:19:07 -04:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
|
|
USING: accessors alien.c-types alien.data alien.strings destructors io
|
2017-07-12 22:00:23 -04:00
|
|
|
io.encodings.utf8 kernel llvm.ffi prettyprint ;
|
2017-07-12 09:19:07 -04:00
|
|
|
IN: llvm.wrappers
|
|
|
|
|
|
|
|
ERROR: llvm-error message ;
|
|
|
|
|
2017-07-12 22:00:23 -04:00
|
|
|
: llvm-throw ( void* -- )
|
2017-07-12 09:19:07 -04:00
|
|
|
[ utf8 alien>string ] [ LLVMDisposeMessage ] bi llvm-error ;
|
|
|
|
|
|
|
|
: <dispose> ( alien class -- disposable ) new swap >>value ;
|
|
|
|
|
|
|
|
TUPLE: module value disposed ;
|
|
|
|
M: module dispose* value>> LLVMDisposeModule ;
|
|
|
|
|
|
|
|
: <module> ( name -- module )
|
|
|
|
LLVMModuleCreateWithName module <dispose> ;
|
|
|
|
|
|
|
|
TUPLE: provider value module disposed ;
|
|
|
|
M: provider dispose* value>> LLVMDisposeModuleProvider ;
|
|
|
|
|
|
|
|
: (provider) ( module -- provider )
|
|
|
|
[ value>> LLVMCreateModuleProviderForExistingModule provider <dispose> ]
|
|
|
|
[ t >>disposed value>> ] bi
|
|
|
|
>>module ;
|
|
|
|
|
|
|
|
: <provider> ( module -- provider )
|
|
|
|
[ (provider) ] with-disposal ;
|
|
|
|
|
2017-07-12 22:00:23 -04:00
|
|
|
TUPLE: engine value disposed ;
|
|
|
|
M: engine dispose* value>> LLVMDisposeExecutionEngine ;
|
|
|
|
|
|
|
|
: (engine) ( LLVMModuleRef -- LLVMExecutionEngineRef )
|
|
|
|
f void* <ref> f void* <ref>
|
|
|
|
[ swapd LLVMCreateExecutionEngineForModule drop ] 2keep
|
|
|
|
void* deref [ llvm-throw ] when*
|
|
|
|
void* deref ;
|
|
|
|
|
|
|
|
: <engine> ( module -- engine )
|
|
|
|
[
|
|
|
|
[ value>> (engine) engine <dispose> ]
|
|
|
|
[ t >>disposed drop ] bi
|
|
|
|
] with-disposal ;
|
|
|
|
|
|
|
|
: find-function ( engine name -- function/f )
|
|
|
|
[ value>> ] dip f void* <ref>
|
|
|
|
[ LLVMFindFunction drop ] keep void* deref ;
|
|
|
|
|
|
|
|
: function-pointer ( engine function -- alien )
|
|
|
|
[ value>> ] dip LLVMGetPointerToGlobal ;
|
|
|
|
|
2017-07-12 09:19:07 -04:00
|
|
|
TUPLE: buffer value disposed ;
|
|
|
|
M: buffer dispose* value>> LLVMDisposeMemoryBuffer ;
|
|
|
|
|
|
|
|
: <buffer> ( path -- buffer )
|
|
|
|
f void* <ref> f void* <ref>
|
|
|
|
[ LLVMCreateMemoryBufferWithContentsOfFile drop ] 2keep
|
|
|
|
void* deref [ llvm-throw ] when* void* deref buffer <dispose> ;
|