1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
/*
* Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
* Copyright (C) 2012 - Scilab Enterprises - Calixte DENIZET
*
* This file must be used under the terms of the CeCILL.
* This source file is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
* are also available at
* http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
*
*/
#include "ScilabGateway.hxx"
#include <cstring>
namespace org_modules_external_objects
{
int ScilabGateway::convMatrixMethod(char * fname, const int envId, void * pvApiCtx)
{
char * method = 0;
int rc = 0;
int cr = 0;
CheckInputArgument(pvApiCtx, 0, 1);
ScilabAbstractEnvironment & env = ScilabEnvironments::getEnvironment(envId);
OptionsHelper & helper = env.getOptionsHelper();
ScilabGatewayOptions & options = env.getGatewayOptions();
OptionsHelper::setCopyOccurred(false);
ScilabObjects::initialization(env, pvApiCtx);
options.setIsNew(false);
if (Rhs == 0)
{
SciErr err;
const char * meth = "cr";
if (helper.getMethodOfConv())
{
meth = "rc";
}
err = createMatrixOfString(pvApiCtx, Rhs + 1, 1, 1, const_cast<const char * const *>(&meth));
if (err.iErr)
{
throw ScilabAbstractEnvironmentException(__LINE__, __FILE__, gettext("Invalid variable: cannot retrieve the data"));
}
LhsVar(1) = Rhs + 1;
PutLhsVar();
return 0;
}
method = ScilabObjects::getSingleString(1, pvApiCtx);
rc = std::strcmp(method, "rc");
cr = std::strcmp(method, "cr");
freeAllocatedSingleString(method);
if (rc && cr)
{
throw ScilabAbstractEnvironmentException(__LINE__, __FILE__, gettext("The argument must be \'rc\' or \'cr\'."));
}
helper.setMethodOfConv(cr != 0);
LhsVar(1) = 0;
PutLhsVar();
return 0;
}
}
|