ExternalLibraryFunction.st
author Michael Beyl <mb@exept.de>
Thu, 01 Mar 2012 16:22:21 +0100
changeset 14037 38519c7f45fa
parent 13782 1994fe87f21e
child 14103 3df000b77712
permissions -rw-r--r--
added: #name:module:callType:returnType:argumentTypes: #tryAgainWithAsyncSafeArguments:forCPPInstance: changed: #example #invokeFFIwithArguments:forCPPInstance: allow string and bytearray args to async ffi calls, by allocating temporary externalbytes buffers and copying values in and out of them
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
8728
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     1
"
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     2
 COPYRIGHT (c) 2004 by eXept Software AG
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
     3
	      All Rights Reserved
8728
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     4
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     5
 This software is furnished under a license and may be used
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     6
 only in accordance with the terms of that license and with the
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     8
 be provided or otherwise made available to, or used by, any
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
     9
 other person.  No title to or ownership of the software is
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    10
 hereby transferred.
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    11
"
8533
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
"{ Package: 'stx:libbasic' }"
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
ExternalFunction subclass:#ExternalLibraryFunction
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
    15
	instanceVariableNames:'flags moduleName returnType argumentTypes owningClass'
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
    16
	classVariableNames:'DLLPATH FLAG_VIRTUAL FLAG_NONVIRTUAL FLAG_ASYNC
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
    17
		FLAG_UNLIMITEDSTACK FLAG_RETVAL_IS_CONST CALLTYPE_MASK
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
    18
		CALLTYPE_API CALLTYPE_C CALLTYPE_OLE CALLTYPE_V8 CALLTYPE_V9
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
    19
		CALLTYPE_UNIX64'
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
    20
	poolDictionaries:''
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
    21
	category:'System-Support'
8533
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
!
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    24
!ExternalLibraryFunction primitiveDefinitions!
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    25
%{
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    26
9337
ab6bbf58bf0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9336
diff changeset
    27
#ifdef HAVE_FFI
ab6bbf58bf0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9336
diff changeset
    28
# include <ffi.h>
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    29
# define MAX_ARGS    128
9365
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    30
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    31
extern ffi_type *__get_ffi_type_sint();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    32
extern ffi_type *__get_ffi_type_sint8();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    33
extern ffi_type *__get_ffi_type_sint16();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    34
extern ffi_type *__get_ffi_type_sint32();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    35
extern ffi_type *__get_ffi_type_sint64();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    36
extern ffi_type *__get_ffi_type_uint();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    37
extern ffi_type *__get_ffi_type_uint8();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    38
extern ffi_type *__get_ffi_type_uint16();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    39
extern ffi_type *__get_ffi_type_uint32();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    40
extern ffi_type *__get_ffi_type_uint64();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    41
extern ffi_type *__get_ffi_type_float();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    42
extern ffi_type *__get_ffi_type_double();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    43
extern ffi_type *__get_ffi_type_void();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    44
extern ffi_type *__get_ffi_type_pointer();
9003f8432516 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9347
diff changeset
    45
13412
9a5f99d66cd9 Jan's changes
vrany
parents: 13337
diff changeset
    46
#else
9a5f99d66cd9 Jan's changes
vrany
parents: 13337
diff changeset
    47
#error "HAVE_FFI not defined!"
9337
ab6bbf58bf0a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9336
diff changeset
    48
#endif
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    49
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    50
%}
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    51
! !
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    52
8728
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    53
!ExternalLibraryFunction class methodsFor:'documentation'!
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    54
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    55
copyright
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    56
"
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    57
 COPYRIGHT (c) 2004 by eXept Software AG
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
    58
	      All Rights Reserved
8728
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    59
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    60
 This software is furnished under a license and may be used
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    61
 only in accordance with the terms of that license and with the
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    62
 inclusion of the above copyright notice.   This software may not
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    63
 be provided or otherwise made available to, or used by, any
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    64
 other person.  No title to or ownership of the software is
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    65
 hereby transferred.
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
    66
"
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    67
!
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
    68
9331
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    69
documentation
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    70
"
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    71
    instances of me are used to interface to external library functions (as found in a dll/shared object).
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    72
12680
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    73
    Inside a method, when a special external-call pragma such as:
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    74
        <api: bool MessageBeep(uint)>
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    75
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    76
    is encountered by the parser, the compiler generates a call via
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    77
        <correspondingExternalLibraryFunctionObject> invokeWithArguments: argumentArray.
9331
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    78
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    79
    In the invoke method, the library is checked to be loaded (and loaded if not already),
9336
f604a89f17f5 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9331
diff changeset
    80
    the arguments are converted to C and pushed onto the C-stack, the function is called,
9331
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
    81
    and finally, the return value is converted back from C to a smalltalk object.
12680
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    82
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    83
    The parser supports the call-syntax of various other smalltalk dialects:
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    84
        Squeak / ST-X:
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    85
            <cdecl:   [async] [virtual|nonVirtual][const] returnType functionNameStringOrIndex ( argType1..argTypeN ) module: moduleName > 
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    86
            <apicall: [async] [virtual|nonVirtual][const] returnType functionNameStringOrIndex ( argType1..argTypeN ) module: moduleName >
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    87
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    88
        Dolphin:
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    89
            <stdcall: [virtual|nonVirtual][const] returnType functionNameStringOrIndex argType1..argTypeN>
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    90
            <cdecl:   [virtual|nonVirtual][const] returnType functionNameStringOrIndex argType1..argTypeN> 
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    91
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    92
        ST/V:
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    93
            <api: functionName argType1 .. argTypeN returnType> 
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    94
            <ccall: functionName argType1 .. argTypeN returnType> 
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    95
            <ole: vFunctionIndex argType1 .. argTypeN returnType>
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    96
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    97
        VisualWorks:
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    98
            <c: ...>
b0661f4ef910 changed: #documentation
Claus Gittinger <cg@exept.de>
parents: 12657
diff changeset
    99
            <c: #define NAME value>
9331
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
   100
"
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
   101
!
c26a7de1468c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9330
diff changeset
   102
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   103
example
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   104
"
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   105
                                                                [exBegin]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   106
        |f|
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   107
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   108
        f := ExternalLibraryFunction new.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   109
        f beCallTypeWINAPI.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   110
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   111
        f name:'MessageBeep'
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   112
          module:'user32.dll'
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   113
          returnType:#boolean
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   114
          argumentTypes:#(uint).
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   115
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   116
        f invokeWith:1.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   117
                                                                [exEnd]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   118
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   119
  Synchronous vs. Asynchronous calls:
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   120
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   121
    by default, foreign function calls are synchronous, effecftively blocking the whole ST/X system
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   122
    (that is by purpose,´because most C-code is not prepared for being interrupted, and also, normal
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   123
     code is not prepared for a garbage collector to move objects around, while another C thread might
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   124
     access the data...).
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   125
    Therefore, the following will block all ST/X activity for 10 seconds 
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   126
    (try interacting with the launcher while the Sleep is performing):
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   127
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   128
                                                                [exBegin]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   129
        |f|
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   130
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   131
        f := ExternalLibraryFunction new.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   132
        f beCallTypeWINAPI.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   133
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   134
        f name:'Sleep'
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   135
          module:'kernel32.dll'
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   136
          returnType:#void
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   137
          argumentTypes:#(uint).
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   138
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   139
        f invokeWith:10000.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   140
                                                                [exEnd]
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   141
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   142
    if you know what you do and you do not pass any possibly moving objects (such as strings) as argument,
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   143
    the call can be made asynchronous. In that case, ONLY the calling thread will be blocked; all other smalltalk
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   144
    threads wil continue to execute.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   145
    (try interacting now with the launcher while the Sleep is performing):
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   146
                                                                [exBegin]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   147
        |f|
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   148
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   149
        f := ExternalLibraryFunction new.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   150
        f beCallTypeWINAPI.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   151
        f beAsync.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   152
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   153
        f name:'Sleep'
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   154
          module:'kernel32.dll'
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   155
          returnType:#void
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   156
          argumentTypes:#(uint).
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   157
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   158
        f invokeWith:10000.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   159
                                                                [exEnd]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   160
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   161
"
8728
d70396dc4e96 copyright
Claus Gittinger <cg@exept.de>
parents: 8550
diff changeset
   162
! !
8533
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
8550
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   164
!ExternalLibraryFunction class methodsFor:'instance creation'!
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   165
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   166
name:functionName module:moduleName returnType:returnType argumentTypes:argTypes
8550
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   167
    ^ self new
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   168
	name:functionName module:moduleName
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   169
	returnType:returnType argumentTypes:argTypes
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   170
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   171
    "Created: / 01-08-2006 / 15:19:08 / cg"
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   172
! !
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   173
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   174
!ExternalLibraryFunction class methodsFor:'class initialization'!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   175
11050
226b25e4bb97 comments
Claus Gittinger <cg@exept.de>
parents: 11013
diff changeset
   176
addToDllPath:aDirectoryPathName
226b25e4bb97 comments
Claus Gittinger <cg@exept.de>
parents: 11013
diff changeset
   177
    "can be used during initialization, to add more places for dll-loading"
226b25e4bb97 comments
Claus Gittinger <cg@exept.de>
parents: 11013
diff changeset
   178
11053
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   179
    |oldPath|
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   180
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   181
    oldPath := self dllPath.
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   182
    (oldPath includes:aDirectoryPathName) ifFalse:[
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   183
	self dllPath:(oldPath asOrderedCollection copyWith:aDirectoryPathName)
11053
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   184
    ]
11050
226b25e4bb97 comments
Claus Gittinger <cg@exept.de>
parents: 11013
diff changeset
   185
!
226b25e4bb97 comments
Claus Gittinger <cg@exept.de>
parents: 11013
diff changeset
   186
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   187
dllPath
13337
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   188
    ^ DLLPATH
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   189
!
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   190
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   191
dllPath:aCollectionOfDirectoryPathNames
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   192
    DLLPATH := aCollectionOfDirectoryPathNames
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   193
!
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   194
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   195
initialize
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   196
    "using inline access to corresponding c--defines to avoid duplicate places of knowledge"
13337
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   197
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   198
    DLLPATH isNil ifTrue:[
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   199
        DLLPATH := #('.').
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   200
        FLAG_VIRTUAL := %{ __MKSMALLINT(__EXTL_FLAG_VIRTUAL) %}.                "/ a virtual c++ call
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   201
        FLAG_NONVIRTUAL := %{ __MKSMALLINT(__EXTL_FLAG_NONVIRTUAL) %}.          "/ a non-virtual c++ call
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   202
        FLAG_UNLIMITEDSTACK := %{ __MKSMALLINT(__EXTL_FLAG_UNLIMITEDSTACK) %}.  "/ unlimitedstack under unix
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   203
        FLAG_ASYNC := %{ __MKSMALLINT(__EXTL_FLAG_ASYNC) %}.                    "/ async under win32
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   204
        FLAG_RETVAL_IS_CONST := %{ __MKSMALLINT(__EXTL_FLAG_RETVAL_IS_CONST) %}."/ return value is not to be registered for finalization
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   205
13337
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   206
        CALLTYPE_API := %{ __MKSMALLINT(__EXTL_CALLTYPE_API) %}.                "/ WINAPI-call (win32 only)
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   207
        CALLTYPE_C := %{ __MKSMALLINT(__EXTL_CALLTYPE_C) %}.                    "/ regular C-call (the default)
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   208
        CALLTYPE_V8 := %{ __MKSMALLINT(__EXTL_CALLTYPE_V8) %}.                  "/ v8 call (sparc only)
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   209
        CALLTYPE_V9 := %{ __MKSMALLINT(__EXTL_CALLTYPE_V9) %}.                  "/ v9 call (sparc only)
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   210
        CALLTYPE_UNIX64 := %{ __MKSMALLINT(__EXTL_CALLTYPE_UNIX64) %}.          "/ unix64 call (alpha only)
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   211
13337
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   212
        CALLTYPE_MASK := %{ __MKSMALLINT(__EXTL_CALLTYPE_MASK) %}.
d1733931bc10 changed:
Stefan Vogel <sv@exept.de>
parents: 13334
diff changeset
   213
    ].
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   214
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   215
    "
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   216
     self initialize
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   217
    "
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   218
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   219
    "Modified: / 03-10-2006 / 21:27:47 / cg"
11053
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   220
!
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   221
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   222
removeFromDllPath:aDirectoryPathName
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   223
    "remove added places from dll-loading"
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   224
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   225
    |oldPath|
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   226
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   227
    oldPath := self dllPath.
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   228
    self dllPath:(oldPath asOrderedCollection copyWithout:aDirectoryPathName)
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   229
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   230
    "
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   231
     self dllPath.
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   232
     self addToDllPath:'C:\aaa\bbb'.
11053
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   233
     self dllPath.
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   234
     self removeFromDllPath:'C:\aaa\bbb'.
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   235
     self dllPath.
bcf4ebb25868 +removeFromDLLPath
Claus Gittinger <cg@exept.de>
parents: 11050
diff changeset
   236
    "
8550
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   237
! !
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   238
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   239
!ExternalLibraryFunction class methodsFor:'constants'!
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   240
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   241
callTypeAPI
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   242
    ^ CALLTYPE_API
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   243
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   244
    "Modified: / 01-08-2006 / 13:44:41 / cg"
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   245
!
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   246
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   247
callTypeC
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   248
    ^ CALLTYPE_C
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   249
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   250
    "Modified: / 01-08-2006 / 13:44:49 / cg"
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   251
!
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   252
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   253
callTypeCDecl
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   254
    ^ CALLTYPE_C
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   255
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   256
    "Modified: / 01-08-2006 / 13:44:52 / cg"
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   257
!
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   258
10619
dc8c965a8602 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10618
diff changeset
   259
callTypeMASK
dc8c965a8602 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10618
diff changeset
   260
    ^ CALLTYPE_MASK
dc8c965a8602 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10618
diff changeset
   261
dc8c965a8602 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10618
diff changeset
   262
    "Modified: / 01-08-2006 / 13:44:57 / cg"
dc8c965a8602 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10618
diff changeset
   263
!
dc8c965a8602 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10618
diff changeset
   264
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   265
callTypeOLE
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   266
    ^ CALLTYPE_OLE
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
   267
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   268
    "Modified: / 01-08-2006 / 13:44:57 / cg"
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   269
! !
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   270
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   271
!ExternalLibraryFunction methodsFor:'accessing'!
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   272
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   273
argumentTypes
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   274
    ^ argumentTypes
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   275
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   276
11426
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   277
argumentTypesString
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   278
    ^ String
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   279
	streamContents:[:s |
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   280
	    argumentTypes do:[:eachArgType |
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   281
		eachArgType printOn:s.
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   282
	    ] separatedBy:[
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   283
		s nextPutAll:','.
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   284
	    ].
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   285
	].
11426
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   286
!
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   287
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   288
beAsync
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   289
    "let this execute in a separate thread, in par with the other execution thread(s).
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   290
     Ignored under unix/linux (until those support multiple threads too)."
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   291
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   292
    flags := (flags ? 0) bitOr: FLAG_ASYNC.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   293
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   294
    "Created: / 01-08-2006 / 13:42:38 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   295
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   296
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   297
beCallTypeAPI
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   298
    flags := (flags ? 0) bitOr: CALLTYPE_API.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   299
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   300
    "Created: / 01-08-2006 / 15:12:40 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   301
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   302
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   303
beCallTypeC
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   304
    flags := (flags ? 0) bitOr: CALLTYPE_C.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   305
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   306
    "Created: / 01-08-2006 / 15:12:40 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   307
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   308
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   309
beCallTypeOLE
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   310
    flags := (flags ? 0) bitOr: FLAG_VIRTUAL.
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   311
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   312
    "Created: / 01-08-2006 / 15:12:40 / cg"
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   313
!
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   314
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   315
beCallTypeUNIX64
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   316
    flags := (flags ? 0) bitOr: CALLTYPE_UNIX64.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   317
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   318
    "Created: / 01-08-2006 / 15:13:38 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   319
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   320
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   321
beCallTypeV8
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   322
    flags := (flags ? 0) bitOr: CALLTYPE_V8.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   323
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   324
    "Created: / 01-08-2006 / 15:13:28 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   325
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   326
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   327
beCallTypeV9
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   328
    flags := (flags ? 0) bitOr: CALLTYPE_V9.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   329
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   330
    "Created: / 01-08-2006 / 15:13:31 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   331
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   332
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   333
beCallTypeWINAPI
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   334
    self beCallTypeAPI
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   335
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   336
    "Modified: / 01-08-2006 / 15:14:02 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   337
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   338
9525
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   339
beConstReturnValue
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   340
    "specify that a pointer return value is not to be finalized
9525
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   341
     (i.e. points to static data or data which is freed by c)"
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   342
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   343
    flags := (flags ? 0) bitOr: FLAG_RETVAL_IS_CONST.
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   344
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   345
    "Created: / 01-08-2006 / 13:56:48 / cg"
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   346
!
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   347
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   348
beNonVirtualCPP
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   349
    "specify this as a non-virtual c++-function"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   350
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   351
    flags := (flags ? 0) bitOr: FLAG_NONVIRTUAL.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   352
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   353
    "Created: / 01-08-2006 / 13:56:44 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   354
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   355
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   356
beUnlimitedStack
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   357
    "let this execute on the c-stack (as opposed to the thread-stack)
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   358
     for unlimited auto-sized-stack under unix/linux.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   359
     Ignored under windows."
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   360
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   361
    flags := (flags ? 0) bitOr: FLAG_UNLIMITEDSTACK.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   362
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   363
    "Created: / 01-08-2006 / 13:41:54 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   364
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   365
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   366
beVirtualCPP
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   367
    "specify this as a virtual c++-function"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   368
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   369
    flags := (flags ? 0) bitOr: FLAG_VIRTUAL.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   370
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   371
    "Created: / 01-08-2006 / 13:56:48 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   372
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   373
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   374
callTypeNumber
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   375
    ^ (flags ? 0) bitAnd: CALLTYPE_MASK.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   376
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   377
    "Created: / 01-08-2006 / 15:12:10 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   378
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   379
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   380
isAsync
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   381
    "is this executed in a separate thread, in par with the other execution thread(s) ?"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   382
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   383
    ^ (flags ? 0) bitTest: FLAG_ASYNC.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   384
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   385
    "Created: / 01-08-2006 / 13:46:53 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   386
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   387
9519
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   388
isCPPFunction
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   389
    "is this a virtual or non-virtual c++-function ?"
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   390
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   391
    ^ (flags ? 0) bitTest: (FLAG_VIRTUAL bitOr: FLAG_NONVIRTUAL).
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   392
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   393
    "Created: / 01-08-2006 / 13:56:54 / cg"
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   394
!
ad18bf96758d *** empty log message ***
ca
parents: 9483
diff changeset
   395
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   396
isCallTypeAPI
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   397
    ^ ((flags ? 0) bitAnd: CALLTYPE_MASK) == CALLTYPE_API.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   398
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   399
    "Created: / 01-08-2006 / 15:21:16 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   400
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   401
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   402
isCallTypeC
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   403
    ^ ((flags ? 0) bitAnd: CALLTYPE_MASK) == CALLTYPE_C.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   404
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   405
    "Created: / 01-08-2006 / 15:21:23 / cg"
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   406
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   407
10483
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   408
isCallTypeOLE
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   409
    ^ ((flags ? 0) bitTest: FLAG_VIRTUAL).
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   410
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   411
    "Created: / 01-08-2006 / 15:21:23 / cg"
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   412
!
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   413
9525
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   414
isConstReturnValue
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   415
    "is the pointer return value not to be finalized
9525
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   416
     (i.e. points to static data or data which is freed by c)"
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   417
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   418
    ^ (flags ? 0) bitTest: FLAG_RETVAL_IS_CONST.
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   419
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   420
    "Created: / 01-08-2006 / 13:56:48 / cg"
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   421
!
120234adc94e const specifier (is this a good name ?)
ca
parents: 9524
diff changeset
   422
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   423
isNonVirtualCPP
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   424
    "is this a non-virtual c++-function ?"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   425
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   426
    ^ (flags ? 0) bitTest: FLAG_NONVIRTUAL.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   427
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   428
    "Created: / 01-08-2006 / 13:56:51 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   429
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   430
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   431
isUnlimitedStack
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   432
    "will this execute on the c-stack (as opposed to the thread-stack)
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   433
     for unlimited auto-sized-stack under unix/linux.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   434
     Ignored under windows."
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   435
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   436
    ^ (flags ? 0) bitTest: FLAG_UNLIMITEDSTACK.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   437
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   438
    "Created: / 01-08-2006 / 14:17:07 / cg"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   439
!
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   440
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   441
isVirtualCPP
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   442
    "is this a virtual c++-function ?"
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   443
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   444
    ^ (flags ? 0) bitTest: FLAG_VIRTUAL.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   445
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   446
    "Created: / 01-08-2006 / 13:56:54 / cg"
10483
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   447
!
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   448
11426
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   449
moduleName
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   450
    ^ moduleName
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   451
!
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   452
10484
29039d89239d + returnType
fm
parents: 10483
diff changeset
   453
returnType
29039d89239d + returnType
fm
parents: 10483
diff changeset
   454
    ^ returnType
29039d89239d + returnType
fm
parents: 10483
diff changeset
   455
!
29039d89239d + returnType
fm
parents: 10483
diff changeset
   456
10483
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   457
vtableIndex
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   458
    name isNumber ifFalse:[^ nil].
79c64bcd4d29 +ole queries
fm
parents: 10481
diff changeset
   459
    ^ name.
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   460
! !
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   461
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   462
!ExternalLibraryFunction methodsFor:'invoking'!
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   463
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   464
invoke
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   465
    self hasCode ifFalse:[
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   466
	self prepareInvoke.
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   467
    ].
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   468
    ^ self invokeFFIWithArguments:nil
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   469
!
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   470
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   471
invokeCPPVirtualOn:anInstance
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   472
    self hasCode ifFalse:[
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   473
	self prepareInvoke.
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   474
    ].
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   475
    ^ self invokeCPPVirtualFFIOn:anInstance withArguments:nil
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   476
!
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   477
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   478
invokeCPPVirtualOn:instance with:arg
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   479
    self hasCode ifFalse:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   480
	self prepareInvoke.
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   481
    ].
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   482
    ^ self invokeCPPVirtualFFIOn:instance withArguments:(Array with:arg)
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   483
!
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   484
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   485
invokeCPPVirtualOn:instance with:arg1 with:arg2
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   486
    self hasCode ifFalse:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   487
	self prepareInvoke.
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   488
    ].
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   489
    ^ self invokeCPPVirtualFFIOn:instance withArguments:(Array with:arg1 with:arg2)
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   490
!
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   491
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   492
invokeCPPVirtualOn:instance with:arg1 with:arg2 with:arg3
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   493
    self hasCode ifFalse:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   494
	self prepareInvoke.
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   495
    ].
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   496
    ^ self invokeCPPVirtualFFIOn:instance withArguments:(Array with:arg1 with:arg2 with:arg3)
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   497
!
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   498
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   499
invokeCPPVirtualOn:instance with:arg1 with:arg2 with:arg3 with:arg4
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   500
    self hasCode ifFalse:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   501
	self prepareInvoke.
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   502
    ].
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   503
    ^ self invokeCPPVirtualFFIOn:instance withArguments:(Array with:arg1 with:arg2 with:arg3 with:arg4)
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   504
!
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   505
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   506
invokeCPPVirtualOn:instance withArguments:args
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   507
    self hasCode ifFalse:[
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   508
	self prepareInvoke.
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   509
    ].
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   510
    ^ self invokeCPPVirtualFFIOn:instance withArguments:args
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   511
!
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   512
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   513
invokeWith:arg
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   514
    self hasCode ifFalse:[
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
   515
	self prepareInvoke.
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   516
    ].
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   517
    ^ self invokeFFIWithArguments:(Array with:arg)
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   518
!
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   519
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   520
invokeWith:arg1 with:arg2
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   521
    self hasCode ifFalse:[
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
   522
	self prepareInvoke.
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   523
    ].
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   524
    ^ self invokeFFIWithArguments:(Array with:arg1 with:arg2)
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   525
!
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   526
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   527
invokeWith:arg1 with:arg2 with:arg3
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   528
    self hasCode ifFalse:[
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
   529
	self prepareInvoke.
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   530
    ].
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   531
    ^ self invokeFFIWithArguments:(Array with:arg1 with:arg2 with:arg3)
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   532
!
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   533
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   534
invokeWith:arg1 with:arg2 with:arg3 with:arg4
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   535
    self hasCode ifFalse:[
9464
157fe6ca53e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9463
diff changeset
   536
	self prepareInvoke.
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   537
    ].
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   538
    ^ self invokeFFIWithArguments:(Array with:arg1 with:arg2 with:arg3 with:arg4)
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   539
!
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   540
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   541
invokeWithArguments:argArray
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   542
    self hasCode ifFalse:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   543
	self prepareInvoke.
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   544
    ].
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   545
    ^ self invokeFFIwithArguments:argArray forCPPInstance:nil
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   546
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   547
    "Modified: / 01-08-2006 / 16:04:08 / cg"
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   548
! !
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   549
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   550
!ExternalLibraryFunction methodsFor:'printing'!
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   551
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   552
printOn:aStream
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   553
    aStream nextPutAll:'<'.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   554
    self isCallTypeAPI ifTrue:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   555
	'API:' printOn:aStream.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   556
    ] ifFalse:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   557
	'C:' printOn:aStream.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   558
    ].
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   559
    aStream nextPutAll:' '.
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   560
    name printOn:aStream.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   561
    moduleName notNil ifTrue:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   562
	aStream nextPutAll:' module:'.
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   563
	moduleName printOn:aStream.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   564
    ].
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   565
    aStream nextPutAll:'>'.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   566
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   567
    "Modified: / 01-08-2006 / 15:21:42 / cg"
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   568
! !
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   569
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   570
!ExternalLibraryFunction methodsFor:'private'!
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   571
10213
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   572
adjustTypes
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   573
    argumentTypes notNil ifTrue:[
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   574
	argumentTypes := argumentTypes collect:[:argType | self ffiTypeSymbolForType:argType].
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   575
    ].
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   576
    returnType := self ffiTypeSymbolForType:returnType.
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   577
!
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   578
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   579
linkToModule
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   580
    "link this function to the external module.
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   581
     I.e. retrieve the module handle and the code pointer."
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   582
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   583
    |handle moduleNameUsed functionName|
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   584
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   585
    name isNumber ifTrue:[
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   586
        self isCPPFunction ifTrue:[
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   587
            "/ no need to load a dll.
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   588
            ^ self
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   589
        ]
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   590
    ].
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
   591
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   592
    "/ in some other smalltalks, there is no moduleName in the ffi-spec;
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   593
    "/ instead, the class provides the libraryName...
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   594
    (moduleNameUsed := moduleName) isNil ifTrue:[
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   595
        owningClass isNil ifTrue:[
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   596
            self error:'Missing moduleName'.
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   597
        ].
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   598
        moduleNameUsed := owningClass theNonMetaclass libraryName asSymbol.
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   599
    ].
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   600
    moduleHandle isNil ifTrue:[
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   601
        handle := self loadLibrary:moduleNameUsed.
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   602
        handle isNil ifTrue:[
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   603
            self error:('Cannot load module: "%1"' bindWith: moduleNameUsed).
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   604
        ].
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   605
        moduleHandle := handle.
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   606
    ].
9341
719fcf48695b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9340
diff changeset
   607
    name isNumber ifFalse:[
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   608
        functionName := name.
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   609
        (moduleHandle getFunctionAddress:functionName into:self) isNil ifTrue:[
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   610
            functionName := ('_', functionName) asSymbol.
9418
df5d2576402d resolve function - if function with name not exists add an underscore in front and retry
ca
parents: 9399
diff changeset
   611
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   612
            (moduleHandle getFunctionAddress:functionName into:self) isNil ifTrue:[
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   613
                moduleHandle := nil.
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   614
                self error:'Missing function: ', name, ' in module: ', moduleNameUsed.
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   615
            ].
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   616
        ].
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   617
    ].
9392
11914531960a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9386
diff changeset
   618
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   619
    "Modified: / 01-08-2006 / 16:24:14 / cg"
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
   620
    "Modified (comment): / 07-10-2011 / 16:43:11 / cg"
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   621
!
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   622
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   623
loadLibrary:dllName
12436
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
   624
    |handle nameString filename|
10279
60c42983fdd4 first test whether the dllName is the complete filename
ca
parents: 10270
diff changeset
   625
60c42983fdd4 first test whether the dllName is the complete filename
ca
parents: 10270
diff changeset
   626
    filename := dllName asFilename.
12436
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
   627
    nameString := filename name.
10279
60c42983fdd4 first test whether the dllName is the complete filename
ca
parents: 10270
diff changeset
   628
12937
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   629
    "try to load, maybe the system knows where to find the dll"
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   630
    handle := ObjectFileLoader loadDynamicObject:filename.
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   631
    handle notNil ifTrue:[^ handle ].
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   632
12436
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
   633
    filename isAbsolute ifFalse:[
13333
1463a5e4f9fa comment/format in: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12937
diff changeset
   634
        "First ask the class defining the ExternalFunction for the location of the dlls ..."
13334
83c2193a234f changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 13333
diff changeset
   635
        owningClass notNil ifTrue:[
83c2193a234f changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 13333
diff changeset
   636
            owningClass dllPath do:[:eachDirectory |
83c2193a234f changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 13333
diff changeset
   637
                handle := ObjectFileLoader
83c2193a234f changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 13333
diff changeset
   638
                            loadDynamicObject:(eachDirectory asFilename construct:nameString) pathName.
83c2193a234f changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 13333
diff changeset
   639
                handle notNil ifTrue:[^ handle ].
83c2193a234f changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 13333
diff changeset
   640
            ].
12937
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   641
        ].
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   642
        ".. then ask the system"
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   643
        self class dllPath do:[:eachDirectory |
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   644
            handle := ObjectFileLoader
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   645
                        loadDynamicObject:(eachDirectory asFilename construct:nameString) pathName.
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   646
            handle notNil ifTrue:[^ handle ].
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   647
        ].
10279
60c42983fdd4 first test whether the dllName is the complete filename
ca
parents: 10270
diff changeset
   648
    ].
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   649
12436
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
   650
    filename suffix isEmpty ifTrue:[
12937
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   651
        "/ try again with the OS-specific dll-extension
7d5f512fb14a changed: #loadLibrary:
Stefan Vogel <sv@exept.de>
parents: 12680
diff changeset
   652
        ^ self loadLibrary:(filename withSuffix:ObjectFileLoader sharedLibrarySuffix)
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   653
    ].
12436
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
   654
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   655
    ^ nil
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   656
!
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   657
9321
734c7c432461 not yet finished
Claus Gittinger <cg@exept.de>
parents: 8891
diff changeset
   658
prepareInvoke
10270
897474c6c785 allow setting the dllPath
fm
parents: 10213
diff changeset
   659
    (moduleHandle isNil or:[self hasCode not]) ifTrue:[
12450
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   660
	self linkToModule.
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   661
	self adjustTypes.
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   662
    ].
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   663
! !
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   664
8550
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   665
!ExternalLibraryFunction methodsFor:'private-accessing'!
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   666
9327
9c15276d61e3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9324
diff changeset
   667
ffiTypeSymbolForType:aType
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   668
    "map type to one of the ffi-supported ones:
12657
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   669
        sint8, sint16, sint32, sint64
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   670
        uint8, uint16, uint32, uint64
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   671
        bool void pointer handle
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   672
    "
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   673
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   674
    aType == #sint8           ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   675
    aType == #sint16          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   676
    aType == #sint32          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   677
    aType == #sint64          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   678
    aType == #uint8           ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   679
    aType == #uint16          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   680
    aType == #uint32          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   681
    aType == #uint64          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   682
    aType == #double          ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   683
    aType == #float           ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   684
    aType == #char            ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   685
    aType == #void            ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   686
    aType == #bool            ifTrue:[^ aType ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   687
    aType == #pointer         ifTrue:[^ aType ].
12657
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   688
    aType == #charPointer     ifTrue:[^ aType ].
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   689
    aType == #wcharPointer    ifTrue:[^ aType ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   690
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   691
    aType == #int8            ifTrue:[^ #sint8 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   692
    aType == #int16           ifTrue:[^ #sint16 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   693
    aType == #int32           ifTrue:[^ #sint32 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   694
    aType == #int64           ifTrue:[^ #sint64 ].
12450
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   695
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   696
    aType == #voidPointer         ifTrue:[^ #pointer ].
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   697
    aType == #uint8Pointer        ifTrue:[^ #pointer ].
12449
ca958524b42f comment/format in: #prepareInvoke
Claus Gittinger <cg@exept.de>
parents: 12436
diff changeset
   698
    aType == #voidPointerPointer  ifTrue:[^ #pointer ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   699
10213
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   700
    aType == #short           ifTrue:[^ #sint16 ].
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   701
    aType == #long            ifTrue:[^ #long ].
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   702
    aType == #int             ifTrue:[^ #int ].
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   703
    aType == #uint            ifTrue:[^ #uint ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   704
    aType == #ushort          ifTrue:[^ #uint16 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   705
    aType == #unsignedShort   ifTrue:[^ #uint16 ].
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   706
    aType == #ulong           ifTrue:[^ #ulong ].
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   707
    aType == #unsignedLong    ifTrue:[^ #ulong ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   708
    aType == #uchar           ifTrue:[^ #uint8 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   709
    aType == #unsignedChar    ifTrue:[^ #uint8 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   710
    aType == #byte            ifTrue:[^ #uint8 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   711
    aType == #dword           ifTrue:[^ #uint32 ].
10213
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   712
    aType == #sdword          ifTrue:[^ #sint32 ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   713
    aType == #word            ifTrue:[^ #uint16 ].
10213
31717eee6fb2 changed #ffiTypeSymbolForType:
fm
parents: 10025
diff changeset
   714
    aType == #sword           ifTrue:[^ #sint16 ].
12503
cb1a875c3d63 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12474
diff changeset
   715
    aType == #longlong        ifTrue:[^ #sint64 ].
12450
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   716
    aType == #longLong        ifTrue:[^ #sint64 ].
12503
cb1a875c3d63 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12474
diff changeset
   717
    aType == #ulonglong       ifTrue:[^ #uint64 ].
12450
c6d60bdca435 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 12449
diff changeset
   718
    aType == #ulongLong       ifTrue:[^ #uint64 ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   719
    aType == #handle          ifTrue:[^ #pointer ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   720
    aType == #lpstr           ifTrue:[^ #charPointer ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   721
    aType == #hresult         ifTrue:[^ #uint32 ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   722
    aType == #boolean         ifTrue:[^ #bool ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   723
    aType == #ulongReturn     ifTrue:[^ #uint32 ].    "/ TODO - care for 64bit machines
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   724
    aType == #none            ifTrue:[^ #void ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   725
    aType == #struct          ifTrue:[^ #pointer ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   726
    aType == #structIn        ifTrue:[^ #pointer ].
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   727
    aType == #structOut       ifTrue:[^ #pointer ].
10981
29c7d48f7560 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10674
diff changeset
   728
    aType == #unsigned        ifTrue:[^ #uint ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   729
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   730
    (aType isString or:[aType isSymbol]) ifFalse:[
12657
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   731
        CType isNil ifTrue:[
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   732
            self error:'unknown type'.
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   733
        ].
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   734
        ^ aType typeSymbol.
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
   735
    ].
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
   736
12579
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
   737
    (aType endsWith:'*') ifTrue:[
12657
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   738
        ^ #pointer.
12579
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
   739
    ].
12449
ca958524b42f comment/format in: #prepareInvoke
Claus Gittinger <cg@exept.de>
parents: 12436
diff changeset
   740
    (aType endsWith:'Pointer') ifTrue:[
12657
7da296a8eeb6 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12656
diff changeset
   741
        ^ #pointer.
12449
ca958524b42f comment/format in: #prepareInvoke
Claus Gittinger <cg@exept.de>
parents: 12436
diff changeset
   742
    ].
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   743
    ^ aType
10625
892203aae858 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10619
diff changeset
   744
892203aae858 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10619
diff changeset
   745
    "Modified: / 14-06-2007 / 17:21:42 / cg"
9322
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   746
!
41c391bfbf03 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9321
diff changeset
   747
9466
73333f358696 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9465
diff changeset
   748
name:functionNameOrVirtualIndex module:aModuleName returnType:aReturnType argumentTypes:argTypes
73333f358696 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9465
diff changeset
   749
    name := functionNameOrVirtualIndex.
73333f358696 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9465
diff changeset
   750
    functionNameOrVirtualIndex isNumber ifTrue:[
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   751
	self beVirtualCPP.
9466
73333f358696 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9465
diff changeset
   752
    ].
8891
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   753
    moduleName := aModuleName.
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   754
    returnType := aReturnType.
c30a030ff5ec more FFI (foreign function interface) support - still incomplete
Stefan Vogel <sv@exept.de>
parents: 8728
diff changeset
   755
    argumentTypes := argTypes.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   756
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   757
    "Created: / 01-08-2006 / 15:19:52 / cg"
9466
73333f358696 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9465
diff changeset
   758
    "Modified: / 02-08-2006 / 17:20:13 / cg"
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   759
!
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   760
11426
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   761
owningClass
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   762
    ^ owningClass
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   763
!
1fccae300393 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 11053
diff changeset
   764
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   765
owningClass:aClass
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   766
    owningClass := aClass.
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   767
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   768
    "Created: / 01-08-2006 / 15:22:50 / cg"
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   769
!
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   770
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   771
setModuleName:aModuleName
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   772
    aModuleName ~= moduleName ifTrue:[
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   773
	self code:nil.
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   774
	moduleHandle := nil.
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   775
	moduleName := aModuleName.
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   776
    ].
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   777
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   778
    "Created: / 07-06-2007 / 10:20:17 / cg"
8550
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   779
! !
72982f85bd41 *** empty log message ***
ca
parents: 8533
diff changeset
   780
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   781
!ExternalLibraryFunction methodsFor:'private-invoking'!
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   782
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   783
invokeCPPVirtualFFIOn:instance withArguments:arguments
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   784
    ^ self invokeFFIwithArguments:arguments forCPPInstance:instance
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   785
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   786
    "Modified: / 01-08-2006 / 13:55:30 / cg"
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   787
!
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   788
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   789
invokeFFIWithArguments:arguments
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   790
    ^ self invokeFFIwithArguments:arguments forCPPInstance:nil
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   791
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   792
    "Modified: / 01-08-2006 / 13:55:35 / cg"
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   793
!
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
   794
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   795
invokeFFIwithArguments:argumentsOrNil forCPPInstance:aCPlusPlusObjectOrNil
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   796
    |argTypeSymbols returnTypeSymbol failureCode failureInfo returnValue stClass vtOffset
12579
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
   797
     virtual async unlimitedStack callTypeNumber returnValueClass argValueClass
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
   798
     oldReturnType oldArgumentTypes
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
   799
    |
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   800
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   801
    argTypeSymbols := argumentTypes.
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   802
    returnTypeSymbol := returnType.
9346
a95e2cf0e56f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9344
diff changeset
   803
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   804
    virtual := self isVirtualCPP.
9524
2af286bbcac3 *** empty log message ***
ca
parents: 9519
diff changeset
   805
    (virtual "or:[self isNonVirtualCPP]") ifTrue:[
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   806
        aCPlusPlusObjectOrNil isNil ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   807
            "/ must have a c++ object instance
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   808
            self primitiveFailed.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   809
        ].
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   810
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   811
        "/ and it must be a kind of ExternalStructure !!
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   812
        (aCPlusPlusObjectOrNil isKindOf:ExternalStructure) ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   813
            self primitiveFailed.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   814
        ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   815
        virtual ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   816
            vtOffset := name.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   817
            (vtOffset between:0 and:10000) ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   818
                self primitiveFailed.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   819
            ]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   820
        ].
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   821
    ] ifFalse:[
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   822
        aCPlusPlusObjectOrNil notNil ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   823
            "/ must NOT have a c++ object instance
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   824
            self primitiveFailed.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   825
        ].
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   826
    ].
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   827
    async := self isAsync.
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
   828
    unlimitedStack := self isUnlimitedStack.
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
   829
    callTypeNumber := self callTypeNumber.
10512
5a01829213ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10484
diff changeset
   830
    "/ Transcript show:name; show:' async:'; showCR:async.
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   831
9459
6cd520c582b3 change from unlimited to big stack, to allow for interrupts to be handled
ca
parents: 9436
diff changeset
   832
%{  /* STACK: 100000 */
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   833
#ifdef HAVE_FFI
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   834
# ifdef __GNUC__
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   835
#  define HAS_LONGLONG
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   836
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   837
# if defined(__BORLANDC__) || defined(__VISUALC__)
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   838
#  define HAS_INT64
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   839
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   840
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   841
    ffi_cif __cif;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   842
    ffi_type *__argTypesIncludingThis[MAX_ARGS+1];
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   843
    ffi_type **__argTypes = __argTypesIncludingThis;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   844
    ffi_type *__returnType = NULL;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   845
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   846
    union u {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   847
        int iVal;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   848
        float fVal;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   849
        double dVal;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   850
        void *pointerVal;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   851
# if defined(HAS_LONGLONG)
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   852
        long long longLongVal;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   853
# else
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   854
#  ifdef HAS_INT64
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   855
        __int64__ longLongVal;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   856
#  else
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   857
        struct ll { long low; long hi; } longLongVal;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   858
#  endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   859
# endif
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   860
    };
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   861
    union u __argValuesIncludingThis[MAX_ARGS+1];
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   862
    union u *__argValues = __argValuesIncludingThis;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   863
    union u __returnValue;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   864
    void *__argValuePointersIncludingThis[MAX_ARGS+1];
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   865
    void **__argValuePointers = __argValuePointersIncludingThis;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   866
    void *__returnValuePointer;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   867
    int __numArgs, __numArgsIncludingThis;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   868
    static int null = 0;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   869
    int i;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   870
    ffi_abi __callType = FFI_DEFAULT_ABI;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   871
    VOIDFUNC codeAddress = (VOIDFUNC)__INST(code_);
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   872
    int __numArgsWanted;
12579
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
   873
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
   874
#   define __FAIL__(fcode) \
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   875
    { \
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   876
        failureCode = fcode; goto getOutOfHere; \
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
   877
    }
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   878
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   879
    if (argumentsOrNil == nil) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   880
        __numArgs = 0;
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   881
    } else if (__isArray(argumentsOrNil)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   882
        __numArgs = __arraySize(argumentsOrNil);
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   883
    } else {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   884
        __FAIL__(@symbol(BadArgumentVector))
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   885
    }
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   886
    if (argTypeSymbols == nil) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   887
        __numArgsWanted = 0;
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   888
    } else if (__isArray(argTypeSymbols)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   889
        __numArgsWanted = __arraySize(argTypeSymbols);
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   890
    } else {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   891
        __FAIL__(@symbol(BadArgumentTypeVector))
10440
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   892
    }
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   893
b643af58f8bf invoking without arguments
fm
parents: 10279
diff changeset
   894
    if (__numArgs != __numArgsWanted) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   895
        __FAIL__(@symbol(ArgumentCountMismatch))
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   896
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   897
    if (__numArgs > MAX_ARGS) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   898
        __FAIL__(@symbol(TooManyArguments))
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   899
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   900
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   901
    /*
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   902
     * validate the return type
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   903
     */
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   904
    __returnValuePointer = &__returnValue;
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   905
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
   906
    if (returnTypeSymbol == @symbol(voidPointer)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   907
        returnTypeSymbol = @symbol(handle);
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
   908
    }
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   909
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   910
    if (returnTypeSymbol == @symbol(int)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   911
        __returnType = __get_ffi_type_sint();
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   912
    } else if (returnTypeSymbol == @symbol(uint)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   913
        __returnType = __get_ffi_type_uint();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   914
    } else if (returnTypeSymbol == @symbol(uint8)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   915
        __returnType = __get_ffi_type_uint8();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   916
    } else if (returnTypeSymbol == @symbol(uint16)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   917
        __returnType = __get_ffi_type_uint16();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   918
    } else if (returnTypeSymbol == @symbol(uint32)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   919
        __returnType = __get_ffi_type_uint32();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   920
    } else if (returnTypeSymbol == @symbol(uint64)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   921
        __returnType = __get_ffi_type_uint64();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   922
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   923
    } else if (returnTypeSymbol == @symbol(sint)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   924
        __returnType = __get_ffi_type_sint();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   925
    } else if (returnTypeSymbol == @symbol(sint8)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   926
        __returnType = __get_ffi_type_sint8();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   927
    } else if (returnTypeSymbol == @symbol(sint16)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   928
        __returnType = __get_ffi_type_sint16();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   929
    } else if (returnTypeSymbol == @symbol(sint32)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   930
        __returnType = __get_ffi_type_sint32();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   931
    } else if (returnTypeSymbol == @symbol(sint64)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   932
        __returnType = __get_ffi_type_sint64();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   933
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   934
    } else if (returnTypeSymbol == @symbol(long)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   935
        if (sizeof(long) == 4) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   936
           returnTypeSymbol = @symbol(sint32);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   937
           __returnType = __get_ffi_type_sint32();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   938
        } else if (sizeof(long) == 8) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   939
           returnTypeSymbol = @symbol(sint64);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   940
           __returnType = __get_ffi_type_sint64();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   941
        } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   942
            __FAIL__(@symbol(UnknownReturnType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   943
        }
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   944
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   945
    } else if (returnTypeSymbol == @symbol(ulong)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   946
        if (sizeof(long) == 4) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   947
           returnTypeSymbol = @symbol(uint32);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   948
           __returnType = __get_ffi_type_uint32();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   949
        }else if (sizeof(long) == 8) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   950
           returnTypeSymbol = @symbol(uint64);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   951
           __returnType = __get_ffi_type_uint64();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   952
        } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   953
            __FAIL__(@symbol(UnknownReturnType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   954
        }
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   955
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
   956
    } else if (returnTypeSymbol == @symbol(bool)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   957
        __returnType = __get_ffi_type_uint();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   958
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   959
    } else if (returnTypeSymbol == @symbol(float)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   960
        __returnType = __get_ffi_type_float();
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   961
    } else if (returnTypeSymbol == @symbol(double)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   962
        __returnType = __get_ffi_type_double();
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
   963
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   964
    } else if (returnTypeSymbol == @symbol(void)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   965
        __returnType = __get_ffi_type_void();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   966
        __returnValuePointer = NULL;
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
   967
    } else if ((returnTypeSymbol == @symbol(pointer))
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   968
               || (returnTypeSymbol == @symbol(handle))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   969
               || (returnTypeSymbol == @symbol(charPointer))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   970
               || (returnTypeSymbol == @symbol(bytePointer))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   971
               || (returnTypeSymbol == @symbol(floatPointer))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   972
               || (returnTypeSymbol == @symbol(doublePointer))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   973
               || (returnTypeSymbol == @symbol(intPointer))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   974
               || (returnTypeSymbol == @symbol(shortPointer))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   975
               || (returnTypeSymbol == @symbol(wcharPointer))) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   976
        __returnType = __get_ffi_type_pointer();
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   977
    } else {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   978
        if (__isSymbol(returnTypeSymbol)
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   979
         && ((returnValueClass = __GLOBAL_GET(returnTypeSymbol)) != nil)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   980
            if (! __isBehaviorLike(returnValueClass)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   981
                __FAIL__(@symbol(NonBehaviorReturnType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   982
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   983
            if (! __qIsSubclassOfExternalAddress(returnValueClass)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   984
                __FAIL__(@symbol(NonExternalAddressReturnType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   985
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   986
            __returnType = __get_ffi_type_pointer();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   987
            returnTypeSymbol = @symbol(pointer);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   988
        } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   989
            __FAIL__(@symbol(UnknownReturnType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   990
        }
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   991
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   992
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   993
    /*
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   994
     * validate the c++ object
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   995
     */
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
   996
    if (aCPlusPlusObjectOrNil != nil) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   997
        struct cPlusPlusInstance {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   998
            void **vTable;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
   999
        };
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1000
        struct cPlusPlusInstance *inst;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1001
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1002
        if (__isExternalAddressLike(aCPlusPlusObjectOrNil)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1003
            inst = (void *)(__externalAddressVal(aCPlusPlusObjectOrNil));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1004
        } else if (__isExternalBytesLike(aCPlusPlusObjectOrNil)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1005
            inst = (void *)(__externalBytesVal(aCPlusPlusObjectOrNil));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1006
        } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1007
            __FAIL__(@symbol(InvalidInstance))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1008
        }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1009
        __argValues[0].pointerVal = inst;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1010
        __argValuePointersIncludingThis[0] = &(__argValues[0]);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1011
        __argTypes[0] = __get_ffi_type_pointer();
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1012
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1013
        __argValuePointers = &__argValuePointersIncludingThis[1];
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1014
        __argTypes = &__argTypesIncludingThis[1];
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1015
        __argValues = &__argValuesIncludingThis[1];
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1016
        __numArgsIncludingThis = __numArgs + 1;
9347
31adc57e6954 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9346
diff changeset
  1017
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1018
        if (virtual == true) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1019
            if (! __isSmallInteger(vtOffset)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1020
                __FAIL__(@symbol(InvalidVTableIndex))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1021
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1022
            codeAddress = inst->vTable[__intVal(vtOffset)];
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1023
# ifdef VERBOSE
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1024
            printf("virtual codeAddress: %x\n", codeAddress);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1025
# endif
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1026
        }
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1027
    } else {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1028
        __numArgsIncludingThis = __numArgs;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1029
# ifdef VERBOSE
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1030
        printf("codeAddress: %x\n", codeAddress);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1031
# endif
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1032
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1033
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1034
    /*
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1035
     * validate all arg types and setup arg-buffers
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1036
     */
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1037
    for (i=0; i<__numArgs; i++) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1038
        ffi_type *thisType;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1039
        void *argValuePtr;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1040
        OBJ typeSymbol;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1041
        OBJ arg;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1042
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1043
        failureInfo = __mkSmallInteger(i+1);   /* in case there is one */
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
  1044
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1045
        typeSymbol = __ArrayInstPtr(argTypeSymbols)->a_element[i];
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1046
        arg = __ArrayInstPtr(argumentsOrNil)->a_element[i];
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1047
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1048
        if (typeSymbol == @symbol(handle)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1049
            typeSymbol = @symbol(pointer);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1050
        } else if (typeSymbol == @symbol(voidPointer)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1051
            typeSymbol = @symbol(pointer);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1052
        }
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1053
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1054
        if (typeSymbol == @symbol(long)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1055
            if (sizeof(long) == sizeof(int)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1056
                typeSymbol = @symbol(sint);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1057
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1058
                if (sizeof(long) == 4) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1059
                    typeSymbol = @symbol(sint32);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1060
                } else if (sizeof(long) == 8) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1061
                    typeSymbol = @symbol(sint64);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1062
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1063
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1064
        }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1065
        if (typeSymbol == @symbol(ulong)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1066
            if (sizeof(unsigned long) == sizeof(unsigned int)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1067
                typeSymbol = @symbol(uint);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1068
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1069
                if (sizeof(long) == 4) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1070
                    typeSymbol = @symbol(uint32);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1071
                } else if (sizeof(long) == 8) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1072
                    typeSymbol = @symbol(uint64);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1073
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1074
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1075
        }
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1076
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1077
        if (typeSymbol == @symbol(int) || typeSymbol == @symbol(sint)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1078
            thisType = __get_ffi_type_sint();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1079
            if (__isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1080
                __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1081
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1082
                __argValues[i].iVal = __signedLongIntVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1083
                if (__argValues[i].iVal == 0) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1084
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1085
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1086
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1087
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1088
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1089
        } else if (typeSymbol == @symbol(uint)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1090
            thisType = __get_ffi_type_uint();
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1091
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1092
            if (__isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1093
                __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1094
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1095
                __argValues[i].iVal = __unsignedLongIntVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1096
                if (__argValues[i].iVal == 0) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1097
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1098
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1099
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1100
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1101
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1102
        } else if (typeSymbol == @symbol(uint8)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1103
            thisType = __get_ffi_type_uint8();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1104
            if (! __isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1105
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1106
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1107
            __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1108
            if (((unsigned)(__argValues[i].iVal)) > 0xFF) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1109
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1110
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1111
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1112
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1113
        } else if (typeSymbol == @symbol(sint8)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1114
            thisType = __get_ffi_type_sint8();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1115
            if (! __isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1116
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1117
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1118
            __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1119
            if (((__argValues[i].iVal) < -0x80) || ((__argValues[i].iVal) > 0x7F))  {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1120
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1121
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1122
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1123
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1124
        } else if (typeSymbol == @symbol(uint16)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1125
            thisType = __get_ffi_type_uint16();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1126
            if (! __isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1127
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1128
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1129
            __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1130
            if (((unsigned)(__argValues[i].iVal)) > 0xFFFF) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1131
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1132
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1133
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1134
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1135
        } else if (typeSymbol == @symbol(sint16)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1136
            thisType = __get_ffi_type_sint16();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1137
            if (! __isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1138
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1139
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1140
            __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1141
            if (((__argValues[i].iVal) < -0x8000) || ((__argValues[i].iVal) > 0x7FFF))  {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1142
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1143
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1144
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1145
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1146
        } else if ((typeSymbol == @symbol(uint32)) || (typeSymbol == @symbol(sint32))) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1147
            thisType = __get_ffi_type_uint32();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1148
            if (__isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1149
                __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1150
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1151
                __argValues[i].iVal = __unsignedLongIntVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1152
                if (__argValues[i].iVal == 0) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1153
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1154
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1155
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1156
            argValuePtr = &(__argValues[i].iVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1157
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1158
        } else if (typeSymbol == @symbol(float)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1159
            thisType = __get_ffi_type_float();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1160
            if (__isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1161
                __argValues[i].fVal = (float)(__intVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1162
            } else if (__isFloat(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1163
                __argValues[i].fVal = (float)(__floatVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1164
            } else if (__isShortFloat(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1165
                __argValues[i].fVal = (float)(__shortFloatVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1166
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1167
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1168
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1169
            argValuePtr = &(__argValues[i].fVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1170
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1171
        } else if (typeSymbol == @symbol(double)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1172
            thisType = __get_ffi_type_double();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1173
            if (__isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1174
                __argValues[i].dVal = (double)(__intVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1175
            } else if (__isFloat(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1176
                __argValues[i].dVal = (double)(__floatVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1177
            } else if (__isShortFloat(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1178
                __argValues[i].dVal = (double)(__shortFloatVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1179
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1180
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1181
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1182
            argValuePtr = &(__argValues[i].dVal);
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1183
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1184
        } else if (typeSymbol == @symbol(void)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1185
            thisType = __get_ffi_type_void();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1186
            argValuePtr = &null;
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1187
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1188
        } else if (typeSymbol == @symbol(charPointer)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1189
            thisType = __get_ffi_type_pointer();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1190
            if (__isStringLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1191
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1192
                __argValues[i].pointerVal = (void *)(__stringVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1193
            } else if (__isBytes(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1194
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1195
                __argValues[i].pointerVal = (void *)(__byteArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1196
            } else if (__isExternalAddressLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1197
                __argValues[i].pointerVal = (void *)(__externalAddressVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1198
            } else if (__isExternalBytesLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1199
                __argValues[i].pointerVal = (void *)(__externalBytesVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1200
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1201
                if (arg == nil) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1202
                    __argValues[i].pointerVal = (void *)0;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1203
                } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1204
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1205
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1206
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1207
            argValuePtr = &(__argValues[i].pointerVal);;
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1208
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1209
        } else if (typeSymbol == @symbol(wcharPointer)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1210
            thisType = __get_ffi_type_pointer();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1211
            if (__isUnicode16String(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1212
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1213
                __argValues[i].pointerVal = (void *)(__unicode16StringVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1214
            } else if (__isBytes(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1215
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1216
                __argValues[i].pointerVal = (void *)(__byteArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1217
            } else if (__isExternalAddressLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1218
                __argValues[i].pointerVal = (void *)(__externalAddressVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1219
            } else if (__isExternalBytesLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1220
                __argValues[i].pointerVal = (void *)(__externalBytesVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1221
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1222
                if (arg == nil) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1223
                    __argValues[i].pointerVal = (void *)0;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1224
                } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1225
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1226
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1227
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1228
            argValuePtr = &(__argValues[i].pointerVal);;
12656
e7854486b4ff wcharPointer arguments
Claus Gittinger <cg@exept.de>
parents: 12591
diff changeset
  1229
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1230
        } else if (typeSymbol == @symbol(floatPointer)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1231
            thisType = __get_ffi_type_pointer();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1232
            if (__isBytes(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1233
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1234
                __argValues[i].pointerVal = (void *)(__byteArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1235
            } else if (__isExternalAddressLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1236
                __argValues[i].pointerVal = (void *)(__externalAddressVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1237
            } else if (__isExternalBytesLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1238
                __argValues[i].pointerVal = (void *)(__externalBytesVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1239
            } else if (__isFloats(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1240
                char *p = (char *)(__FloatArrayInstPtr(arg)->f_element);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1241
                int nInstBytes;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1242
                OBJ cls;
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1243
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1244
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1245
                cls = __qClass(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1246
                nInstBytes = __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1247
                p = p + nInstBytes;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1248
                __argValues[i].pointerVal = p;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1249
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1250
                if (arg == nil) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1251
                    __argValues[i].pointerVal = (void *)0;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1252
                } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1253
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1254
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1255
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1256
            argValuePtr = &(__argValues[i].pointerVal);;
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1257
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1258
        } else if (typeSymbol == @symbol(doublePointer)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1259
            thisType = __get_ffi_type_pointer();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1260
            if (__isBytes(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1261
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1262
                __argValues[i].pointerVal = (void *)(__byteArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1263
            } else if (__isExternalAddressLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1264
                __argValues[i].pointerVal = (void *)(__externalAddressVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1265
            } else if (__isExternalBytesLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1266
                __argValues[i].pointerVal = (void *)(__externalBytesVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1267
            } else if (__isDoubles(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1268
                char *p = (char *)(__DoubleArrayInstPtr(arg)->d_element);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1269
                int nInstBytes;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1270
                OBJ cls;
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1271
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1272
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1273
                cls = __qClass(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1274
                nInstBytes = __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1275
                p = p + nInstBytes;
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1276
# ifdef __NEED_DOUBLE_ALIGN
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1277
                if ((INT)pFirst & (__DOUBLE_ALIGN-1)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1278
                    int delta = __DOUBLE_ALIGN - ((INT)p & (__DOUBLE_ALIGN-1));
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1279
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1280
                    p += delta;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1281
                }
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1282
# endif
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1283
                __argValues[i].pointerVal = p;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1284
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1285
                if (arg == nil) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1286
                    __argValues[i].pointerVal = (void *)0;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1287
                } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1288
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1289
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1290
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1291
            argValuePtr = &(__argValues[i].pointerVal);;
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1292
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1293
        } else if (typeSymbol == @symbol(pointer)) {
9524
2af286bbcac3 *** empty log message ***
ca
parents: 9519
diff changeset
  1294
commonPointerTypeArg: ;
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1295
            thisType = __get_ffi_type_pointer();
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1296
            if (arg == nil) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1297
                __argValues[i].pointerVal = NULL;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1298
            } else if (__isExternalAddressLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1299
                __argValues[i].pointerVal = (void *)(__externalAddressVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1300
            } else if (__isExternalBytesLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1301
                __argValues[i].pointerVal = (void *)(__externalBytesVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1302
            } else if (__isByteArrayLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1303
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1304
                __argValues[i].pointerVal = (void *)(__byteArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1305
            } else if (__isWordArray(arg) || __isSignedWordArray(arg)
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1306
                    || __isIntegerArray(arg) || __isSignedIntegerArray(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1307
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1308
                __argValues[i].pointerVal = (void *)(__integerArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1309
            } else if (__isFloatArray(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1310
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1311
                __argValues[i].pointerVal = (void *)(__FloatArrayInstPtr(arg)->f_element);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1312
            } else if (__isDoubleArray(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1313
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1314
                __argValues[i].pointerVal = (void *)(__DoubleArrayInstPtr(arg)->d_element);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1315
            } else if (__isStringLike(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1316
                if (async == true) {
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
  1317
badArgForAsyncCall: ;
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1318
                    __FAIL__(@symbol(BadArgForAsyncCall))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1319
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1320
                __argValues[i].pointerVal = (void *)(__stringVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1321
            } else if (__isBytes(arg) || __isWords(arg) || __isLongs(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1322
                char *p = (char *)(__byteArrayVal(arg));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1323
                int nInstBytes;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1324
                OBJ cls;
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
  1325
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1326
                if (async == true) goto badArgForAsyncCall;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1327
                cls = __qClass(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1328
                nInstBytes = __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars));
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1329
                __argValues[i].pointerVal = p + nInstBytes;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1330
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1331
                __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1332
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1333
            argValuePtr = &(__argValues[i].pointerVal);;
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1334
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1335
        } else if (typeSymbol == @symbol(bool)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1336
            thisType = __get_ffi_type_uint();
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1337
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1338
            if (arg == true) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1339
                __argValues[i].iVal = 1;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1340
            } else if (arg == false) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1341
                __argValues[i].iVal = 0;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1342
            } else if (__isSmallInteger(arg)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1343
                __argValues[i].iVal = __intVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1344
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1345
                __argValues[i].iVal = __unsignedLongIntVal(arg);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1346
                if (__argValues[i].iVal == 0) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1347
                    __FAIL__(@symbol(InvalidArgument))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1348
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1349
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1350
            argValuePtr = &(__argValues[i].iVal);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1351
        } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1352
            if (__isSymbol(typeSymbol)
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1353
             && ((argValueClass = __GLOBAL_GET(typeSymbol)) != nil)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1354
                if (! __isBehaviorLike(argValueClass)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1355
                    __FAIL__(@symbol(NonBehaviorArgumentType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1356
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1357
                if (! __qIsSubclassOfExternalAddress(argValueClass)) {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1358
                    __FAIL__(@symbol(NonExternalAddressArgumentType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1359
                }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1360
                goto commonPointerTypeArg; /* sorry */
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1361
            } else {
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1362
                __FAIL__(@symbol(UnknownArgumentType))
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1363
            }
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1364
        }
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1365
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1366
        __argTypes[i] = thisType;
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1367
        __argValuePointers[i] = argValuePtr;
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
  1368
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1369
# ifdef VERBOSE
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1370
        printf("arg%d: %x\n", i, __argValues[i].iVal);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1371
# endif
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1372
    }
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
  1373
    failureInfo = nil;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1374
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1375
    __callType = FFI_DEFAULT_ABI;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1376
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1377
# ifdef CALLTYPE_FFI_STDCALL
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
  1378
    if (callTypeNumber == @global(CALLTYPE_API)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1379
        __callType = CALLTYPE_FFI_STDCALL;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1380
    }
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1381
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1382
# ifdef CALLTYPE_FFI_V8
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
  1383
    if (callTypeNumber == @global(CALLTYPE_V8)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1384
        __callType = CALLTYPE_FFI_V8;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1385
    }
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1386
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1387
# ifdef CALLTYPE_FFI_V9
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
  1388
    if (callTypeNumber == @global(CALLTYPE_V9)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1389
        __callType = CALLTYPE_FFI_V9;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1390
    }
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1391
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1392
# ifdef CALLTYPE_FFI_UNIX64
9465
d11885052713 rewrite & cleanup
Claus Gittinger <cg@exept.de>
parents: 9464
diff changeset
  1393
    if (callTypeNumber == @global(CALLTYPE_UNIX64)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1394
        __callType = CALLTYPE_FFI_UNIX64;
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1395
    }
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1396
# endif
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1397
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1398
    if (ffi_prep_cif(&__cif, __callType, __numArgsIncludingThis, __returnType, __argTypesIncludingThis) != FFI_OK) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1399
        __FAIL__(@symbol(FFIPrepareFailed))
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1400
    }
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1401
    if (async == true) {
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1402
# ifdef VERBOSE
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1403
        printf("async call 0x%x\n", codeAddress);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1404
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1405
# ifdef WIN32
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1406
        __STX_C_CALL4( "ffi_call", ffi_call, &__cif, codeAddress, __returnValuePointer, __argValuePointersIncludingThis);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1407
# else
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1408
        __BEGIN_INTERRUPTABLE__
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1409
        ffi_call(&__cif, codeAddress, __returnValuePointer, __argValuePointersIncludingThis);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1410
        __END_INTERRUPTABLE__
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1411
# endif
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
  1412
    } else {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1413
        if (unlimitedStack == true) {
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1414
# ifdef VERBOSE
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1415
            printf("UNLIMITEDSTACKCALL call 0x%x\n", codeAddress);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1416
# endif
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1417
# if 0
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1418
            __UNLIMITEDSTACKCALL__(ffi_call, &__cif, codeAddress, __returnValuePointer, __argValuePointersIncludingThis);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1419
# endif
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1420
        } else {
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1421
# ifdef VERBOSE
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1422
            printf("call 0x%x\n", codeAddress);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1423
# endif
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1424
            ffi_call(&__cif, codeAddress, __returnValuePointer, __argValuePointersIncludingThis);
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1425
        }
9435
68f7e39efad7 support of asynchronous calls
ca
parents: 9418
diff changeset
  1426
    }
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1427
# ifdef VERBOSE
9524
2af286bbcac3 *** empty log message ***
ca
parents: 9519
diff changeset
  1428
    printf("retval is %d (0x%x)\n", __returnValue.iVal, __returnValue.iVal);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1429
# endif
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
  1430
    if ((returnTypeSymbol == @symbol(int))
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
  1431
     || (returnTypeSymbol == @symbol(sint))
9479
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1432
     || (returnTypeSymbol == @symbol(sint8))
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1433
     || (returnTypeSymbol == @symbol(sint16))
68d12a181d4a handle types; sint32 types.
ca
parents: 9466
diff changeset
  1434
     || (returnTypeSymbol == @symbol(sint32))) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1435
        RETURN ( __MKINT(__returnValue.iVal) );
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1436
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1437
    if ((returnTypeSymbol == @symbol(uint))
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1438
     || (returnTypeSymbol == @symbol(uint8))
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1439
     || (returnTypeSymbol == @symbol(uint16))
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1440
     || (returnTypeSymbol == @symbol(uint32))) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1441
        RETURN ( __MKUINT(__returnValue.iVal) );
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1442
    }
10025
053904a63549 stc-compiled ExternalLibraryFunctions
Claus Gittinger <cg@exept.de>
parents: 9981
diff changeset
  1443
    if (returnTypeSymbol == @symbol(bool)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1444
        RETURN ( __returnValue.iVal ? true : false );
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1445
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1446
    if (returnTypeSymbol == @symbol(float)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1447
        RETURN ( __MKFLOAT(__returnValue.fVal ));
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1448
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1449
    if (returnTypeSymbol == @symbol(double)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1450
        RETURN ( __MKFLOAT(__returnValue.dVal ));
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1451
    }
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1452
    if (returnTypeSymbol == @symbol(void)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1453
        RETURN ( nil );
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1454
    }
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1455
    if (returnTypeSymbol == @symbol(char)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1456
        RETURN ( __MKCHARACTER(__returnValue.iVal & 0xFF) );
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1457
    }
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1458
    if (returnTypeSymbol == @symbol(wchar)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1459
        RETURN ( __MKUCHARACTER(__returnValue.iVal & 0xFFFF) );
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1460
    }
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1461
    if (returnTypeSymbol == @symbol(sint64)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1462
        RETURN ( __MKINT64(&__returnValue.longLongVal) );
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1463
    }
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1464
    if (returnTypeSymbol == @symbol(uint64)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1465
        RETURN ( __MKUINT64(&__returnValue.longLongVal) );
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1466
    }
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
  1467
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1468
# ifdef VERBOSE
11586
a3b2eef8a74c int vs. sint
Claus Gittinger <cg@exept.de>
parents: 11426
diff changeset
  1469
    printf("%x\n", __returnValue.pointerVal);
12504
c9987bb76eb6 untested long long return value
Claus Gittinger <cg@exept.de>
parents: 12503
diff changeset
  1470
# endif
9346
a95e2cf0e56f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9344
diff changeset
  1471
    if (returnTypeSymbol == @symbol(handle)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1472
        returnValue = __MKEXTERNALADDRESS(__returnValue.pointerVal);
9346
a95e2cf0e56f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9344
diff changeset
  1473
    } else if (returnTypeSymbol == @symbol(pointer)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1474
        returnValue = __MKEXTERNALBYTES(__returnValue.pointerVal);
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1475
    } else if (returnTypeSymbol == @symbol(bytePointer)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1476
        returnValue = __MKEXTERNALBYTES(__returnValue.pointerVal);
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1477
    } else if (returnTypeSymbol == @symbol(charPointer)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1478
        returnValue = __MKSTRING(__returnValue.pointerVal);
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1479
    } else if (returnTypeSymbol == @symbol(wcharPointer)) {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1480
        returnValue = __MKU16STRING(__returnValue.pointerVal);
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1481
    } else {
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1482
        __FAIL__(@symbol(UnknownReturnType2))
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1483
    }
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1484
#else /* no FFI support */
10618
343d0bf4646a Now can compile even #ifndef HAVE_FFI
Stefan Vogel <sv@exept.de>
parents: 10614
diff changeset
  1485
    failureCode = @symbol(FFINotSupported);
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1486
#endif /* HAVE_FFI */
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1487
getOutOfHere: ;
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1488
%}.
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1489
    failureCode notNil ifTrue:[
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1490
        (failureCode == #UnknownReturnType or:[ failureCode == #UnknownArgumentType ]) ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1491
            oldReturnType := returnType.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1492
            oldArgumentTypes := argumentTypes.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1493
            self adjustTypes.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1494
            ((oldReturnType ~= returnType) or:[oldArgumentTypes ~= argumentTypes]) ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1495
                thisContext restart
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1496
            ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1497
        ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1498
        (failureCode == #BadArgForAsyncCall) ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1499
            ^ self tryAgainWithAsyncSafeArguments:argumentsOrNil forCPPInstance:aCPlusPlusObjectOrNil
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1500
        ].
12579
516bba5b3e57 changed: #ffiTypeSymbolForType:
Claus Gittinger <cg@exept.de>
parents: 12504
diff changeset
  1501
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1502
        self primitiveFailed.   "see failureCode and failureInfo for details"
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1503
        ^ nil
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1504
    ].
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1505
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
  1506
    returnType isSymbol ifTrue:[
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1507
        returnValueClass notNil ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1508
            self isConstReturnValue ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1509
                returnValue changeClassTo:returnValueClass.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1510
                ^ returnValue
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1511
            ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1512
            ^ returnValueClass fromExternalAddress:returnValue.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1513
        ].
9483
3bea515ce81e *** empty log message ***
fm
parents: 9479
diff changeset
  1514
    ] ifFalse:[
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1515
        returnType isCPointer ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1516
            returnType baseType isCStruct ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1517
                stClass := Smalltalk classNamed:returnType baseType name.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1518
                stClass notNil ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1519
                    self isConstReturnValue ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1520
                        returnValue changeClassTo:returnValueClass.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1521
                        ^ returnValue
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1522
                    ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1523
                    ^ stClass fromExternalAddress:returnValue.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1524
                ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1525
            ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1526
            returnType baseType isCChar ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1527
                ^ returnValue stringAt:1
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1528
            ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1529
        ].
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1530
    ].
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1531
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1532
    ^ returnValue
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1533
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1534
    "Created: / 01-08-2006 / 13:56:23 / cg"
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1535
    "Modified: / 11-06-2007 / 01:50:36 / cg"
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1536
!
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1537
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1538
tryAgainWithAsyncSafeArguments:argumentsOrNil forCPPInstance:aCPlusPlusObjectOrNil
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1539
    "invoked by the call primitive, iff GC-unsave arguments where passed to the call.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1540
     Here, allocate non-movable blocks of memory and copy the arguments into them,
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1541
     then try the call again, copy changed values back, and release the memeory."
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1542
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1543
    |saveArguments anyBadArg result originalToSaveArgMapping|
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1544
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1545
    argumentsOrNil isNil ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1546
        ^ self primitiveFailed
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1547
    ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1548
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1549
    anyBadArg := false.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1550
    originalToSaveArgMapping := IdentityDictionary new.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1551
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1552
    saveArguments := argumentsOrNil 
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1553
                        collect:[:eachArg |
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1554
                            |saveArg|
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1555
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1556
                            (originalToSaveArgMapping includesKey:eachArg) ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1557
                                saveArg := originalToSaveArgMapping at:eachArg
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1558
                            ] ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1559
                                eachArg isString ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1560
                                    saveArg := (ExternalBytes fromString:eachArg) register.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1561
                                    anyBadArg := true.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1562
                                    originalToSaveArgMapping at:eachArg put:saveArg.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1563
                                ] ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1564
                                    eachArg isByteCollection ifTrue:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1565
                                        saveArg := (ExternalBytes from:eachArg) register.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1566
                                        originalToSaveArgMapping at:eachArg put:saveArg.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1567
                                        anyBadArg := true.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1568
                                    ] ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1569
                                        saveArg := eachArg
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1570
                                    ]
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1571
                                ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1572
                            ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1573
                            saveArg
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1574
                        ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1575
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1576
    anyBadArg ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1577
        "avoid recursion..."
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1578
        ^ self primitiveFailed
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1579
    ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1580
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1581
    result := self invokeFFIwithArguments:saveArguments forCPPInstance:aCPlusPlusObjectOrNil.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1582
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1583
    "/ copy back !!
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1584
    originalToSaveArgMapping keysAndValuesDo:[:arg :saveArg |
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1585
        arg isSymbol ifFalse:[
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1586
            arg replaceFrom:1 to:(arg size) with:saveArg startingAt:1.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1587
        ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1588
        saveArg free.
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1589
    ].
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1590
    ^ result.
9342
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1591
! !
e548ce80ab02 virtual calls
Claus Gittinger <cg@exept.de>
parents: 9341
diff changeset
  1592
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
  1593
!ExternalLibraryFunction methodsFor:'testing'!
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
  1594
10603
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1595
isExternalLibraryFunction
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1596
    "return true, if the receiver is some kind of externalLibrary function;
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1597
     true is returned here"
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1598
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1599
    ^true
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1600
da9b7ed81caf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 10514
diff changeset
  1601
    "Created: / 07-06-2007 / 10:36:40 / cg"
10481
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
  1602
! !
b3526180579f +isExternalLibraryFunction
fm
parents: 10440
diff changeset
  1603
8533
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1604
!ExternalLibraryFunction class methodsFor:'documentation'!
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1605
13412
9a5f99d66cd9 Jan's changes
vrany
parents: 13337
diff changeset
  1606
version_CVS
14037
Michael Beyl <mb@exept.de>
parents: 13782
diff changeset
  1607
    ^ '$Header: /cvs/stx/stx/libbasic/ExternalLibraryFunction.st,v 1.85 2012-03-01 15:22:21 mb Exp $'
12436
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
  1608
!
92a968c9ca92 changed:
Claus Gittinger <cg@exept.de>
parents: 11586
diff changeset
  1609
13412
9a5f99d66cd9 Jan's changes
vrany
parents: 13337
diff changeset
  1610
version_SVN
13782
1994fe87f21e comment/format in: #linkToModule
Claus Gittinger <cg@exept.de>
parents: 13412
diff changeset
  1611
    ^ '§ Id: ExternalLibraryFunction.st 10643 2011-06-08 21:53:07Z vranyj1  §'
8533
9065c547ea75 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  1612
! !
9463
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1613
864880338d7e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 9460
diff changeset
  1614
ExternalLibraryFunction initialize!