init.cc 5.3 KB
/*
 * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270  e X3270
 * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a
 * aplicativos mainframe. Registro no INPI sob o nome G3270.
 *
 * Copyright (C) <2008> <Banco do Brasil S.A.>
 *
 * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob
 * os termos da GPL v.2 - Licença Pública Geral  GNU,  conforme  publicado  pela
 * Free Software Foundation.
 *
 * Este programa é distribuído na expectativa de  ser  útil,  mas  SEM  QUALQUER
 * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou  de  ADEQUAÇÃO
 * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para
 * obter mais detalhes.
 *
 * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este
 * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin
 * St, Fifth Floor, Boston, MA  02110-1301  USA
 *
 * Este programa está nomeado como py3270.cc e possui - linhas de código.
 *
 * Contatos:
 *
 * perry.werneck@gmail.com	(Alexandre Perry de Souza Werneck)
 * erico.mendonca@gmail.com	(Erico Mascarenhas Mendonça)
 *
 * Implementa métodos básicos inicio/final do objeto python
 *
 * Referências:
 *
 * <https://docs.python.org/2/extending/newtypes.html>
 * <https://docs.python.org/2.7/extending/extending.html#a-simple-example>
 *
 */

 #include <py3270.h>
 #include <lib3270/ipc.h>

/*---[ Implement ]----------------------------------------------------------------------------------*/

static void cleanup(pySession * session) {

	if(session->host) {
		delete session->host;
		session->host = nullptr;
	}

}

static void py3270_session_attribute_init(struct PyGetSetDef *attribute, const LIB3270_PROPERTY * descriptor) {

	attribute->name    = (char *) descriptor->name;
	attribute->doc     = (char *) (descriptor->description ? descriptor->description : descriptor->summary);

}

void py3270_session_type_init(PyTypeObject *type) {

	// Load attributes
	{
		auto attributes = TN3270::getAttributes();
		auto actions	= TN3270::getActions();
		size_t ix = 0;

		size_t szData = sizeof(struct PyGetSetDef) * (attributes.size() + actions.size() + 1);

		type->tp_getset = (struct PyGetSetDef *) malloc(szData);
		memset(type->tp_getset,0,szData);

		for(auto attribute : attributes) {

//			debug("Creating attribute %s",attribute->name);

			py3270_session_attribute_init(&type->tp_getset[ix], (const LIB3270_PROPERTY *) attribute);

			type->tp_getset[ix].get     = py3270_session_getter;
			type->tp_getset[ix].set     = py3270_session_setter;
			type->tp_getset[ix].closure = (void *) attribute->name;

			ix++;

		}

		for(auto action : actions) {

//			debug("Creating action %s",action->name);

			py3270_session_attribute_init(&type->tp_getset[ix], (const LIB3270_PROPERTY *) action);

			type->tp_getset[ix].get = py3270_action_new_from_session;
			type->tp_getset[ix].closure = (void *) action;

			ix++;

		}
	}


}


int py3270_session_init(PyObject *self, PyObject *args, PyObject *kwds) {

	pySession * session = (pySession *) self;
	debug("%s session=%p host=%p",__FUNCTION__,session,session->host);

	try {

		cleanup(session);

		const char *id = "";

		if (!PyArg_ParseTuple(args, "s", &id))
			id = "";

		session->host = new TN3270::Host(id);

		/*
		// Load lib3270's actions
		{
			auto actions = TN3270::getActions();

			for(auto action : actions) {

				pyAction * object = (pyAction *) _PyObject_New(&py3270_action_type);

				object->host = session->host;
				object->action = action;

				PyObject_SetAttr(self, PyUnicode_FromString(action->name), (PyObject *) object);

			}

		}
		*/

        return 0;

	} catch(const std::exception &e) {

		PyErr_SetString(PyExc_RuntimeError, e.what());

	} catch(...) {

		PyErr_SetString(PyExc_RuntimeError, "Unexpected error in core module");

	}

	return -1;

}

void py3270_session_finalize(PyObject *self) {

	debug("%s",__FUNCTION__);
	cleanup((pySession *) self);

}

PyObject * py3270_session_alloc(PyTypeObject *type, PyObject *args, PyObject *kwds) {

	debug("%s",__FUNCTION__);
	return type->tp_alloc(type,0);

}

void py3270_session_dealloc(PyObject * self) {

	debug("%s",__FUNCTION__);

	cleanup((pySession *) self);
	Py_TYPE(self)->tp_free(self);

}

	/*

	const char *id = "";

	if (!PyArg_ParseTuple(args, "s", &id))
		id = "";


	if(session) {

		try {

			session->host = new TN3270::Host(id);

		} catch(const exception &e) {

			PyErr_SetString(PyExc_RuntimeError, e.what());

		} catch( ... ) {

			PyErr_SetString(PyExc_RuntimeError, "Unexpected error in core module");

		}

	}

	type->tp_free(session);

	return NULL;

}

void py3270_session_dealloc(pySession * self) {

	if(self->host) {
		delete self->host;
	}

	Py_TYPE(self)->tp_free((PyObject *) self);

}
	*/


/*
PyObject * terminal_new(PyTypeObject *type, PyObject *args, PyObject *kwds) {

	PW3270_NAMESPACE::session * session;
	const char *id = "";

	if (!PyArg_ParseTuple(args, "s", &id)) {
		id = "";
	}

	trace("%s(%s)",__FUNCTION__,id);

	try {

		session = PW3270_NAMESPACE::session::create(id);

	} catch(std::exception &e) {

		trace("%s failed: %s",__FUNCTION__,e.what());
		PyErr_SetString(terminalError, e.what());
		return NULL;

	}

    pw3270_TerminalObject *self = (pw3270_TerminalObject *) type->tp_alloc(type, 0);

	self->session = session;

    return (PyObject *)self;
}


*/