static int lua_proto_get_err_packet (lua_State *L) {
	size_t packet_len;
	const char *packet_str = luaL_checklstring(L, 1, &packet_len);
	network_mysqld_err_packet_t *err_packet;
	network_packet packet;
	GString s;
	int err = 0;

	s.str = (char *)packet_str;
	s.len = packet_len;

	packet.data = &s;
	packet.offset = 0;

	err_packet = network_mysqld_err_packet_new();

	err = err || network_mysqld_proto_get_err_packet(&packet, err_packet);
	if (err) {
		network_mysqld_err_packet_free(err_packet);

		luaL_error(L, "%s: network_mysqld_proto_get_err_packet() failed", G_STRLOC);
		return 0;
	}

	lua_newtable(L);

	LUA_EXPORT_STR(err_packet, errmsg);
	LUA_EXPORT_STR(err_packet, sqlstate);
	LUA_EXPORT_INT(err_packet, errcode);

	network_mysqld_err_packet_free(err_packet);

	return 1;
}
Beispiel #2
0
static PyObject *
python_proto_get_err_packet(PyObject *self, PyObject *args){
	int packet_len;
	const char* packet_str;
	if(!PyArg_ParseTuple(args, "s#", &packet_str, &packet_len))
		return NULL;
	network_mysqld_err_packet_t *err_packet;
	network_packet packet;
	GString s;
	int err = 0;
	s.str = (char *)packet_str;
	s.len = packet_len;
	packet.data = &s;
	packet.offset = 0;

	err_packet = network_mysqld_err_packet_new();

	err = err || network_mysqld_proto_get_err_packet(&packet, err_packet);
	if (err) {
		network_mysqld_err_packet_free(err_packet);
		PyErr_SetString(PyExc_ValueError, "network_mysqld_proto_get_err_packet() failed");
		return NULL;
	}

	PyObject *result = Spain_New();
	if(!result)
		return NULL;

#define PYTHON_EXPORT_STR(x, y) \
	PyObject *s_ ## y = PyString_FromString(x->y->str);\
	if(!s_ ## y){\
		Py_DECREF(result);\
		network_mysqld_err_packet_free(err_packet);\
		return NULL;\
	}\
	PyObject_SetAttrString(result, #y, s_ ## y);\
	Py_DECREF(s_ ## y);

#define PYTHON_EXPORT_INT(x, y) \
	PyObject *s_ ## y = PyInt_FromLong(x->y);\
	if(!s_ ## y){\
		Py_DECREF(result);\
		network_mysqld_err_packet_free(err_packet);\
		return NULL;\
	}\
	PyObject_SetAttrString(result, #y, s_ ## y);\
	Py_DECREF(s_ ## y);

	PYTHON_EXPORT_STR(err_packet, errmsg)
	PYTHON_EXPORT_STR(err_packet, sqlstate)
	PYTHON_EXPORT_INT(err_packet, errcode)

	network_mysqld_err_packet_free(err_packet);
	return result;
}