The function
invoke-dispatch-get-property
is used to invoke an Automation property getter method from Lisp without needing to compile a type library as part of the application. This is similar to using
Dim var as Object
Print #output, var.Prop
in Microsoft Visual Basic and contrasts with the macro call-dispatch-get-property which requires a type library to be compiled.
The
dispinterface-ptr
should be a COM interface pointer for the
i-dispatch
interface. The appropriate Automation method, chosen using
name
, which is either a string naming the method or the integer id of the method. The
args
are converted to Automation values and are passed as the method's
in
and
in-out
parameters in the order in which they appear. The
values
returned consist of the primary value of the method (if not void) and the values of any
out
or
in-out
parameters. See Data conversion when calling Automation methods for more details.
There is also
setf
expander for
invoke-dispatch-get-property
, which can be used as an alternative to the
call-dispatch-put-property macro.
For example, in order to get and set the
Width
property of an interface pointer in the variable
doc
:
(invoke-dispatch-get-property doc "Width")
(setf (invoke-dispatch-get-property
doc "Width")
10)
LispWorks COM/Automation User Guide and Reference Manual - 19 Dec 2011