Update giws files with version 2.0.2 to improve performances:
[scilab.git] / scilab / modules / console / src / jni / CallScilabBridge.hxx
1 /* Generated by GIWS (version 2.0.2) with command:
2 giws --disable-return-size-array --output-dir src/jni/ --throws-exception-on-error --description-file src/jni/CallScilabBridge.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_GUI_BRIDGE_CALLSCILABBRIDGE__
40 #define __ORG_SCILAB_MODULES_GUI_BRIDGE_CALLSCILABBRIDGE__
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_gui_bridge
73 {
74 class GIWSEXPORT CallScilabBridge
75 {
76
77 private:
78     JavaVM * jvm;
79
80 protected:
81     jmethodID voiddisplayjstringjava_lang_StringID; // cache method id
82     jmethodID jstringreadLineID; // cache method id
83     jmethodID voidclearID; // cache method id
84     jmethodID voidclearjintintID; // cache method id
85     jmethodID jintgetCharWithoutOutputID; // cache method id
86     jmethodID voidtoHomeID; // cache method id
87     jmethodID voidscilabLinesUpdateID; // cache method id
88     jmethodID voidsetPromptjstringjava_lang_StringID; // cache method id
89     jmethodID jbooleanisWaitingForInputID; // cache method id
90
91
92
93     jobject instance;
94     jclass instanceClass; // cache class
95
96
97     // Caching (if any)
98
99
100     /**
101     * Get the environment matching to the current thread.
102     */
103     virtual JNIEnv * getCurrentEnv();
104
105 public:
106     // Constructor
107     /**
108     * Create a wrapping of the object from a JNIEnv.
109     * It will call the default constructor
110     * @param JEnv_ the Java Env
111     */
112     CallScilabBridge(JavaVM * jvm_);
113
114     /**
115     * Create a wrapping of an already existing object from a JNIEnv.
116     * The object must have already been instantiated
117     * @param JEnv_ the Java Env
118     * @param JObj the object
119     */
120     CallScilabBridge(JavaVM * jvm_, jobject JObj);
121
122
123     /**
124     * This is a fake constructor to avoid the constructor
125     * chaining when dealing with extended giws classes
126     */
127 #ifdef FAKEGIWSDATATYPE
128     CallScilabBridge(fakeGiwsDataType::fakeGiwsDataType /* unused */) {}
129 #endif
130
131     // Destructor
132     ~CallScilabBridge();
133
134     // Generic method
135     // Synchronization methods
136     /**
137     * Enter monitor associated with the object.
138     * Equivalent of creating a "synchronized(obj)" scope in Java.
139     */
140     void synchronize();
141
142     /**
143     * Exit monitor associated with the object.
144     * Equivalent of ending a "synchronized(obj)" scope.
145     */
146     void endSynchronize();
147
148     // Methods
149     static void display(JavaVM * jvm_, char const* dataToDisplay);
150
151     static char* readLine(JavaVM * jvm_);
152
153     static void clear(JavaVM * jvm_);
154
155     static void clear(JavaVM * jvm_, int nbLines);
156
157     static int getCharWithoutOutput(JavaVM * jvm_);
158
159     static void toHome(JavaVM * jvm_);
160
161     static void scilabLinesUpdate(JavaVM * jvm_);
162
163     static void setPrompt(JavaVM * jvm_, char const* promptToSet);
164
165     static bool isWaitingForInput(JavaVM * jvm_);
166
167
168     /**
169     * Get class name to use for static methods
170     * @return class name to use for static methods
171     */
172
173     static const std::string className()
174     {
175         return "org/scilab/modules/gui/bridge/CallScilabBridge";
176     }
177
178
179     /**
180     * Get class to use for static methods
181     * @return class to use for static methods
182     */
183
184     static jclass initClass(JNIEnv * curEnv)
185     {
186         static jclass cls = 0;
187
188         if (cls == 0)
189         {
190             jclass _cls = curEnv->FindClass(className().c_str());
191             if (_cls)
192             {
193                 cls = static_cast<jclass>(curEnv->NewGlobalRef(_cls));
194             }
195         }
196
197         return cls;
198     }
199
200 };
201
202
203 }
204 #endif