! 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 combinators effects fry generalizations grouping io.files io.files.info io.files.temp kernel lexer locals math math.order math.ranges multiline namespaces quotations sequences source-files splitting strings system vocabs.loader words ; IN: alien.inline SYMBOL: c-library SYMBOL: library-is-c++ SYMBOL: compiler-args SYMBOL: c-strings > [ file-info modified>> ] bi@ <=> +lt+ = ] [ drop t ] if ; : compile-library ( -- ) library-is-c++ get [ C++ ] [ C ] if compiler-args get c-strings get "\n" join c-library get compile-to-library ; PRIVATE> : function-types-effect ( -- function types effect ) scan scan swap ")" parse-tokens [ "(" subseq? not ] filter swap parse-arglist ; : c-function-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 append-function-body ; : c-function-string' ( function types return -- str ) [ dup arg-list ] c-function-string append-function-body ; : 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 concat make-function ; : define-c-library ( name -- ) c-library set V{ } clone c-strings set V{ } clone compiler-args set ; : compile-c-library ( -- ) compile-library? [ compile-library ] when c-library get dup library-path "cdecl" add-library ; : define-c-function ( function types effect -- ) [ factor-function define-declared ] 3keep c-function-string c-strings get push ; : define-c-function' ( function effect -- ) [ in>> ] keep [ factor-function define-declared ] 3keep out>> c-function-string' 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 ; SYNTAX: COMPILE-AS-C++ t library-is-c++ set ; SYNTAX: C-LINK: scan define-c-link ; SYNTAX: C-FRAMEWORK: scan define-c-framework ; SYNTAX: C-LINK/FRAMEWORK: scan define-c-link/framework ; SYNTAX: C-INCLUDE: scan define-c-include ; SYNTAX: C-FUNCTION: function-types-effect define-c-function ; SYNTAX: ;C-LIBRARY compile-c-library ;