Implement fixes for string handling in py2/3
This commit is contained in:
parent
9e70eb1a13
commit
30518100f0
97
python-tg.c
97
python-tg.c
@ -100,14 +100,17 @@ PyObject* get_peer (tgl_peer_id_t id, tgl_peer_t *P);
|
|||||||
// Utility functions
|
// Utility functions
|
||||||
PyObject* get_datetime(long datetime)
|
PyObject* get_datetime(long datetime)
|
||||||
{
|
{
|
||||||
return PyDateTime_FromTimestamp(Py_BuildValue("(O)", PyLong_FromLong(datetime)));
|
return PyDateTime_FromTimestamp(Py_BuildValue("(O)", PyLong_FromLong(datetime)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void py_add_string_field (PyObject* dict, char *name, const char *value) {
|
void py_add_string_field (PyObject* dict, char *name, const char *value) {
|
||||||
assert (PyDict_Check(dict));
|
assert (PyDict_Check(dict));
|
||||||
assert (name && strlen (name));
|
assert (name && strlen (name));
|
||||||
if (!value || !strlen (value)) { return; }
|
if (!value || !strlen (value)) { return; }
|
||||||
PyDict_SetItemString (dict, name, PyUnicode_FromString(value));
|
PyObject *str = PyUnicode_FromString(value);
|
||||||
|
|
||||||
|
if(PyUnicode_Check(str))
|
||||||
|
PyDict_SetItemString (dict, name, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
void py_add_string_field_arr (PyObject* list, int num, const char *value) {
|
void py_add_string_field_arr (PyObject* list, int num, const char *value) {
|
||||||
@ -998,9 +1001,10 @@ void py_do_all (void) {
|
|||||||
|
|
||||||
enum py_query_type f = (long)py_ptr[p ++];
|
enum py_query_type f = (long)py_ptr[p ++];
|
||||||
PyObject *args = (PyObject *)py_ptr[p ++];
|
PyObject *args = (PyObject *)py_ptr[p ++];
|
||||||
PyObject *pyObj1, *pyObj2;
|
const char *str;
|
||||||
PyObject *ustr, *str;
|
int len;
|
||||||
str = NULL;
|
PyObject *pyObj1 = NULL;
|
||||||
|
PyObject *pyObj2 = NULL;
|
||||||
|
|
||||||
//struct tgl_message *M;
|
//struct tgl_message *M;
|
||||||
tgl_peer_id_t peer, peer1;
|
tgl_peer_id_t peer, peer1;
|
||||||
@ -1013,12 +1017,8 @@ void py_do_all (void) {
|
|||||||
tgl_do_get_dialog_list (TLS, py_dialog_list_cb, NULL);
|
tgl_do_get_dialog_list (TLS, py_dialog_list_cb, NULL);
|
||||||
break;
|
break;
|
||||||
case pq_msg:
|
case pq_msg:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis#", &peer.type, &peer.id, &str, &len);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_message (TLS, peer, str, len, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_message (TLS, peer, PyBytes_AsString(str), PyBytes_Size (str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_typing:
|
case pq_send_typing:
|
||||||
PyArg_ParseTuple(args, "ii", &peer.type, &peer.id);
|
PyArg_ParseTuple(args, "ii", &peer.type, &peer.id);
|
||||||
@ -1029,68 +1029,36 @@ void py_do_all (void) {
|
|||||||
tgl_do_send_typing (TLS, peer, tgl_typing_cancel, py_empty_cb, NULL);
|
tgl_do_send_typing (TLS, peer, tgl_typing_cancel, py_empty_cb, NULL);
|
||||||
break;
|
break;
|
||||||
case pq_rename_chat:
|
case pq_rename_chat:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_rename_chat (TLS, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_rename_chat (TLS, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_photo:
|
case pq_send_photo:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_document (TLS, -1, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_document (TLS, -1, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_video:
|
case pq_send_video:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_document (TLS, FLAG_DOCUMENT_VIDEO, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_document (TLS, FLAG_DOCUMENT_VIDEO, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_audio:
|
case pq_send_audio:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_document (TLS, FLAG_DOCUMENT_AUDIO, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_document (TLS, FLAG_DOCUMENT_AUDIO, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_document:
|
case pq_send_document:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_document (TLS, 0, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_document (TLS, 0, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_file:
|
case pq_send_file:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_document (TLS, -2, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_document (TLS, -2, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_send_text:
|
case pq_send_text:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_send_text (TLS, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_send_text (TLS, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
case pq_chat_set_photo:
|
case pq_chat_set_photo:
|
||||||
PyArg_ParseTuple(args, "iiU", &peer.type, &peer.id, &ustr);
|
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str);
|
||||||
str = PyUnicode_AsUnicodeEscapeString(ustr);
|
tgl_do_set_chat_photo (TLS, peer, str, py_msg_cb, NULL);
|
||||||
if(str == NULL)
|
|
||||||
PyErr_Print();
|
|
||||||
else
|
|
||||||
tgl_do_set_chat_photo (TLS, peer, PyBytes_AsString(str), py_msg_cb, NULL);
|
|
||||||
break;
|
break;
|
||||||
/* case pq_load_photo:
|
/* case pq_load_photo:
|
||||||
case pq_load_video:
|
case pq_load_video:
|
||||||
@ -1198,6 +1166,8 @@ void py_do_all (void) {
|
|||||||
case pq_send_location:
|
case pq_send_location:
|
||||||
PyArg_ParseTuple(args, "iiOO", &peer.type, &peer.id, &pyObj1, &pyObj2);
|
PyArg_ParseTuple(args, "iiOO", &peer.type, &peer.id, &pyObj1, &pyObj2);
|
||||||
tgl_do_send_location (TLS, peer, PyFloat_AsDouble(pyObj1), PyFloat_AsDouble(pyObj2), py_msg_cb, NULL);
|
tgl_do_send_location (TLS, peer, PyFloat_AsDouble(pyObj1), PyFloat_AsDouble(pyObj2), py_msg_cb, NULL);
|
||||||
|
Py_XDECREF(pyObj1);
|
||||||
|
Py_XDECREF(pyObj2);
|
||||||
break;
|
break;
|
||||||
/*
|
/*
|
||||||
pq_delete_msg,
|
pq_delete_msg,
|
||||||
@ -1220,11 +1190,7 @@ void py_do_all (void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Clean up any arg variables we could have used.
|
// Clean up any arg variables we could have used.
|
||||||
Py_XDECREF(args);
|
//Py_XDECREF(args); // TODO: this is going negative ref and causing segfaults
|
||||||
Py_XDECREF(pyObj1);
|
|
||||||
Py_XDECREF(pyObj2);
|
|
||||||
Py_XDECREF(str);
|
|
||||||
Py_XDECREF(ustr);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
pos = 0;
|
pos = 0;
|
||||||
@ -1447,11 +1413,12 @@ void py_init (const char *file) {
|
|||||||
|
|
||||||
#if PY_MAJOR_VERSION >= 3
|
#if PY_MAJOR_VERSION >= 3
|
||||||
PyImport_AppendInittab("tgl", &PyInit_tgl);
|
PyImport_AppendInittab("tgl", &PyInit_tgl);
|
||||||
|
Py_Initialize();
|
||||||
#else
|
#else
|
||||||
|
Py_Initialize();
|
||||||
inittgl();
|
inittgl();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Py_Initialize();
|
|
||||||
|
|
||||||
PyObject* sysPath = PySys_GetObject((char*)"path");
|
PyObject* sysPath = PySys_GetObject((char*)"path");
|
||||||
PyList_Append(sysPath, PyUnicode_FromString(dirname(filename)));
|
PyList_Append(sysPath, PyUnicode_FromString(dirname(filename)));
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
import tgl
|
import tgl
|
||||||
import geopy
|
|
||||||
import pprint
|
import pprint
|
||||||
from geopy.geocoders import Nominatim
|
|
||||||
|
|
||||||
our_id = 0
|
our_id = 0
|
||||||
pp = pprint.PrettyPrinter(indent=4)
|
pp = pprint.PrettyPrinter(indent=4)
|
||||||
@ -34,14 +32,9 @@ def on_msg_receive(msg):
|
|||||||
text = msg["text"]
|
text = msg["text"]
|
||||||
|
|
||||||
if text.startswith("!ping"):
|
if text.startswith("!ping"):
|
||||||
|
print("SENDING PONG")
|
||||||
tgl.send_msg(ptype, pid, "PONG!")
|
tgl.send_msg(ptype, pid, "PONG!")
|
||||||
|
|
||||||
if text.startswith("!location"):
|
|
||||||
geolocator = Nominatim()
|
|
||||||
location = geolocator.geocode(msg["text"][9:])
|
|
||||||
pp.pprint(location)
|
|
||||||
tgl.send_location(ptype, pid, location.latitude, location.longitude)
|
|
||||||
|
|
||||||
def on_secret_chat_update(peer, types):
|
def on_secret_chat_update(peer, types):
|
||||||
return "on_secret_chat_update"
|
return "on_secret_chat_update"
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user