We help IT Professionals succeed at work.

We've partnered with Certified Experts, Carl Webster and Richard Faulkner, to bring you a podcast all about Citrix Workspace, moving to the cloud, and analytics & intelligence. Episode 2 coming soon!Listen Now

x

# VarArrays and Automation

on
Medium Priority
848 Views
I have the following function declaration
(from the typelib) of an Automation server:

Declare Function DrawLine (ByVal startPoint As SAFEARRAY,
ByVal endPoint As SAFEARRAY) As USERDEFINED

This function is expecting two arrays, each containing
three doubles.

If I attempt to call this function from Delphi as shown here,
I get an OLESys error from the server (type mismatch):

p1, p2: variant;
x1, y1, z1, x2, y2, z2: double;
x1 := 2.0; y1 := 4.0; z1 := 6.0;
x2 := 3.0; y2 := 5.0; z2 := 7.0;

p1 := VarArrayOf([x1, y1, z1]);
p2 := VarArrayOf([x2, y2, z2]);

MyAutoObject.DrawLine(p1, p2);

Does anyone know what the problem is here?

Comment
Watch Question

## View Solution Only

Commented:
VarArrayOf returns an array and its size.

The function expects an array without a size.

type
TSafeArray = ARRAY [1..3] OF DOUBLE

var
p1, p2     : TSafeArray;

p1[1] := x1;
p1[2] := x2;

and so on.

Haven't tried, but it ought to do the trick.

Regards,

Erik.

Commented:
Eric - You haven't really answered the question entirely.

Please show how the TSafeArray variables p1 and p2 in your example get to the Automation Server via the call to the method that requires two variants.

Commented:
Have you tried

MyAutoObject.DrawLine(p1, p2);

with p1 and p2 declared as ARRAY [1..3] of Double

I don't know VB very much. Is SAFEARRAY predefined? If not, what is the definition? If I can assume that SAFEARRAY is declared as an array of 3 doubles, this should indeed work.

BTW! If my answer is wrong, reject it. If my answer needs clarification, leave a comment... Makes life much easier for us answering the questions... ;) And, you won't get remarks for rejecting too often.

Regards,

Erik.

Commented:
methods must be of the type variant, you can't pass Delphi types to them.

The declaration shown is not Visual Basic, it's from the OLE type library of the server.

Commented:
I've never declared variants for anything but the OLE server object.... Done quite some automation against Word and Excel without problems. From Delphi I've passed PChars, integers, enumerated types and so on.

Declare Function DrawLine (ByVal startPoint As SAFEARRAY, ByVal endPoint As SAFEARRAY) As USERDEFINED

This is indeed Visual Basic syntax. Still, do you know the definition of SAFEARRAY? And, what automation server is this? Anything common like Office and so on, or some specialiced stuff?

And, did you actually *try* my code?

Regards,

Erik.

Commented:
I suspect what's going on is that VarArrayOf creates a safe array of Variant elements. Try using VarArrayCreate - it's lot less *convenient* than MyAutoObject.DrawLine(VarArrayOf([1, 2, 3], VarArrayOf([4, 5, 6]) - but it lets you create an array of varDouble's.

Not the solution you were looking for? Getting a personalized solution is easy.

Commented:
The problem has been identified by Borland. The Automation Server is expecting a safearray of three OLE doubles. Under all circumstances, Delphi insists on using Variants.

VarArrayCreate demonstrates the exact same problem, and at this point, I should withdraw the question because the problem is inherint to Delphi's implementation of Automation.
##### Thanks for using Experts Exchange.

• View three pieces of content (articles, solutions, posts, and videos)
• Ask the experts questions (counted toward content limit)
• Customize your dashboard and profile