| MvComponentExecDuplexObjectCallbackAsync Method |
This function executes a member callback on the server and get its result in
an asynchronous task.
Namespace:
RW.Server.Component
Assembly:
RW.Server.Component (in RW.Server.Component.dll) Version: 6.5.0.0 (6.5.0.0)
Syntax public Task<MvValue> ExecDuplexObjectCallbackAsync(
MvRef mvref,
string funNm,
MvValue[] args
)
Public Function ExecDuplexObjectCallbackAsync (
mvref As MvRef,
funNm As String,
args As MvValue()
) As Task(Of MvValue)
public:
Task<MvValue^>^ ExecDuplexObjectCallbackAsync(
MvRef mvref,
String^ funNm,
array<MvValue^>^ args
)
Parameters
- mvref
- Type: RW.Server.ComponentMvRef
Reference on the object the callback is member of. - funNm
- Type: SystemString
Name of the callback to execute on server side. - args
- Type: RW.Server.ComponentMvValue
Arguments to send to the server callback.
Return Value
Type:
TaskMvValueAn asynchronous result.
Remarks
The task may be canceled in the two following situations:
- The callback has been rolled back by the server ;
- The component has been disconnected and disposed.
In such a case, an
TaskCanceledException is raised.
This exception might be embedded into an
AggregateException when
using
Result or
Wait.
Examples
It is possible to wait the result into a separate thread or task.
MvValue[] parameters = new MvValue[2];
parameters[0] = new MvValue(42);
parameters[1] = new MvValue(51);
var tresult = _component.ExecDuplexObjectCallbackAsync(new MvRef(object),"Multiply", parameters);
Task.Run(() => {
try {
var result = tresult.Result;
Console.WriteLine(" Duplex result = " + result.AsString());
}
catch(AggregateException e) {
Console.WriteLine(" Duplex result canceled.");
}
});
Examples
In an asynchronous function, you can use:
MvValue[] parameters = new MvValue[2];
parameters[0] = new MvValue(42);
parameters[1] = new MvValue(51);
try {
MvValue result = await _component.ExecDuplexObjectCallbackAsync(new MvRef(object),"Multiply", parameters);
Console.WriteLine(result.AsString());
}
catch(TaskCanceledException e) {
Console.WriteLine(" Duplex result canceled.");
}
See Also