Add Callback support for async calls.

This commit is contained in:
Vincent Castellano 2015-05-12 01:04:47 -07:00
parent c263a93a8b
commit 871fc440b7
2 changed files with 309 additions and 426 deletions

View File

@ -641,424 +641,362 @@ enum py_query_type {
pq_extf pq_extf
}; };
struct py_query_extra {
int func;
int param;
};
void py_empty_cb (struct tgl_state *TLSR, void *cb_extra, int success) { void py_empty_cb (struct tgl_state *TLSR, void *cb_extra, int success) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *result = NULL;
// my_lua_checkstack (luaState, 20);
// if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); arglist = Py_BuildValue("(O)", success ? Py_True : Py_False);
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// lua_pushnumber (luaState, success);
// if(result == NULL)
// assert (lua_gettop (luaState) == 3); PyErr_Print();
//
// int r = lua_pcall (luaState, 2, 0, 0); Py_XDECREF(result);
// }
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); Py_XDECREF(callable);
//
// if (r) {
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_contact_list_cb (struct tgl_state *TLSR, void *cb_extra, int success, int num, struct tgl_user **UL) { void py_contact_list_cb (struct tgl_state *TLSR, void *cb_extra, int success, int num, struct tgl_user **UL) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *peers = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); peers = PyList_New(0);
// if (success) {
// lua_pushnumber (luaState, success); int i;
// for (i = 0; i < num; i++) {
// if (success) { PyList_Append(peers, get_peer (UL[i]->id, (void *)UL[i]));
// lua_newtable (luaState); }
// int i; }
// for (i = 0; i < num; i++) {
// lua_pushnumber (luaState, i); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, peers);
// push_peer (UL[i]->id, (void *)UL[i]); result = PyEval_CallObject(callable, arglist);
// lua_settable (luaState, -3); Py_DECREF(arglist);
// }
// } else { if(result == NULL)
// lua_pushboolean (luaState, 0); PyErr_Print();
// }
// Py_XDECREF(result);
// assert (lua_gettop (luaState) == 4); }
//
// int r = lua_pcall (luaState, 3, 0, 0); Py_XDECREF(callable);
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param);
//
// if (r) {
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_dialog_list_cb (struct tgl_state *TLSR, void *cb_extra, int success, int num, tgl_peer_id_t peers[], int msgs[], int unread[]) { void py_dialog_list_cb (struct tgl_state *TLSR, void *cb_extra, int success, int num, tgl_peer_id_t peers[], int msgs[], int unread[]) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *dialog_list = NULL;
// my_lua_checkstack (luaState, 20); PyObject *dialog = NULL;
// PyObject *result = NULL;
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func);
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if(PyCallable_Check(callable)) {
// dialog_list = PyList_New(0);
// lua_pushnumber (luaState, success); if (success) {
// if (success) { int i;
// lua_newtable (luaState); for (i = 0; i < num; i++) {
// int i; dialog = PyDict_New();
// for (i = 0; i < num; i++) { PyDict_SetItemString(dialog, "peer", get_peer(peers[i], tgl_peer_get (TLS, peers[i])));
// lua_pushnumber (luaState, i);
// struct tgl_message *M = tgl_message_get (TLS, msgs[i]);
// lua_newtable (luaState); if (M && (M->flags & FLAG_CREATED)) {
// PyDict_SetItemString(dialog, "message", get_message(M));
// lua_pushstring (luaState, "peer"); }
// push_peer (peers[i], tgl_peer_get (TLS, peers[i])); PyDict_SetItemString(dialog, "unread", unread[i] ? Py_True : Py_False);
// lua_settable (luaState, -3);
// PyList_Append(dialog_list, dialog);
// struct tgl_message *M = tgl_message_get (TLS, msgs[i]); }
// if (M && (M->flags & FLAG_CREATED)) { }
// lua_pushstring (luaState, "message");
// push_message (M); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, dialog_list);
// lua_settable (luaState, -3); result = PyEval_CallObject(callable, arglist);
// } Py_DECREF(arglist);
//
// lua_pushstring (luaState, "unread"); if(result == NULL)
// lua_pushnumber (luaState, unread[i]); PyErr_Print();
// lua_settable (luaState, -3);
// Py_XDECREF(result);
// lua_settable (luaState, -3); }
// }
// } else { Py_XDECREF(callable);
// lua_pushboolean (luaState, 0);
// }
// assert (lua_gettop (luaState) == 4);
//
//
// int r = lua_pcall (luaState, 3, 0, 0);
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param);
//
// if (r) {
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_msg_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_message *M) { void py_msg_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_message *M) {
assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *msg = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if (success) {
// msg = get_message(M);
// lua_pushnumber (luaState, success); } else {
// Py_INCREF(Py_None);
// if (success) { msg = Py_None;
// push_message (M); }
// } else {
// lua_pushboolean (luaState, 0); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, msg);
// } result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// assert (lua_gettop (luaState) == 4);
// if(result == NULL)
// int r = lua_pcall (luaState, 3, 0, 0); PyErr_Print();
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func); Py_XDECREF(result);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); }
//
// if (r) { Py_XDECREF(callable);
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_msg_list_cb (struct tgl_state *TLSR, void *cb_extra, int success, int num, struct tgl_message *M[]) { void py_msg_list_cb (struct tgl_state *TLSR, void *cb_extra, int success, int num, struct tgl_message *M[]) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *msgs = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); msgs = PyList_New(0);
// if (success) {
// lua_pushnumber (luaState, success); int i;
// for (i = 0; i < num; i++) {
// if (success) { PyList_Append(msgs, get_message (M[i]));
// lua_newtable (luaState); }
// int i; }
// for (i = 0; i < num; i++) {
// lua_pushnumber (luaState, i); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, msgs);
// push_message (M[i]); result = PyEval_CallObject(callable, arglist);
// lua_settable (luaState, -3); Py_DECREF(arglist);
// }
// } else { if(result == NULL)
// lua_pushboolean (luaState, 0); PyErr_Print();
// }
// Py_XDECREF(result);
// assert (lua_gettop (luaState) == 4); }
//
// int r = lua_pcall (luaState, 3, 0, 0); Py_XDECREF(callable);
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param);
//
// if (r) {
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_file_cb (struct tgl_state *TLSR, void *cb_extra, int success, char *file_name) { void py_file_cb (struct tgl_state *TLSR, void *cb_extra, int success, char *file_name) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *filename = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if(success)
// filename = PyUnicode_FromString(file_name);
// lua_pushnumber (luaState, success); else {
// Py_INCREF(Py_None);
// if (success) { filename = Py_None;
// lua_pushstring (luaState, file_name); }
// } else {
// lua_pushboolean (luaState, 0); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, filename);
// } result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// assert (lua_gettop (luaState) == 4);
// if(result == NULL)
// int r = lua_pcall (luaState, 3, 0, 0); PyErr_Print();
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func); Py_XDECREF(result);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); }
//
// if (r) { Py_XDECREF(callable);
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_chat_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_chat *C) { void py_chat_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_chat *C) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *peer = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if (success) {
// peer = get_peer(C->id, (void *)C);
// lua_pushnumber (luaState, success); } else {
// Py_INCREF(Py_None);
// if (success) { peer = Py_None;
// push_peer (C->id, (void *)C); }
// } else {
// lua_pushboolean (luaState, 0); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, peer);
// } result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// assert (lua_gettop (luaState) == 4);
// if(result == NULL)
// int r = lua_pcall (luaState, 3, 0, 0); PyErr_Print();
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func); Py_XDECREF(result);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); }
//
// if (r) { Py_XDECREF(callable);
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_secret_chat_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_secret_chat *C) { void py_secret_chat_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_secret_chat *C) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *peer = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if (success) {
// peer = get_peer(C->id, (void *)C);
// lua_pushnumber (luaState, success); } else {
// Py_INCREF(Py_None);
// if (success) { peer = Py_None;
// push_peer (C->id, (void *)C); }
// } else {
// lua_pushboolean (luaState, 0); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, peer);
// } result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// assert (lua_gettop (luaState) == 4);
// if(result == NULL)
// int r = lua_pcall (luaState, 3, 0, 0); PyErr_Print();
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func); Py_XDECREF(result);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); }
//
// if (r) { Py_XDECREF(callable);
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_user_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_user *C) { void py_user_cb (struct tgl_state *TLSR, void *cb_extra, int success, struct tgl_user *C) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *peer = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if (success) {
// peer = get_peer(C->id, (void *)C);
// lua_pushnumber (luaState, success); } else {
// Py_INCREF(Py_None);
// if (success) { peer = Py_None;
// push_peer (C->id, (void *)C); }
// } else {
// lua_pushboolean (luaState, 0); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, peer);
// } result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// assert (lua_gettop (luaState) == 4);
// if(result == NULL)
// int r = lua_pcall (luaState, 3, 0, 0); PyErr_Print();
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func); Py_XDECREF(result);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); }
//
// if (r) { Py_XDECREF(callable);
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_str_cb (struct tgl_state *TLSR, void *cb_extra, int success, char *data) { void py_str_cb (struct tgl_state *TLSR, void *cb_extra, int success, char *data) {
// assert (TLSR == TLS); assert (TLSR == TLS);
// struct lua_query_extra *cb = cb_extra; PyObject *callable = cb_extra;
// lua_settop (luaState, 0); PyObject *arglist = NULL;
// //lua_checkstack (luaState, 20); PyObject *str = NULL;
// my_lua_checkstack (luaState, 20); PyObject *result = NULL;
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->func); if(PyCallable_Check(callable)) {
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, cb->param); if(success)
// str = PyUnicode_FromString(data);
// lua_pushnumber (luaState, success); else {
// Py_INCREF(Py_None);
// if (success) { str = Py_None;
// lua_pushstring (luaState, data); }
// } else {
// lua_pushboolean (luaState, 0); arglist = Py_BuildValue("(OO)", success ? Py_True : Py_False, str);
// } result = PyEval_CallObject(callable, arglist);
// Py_DECREF(arglist);
// assert (lua_gettop (luaState) == 4);
// if(result == NULL)
// int r = lua_pcall (luaState, 3, 0, 0); PyErr_Print();
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->func); Py_XDECREF(result);
// luaL_unref (luaState, LUA_REGISTRYINDEX, cb->param); }
//
// if (r) { Py_XDECREF(callable);
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
// free (cb);
} }
void py_do_all (void) { void py_do_all (void) {
int p = 0; int p = 0;
while (p < pos) { while (p < pos) {
assert (p + 1 <= pos); assert (p + 2 <= pos);
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 ++];
const char *str; const char *str;
int len; int len;
PyObject *pyObj1 = NULL; PyObject *pyObj1 = NULL;
PyObject *pyObj2 = NULL; PyObject *pyObj2 = NULL;
PyObject *cb_extra;
//struct tgl_message *M; //struct tgl_message *M;
tgl_peer_id_t peer, peer1; tgl_peer_id_t peer, peer1;
switch (f) { switch (f) {
case pq_contact_list: case pq_contact_list:
tgl_do_update_contact_list (TLS, py_contact_list_cb, NULL); PyArg_ParseTuple(args, "O", &cb_extra);
tgl_do_update_contact_list (TLS, py_contact_list_cb, cb_extra);
break; break;
case pq_dialog_list: case pq_dialog_list:
tgl_do_get_dialog_list (TLS, py_dialog_list_cb, NULL); PyArg_ParseTuple(args, "O", &cb_extra);
tgl_do_get_dialog_list (TLS, py_dialog_list_cb, cb_extra);
break; break;
case pq_msg: case pq_msg:
PyArg_ParseTuple(args, "iis#", &peer.type, &peer.id, &str, &len); PyArg_ParseTuple(args, "iis#O", &peer.type, &peer.id, &str, &len, &cb_extra);
tgl_do_send_message (TLS, peer, str, len, py_msg_cb, NULL); tgl_do_send_message (TLS, peer, str, len, py_msg_cb, cb_extra);
break; break;
case pq_send_typing: case pq_send_typing:
PyArg_ParseTuple(args, "ii", &peer.type, &peer.id); PyArg_ParseTuple(args, "iiO", &peer.type, &peer.id, &cb_extra);
tgl_do_send_typing (TLS, peer, tgl_typing_typing, py_empty_cb, NULL); tgl_do_send_typing (TLS, peer, tgl_typing_typing, py_empty_cb, cb_extra);
break; break;
case pq_send_typing_abort: case pq_send_typing_abort:
PyArg_ParseTuple(args, "ii", &peer.type, &peer.id); PyArg_ParseTuple(args, "iiO", &peer.type, &peer.id, &cb_extra);
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, cb_extra);
break; break;
case pq_rename_chat: case pq_rename_chat:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_rename_chat (TLS, peer, str, py_msg_cb, NULL); tgl_do_rename_chat (TLS, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_send_photo: case pq_send_photo:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_send_document (TLS, -1, peer, str, py_msg_cb, NULL); tgl_do_send_document (TLS, -1, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_send_video: case pq_send_video:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_send_document (TLS, FLAG_DOCUMENT_VIDEO, peer, str, py_msg_cb, NULL); tgl_do_send_document (TLS, FLAG_DOCUMENT_VIDEO, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_send_audio: case pq_send_audio:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_send_document (TLS, FLAG_DOCUMENT_AUDIO, peer, str, py_msg_cb, NULL); tgl_do_send_document (TLS, FLAG_DOCUMENT_AUDIO, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_send_document: case pq_send_document:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_send_document (TLS, 0, peer, str, py_msg_cb, NULL); tgl_do_send_document (TLS, 0, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_send_file: case pq_send_file:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_send_document (TLS, -2, peer, str, py_msg_cb, NULL); tgl_do_send_document (TLS, -2, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_send_text: case pq_send_text:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_send_text (TLS, peer, str, py_msg_cb, NULL); tgl_do_send_text (TLS, peer, str, py_msg_cb, cb_extra);
break; break;
case pq_chat_set_photo: case pq_chat_set_photo:
PyArg_ParseTuple(args, "iis", &peer.type, &peer.id, &str); PyArg_ParseTuple(args, "iisO", &peer.type, &peer.id, &str, &cb_extra);
tgl_do_set_chat_photo (TLS, peer, str, py_msg_cb, NULL); tgl_do_set_chat_photo (TLS, peer, str, py_msg_cb, cb_extra);
break; break;
/* case pq_load_photo: /* case pq_load_photo:
case pq_load_video: case pq_load_video:
@ -1103,12 +1041,12 @@ void py_do_all (void) {
break; break;
*/ */
case pq_chat_add_user: case pq_chat_add_user:
PyArg_ParseTuple(args, "iiii", &peer.type, &peer.id, &peer1.type, &peer1.id); PyArg_ParseTuple(args, "iiiiO", &peer.type, &peer.id, &peer1.type, &peer1.id, &cb_extra);
tgl_do_add_user_to_chat (TLS, peer, peer1, 100, py_msg_cb, NULL); tgl_do_add_user_to_chat (TLS, peer, peer1, 100, py_msg_cb, cb_extra);
break; break;
case pq_chat_del_user: case pq_chat_del_user:
PyArg_ParseTuple(args, "iiii", &peer.type, &peer.id, &peer.type, &peer.id); PyArg_ParseTuple(args, "iiiiO", &peer.type, &peer.id, &peer.type, &peer.id, &cb_extra);
tgl_do_del_user_from_chat (TLS, peer, peer1, py_msg_cb, NULL); tgl_do_del_user_from_chat (TLS, peer, peer1, py_msg_cb, cb_extra);
break; break;
/* case pq_add_contact: /* case pq_add_contact:
tgl_do_add_contact (TLS, s1, strlen (s1), s2, strlen (s2), s3, strlen (s3), 0, py_contact_list_cb, py_ptr[p]); tgl_do_add_contact (TLS, s1, strlen (s1), s2, strlen (s2), s3, strlen (s3), 0, py_contact_list_cb, py_ptr[p]);
@ -1154,18 +1092,20 @@ void py_do_all (void) {
break; break;
*/ */
case pq_status_online: case pq_status_online:
tgl_do_update_status (TLS, 1, py_empty_cb, NULL); PyArg_ParseTuple(args, "O", &cb_extra);
tgl_do_update_status (TLS, 1, py_empty_cb, cb_extra);
break; break;
case pq_status_offline: case pq_status_offline:
tgl_do_update_status (TLS, 0, py_empty_cb, NULL); PyArg_ParseTuple(args, "O", &cb_extra);
tgl_do_update_status (TLS, 0, py_empty_cb, cb_extra);
break; break;
/* case pq_extf: /* case pq_extf:
tgl_do_send_extf (TLS, s, strlen (s), py_str_cb, py_ptr[p]); tgl_do_send_extf (TLS, s, strlen (s), py_str_cb, py_ptr[p]);
break; break;
*/ */
case pq_send_location: case pq_send_location:
PyArg_ParseTuple(args, "iiOO", &peer.type, &peer.id, &pyObj1, &pyObj2); PyArg_ParseTuple(args, "iiOOO", &peer.type, &peer.id, &pyObj1, &pyObj2, &cb_extra);
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, cb_extra);
Py_XDECREF(pyObj1); Py_XDECREF(pyObj1);
Py_XDECREF(pyObj2); Py_XDECREF(pyObj2);
break; break;
@ -1189,6 +1129,9 @@ void py_do_all (void) {
assert (0); assert (0);
} }
// Increment reference on cb_extra as it is passed on to the callback to use
Py_XINCREF(cb_extra);
// Clean up any arg variables we could have used. // Clean up any arg variables we could have used.
//Py_XDECREF(args); // TODO: this is going negative ref and causing segfaults //Py_XDECREF(args); // TODO: this is going negative ref and causing segfaults
@ -1330,76 +1273,12 @@ MOD_INIT(tgl)
} }
//static void lua_postpone_alarm (evutil_socket_t fd, short what, void *arg) { extern int safe_quit;
// int *t = arg; static int safe_quit_from_py() {
// Py_Finalize();
// lua_settop (luaState, 0); safe_quit = 1;
// //lua_checkstack (luaState, 20); return 1;
// my_lua_checkstack (luaState, 20); }
//
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, t[1]);
// lua_rawgeti (luaState, LUA_REGISTRYINDEX, t[0]);
// assert (lua_gettop (luaState) == 2);
//
// int r = lua_pcall (luaState, 1, 0, 0);
//
// luaL_unref (luaState, LUA_REGISTRYINDEX, t[0]);
// luaL_unref (luaState, LUA_REGISTRYINDEX, t[1]);
//
// if (r) {
// logprintf ("lua: %s\n", lua_tostring (luaState, -1));
// }
//
//}
//
//static int postpone_from_lua (lua_State *L) {
// int n = lua_gettop (L);
// if (n != 3) {
// lua_pushboolean (L, 0);
// return 1;
// }
//
// double timeout = lua_tonumber (L, -1);
// if (timeout < 0) {
// lua_pushboolean (L, 0);
// return 1;
// }
//
// lua_pop (L, 1);
// int a1 = luaL_ref (L, LUA_REGISTRYINDEX);
// int a2 = luaL_ref (L, LUA_REGISTRYINDEX);
//
//
// int *t = malloc (16);
// assert (t);
// struct event *ev = evtimer_new (TLS->ev_base, lua_postpone_alarm, t);
// t[0] = a1;
// t[1] = a2;
// *(void **)(t + 2) = ev;
//
// struct timeval ts= {
// .tv_sec = (long)timeout,
// .tv_usec = (timeout - ((long)timeout)) * 1000000
// };
// event_add (ev, &ts);
//
// lua_pushboolean (L, 1);
// return 1;
//}
//extern int safe_quit;
//static int safe_quit_from_lua (lua_State *L) {
// int n = lua_gettop (L);
// if (n != 0) {
// lua_pushboolean (L, 0);
// return 1;
// }
// safe_quit = 1;
//
// lua_pushboolean (L, 1);
// return 1;
//}
//
void py_init (const char *file) { void py_init (const char *file) {
if (!file) { return; } if (!file) { return; }

View File

@ -16,6 +16,10 @@ def on_our_id(id):
our_id = id our_id = id
return "Set ID: " + str(our_id) return "Set ID: " + str(our_id)
def msg_cb(success, msg):
pp.pprint(success)
pp.pprint(msg)
def on_msg_receive(msg): def on_msg_receive(msg):
if msg["out"] and not binlog_done: if msg["out"] and not binlog_done:
return; return;
@ -33,7 +37,7 @@ def on_msg_receive(msg):
if text.startswith("!ping"): if text.startswith("!ping"):
print("SENDING PONG") print("SENDING PONG")
tgl.send_msg(ptype, pid, "PONG!") tgl.send_msg(ptype, pid, "PONG!", msg_cb)
def on_secret_chat_update(peer, types): def on_secret_chat_update(peer, types):
return "on_secret_chat_update" return "on_secret_chat_update"