lrc_variant_<Type-Name>Array_by_ref
Other deprecated syntax variations of this function are currently supported for backwards compatibility:
lrc_Put<Type-Name>ArrayByRefInVariant
lrc_variant<Type-Name>ArrayByRef
lrc_Put<Type-Name>Array_by_refInVariant
| Assignment to Variants - By Reference and By Variant |
Returns a reference to an array of Type-Name in a variant.
Return Values
Parameterization
You cannot use standard parameterization for any arguments in this function.
VARIANT lrc_variant_<Type-Name>Array_by_ref( <Type-Name>Array array );
| Array | An array of the specified type. |
The lrc_variant_<Type-Name>Array_by_ref family of functions returns a reference to an array of the type given in Type-Name. The return type is a variant.
The calls include:
VARIANT lrc_variant_BoolArray_by_ref(BoolArrayarray);
VARIANT lrc_variant_BstrArray_by_ref(BstrArray array);
VARIANT lrc_variant_ByteArray_by_ref(ByteArray array);
VARIANTlrc_variant_CharArray_by_ref(CharArray array);
VARIANT lrc_variant_CoObjectArray_by_ref(CoObjectArray array);
VARIANT lrc_variant_CurrencyArray_by_ref(CurrencyArray array);
VARIANT lrc_variant_DateArray_by_ref(DateArray array);
VARIANT lrc_variant_DispObjectArray_by_ref(DispObjectArray array);
VARIANT lrc_variant_DoubleArray_by_ref(DoubleArray array);
VARIANT lrc_variant_ErrorArray_by_ref(ErrorArray array);
VARIANT lrc_variant_FloatArray_by_ref(FloatArray array);
VARIANTlrc_variant_IntArray_by_ref(IntArray array);
VARIANT lrc_variant_LongArray_by_ref(LongArray array);
VARIANT lrc_variant_ShortArray_by_ref(ShortArray array);
VARIANTlrc_variant_UintArray_by_ref(UintArray array);
VARIANT lrc_variant_UlongArray_by_ref(UlongArray array);
VARIANT lrc_variant_UshortArray_by_ref(UshortArray array);
VARIANT lrc_variant_VariantArray_by_ref(VariantArray array);
Example
This example demonstrates that the lrc_*_ByRef class of functions deals with references to the underlying data, and not the data itself.
VARIANT vRef, vRef1;
FloatArray array0, array1, array2;
float fValue;
// Create and populate an array
array0 = Create1DFloatArray(0, 5);
PutElementIn1DFloatArray(array0, 0, lrc_float("1.1"));
PutElementIn1DFloatArray(array0, 1, lrc_float("20.02"));
PutElementIn1DFloatArray(array0, 2, lrc_float("300.003"));
PutElementIn1DFloatArray(array0, 3, lrc_float("4000"));
PutElementIn1DFloatArray(array0, 4, lrc_float("50000"));
// Get an element from the array and display it
fValue = GetElementFrom1DFloatArray(array0,1);
lr_output_message("Second element in array0 = %f", fValue);Example: Output:
Action.c(20): Second element in array0 = 20.020000
// Get references to the array with two possible syntaxes
vRef = lrc_variant_FloatArray_by_ref(array0);
vRef1 = lrc_PutFloatArrayByRefInVariant(array0);
//Convert the reference to a float array
array1= lrc_GetFloatArrayFromVariant(&vRef);
// Get an element from the new array and display it
fValue = GetElementFrom1DFloatArray(array1,1);
lr_output_message("Second element in array1 = %f", fValue);Example: Output:
Action.c(30): Second element in array1 = 20.020000
//Change an element in the original array
PutElementIn1DFloatArray(array0, 1, lrc_float("101.99"));
// Get an element from the original array and display it
fValue = GetElementFrom1DFloatArray(array0,1);
lr_output_message("Second element in array0 after change = %f", fValue);Example: Output:
Action.c(38): Second element in array0 after change = 101.989998
// Get an element from the new array and display it. It's the same array
fValue = GetElementFrom1DFloatArray(array1,1);
lr_output_message("Second element in array1 after change to array0 = %f", fValue);Example: Output:
Action.c(43): Second element in array1 after change to array0 = 101.989998
/* Confirm that what we've been passing is references to the same array
by showing that the addresses are the same.*/
if (array0 == array1) lr_output_message("There is only one array");Example: Output:
Action.c(46): There is only one array
// Used different syntax above to get the reference, but still the same array.
array2= lrc_GetFloatArrayFromVariant(&vRef1);
fValue = GetElementFrom1DFloatArray(array2,1);
lr_output_message("Second element in array2 after change to array0 = %f", fValue);Example: Output: Action.c(53): Second element in array2 after change to array0 = 101.989998

