core: on error, a crash could happen
[scilab.git] / scilab / modules / core / sci_gateway / cpp / sci_where.cpp
1 /*
2  *  Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  *  Copyright (C) 2013 - scilab Enterprises - Cedric Delamarre
4  *
5  * Copyright (C) 2012 - 2016 - Scilab Enterprises
6  *
7  * This file is hereby licensed under the terms of the GNU GPL v2.0,
8  * pursuant to article 5.3.4 of the CeCILL v.2.1.
9  * This file was originally licensed under the terms of the CeCILL v2.1,
10  * and continues to be available under such terms.
11  * For more information, see the COPYING file which you should have received
12  * along with this program.
13  *
14  */
15
16 #include <vector>
17
18 #include "core_gw.hxx"
19 #include "function.hxx"
20 #include "configvariable.hxx"
21 #include "double.hxx"
22 #include "string.hxx"
23
24 extern "C"
25 {
26 #include "localization.h"
27 #include "Scierror.h"
28 }
29
30 types::Function::ReturnValue sci_where(types::typed_list &in, int _iRetCount, types::typed_list &out)
31 {
32     if (in.size() != 0)
33     {
34         Scierror(77, _("%s: Wrong number of input argument(s): %d expected."), "where", 0);
35         return types::Function::Error;
36     }
37
38     if (_iRetCount != 2)
39     {
40         Scierror(78, _("%s: Wrong number of output argument(s): %d expected."), "where", 2);
41         return types::Function::Error;
42     }
43
44     const std::vector<ConfigVariable::WhereEntry>& where = ConfigVariable::getWhere();
45     if (where.size() <= 1)
46     {
47         out.push_back(types::Double::Empty());
48         out.push_back(types::Double::Empty());
49         return types::Function::OK;
50     }
51
52     types::Double* pDblLines = new types::Double((int)where.size() - 1, 1);
53     types::String* pStrNames = new types::String((int)where.size() - 1, 1);
54
55     auto it = where.rbegin();
56     pDblLines->set(0, it->m_line);
57     it++;
58     for (int i = 0; it != where.rend(); it++, i++)
59     {
60         pDblLines->set(i + 1, it->m_line);
61         pStrNames->set(i, it->call->getName().c_str());
62     }
63
64     pStrNames->set(static_cast<int>(where.size()) - 1, where.back().call->getName().c_str());
65
66     out.push_back(pDblLines);
67     out.push_back(pStrNames);
68     return types::Function::OK;
69 }