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