factor/basis/alien/inline/inline.factor

108 lines
3.1 KiB
Factor
Raw Normal View History

2009-07-02 19:35:02 -04:00
! Copyright (C) 2009 Jeremy Hughes.
! See http://factorcode.org/license.txt for BSD license.
USING: accessors alien.inline.compiler alien.inline.types
alien.libraries alien.parser arrays assocs effects fry
generalizations grouping io.files io.files.info io.files.temp
kernel lexer math math.order math.ranges multiline namespaces
sequences splitting strings system vocabs.loader
vocabs.parser words ;
IN: alien.inline
2009-07-01 18:43:51 -04:00
<PRIVATE
SYMBOL: c-library
SYMBOL: library-is-c++
SYMBOL: compiler-args
SYMBOL: c-strings
: function-types-effect ( -- function types effect )
scan scan swap ")" parse-tokens
[ "(" subseq? not ] filter swap parse-arglist ;
2009-07-02 15:33:14 -04:00
: arg-list ( types -- params )
CHAR: a swap length CHAR: a + [a,b]
[ 1string ] map ;
2009-07-05 05:49:31 -04:00
: factor-function ( function types effect -- word quot effect )
annotate-effect [ c-library get ] 3dip
[ [ factorize-type ] map ] dip
types-effect>params-return factorize-type -roll
2009-07-05 05:49:31 -04:00
concat make-function ;
2009-07-01 18:43:51 -04:00
: prototype-string ( function types effect -- str )
[ [ cify-type ] map ] dip
types-effect>params-return cify-type -rot
[ " " join ] map ", " join
"(" prepend ")" append 3array " " join
library-is-c++ get [ "extern \"C\" " prepend ] when ;
2009-07-01 18:43:51 -04:00
: prototype-string' ( function types return -- str )
[ dup arg-list ] <effect> prototype-string ;
: append-function-body ( prototype-str -- str )
" {\n" append parse-here append "\n}\n" append ;
2009-07-01 18:43:51 -04:00
: library-path ( -- str )
"lib" c-library get library-suffix
2009-07-01 18:43:51 -04:00
3array concat temp-file ;
: compile-library? ( -- ? )
2009-07-02 15:33:14 -04:00
library-path dup exists? [
current-vocab vocab-source-path
[ file-info modified>> ] bi@ <=> +lt+ =
] [ drop t ] if ;
2009-07-01 18:43:51 -04:00
: compile-library ( -- )
library-is-c++ get [ C++ ] [ C ] if
compiler-args get
c-strings get "\n" join
c-library get compile-to-library ;
PRIVATE>
2009-07-01 18:43:51 -04:00
: define-c-library ( name -- )
c-library set
V{ } clone c-strings set
V{ } clone compiler-args set ;
: compile-c-library ( -- )
2009-07-01 18:43:51 -04:00
compile-library? [ compile-library ] when
c-library get library-path "cdecl" add-library ;
2009-07-01 18:43:51 -04:00
2009-07-05 19:06:44 -04:00
: define-c-function ( function types effect -- )
[ factor-function define-declared ] 3keep prototype-string
append-function-body c-strings get push ;
2009-07-05 19:06:44 -04:00
: define-c-function' ( function effect -- )
2009-07-05 05:49:31 -04:00
[ in>> ] keep [ factor-function define-declared ] 3keep
2009-07-05 19:06:44 -04:00
out>> prototype-string'
append-function-body c-strings get push ;
: define-c-link ( str -- )
"-l" prepend compiler-args get push ;
: define-c-framework ( str -- )
"-framework" swap compiler-args get '[ _ push ] bi@ ;
: define-c-link/framework ( str -- )
os macosx? [ define-c-framework ] [ define-c-link ] if ;
: define-c-include ( str -- )
"#include " prepend c-strings get push ;
SYNTAX: C-LIBRARY: scan define-c-library ;
2009-07-01 18:43:51 -04:00
SYNTAX: COMPILE-AS-C++ t library-is-c++ set ;
2009-07-01 18:43:51 -04:00
SYNTAX: C-LINK: scan define-c-link ;
2009-07-01 18:43:51 -04:00
SYNTAX: C-FRAMEWORK: scan define-c-framework ;
2009-07-01 18:43:51 -04:00
SYNTAX: C-LINK/FRAMEWORK: scan define-c-link/framework ;
2009-07-01 18:43:51 -04:00
SYNTAX: C-INCLUDE: scan define-c-include ;
2009-07-01 18:43:51 -04:00
2009-07-05 05:49:31 -04:00
SYNTAX: C-FUNCTION:
2009-07-05 19:06:44 -04:00
function-types-effect define-c-function ;
2009-07-01 18:43:51 -04:00
SYNTAX: ;C-LIBRARY compile-c-library ;