display of some types and lines function fixed.
[scilab.git] / scilab / modules / console / sci_gateway / cpp / sci_lines.cpp
1 /*
2 * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3 * Copyright (C) 2011-2014 - DIGITEO - Cedric DELAMARRE
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
14 #include "console_gw.hxx"
15 #include "function.hxx"
16 #include "double.hxx"
17 #include "configvariable.hxx"
18
19 extern "C"
20 {
21 #include "localization.h"
22 #include "Scierror.h"
23 }
24 /*--------------------------------------------------------------------------*/
25
26 types::Function::ReturnValue sci_lines(types::typed_list &in, int _iRetCount, types::typed_list &out)
27 {
28     if (in.size() > 2)
29     {
30         Scierror(77, _("%s: Wrong number of input argument(s): %d to %d expected.\n"), "lines", 0, 2);
31         return types::Function::Error;
32     }
33
34     if (in.size() == 0)
35     {
36         types::Double* pDbl = new types::Double(1, 2);
37         double* pdblSize = pDbl->get();
38         pdblSize[0] = (double)ConfigVariable::getConsoleWidth();
39         pdblSize[1] = (double)ConfigVariable::getConsoleLines();
40         out.push_back(pDbl);
41         return types::Function::OK;
42     }
43
44     if (in.size() == 1)
45     {
46         if ((in[0]->isDouble() == false))
47         {
48             Scierror(999, _("%s: Wrong type for input argument #%d: A scalar expected.\n"), "lines", 1);
49             return types::Function::Error;
50         }
51
52         types::Double* pDblIn = in[0]->getAs<types::Double>();
53         double* pdblIn = in[0]->getAs<types::Double>()->get();
54
55         if (pDblIn->isScalar())
56         {
57             ConfigVariable::setConsoleLines((int)pdblIn[0]);
58         }
59         else if (pDblIn->getRows() == 1 && pDblIn->getCols() == 2)
60         {
61             ConfigVariable::setConsoleWidth((int)pdblIn[0]);
62             ConfigVariable::setConsoleLines((int)pdblIn[1]);
63         }
64         else
65         {
66             Scierror(999, _("%s: Wrong type for input argument #%d: A scalar expected.\n"), "lines", 1);
67             return types::Function::Error;
68         }
69
70         return types::Function::OK;
71     }
72
73     if ((in[0]->isDouble() == false) || in[0]->getAs<types::Double>()->isScalar() == false)
74     {
75         Scierror(999, _("%s: Wrong type for input argument #%d: A scalar expected.\n"), "lines", 1);
76         return types::Function::Error;
77     }
78
79     if ((in[1]->isDouble() == false) || in[1]->getAs<types::Double>()->isScalar() == false)
80     {
81         Scierror(999, _("%s: Wrong type for input argument #%d: A scalar expected.\n"), "lines", 2);
82         return types::Function::Error;
83     }
84
85     ConfigVariable::setConsoleWidth((int)in[1]->getAs<types::Double>()->get(0));
86     ConfigVariable::setConsoleLines((int)in[0]->getAs<types::Double>()->get(0));
87
88     return types::Function::OK;
89 }
90 /*--------------------------------------------------------------------------*/