Graphics: return a null pointer in C when property does not exist
[scilab.git] / scilab / modules / graphics / src / c / getHandleProperty / get_sub_tics_property.c
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) 2004-2006 - INRIA - Fabrice Leray
4  * Copyright (C) 2006 - INRIA - Allan Cornet
5  * Copyright (C) 2006 - INRIA - Jean-Baptiste Silvy
6  * Copyright (C) 2010 - DIGITEO - Manuel Juliachs
7  * Copyright (C) 2011 - DIGITEO - Vincent Couvert
8  *
9  * This file must be used under the terms of the CeCILL.
10  * This source file is licensed as described in the file COPYING, which
11  * you should have received as part of this distribution.  The terms
12  * are also available at
13  * http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
14  *
15  */
16
17 /*------------------------------------------------------------------------*/
18 /* file: get_sub_tics_property.c                                          */
19 /* desc : function to retrieve in Scilab the sub_tics or sub_ticks field  */
20 /*        of a handle                                                     */
21 /*------------------------------------------------------------------------*/
22
23 #include <string.h>
24
25 #include "getHandleProperty.h"
26 #include "GetProperty.h"
27 #include "returnProperty.h"
28 #include "Scierror.h"
29 #include "localization.h"
30
31 #include "getGraphicObjectProperty.h"
32 #include "graphicObjectProperties.h"
33
34 /*------------------------------------------------------------------------*/
35 int get_sub_tics_property(void* _pvCtx, char* pobjUID)
36 {
37     int iType = -1;
38     int *piType = &iType;
39     int iSubTicks = 0;
40     int* piSubTicks = &iSubTicks;
41
42     /*Dj.A 17/12/2003*/
43     /* modified jb Silvy 01/2006 */
44
45     getGraphicObjectProperty(pobjUID, __GO_TYPE__, jni_int, (void **)&piType);
46     if (piType == NULL)
47     {
48         Scierror(999, _("'%s' property does not exist for this handle.\n"), "type");
49         return -1;
50     }
51
52     /*
53      * Type test required as the Axis object stores subticks as a single int
54      * whereas Axes maintain a 3-element int vector.
55      */
56     if (iType == __GO_AXIS__)
57     {
58         getGraphicObjectProperty(pobjUID, __GO_SUBTICKS__, jni_int, (void**)&piSubTicks);
59
60         if (piSubTicks == NULL)
61         {
62             Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
63             return -1;
64         }
65
66         return sciReturnDouble(_pvCtx, iSubTicks);
67     }
68     else if (iType == __GO_AXES__)
69     {
70         double sub_ticks[3];
71         int iView = 0;
72         int* piView = &iView;
73
74         getGraphicObjectProperty(pobjUID, __GO_X_AXIS_SUBTICKS__, jni_int, (void**)&piSubTicks);
75         if (piSubTicks == NULL)
76         {
77             Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
78             return -1;
79         }
80
81         sub_ticks[0] = iSubTicks;
82
83         getGraphicObjectProperty(pobjUID, __GO_Y_AXIS_SUBTICKS__, jni_int, (void**)&piSubTicks);
84         if (piSubTicks == NULL)
85         {
86             Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
87             return -1;
88         }
89
90         sub_ticks[1] = iSubTicks;
91
92         getGraphicObjectProperty(pobjUID, __GO_Z_AXIS_SUBTICKS__, jni_int, (void**)&piSubTicks);
93         if (piSubTicks == NULL)
94         {
95             Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
96             return -1;
97         }
98
99         sub_ticks[2] = iSubTicks;
100
101         getGraphicObjectProperty(pobjUID, __GO_VIEW__, jni_int, (void**)&piView);
102         if (piView == NULL)
103         {
104             Scierror(999, _("'%s' property does not exist for this handle.\n"), "view");
105             return -1;
106         }
107
108         if (iView == 1)
109         {
110             return sciReturnRowVector(_pvCtx, sub_ticks, 3);
111         }
112         else
113         {
114             return sciReturnRowVector(_pvCtx, sub_ticks, 2);
115         }
116     }
117     else
118     {
119         Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
120         return -1;
121     }
122 }
123 /*------------------------------------------------------------------------*/