* Bug #13690 fixed - tight_limits property can now manage X, Y and Z axis separately.
[scilab.git] / scilab / modules / graphics / src / c / getHandleProperty / get_tight_limits_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  * Copyright (C) 2014 - Scilab Enterprises - Vincent Couvert
9  *
10  * This file must be used under the terms of the CeCILL.
11  * This source file is licensed as described in the file COPYING, which
12  * you should have received as part of this distribution.  The terms
13  * are also available at
14  * http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
15  *
16  */
17
18 /*------------------------------------------------------------------------*/
19 /* file: get_tight_limits_property.c                                      */
20 /* desc : function to retrieve in Scilab the tight_limits field of        */
21 /*        a handle                                                        */
22 /*------------------------------------------------------------------------*/
23
24 #include <string.h>
25 #include "getHandleProperty.h"
26 #include "GetProperty.h"
27 #include "returnProperty.h"
28 #include "Scierror.h"
29 #include "localization.h"
30 #ifdef _MSC_VER
31 #include "strdup_windows.h"
32 #endif
33
34 #include "getGraphicObjectProperty.h"
35 #include "graphicObjectProperties.h"
36
37 /*------------------------------------------------------------------------*/
38 int get_tight_limits_property(void* _pvCtx, int iObjUID)
39 {
40     char * tightLimits[3]  = { NULL, NULL, NULL };
41     int const axesTightLimitsPropertiesNames[3] = {__GO_X_TIGHT_LIMITS__, __GO_Y_TIGHT_LIMITS__, __GO_Z_TIGHT_LIMITS__};
42     int iTightLimits = 0;
43     int* piTightLimits = &iTightLimits;
44
45     int i = 0;
46     int j = 0;
47     int status = -1;
48
49     for (i = 0 ; i < 3 ; i++)
50     {
51         getGraphicObjectProperty(iObjUID, axesTightLimitsPropertiesNames[i], jni_bool, (void **)&piTightLimits);
52
53         if (piTightLimits == NULL)
54         {
55             Scierror(999, _("'%s' property does not exist for this handle.\n"), "tight_limits");
56             return -1;
57         }
58
59         if (iTightLimits)
60         {
61             tightLimits[i] = strdup("on");
62         }
63         else
64         {
65             tightLimits[i] = strdup("off");
66         }
67
68         if (tightLimits[i] == NULL)
69         {
70             for (j = 0 ; j < i ; j++)
71             {
72                 free(tightLimits[j]);
73             }
74
75             Scierror(999, _("%s: No more memory.\n"), "get_tight_limits_property");
76             return -1;
77         }
78
79     }
80
81     status = sciReturnRowStringVector(_pvCtx, tightLimits, 3);
82
83     for (i = 0 ; i < 3 ; i++)
84     {
85         free(tightLimits[i]);
86     }
87
88     return status;
89 }
90 /*------------------------------------------------------------------------*/