bug 13972 : use of wildcard '*' in printf expressions was not managed
[scilab.git] / scilab / modules / output_stream / sci_gateway / cpp / sci_msprintf.cpp
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) INRIA
4  * Copyright (C) 2010 - DIGITEO - ELIAS Antoine
5  *
6  * This file must be used under the terms of the CeCILL.
7  * This source file is licensed as described in the file COPYING, which
8  * you should have received as part of this distribution.  The terms
9  * are also available at
10  * http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
11  *
12  */
13
14 #include "funcmanager.hxx"
15 #include "output_stream_gw.hxx"
16 #include "scilab_sprintf.hxx"
17 #include "function.hxx"
18 #include "string.hxx"
19 #include "overload.hxx"
20 #include "execvisitor.hxx"
21
22 extern "C"
23 {
24 #include "Scierror.h"
25 #include "localization.h"
26 #include "freeArrayOfString.h"
27 }
28
29 /*--------------------------------------------------------------------------*/
30 types::Callable::ReturnValue sci_msprintf(types::typed_list &in, int _iRetCount, types::typed_list &out)
31 {
32     if (in.size() < 1)
33     {
34         Scierror(999, _("%s: Wrong number of input arguments: at least %d expected.\n"), "msprintf", 1);
35         return types::Function::Error;
36     }
37
38     if (in[0]->isString() == false || in[0]->getAs<types::String>()->getSize() != 1)
39     {
40         Scierror(999, _("%s: Wrong type for input argument #%d: A string expected.\n"), "msprintf" , 1);
41         return types::Function::Error;
42     }
43
44     for (int i = 1 ; i < in.size() ; i++)
45     {
46         if (in[i]->isDouble() == false && in[i]->isString() == false)
47         {
48             ast::ExecVisitor exec;
49             std::wstring wstFuncName = L"%" + in[i]->getShortTypeStr() + L"_msprintf";
50             return Overload::call(wstFuncName, in, _iRetCount, out, &exec);
51         }
52     }
53
54     int iOutputRows = 0;
55     int iNewLine = 0;
56     wchar_t* pwstInput = in[0]->getAs<types::String>()->get()[0];
57     wchar_t** pwstOutput = scilab_sprintf("msprintf", pwstInput, in, &iOutputRows, &iNewLine);
58
59     if (pwstOutput == NULL)
60     {
61         return types::Function::Error;
62     }
63
64     types::String* pOut = new types::String(iOutputRows, 1);
65     pOut->set(pwstOutput);
66     freeArrayOfWideString(pwstOutput, iOutputRows);
67     out.push_back(pOut);
68     return types::Function::OK;
69 }
70 /*--------------------------------------------------------------------------*/