GPL + CeCILL Header change
[scilab.git] / scilab / modules / graphics / sci_gateway / c / sci_name2rgb.c
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) 2014 - Scilab Enterprises - Antoine ELIAS
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  * === LICENSE_END ===
14  *
15  */
16 #include "sci_malloc.h"
17 #include "gw_graphics.h"
18 #include "api_scilab.h"
19 #include "localization.h"
20 #include "Scierror.h"
21 #include "name2rgb.h"
22 #include "CurrentFigure.h"
23 #include "createGraphicObject.h"
24
25 int sci_name2rgb(char *fname, void* pvApiCtx)
26 {
27     SciErr sciErr;
28     int* piAddr = NULL;
29     char* pstColor = NULL;
30     double color[3];
31     int i;
32     int nRows;
33     int nCols;
34     int nRowsCols;
35     char** pstColorMatrix = NULL;
36     double* pColor = NULL;
37
38     CheckInputArgument(pvApiCtx, 1, 1);
39
40     sciErr = getVarAddressFromPosition(pvApiCtx, 1, &piAddr);
41     if (sciErr.iErr)
42     {
43         printError(&sciErr, 0);
44         return 1;
45     }
46
47     if (isStringType(pvApiCtx, piAddr) == FALSE)
48     {
49         Scierror(999, _("%s: Wrong type for input argument #%d: string expected.\n"), fname, 1);
50         return 1;
51     }
52
53     if (isScalar(pvApiCtx, piAddr) == TRUE)
54     {
55         getAllocatedSingleString(pvApiCtx, piAddr, &pstColor);
56         name2rgb(pstColor, color);
57         freeAllocatedSingleString(pstColor);
58
59         if (color[0] == -1 || color[1] == -1 || color[2] == -1)
60         {
61             createEmptyMatrix(pvApiCtx, 2);
62         }
63         else
64         {
65             createMatrixOfDouble(pvApiCtx, 2, 1, 3, color);
66         }
67     }
68     else
69     {
70         getAllocatedMatrixOfString(pvApiCtx, piAddr, &nRows, &nCols, &pstColorMatrix);
71         nRowsCols = nRows * nCols;
72         pColor = (double*)MALLOC(3 * nRowsCols * sizeof(double));
73         for (i = 0; i < nRowsCols; ++i)
74         {
75             name2rgb(pstColorMatrix[i], color);
76             if (color[0] == -1 || color[1] == -1 || color[2] == -1)
77             {
78                 break;
79             }
80             pColor[i] = color[0];
81             pColor[i + nRowsCols] = color[1];
82             pColor[i + 2 * nRowsCols] = color[2];
83         }
84         freeAllocatedMatrixOfString(nRows, nCols, pstColorMatrix);
85         if (color[0] == -1 || color[1] == -1 || color[2] == -1)
86         {
87             createEmptyMatrix(pvApiCtx, 2);
88             FREE(pColor);
89         }
90         else
91         {
92             createMatrixOfDouble(pvApiCtx, 2, nRowsCols, 3, pColor);
93             FREE(pColor);
94         }
95     }
96     AssignOutputVariable(pvApiCtx, 1) = 2;
97     ReturnArguments(pvApiCtx);
98     return 0;
99 }