220e79598b7326fa4dd6b790af07d5cc0ca521f0
[scilab.git] / scilab / modules / external_objects / src / cpp / array.cpp
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) 2012 - Scilab Enterprises - Calixte DENIZET
4  *
5  * This file must be used under the terms of the CeCILL.
6  * This source file is licensed as described in the file COPYING, which
7  * you should have received as part of this distribution.  The terms
8  * are also available at
9  * http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
10  *
11  */
12
13 #include "ScilabGateway.hxx"
14
15 namespace org_modules_external_objects
16 {
17
18 int ScilabGateway::array(char * fname, const int envId, void * pvApiCtx)
19 {
20     SciErr err;
21     int ret = 0;
22     int * addr = 0;
23     char * className = 0;
24     int * args = 0;
25     char * errmsg = 0;
26
27     ScilabAbstractEnvironment & env = ScilabEnvironments::getEnvironment(envId);
28
29     if (Rhs < 2)
30     {
31         throw ScilabAbstractEnvironmentException(__LINE__, __FILE__, gettext("Wrong number of arguments : more than %d expected."), 2);
32     }
33
34     OptionsHelper::setCopyOccured(false);
35     ScilabObjects::initialization(env, pvApiCtx);
36     env.getGatewayOptions().setIsNew(false);
37
38     className = ScilabObjects::getSingleString(1, pvApiCtx);
39
40     args = new int[Rhs - 1];
41
42     for (int i = 0; i < Rhs - 1; i++)
43     {
44         err = getVarAddressFromPosition(pvApiCtx, i + 2, &addr);
45         if (err.iErr)
46         {
47             delete[] args;
48             freeAllocatedSingleString(className);
49             throw ScilabAbstractEnvironmentException(__LINE__, __FILE__, gettext("Invalid variable: cannot retrieve the data"));
50         }
51
52         args[i] = ScilabObjects::isPositiveIntegerAtAddress(addr, pvApiCtx);
53
54         if (args[i] == -1 || args[i] == 0)
55         {
56             delete[] args;
57             freeAllocatedSingleString(className);
58             throw ScilabAbstractEnvironmentException(__LINE__, __FILE__, gettext("A strictly positive integer is expected at position %d."), i + 2);
59         }
60     }
61
62     try
63     {
64         ret = env.createarray(className, args, Rhs - 1);
65     }
66     catch (std::exception & e)
67     {
68         delete[] args;
69         freeAllocatedSingleString(className);
70         throw;
71     }
72
73     delete[] args;
74     freeAllocatedSingleString(className);
75
76     try
77     {
78         ScilabObjects::createEnvironmentObjectAtPos(EXTERNAL_OBJECT, Rhs + 1, ret, envId, pvApiCtx);
79     }
80     catch (ScilabAbstractEnvironmentException & e)
81     {
82         env.removeobject(ret);
83         throw;
84     }
85
86     LhsVar(1) = Rhs + 1;
87     PutLhsVar();
88
89     return 0;
90 }
91 }