Graphics: return a null pointer in C when property does not exist
[scilab.git] / scilab / modules / graphics / src / c / getHandleProperty / get_data_bounds_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_data_bounds_property.c                                       */
19 /* desc : function to retrieve in Scilab the data_bounds field of         */
20 /*        a handle                                                        */
21 /*------------------------------------------------------------------------*/
22
23 #include "getHandleProperty.h"
24 #include "returnProperty.h"
25 #include "Scierror.h"
26 #include "localization.h"
27
28 #include "getGraphicObjectProperty.h"
29 #include "graphicObjectProperties.h"
30
31 /*------------------------------------------------------------------------*/
32 int get_data_bounds_property(void* _pvCtx, char* pobjUID)
33 {
34     double* dataBounds = NULL;
35     int iView = 0;
36     int* piView = &iView;
37
38     getGraphicObjectProperty(pobjUID, __GO_DATA_BOUNDS__, jni_double_vector, (void **)&dataBounds);
39
40     if (dataBounds == NULL)
41     {
42         Scierror(999, _("'%s' property does not exist for this handle.\n"), "data_bounds");
43         return -1;
44     }
45
46     getGraphicObjectProperty(pobjUID, __GO_VIEW__, jni_int, (void **)&piView);
47     if (piView == NULL)
48     {
49         Scierror(999, _("'%s' property does not exist for this handle.\n"), "view");
50         return -1;
51     }
52
53     /**DJ.Abdemouche 2003**/
54     if (iView == 1)
55     {
56         return sciReturnMatrix(_pvCtx, dataBounds, 2, 3);
57     }
58     else
59     {
60         return sciReturnMatrix(_pvCtx, dataBounds, 2, 2);
61     }
62 }
63 /*------------------------------------------------------------------------*/