Use hxx extensions instead of hpp
[scilab.git] / scilab / modules / xml / sci_gateway / cpp / sci_percent_XMLAttr_size.cpp
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) 2011 - Scilab Enterprises - Calixte DENIZET
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 #include "XMLObject.hxx"
14 #include "XMLAttr.hxx"
15
16 extern "C"
17 {
18 #include "gw_xml.h"
19 #include "Scierror.h"
20 #include "api_scilab.h"
21 #include "xml_mlist.h"
22 #include "localization.h"
23 #include <string.h>
24 }
25
26 using namespace org_modules_xml;
27
28 /*--------------------------------------------------------------------------*/
29 int sci_percent_XMLAttr_size(char *fname, unsigned long fname_len)
30 {
31     int id;
32     SciErr err;
33     double d[2] = { 1, 0 };
34     int * addr = 0;
35     XMLAttr * attrs;
36     int size;
37     char * option = 0;
38
39     CheckLhs(1, 1);
40     CheckRhs(1, 2);
41
42     err = getVarAddressFromPosition(pvApiCtx, 1, &addr);
43     if (err.iErr)
44     {
45         printError(&err, 0);
46         Scierror(999, _("%s: Can not read input argument #%d.\n"), fname, 1);
47         return 0;
48     }
49
50     if (!isXMLAttr(addr, pvApiCtx))
51     {
52         Scierror(999, gettext("%s: Wrong type for input argument #%d: A %s expected.\n"), fname, 1, "XMLAttr");
53         return 0;
54
55     }
56
57     id = getXMLObjectId(addr, pvApiCtx);
58     attrs = XMLObject::getFromId<XMLAttr>(id);
59     if (!attrs)
60     {
61         Scierror(999, gettext("%s: XMLList does not exist.\n"), fname);
62         return 0;
63     }
64
65     if (Rhs == 2)
66     {
67         err = getVarAddressFromPosition(pvApiCtx, 2, &addr);
68         if (err.iErr)
69         {
70             printError(&err, 0);
71             Scierror(999, _("%s: Can not read input argument #%d.\n"), fname, 2);
72             return 0;
73         }
74
75         if (!isStringType(pvApiCtx, addr) || !checkVarDimension(pvApiCtx, addr, 1, 1))
76         {
77             Scierror(999, gettext("%s: Wrong type for input argument #%d: A string expected.\n"), fname, 2);
78             return 0;
79         }
80         if (getAllocatedSingleString(pvApiCtx, addr, &option) != 0)
81         {
82             Scierror(999, _("%s: No more memory.\n"), fname);
83             return 0;
84         }
85
86         if (strcmp(option, "r") && strcmp(option, "c") && strcmp(option, "*"))
87         {
88             freeAllocatedSingleString(option);
89             Scierror(44, _("%s: Wrong value for input argument #%d: '%s', '%s' or '%s' expected.\n"), fname, 2, "r", "c", "*");
90             return 0;
91         }
92     }
93
94     size = (int)(attrs->getSize());
95     if (Rhs == 1)
96     {
97         d[1] = size;
98         if (size == 0)
99         {
100             d[0] = 0;
101         }
102         err = createMatrixOfDouble(pvApiCtx, Rhs + 1, 1, 2, d);
103     }
104     else
105     {
106         if (option[0] == 'r')
107         {
108             if (size == 0)
109             {
110                 d[0] = 0;
111             }
112         }
113         else
114         {
115             d[0] = size;
116         }
117         freeAllocatedSingleString(option);
118         err = createMatrixOfDouble(pvApiCtx, Rhs + 1, 1, 1, d);
119     }
120
121     if (err.iErr)
122     {
123         printError(&err, 0);
124         Scierror(999, _("%s: Memory allocation error.\n"), fname);
125         return 0;
126     }
127
128     LhsVar(1) = Rhs + 1;
129     PutLhsVar();
130     return 0;
131 }
132
133 /*--------------------------------------------------------------------------*/