e8263aab557887f80c11830adc1893f2419bc90c
[scilab.git] / scilab / modules / xcos / src / jni / Palette.hxx
1 /* Generated by GIWS (version 2.0.1) with command:
2 giws --disable-return-size-array --output-dir src/jni/ --throws-exception-on-error --description-file src/jni/Palette.giws.xml 
3 */
4 /*
5
6 This is generated code.
7
8 This software is a computer program whose purpose is to hide the complexity
9 of accessing Java objects/methods from C++ code.
10
11 This software is governed by the CeCILL-B license under French law and
12 abiding by the rules of distribution of free software.  You can  use, 
13 modify and/ or redistribute the software under the terms of the CeCILL-B
14 license as circulated by CEA, CNRS and INRIA at the following URL
15 "http://www.cecill.info". 
16
17 As a counterpart to the access to the source code and  rights to copy,
18 modify and redistribute granted by the license, users are provided only
19 with a limited warranty  and the software's author,  the holder of the
20 economic rights,  and the successive licensors  have only  limited
21 liability. 
22
23 In this respect, the user's attention is drawn to the risks associated
24 with loading,  using,  modifying and/or developing or reproducing the
25 software by the user in light of its specific status of free software,
26 that may mean  that it is complicated to manipulate,  and  that  also
27 therefore means  that it is reserved for developers  and  experienced
28 professionals having in-depth computer knowledge. Users are therefore
29 encouraged to load and test the software's suitability as regards their
30 requirements in conditions enabling the security of their systems and/or 
31 data to be ensured and,  more generally, to use and operate it in the 
32 same conditions as regards security. 
33
34 The fact that you are presently reading this means that you have had
35 knowledge of the CeCILL-B license and that you accept its terms.
36 */
37
38
39 #ifndef __ORG_SCILAB_MODULES_XCOS_PALETTE_PALETTE__
40 #define __ORG_SCILAB_MODULES_XCOS_PALETTE_PALETTE__
41 #include <iostream>
42 #include <string>
43 #include <string.h>
44 #include <stdlib.h>
45 #include <jni.h>
46
47 #include "GiwsException.hxx"
48
49         #if defined(_MSC_VER) /* Defined anyway with Visual */
50             #include <Windows.h>
51         #else
52             typedef signed char byte;
53         #endif
54
55
56 #ifndef GIWSEXPORT
57 # if defined(_MSC_VER) || defined(__WIN32__) || defined(__CYGWIN__)
58 #   if defined(STATIC_LINKED)
59 #     define GIWSEXPORT
60 #   else
61 #     define GIWSEXPORT __declspec(dllexport)
62 #   endif
63 # else
64 #   if __GNUC__ >= 4
65 #     define GIWSEXPORT __attribute__ ((visibility ("default")))
66 #   else
67 #     define GIWSEXPORT
68 #   endif
69 # endif
70 #endif
71
72 namespace org_scilab_modules_xcos_palette {
73 class GIWSEXPORT Palette {
74
75 private:
76 JavaVM * jvm;
77
78 protected:
79 jmethodID voidloadPaljstringjava_lang_StringjobjectArray_java_lang_Stringjava_lang_StringID; // cache method id
80 jclass stringArrayClass;
81 jmethodID voidloadPaljstringjava_lang_StringID; // cache method id
82 jmethodID voidaddCategoryjobjectArray_java_lang_Stringjava_lang_StringjbooleanbooleanID; // cache method id
83 jmethodID voidremovejobjectArray_java_lang_Stringjava_lang_StringID; // cache method id
84 jmethodID voidenablejobjectArray_java_lang_Stringjava_lang_StringjbooleanbooleanID; // cache method id
85 jmethodID voidmovejobjectArray_java_lang_Stringjava_lang_StringjobjectArray_java_lang_Stringjava_lang_StringID; // cache method id
86 jmethodID voidgeneratePaletteIconjstringjava_lang_StringID; // cache method id
87
88
89
90 jobject instance;
91 jclass instanceClass; // cache class
92
93                        
94 // Caching (if any)
95
96
97 /**
98 * Get the environment matching to the current thread.
99 */
100 virtual JNIEnv * getCurrentEnv();
101
102 public:
103 // Constructor
104 /**
105 * Create a wrapping of the object from a JNIEnv.
106 * It will call the default constructor
107 * @param JEnv_ the Java Env
108 */
109 Palette(JavaVM * jvm_);
110
111 /**
112 * Create a wrapping of an already existing object from a JNIEnv.
113 * The object must have already been instantiated
114 * @param JEnv_ the Java Env
115 * @param JObj the object
116 */
117 Palette(JavaVM * jvm_, jobject JObj);
118
119
120 /** 
121 * This is a fake constructor to avoid the constructor
122 * chaining when dealing with extended giws classes 
123 */
124 #ifdef FAKEGIWSDATATYPE
125 Palette(fakeGiwsDataType::fakeGiwsDataType /* unused */) {}
126 #endif
127
128 // Destructor
129 ~Palette();
130
131 // Generic method
132 // Synchronization methods
133 /**
134 * Enter monitor associated with the object.
135 * Equivalent of creating a "synchronized(obj)" scope in Java.
136 */
137 void synchronize();
138
139 /**
140 * Exit monitor associated with the object.
141 * Equivalent of ending a "synchronized(obj)" scope.
142 */
143 void endSynchronize();
144
145 // Methods
146 static void loadPal(JavaVM * jvm_, char const* name, char const* const* category, int categorySize);
147
148 static void loadPal(JavaVM * jvm_, char const* name);
149
150 static void addCategory(JavaVM * jvm_, char const* const* name, int nameSize, bool visible);
151
152 static void remove(JavaVM * jvm_, char const* const* name, int nameSize);
153
154 static void enable(JavaVM * jvm_, char const* const* name, int nameSize, bool status);
155
156 static void move(JavaVM * jvm_, char const* const* source, int sourceSize, char const* const* target, int targetSize);
157
158 static void generatePaletteIcon(JavaVM * jvm_, char const* iconPath);
159
160
161                         /**
162                         * Get class name to use for static methods
163                         * @return class name to use for static methods
164                         */
165                         
166                 static const std::string className()
167                 {
168                 return "org/scilab/modules/xcos/palette/Palette";
169                 }
170                 
171 };
172
173
174 }
175 #endif