Commit 96cee301ec9eeb8794e2e0572d89e04f6e7a5d6f
1 parent
36238ae4
Exists in
master
Refactoring python object.
Showing
8 changed files
with
233 additions
and
128 deletions
Show diff stats
Makefile.in
... | ... | @@ -29,6 +29,7 @@ |
29 | 29 | LIBNAME=tn3270 |
30 | 30 | |
31 | 31 | SOURCES= \ |
32 | + $(wildcard src/module/*.c) \ | |
32 | 33 | $(wildcard src/module/*.cc) \ |
33 | 34 | $(wildcard src/module/@OSNAME@/*.cc) \ |
34 | 35 | $(wildcard src/terminal/*.cc) |
... | ... | @@ -36,6 +37,7 @@ SOURCES= \ |
36 | 37 | #---[ Tools ]---------------------------------------------------------------------------- |
37 | 38 | |
38 | 39 | CXX=@CXX@ |
40 | +CC=@CC@ | |
39 | 41 | LD=@CXX@ |
40 | 42 | LN_S=@LN_S@ |
41 | 43 | MKDIR=@MKDIR_P@ |
... | ... | @@ -91,6 +93,14 @@ CFLAGS= \ |
91 | 93 | -DBUILD_DATE=`date +%Y%m%d` \ |
92 | 94 | @IPC3270_CFLAGS@ |
93 | 95 | |
96 | +CXXFLAGS= \ | |
97 | + @CXXFLAGS@ \ | |
98 | + @PYTHON_CFLAGS@ \ | |
99 | + -g \ | |
100 | + -Isrc/include \ | |
101 | + -DBUILD_DATE=`date +%Y%m%d` \ | |
102 | + @IPC3270_CFLAGS@ | |
103 | + | |
94 | 104 | LDFLAGS= \ |
95 | 105 | @LDFLAGS@ |
96 | 106 | |
... | ... | @@ -109,6 +119,20 @@ $(OBJDBG)/%.o: \ |
109 | 119 | @$(MKDIR) $(dir $@) |
110 | 120 | |
111 | 121 | @$(CXX) \ |
122 | + $(CXXFLAGS) \ | |
123 | + -Wall -Wextra -fstack-check \ | |
124 | + -DDEBUG=1 \ | |
125 | + -o $@ \ | |
126 | + -c $< | |
127 | + | |
128 | +$(OBJDBG)/%.o: \ | |
129 | + %.c \ | |
130 | + $(DEPENDS) | |
131 | + | |
132 | + @echo $< ... | |
133 | + @$(MKDIR) $(dir $@) | |
134 | + | |
135 | + @$(CC) \ | |
112 | 136 | $(CFLAGS) \ |
113 | 137 | -Wall -Wextra -fstack-check \ |
114 | 138 | -DDEBUG=1 \ | ... | ... |
configure.ac
... | ... | @@ -99,6 +99,7 @@ case "$host" in |
99 | 99 | app_cv_osname="windows" |
100 | 100 | |
101 | 101 | CFLAGS="$CFLAGS -pthread -D_WIN32_WINNT=0x0600" |
102 | + CXXFLAGS="$CXXFLAGS -pthread -D_WIN32_WINNT=0x0600" | |
102 | 103 | LIBS="$LIBS -lws2_32 -lwtsapi32 -lcomdlg32" |
103 | 104 | DLLEXT=".dll" |
104 | 105 | |
... | ... | @@ -127,6 +128,7 @@ dnl AC_SUBST(SONAME,py3270.dll) |
127 | 128 | |
128 | 129 | *) |
129 | 130 | CFLAGS="$CFLAGS -pthread" |
131 | + CXXFLAGS="$CXXFLAGS -pthread" | |
130 | 132 | LDFLAGS="$LDFLAGS -pthread" |
131 | 133 | app_cv_osname="linux" |
132 | 134 | LOGDIR="/var/log" |
... | ... | @@ -164,7 +166,7 @@ AS_IF([test x"AS_VAR_GET(CACHEVAR)" = xyes], |
164 | 166 | AS_VAR_POPDEF([CACHEVAR])dnl |
165 | 167 | ])dnl AX_CHECK_COMPILE_FLAGS |
166 | 168 | |
167 | -AX_CHECK_COMPILE_FLAG([-std=gnu++11], [CFLAGS="$CFLAGS -std=gnu++11"]) | |
169 | +AX_CHECK_COMPILE_FLAG([-std=gnu++11], [CXXFLAGS="$CXXFLAGS -std=gnu++11"]) | |
168 | 170 | |
169 | 171 | dnl --------------------------------------------------------------------------- |
170 | 172 | dnl Check for IPC3270 | ... | ... |
py3270.cbp
... | ... | @@ -45,7 +45,9 @@ |
45 | 45 | <Unit filename="src/include/config.h" /> |
46 | 46 | <Unit filename="src/include/config.h.in" /> |
47 | 47 | <Unit filename="src/include/py3270.h" /> |
48 | - <Unit filename="src/module/init.cc" /> | |
48 | + <Unit filename="src/module/init.c"> | |
49 | + <Option compilerVar="CC" /> | |
50 | + </Unit> | |
49 | 51 | <Unit filename="src/module/properties.cc" /> |
50 | 52 | <Unit filename="src/terminal/actions.cc" /> |
51 | 53 | <Unit filename="src/terminal/get.cc" /> | ... | ... |
src/include/py3270.h
... | ... | @@ -35,7 +35,6 @@ |
35 | 35 | #include <Python.h> |
36 | 36 | |
37 | 37 | #include <config.h> |
38 | - #include <lib3270/ipc.h> | |
39 | 38 | |
40 | 39 | #if defined(_WIN32) |
41 | 40 | |
... | ... | @@ -60,13 +59,38 @@ |
60 | 59 | |
61 | 60 | #endif |
62 | 61 | |
62 | +#ifdef __cplusplus | |
63 | + | |
63 | 64 | #include <functional> |
65 | + #include <exception> | |
66 | + #include <stdexcept> | |
67 | + #include <lib3270/ipc.h> | |
68 | + | |
69 | + using std::exception; | |
70 | + using std::runtime_error; | |
71 | + using TN3270::Host; | |
64 | 72 | |
65 | 73 | extern "C" { |
66 | 74 | |
75 | +#else | |
76 | + | |
77 | + typedef void Host; | |
78 | + | |
79 | +#endif | |
80 | + | |
81 | + typedef struct { | |
82 | + PyObject_HEAD | |
83 | + Host *host; | |
84 | + } pySession; | |
85 | + | |
67 | 86 | DLL_PRIVATE PyObject * py3270_get_module_version(PyObject *self, PyObject *args); |
68 | 87 | DLL_PRIVATE PyObject * py3270_get_module_revision(PyObject *self, PyObject *args); |
69 | 88 | |
89 | + DLL_PRIVATE PyObject * py3270_session_new(PyTypeObject *type, PyObject *args, PyObject *kwds); | |
90 | +// DLL_PRIVATE int py3270_session_init(pySession *self, PyObject *args, PyObject *kwds); | |
91 | + DLL_PRIVATE void py3270_session_dealloc(pySession * self); | |
92 | + | |
93 | + | |
70 | 94 | /* |
71 | 95 | |
72 | 96 | DLL_PRIVATE PyObject * py3270_alloc(PyTypeObject *type, PyObject *args, PyObject *kwds); |
... | ... | @@ -99,6 +123,8 @@ |
99 | 123 | DLL_PRIVATE PyObject * terminal_wait_for_string_at(PyObject *self, PyObject *args); |
100 | 124 | */ |
101 | 125 | |
126 | +#ifdef __cplusplus | |
102 | 127 | } |
128 | +#endif | |
103 | 129 | |
104 | 130 | #endif // PY3270_H_INCLUDED | ... | ... |
... | ... | @@ -0,0 +1,124 @@ |
1 | +/* | |
2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
5 | + * | |
6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
7 | + * | |
8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
10 | + * Free Software Foundation. | |
11 | + * | |
12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
15 | + * obter mais detalhes. | |
16 | + * | |
17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
20 | + * | |
21 | + * Este programa está nomeado como - e possui - linhas de código. | |
22 | + * | |
23 | + * Contatos: | |
24 | + * | |
25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
27 | + * | |
28 | + * <https://docs.python.org/3/extending/extending.html> | |
29 | + * | |
30 | + */ | |
31 | + | |
32 | + #include <py3270.h> | |
33 | + | |
34 | +/*---[ Globals ]------------------------------------------------------------------------------------*/ | |
35 | + | |
36 | +static PyMethodDef methods[] = { | |
37 | + | |
38 | + { | |
39 | + "version", | |
40 | + py3270_get_module_version, | |
41 | + METH_NOARGS, | |
42 | + "Get " PACKAGE_NAME " version" | |
43 | + }, | |
44 | + | |
45 | + { | |
46 | + "revision", | |
47 | + py3270_get_module_revision, | |
48 | + METH_NOARGS, | |
49 | + "Get " PACKAGE_NAME " revision" | |
50 | + | |
51 | + }, | |
52 | + | |
53 | + { | |
54 | + NULL, | |
55 | + NULL, | |
56 | + 0, | |
57 | + NULL | |
58 | + } | |
59 | + | |
60 | +}; | |
61 | + | |
62 | +static struct PyModuleDef definition = { | |
63 | + PyModuleDef_HEAD_INIT, | |
64 | + .m_name = "tn3270", // name of module | |
65 | + .m_doc = PACKAGE_DESCRIPTION, // module documentation, may be NUL | |
66 | + .m_size = -1, // size of per-interpreter state of the module or -1 if the module keeps state in global variables. | |
67 | + .m_methods = methods // Module methods | |
68 | +}; | |
69 | + | |
70 | +static PyTypeObject SessionType = { | |
71 | + PyVarObject_HEAD_INIT(NULL, 0) | |
72 | + .tp_name = "tn3270.Session", | |
73 | + .tp_doc = "TN3270 Session Object", | |
74 | + .tp_basicsize = sizeof(pySession), | |
75 | + .tp_itemsize = 0, | |
76 | + .tp_flags = Py_TPFLAGS_DEFAULT, | |
77 | + .tp_dealloc = py3270_session_dealloc, | |
78 | + .tp_new = py3270_session_new, | |
79 | +}; | |
80 | + | |
81 | +/*---[ Implement ]----------------------------------------------------------------------------------*/ | |
82 | + | |
83 | +PyMODINIT_FUNC PyInit_tn3270(void) | |
84 | +{ | |
85 | + // | |
86 | + // Initialize module. | |
87 | + // | |
88 | + if (PyType_Ready(&SessionType) < 0) | |
89 | + return NULL; | |
90 | + | |
91 | + Py_Initialize(); | |
92 | + | |
93 | + PyObject *module = PyModule_Create(&definition); | |
94 | + | |
95 | + if(!module) | |
96 | + return NULL; | |
97 | + | |
98 | + /* | |
99 | + // | |
100 | + // Create exception object | |
101 | + // | |
102 | + PyObject * except = PyErr_NewException("tn3270.Error", NULL, NULL); | |
103 | + | |
104 | + Py_XINCREF(except); | |
105 | + if (PyModule_AddObject(module, "error", except) < 0) { | |
106 | + Py_XDECREF(except); | |
107 | + Py_CLEAR(except); | |
108 | + Py_DECREF(module); | |
109 | + return NULL; | |
110 | + } | |
111 | + */ | |
112 | + | |
113 | + // | |
114 | + // Create custom type | |
115 | + // | |
116 | + Py_INCREF(&SessionType); | |
117 | + if (PyModule_AddObject(module, "Session", (PyObject *) &SessionType) < 0) { | |
118 | + Py_DECREF(&SessionType); | |
119 | + Py_DECREF(module); | |
120 | + return NULL; | |
121 | + } | |
122 | + | |
123 | + return module; | |
124 | +} | ... | ... |
src/module/init.cc
... | ... | @@ -1,109 +0,0 @@ |
1 | -/* | |
2 | - * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | - * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
4 | - * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
5 | - * | |
6 | - * Copyright (C) <2008> <Banco do Brasil S.A.> | |
7 | - * | |
8 | - * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
9 | - * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
10 | - * Free Software Foundation. | |
11 | - * | |
12 | - * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
13 | - * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
14 | - * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
15 | - * obter mais detalhes. | |
16 | - * | |
17 | - * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
18 | - * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
19 | - * St, Fifth Floor, Boston, MA 02110-1301 USA | |
20 | - * | |
21 | - * Este programa está nomeado como - e possui - linhas de código. | |
22 | - * | |
23 | - * Contatos: | |
24 | - * | |
25 | - * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
26 | - * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
27 | - * | |
28 | - * <https://docs.python.org/3/extending/extending.html> | |
29 | - * | |
30 | - */ | |
31 | - | |
32 | - #include <py3270.h> | |
33 | - | |
34 | -/*---[ Implement ]----------------------------------------------------------------------------------*/ | |
35 | - | |
36 | -PyMODINIT_FUNC PyInit_tn3270(void) | |
37 | -{ | |
38 | - static PyMethodDef methods[] = { | |
39 | - | |
40 | - { | |
41 | - "version", | |
42 | - py3270_get_module_version, | |
43 | - METH_NOARGS, | |
44 | - "Get " PACKAGE_NAME " version" | |
45 | - }, | |
46 | - | |
47 | - { | |
48 | - "revision", | |
49 | - py3270_get_module_revision, | |
50 | - METH_NOARGS, | |
51 | - "Get " PACKAGE_NAME " revision" | |
52 | - | |
53 | - }, | |
54 | - | |
55 | - { | |
56 | - NULL, | |
57 | - NULL, | |
58 | - 0, | |
59 | - NULL | |
60 | - } | |
61 | - | |
62 | - }; | |
63 | - | |
64 | - static struct PyModuleDef definition = { | |
65 | - PyModuleDef_HEAD_INIT, | |
66 | - "tn3270", // name of module | |
67 | - PACKAGE_DESCRIPTION, // module documentation, may be NUL | |
68 | - -1, // size of per-interpreter state of the module or -1 if the module keeps state in global variables. | |
69 | - methods // Module methods | |
70 | - }; | |
71 | - | |
72 | - Py_Initialize(); | |
73 | - | |
74 | - PyObject *module = PyModule_Create(&definition); | |
75 | - | |
76 | - if(module) { | |
77 | - | |
78 | - PyObject * except = PyErr_NewException("tn3270.error", NULL, NULL); | |
79 | - | |
80 | - Py_XINCREF(except); | |
81 | - if (PyModule_AddObject(module, "error", except) < 0) { | |
82 | - Py_XDECREF(except); | |
83 | - Py_CLEAR(except); | |
84 | - Py_DECREF(module); | |
85 | - return NULL; | |
86 | - } | |
87 | - | |
88 | - } | |
89 | - | |
90 | - | |
91 | - /* | |
92 | - | |
93 | - m = PyModule_Create(&spammodule); | |
94 | - if (m == NULL) | |
95 | - return NULL; | |
96 | - | |
97 | - SpamError = PyErr_NewException("spam.error", NULL, NULL); | |
98 | - Py_XINCREF(SpamError); | |
99 | - if (PyModule_AddObject(m, "error", SpamError) < 0) { | |
100 | - Py_XDECREF(SpamError); | |
101 | - Py_CLEAR(SpamError); | |
102 | - Py_DECREF(m); | |
103 | - return NULL; | |
104 | - } | |
105 | - | |
106 | - */ | |
107 | - | |
108 | - return module; | |
109 | -} |
src/terminal/init.cc
... | ... | @@ -38,6 +38,57 @@ |
38 | 38 | |
39 | 39 | /*---[ Implement ]----------------------------------------------------------------------------------*/ |
40 | 40 | |
41 | +PyObject * py3270_session_new(PyTypeObject *type, PyObject *args, PyObject *kwds) { | |
42 | + | |
43 | + const char *id = ""; | |
44 | + | |
45 | + if (!PyArg_ParseTuple(args, "s", &id)) | |
46 | + id = ""; | |
47 | + | |
48 | + pySession * session = (pySession *) type->tp_alloc(type,0); | |
49 | + | |
50 | + printf("---[%s]---\n",id); | |
51 | + | |
52 | + if(session) { | |
53 | + | |
54 | + try { | |
55 | + | |
56 | + session->host = new TN3270::Host(id); | |
57 | + | |
58 | + printf("---[%s=%p]---\n",id,session->host); | |
59 | + return (PyObject *) session; | |
60 | + | |
61 | + } catch(const exception &e) { | |
62 | + | |
63 | + printf("---[%s]---\n",e.what()); | |
64 | + PyErr_SetString(PyExc_RuntimeError, e.what()); | |
65 | + | |
66 | + } catch( ... ) { | |
67 | + | |
68 | + printf("---[%s]---\n","???"); | |
69 | + PyErr_SetString(PyExc_RuntimeError, "Unexpected error in core module"); | |
70 | + | |
71 | + } | |
72 | + | |
73 | + } | |
74 | + | |
75 | + type->tp_free(session); | |
76 | + | |
77 | + return NULL; | |
78 | + | |
79 | +} | |
80 | + | |
81 | +void py3270_session_dealloc(pySession * self) { | |
82 | + | |
83 | + if(self->host) { | |
84 | + delete self->host; | |
85 | + } | |
86 | + | |
87 | + Py_TYPE(self)->tp_free((PyObject *) self); | |
88 | + | |
89 | +} | |
90 | + | |
91 | + | |
41 | 92 | /* |
42 | 93 | PyObject * terminal_new(PyTypeObject *type, PyObject *args, PyObject *kwds) { |
43 | 94 | |
... | ... | @@ -70,19 +121,4 @@ PyObject * terminal_new(PyTypeObject *type, PyObject *args, PyObject *kwds) { |
70 | 121 | } |
71 | 122 | |
72 | 123 | |
73 | -int terminal_init(pw3270_TerminalObject *self, PyObject *args, PyObject *kwds) { | |
74 | - | |
75 | - return 0; | |
76 | - | |
77 | -} | |
78 | - | |
79 | -void terminal_dealloc(pw3270_TerminalObject * self) { | |
80 | - | |
81 | - trace("%s",__FUNCTION__); | |
82 | - | |
83 | - delete self->session; | |
84 | - | |
85 | - self->ob_type->tp_free((PyObject*)self); | |
86 | - | |
87 | -} | |
88 | 124 | */ | ... | ... |
testprograms/sample.py
... | ... | @@ -8,7 +8,7 @@ print("Teste extensão pw3270") |
8 | 8 | print("Using TN3270 Version " + tn3270.version()) |
9 | 9 | print(tn3270.revision()) |
10 | 10 | |
11 | -#term = py3270.Terminal("") | |
11 | +session = tn3270.Session(":a") | |
12 | 12 | |
13 | 13 | #print "Using pw3270 version " + term.Version() + " revision " + term.Revision() |
14 | 14 | ... | ... |