bug_11077 fixed.
[scilab.git] / scilab / modules / data_structures / sci_gateway / cpp / sci_rlist.cpp
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) 2014 - 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 /*--------------------------------------------------------------------------*/
17 #include "data_structures_gw.hxx"
18 #include "function.hxx"
19 #include "string.hxx"
20 #include "tlist.hxx"
21 #include "double.hxx"
22
23 extern "C"
24 {
25 #include "Scierror.h"
26 #include "localization.h"
27 }
28
29 /*-----------------------------------------------------------------------------------*/
30 types::Function::ReturnValue sci_rlist(types::typed_list &in, int _iRetCount, types::typed_list &out)
31 {
32     if (in.size() != 2 && in.size() != 3)
33     {
34         Scierror(77, _("%s: Wrong number of input argument(s): %d or %d expected.\n"), "rlist", 2, 3);
35         return types::Function::Error;
36     }
37
38     if (_iRetCount > 1)
39     {
40         Scierror(78, _("%s: Wrong number of output argument(s): %d expected.\n"), "rlist", 1);
41         return types::Function::Error;
42     }
43
44     types::TList* pTLOut = new types::TList();
45     const wchar_t * wcsFields[4] = {L"r", L"num", L"den", L"dt"};
46     types::String* pStr = new types::String(1, 4, wcsFields);
47     pTLOut->set(0, pStr);
48
49     for (int i = 0; i < in.size(); i++)
50     {
51         pTLOut->set(i + 1, in[i]);
52     }
53
54     // set dt
55     if (in.size() == 2)
56     {
57         pTLOut->set(3, types::Double::Empty());
58     }
59
60     out.push_back(pTLOut);
61     return types::Function::OK;
62 }