Integer use case.
This example shows how to get an integer variable and return it to Scilab.
#include "api_scilab.h"
int integerExample(char *fname,unsigned long fname_len)
{
SciErr sciErr;
int* piAddr = NULL;
int iType = 0;
int iRet = 0;
int iPrec = 0;
CheckInputArgument(pvApiCtx, 1, 1);
CheckOutputArgument(pvApiCtx, 0, 1);
sciErr = getVarAddressFromPosition(pvApiCtx, 1, &piAddr);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return 0;
}
if(isIntegerType(pvApiCtx, piAddr))
{
sciErr = getMatrixOfIntegerPrecision(pvApiCtx, piAddr, &iPrec);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
switch(iPrec)
{
case SCI_INT8 :
if(isScalar(pvApiCtx, piAddr))
{
char cData = 0;
iRet = getScalarInteger8(pvApiCtx, piAddr, &cData);
if(iRet)
{
return iRet;
}
iRet = createScalarInteger8(pvApiCtx, nbInputArgument + 1, cData);
if(iRet)
{
return iRet;
}
}
else
{
int iRows = 0;
int iCols = 0;
char* pcData = NULL;
sciErr = getMatrixOfInteger8(pvApiCtx, piAddr, &iRows, &iCols, &pcData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
sciErr = createMatrixOfInteger8(pvApiCtx, nbInputArgument + 1, iRows, iCols, pcData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
}
break;
case SCI_INT16 :
if(isScalar(pvApiCtx, piAddr))
{
short sData = 0;
iRet = getScalarInteger16(pvApiCtx, piAddr, &sData);
if(iRet)
{
return iRet;
}
iRet = createScalarInteger16(pvApiCtx, nbInputArgument + 1, sData);
if(iRet)
{
return iRet;
}
}
else
{
int iRows = 0;
int iCols = 0;
short* psData = NULL;
sciErr = getMatrixOfInteger16(pvApiCtx, piAddr, &iRows, &iCols, &psData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
sciErr = createMatrixOfInteger16(pvApiCtx, nbInputArgument + 1, iRows, iCols, psData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
}
break;
case SCI_INT32 :
if(isScalar(pvApiCtx, piAddr))
{
int iData = 0;
iRet = getScalarInteger32(pvApiCtx, piAddr, &iData);
if(iRet)
{
return iRet;
}
iRet = createScalarInteger32(pvApiCtx, nbInputArgument + 1, iData);
if(iRet)
{
return iRet;
}
}
else
{
int iRows = 0;
int iCols = 0;
int* piData = NULL;
sciErr = getMatrixOfInteger32(pvApiCtx, piAddr, &iRows, &iCols, &piData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
sciErr = createMatrixOfInteger32(pvApiCtx, nbInputArgument + 1, iRows, iCols, piData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
}
break;
#ifdef __SCILAB_INT64__
case SCI_INT64 :
#endif
case SCI_UINT8 :
if(isScalar(pvApiCtx, piAddr))
{
unsigned char ucData = 0;
iRet = getScalarUnsignedInteger8(pvApiCtx, piAddr, &ucData);
if(iRet)
{
return iRet;
}
iRet = createScalarUnsignedInteger8(pvApiCtx, nbInputArgument + 1, ucData);
if(iRet)
{
return iRet;
}
}
else
{
int iRows = 0;
int iCols = 0;
unsigned char* pucData = NULL;
sciErr = getMatrixOfUnsignedInteger8(pvApiCtx, piAddr, &iRows, &iCols, &pucData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
sciErr = createMatrixOfUnsignedInteger8(pvApiCtx, nbInputArgument + 1, iRows, iCols, pucData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
}
break;
case SCI_UINT16 :
if(isScalar(pvApiCtx, piAddr))
{
unsigned short usData = 0;
iRet = getScalarUnsignedInteger16(pvApiCtx, piAddr, &usData);
if(iRet)
{
return iRet;
}
iRet = createScalarUnsignedInteger16(pvApiCtx, nbInputArgument + 1, usData);
if(iRet)
{
return iRet;
}
}
else
{
int iRows = 0;
int iCols = 0;
unsigned short* pusData = NULL;
sciErr = getMatrixOfUnsignedInteger16(pvApiCtx, piAddr, &iRows, &iCols, &pusData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
sciErr = createMatrixOfUnsignedInteger16(pvApiCtx, nbInputArgument + 1, iRows, iCols, pusData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
}
break;
case SCI_UINT32 :
if(isScalar(pvApiCtx, piAddr))
{
unsigned int uiData = 0;
iRet = getScalarUnsignedInteger32(pvApiCtx, piAddr, &uiData);
if(iRet)
{
return iRet;
}
iRet = createScalarUnsignedInteger32(pvApiCtx, nbInputArgument + 1, uiData);
if(iRet)
{
return iRet;
}
}
else
{
int iRows = 0;
int iCols = 0;
unsigned int* puiData = NULL;
sciErr = getMatrixOfUnsignedInteger32(pvApiCtx, piAddr, &iRows, &iCols, &puiData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
sciErr = createMatrixOfUnsignedInteger32(pvApiCtx, nbInputArgument + 1, iRows, iCols, puiData);
if(sciErr.iErr)
{
printError(&sciErr, 0);
return sciErr.iErr;
}
}
break;
#ifdef __SCILAB_INT64__
case SCI_UINT64 :
#endif
default :
break;
}
}
AssignOutputVariable(1) = nbInputArgument + 1;
return 0;
}
i8_1 = `int8`_(1);
i8_2 = `int8`_([1,2,3;4,5,6]);
ui8_1 = `uint8`_(1);
ui8_2 = `uint8`_([1,2,3;4,5,6]);
i16_1 = `int16`_(1);
i16_2 = `int16`_([1,2,3;4,5,6]);
ui16_1 = `uint16`_(1);
ui16_2 = `uint16`_([1,2,3;4,5,6]);
i32_1 = `int32`_(1);
i32_2 = `int32`_([1,2,3;4,5,6]);
ui32_1 = `uint32`_(1);
ui32_2 = `uint32`_([1,2,3;4,5,6]);
if integerExample(i8_1) <> i8_1 then pause;end
if integerExample(i8_2) <> i8_2 then pause;end
if integerExample(ui8_1) <> ui8_1 then pause;end
if integerExample(ui8_2) <> ui8_2 then pause;end
if integerExample(i16_1) <> i16_1 then pause;end
if integerExample(i16_2) <> i16_2 then pause;end
if integerExample(ui16_1) <> ui16_1 then pause;end
if integerExample(ui16_2) <> ui16_2 then pause;end
if integerExample(i8_1) <> i16_1 then pause;end
if integerExample(i8_2) <> i16_2 then pause;end
if integerExample(ui8_1) <> ui16_1 then pause;end
if integerExample(ui8_2) <> ui16_2 then pause;end