utf: output_stream 3
[scilab.git] / scilab / modules / output_stream / sci_gateway / cpp / sci_mprintf.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 "scilabWrite.hxx"
18 #include "function.hxx"
19 #include "string.hxx"
20 #include "overload.hxx"
21
22 #include <iterator>
23
24 extern "C"
25 {
26 #include <stdio.h>
27 #include "Scierror.h"
28 #include "localization.h"
29 #include "os_wtoi.h"
30 }
31
32 /*--------------------------------------------------------------------------*/
33 types::Callable::ReturnValue sci_mprintf(types::typed_list &in, int _iRetCount, types::typed_list &out)
34 {
35     if (in.size() < 1)
36     {
37         Scierror(999, _("%s: Wrong number of input arguments: at least %d expected.\n"), "mprintf", 1);
38         return types::Function::Error;
39     }
40
41     if (in[0]->isString() == false || in[0]->getAs<types::String>()->getSize() != 1)
42     {
43         Scierror(999, _("%s: Wrong type for input argument #%d: string expected.\n"), "mprintf" , 1);
44         return types::Function::Error;
45     }
46
47     for (int i = 1 ; i < in.size() ; i++)
48     {
49         if (in[i]->isDouble() == false && in[i]->isString() == false)
50         {
51             std::string stFuncName = "%" + in[i]->getShortTypeStr() + "_mprintf";
52             return Overload::call(stFuncName, in, _iRetCount, out);
53         }
54     }
55
56     int iOutputRows = 0;
57     int iNewLine = 0;
58     char* pstInput = in[0]->getAs<types::String>()->get()[0];
59     char** pstOutput = scilab_sprintf("mprintf", pstInput, in, &iOutputRows, &iNewLine);
60     if (pstOutput == NULL)
61     {
62         //error already set by scilab_sprintf
63         return types::Function::Error;
64     }
65
66     for (int i = 0 ; i < iOutputRows ; i++)
67     {
68         if (i)
69         {
70             scilabForcedWrite("\n");
71         }
72
73         scilabForcedWrite(pstOutput[i]);
74
75         fflush(NULL);
76         FREE(pstOutput[i]);
77     }
78
79     if (iNewLine)
80     {
81         scilabForcedWrite("\n");
82     }
83
84     FREE(pstOutput);
85     return types::Function::OK;
86 }
87 /*--------------------------------------------------------------------------*/