Implement reprs and fix dates

This commit is contained in:
Vincent Castellano 2015-05-20 01:12:48 -07:00
parent b547ca7158
commit 354aa64ae1
3 changed files with 90 additions and 19 deletions

View File

@ -109,12 +109,6 @@ PyObject *_py_chat_update;
PyObject* get_peer (tgl_peer_id_t id, tgl_peer_t *P); PyObject* get_peer (tgl_peer_id_t id, tgl_peer_t *P);
// Utility functions
PyObject* get_datetime(long 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));

View File

@ -20,6 +20,14 @@ extern PyObject *TglError;
extern PyObject *PeerError; extern PyObject *PeerError;
extern PyObject *MsgError; extern PyObject *MsgError;
// Utility functions
PyObject* get_datetime(long datetime)
{
return PyDateTime_FromTimestamp(Py_BuildValue("(O)", PyLong_FromLong(datetime)));
}
// //
// tgl_peer_t wrapper // tgl_peer_t wrapper
// //
@ -34,6 +42,7 @@ tgl_Peer_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
{ {
tgl_Peer *self; tgl_Peer *self;
PyDateTime_IMPORT;
self = (tgl_Peer *)type->tp_alloc(type, 0); self = (tgl_Peer *)type->tp_alloc(type, 0);
return (PyObject *)self; return (PyObject *)self;
} }
@ -148,8 +157,7 @@ tgl_Peer_getuser_status(tgl_Peer *self, void *closure)
case TGL_PEER_USER: case TGL_PEER_USER:
ret = PyDict_New(); ret = PyDict_New();
PyDict_SetItemString(ret, "online", self->peer->user.status.online? Py_True : Py_False); PyDict_SetItemString(ret, "online", self->peer->user.status.online? Py_True : Py_False);
PyDict_SetItemString(ret, "when", PyDateTime_FromTimestamp(Py_BuildValue("(O)", PyDict_SetItemString(ret, "when", get_datetime(self->peer->user.status.when));
PyLong_FromLong(self->peer->user.status.when))));
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
@ -173,7 +181,10 @@ tgl_Peer_getphone (tgl_Peer *self, void *closure)
switch(self->peer->id.type) { switch(self->peer->id.type) {
case TGL_PEER_USER: case TGL_PEER_USER:
ret = PyUnicode_FromString(self->peer->user.phone); if(self->peer->user.phone)
ret = PyUnicode_FromString(self->peer->user.phone);
else
Py_RETURN_NONE;
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
@ -196,7 +207,10 @@ tgl_Peer_getusername (tgl_Peer *self, void *closure)
switch(self->peer->id.type) { switch(self->peer->id.type) {
case TGL_PEER_USER: case TGL_PEER_USER:
ret = PyUnicode_FromString(self->peer->user.username); if(self->peer->user.username)
ret = PyUnicode_FromString(self->peer->user.username);
else
Py_RETURN_NONE;
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
@ -219,7 +233,10 @@ tgl_Peer_getfirst_name (tgl_Peer *self, void *closure)
switch(self->peer->id.type) { switch(self->peer->id.type) {
case TGL_PEER_USER: case TGL_PEER_USER:
ret = PyUnicode_FromString(self->peer->user.first_name); if(self->peer->user.first_name)
ret = PyUnicode_FromString(self->peer->user.first_name);
else
Py_RETURN_NONE;
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
@ -242,7 +259,10 @@ tgl_Peer_getlast_name (tgl_Peer *self, void *closure)
switch(self->peer->id.type) { switch(self->peer->id.type) {
case TGL_PEER_USER: case TGL_PEER_USER:
ret = PyUnicode_FromString(self->peer->user.username); if(self->peer->user.last_name)
ret = PyUnicode_FromString(self->peer->user.last_name);
else
Py_RETURN_NONE;
break; break;
case TGL_PEER_CHAT: case TGL_PEER_CHAT:
case TGL_PEER_ENCR_CHAT: case TGL_PEER_ENCR_CHAT:
@ -381,6 +401,39 @@ static PyMethodDef tgl_Peer_methods[] = {
}; };
static PyObject *
tgl_Peer_repr(tgl_Peer *self)
{
PyObject *ret;
switch(self->peer->id.type) {
case TGL_PEER_USER:
ret = PyUnicode_FromFormat("<tgl.Peer: type=user, id=%ld, username=%R, name=%R, first_name=%R, last_name=%R, phone=%R>",
self->peer->id.id,
PyObject_GetAttrString((PyObject*)self, "username"),
PyObject_GetAttrString((PyObject*)self, "name"),
PyObject_GetAttrString((PyObject*)self, "first_name"),
PyObject_GetAttrString((PyObject*)self, "last_name"),
PyObject_GetAttrString((PyObject*)self, "phone")
);
break;
case TGL_PEER_CHAT:
ret = PyUnicode_FromFormat("<tgl.Peer: type=chat, id=%ld, name=%s>",
self->peer->id.id, self->peer->chat.print_title);
break;
case TGL_PEER_ENCR_CHAT:
ret = PyUnicode_FromFormat("<tgl.Peer: type=secret_chat, id=%ld, name=%s, user=%R>",
self->peer->id.id, self->peer->encr_chat.print_name,
PyObject_GetAttrString((PyObject*)self, "user"));
break;
default:
ret = PyUnicode_FromFormat("<tgl.Peer: Type Unknown>");
}
return ret;
}
PyTypeObject tgl_PeerType = { PyTypeObject tgl_PeerType = {
PyVarObject_HEAD_INIT(NULL, 0) PyVarObject_HEAD_INIT(NULL, 0)
"tgl.Peer", /* tp_name */ "tgl.Peer", /* tp_name */
@ -391,7 +444,7 @@ PyTypeObject tgl_PeerType = {
0, /* tp_getattr */ 0, /* tp_getattr */
0, /* tp_setattr */ 0, /* tp_setattr */
0, /* tp_reserved */ 0, /* tp_reserved */
0, /* tp_repr */ (reprfunc)tgl_Peer_repr, /* tp_repr */
0, /* tp_as_number */ 0, /* tp_as_number */
0, /* tp_as_sequence */ 0, /* tp_as_sequence */
0, /* tp_as_mapping */ 0, /* tp_as_mapping */
@ -446,6 +499,7 @@ tgl_Msg_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
{ {
tgl_Msg *self; tgl_Msg *self;
PyDateTime_IMPORT;
self = (tgl_Msg *)type->tp_alloc(type, 0); self = (tgl_Msg *)type->tp_alloc(type, 0);
return (PyObject *)self; return (PyObject *)self;
} }
@ -636,8 +690,7 @@ tgl_Msg_getdate (tgl_Msg *self, void *closure)
PyObject *ret; PyObject *ret;
if(self->msg->date) { if(self->msg->date) {
ret = PyDateTime_FromTimestamp(Py_BuildValue("(O)", ret = get_datetime(self->msg->date);
PyLong_FromLong(self->msg->date)));
} else { } else {
Py_RETURN_NONE; Py_RETURN_NONE;
} }
@ -667,8 +720,7 @@ tgl_Msg_getfwd_date (tgl_Msg *self, void *closure)
PyObject *ret; PyObject *ret;
if(tgl_get_peer_type (self->msg->fwd_from_id)) { if(tgl_get_peer_type (self->msg->fwd_from_id)) {
ret = PyDateTime_FromTimestamp(Py_BuildValue("(O)", ret = get_datetime(self->msg->fwd_date);
PyLong_FromLong(self->msg->fwd_date)));
} else { } else {
Py_RETURN_NONE; Py_RETURN_NONE;
} }
@ -712,7 +764,31 @@ tgl_Msg_getreply_id (tgl_Msg *self, void *closure)
return ret; return ret;
} }
static PyObject *
tgl_Msg_repr(tgl_Msg *self)
{
PyObject *ret;
ret = PyUnicode_FromFormat("<tgl.Msg id=%ld, flags=%d, mention=%R, out=%R, unread=%R, service=%R, src=%R, "
"dest=%R, text=%R, media=%R, date=%R, fwd_src=%R, fwd_date=%R, reply_id=%R, reply=%R>",
self->msg->id, self->msg->flags,
PyObject_GetAttrString((PyObject*)self, "mention"),
PyObject_GetAttrString((PyObject*)self, "out"),
PyObject_GetAttrString((PyObject*)self, "unread"),
PyObject_GetAttrString((PyObject*)self, "service"),
PyObject_GetAttrString((PyObject*)self, "src"),
PyObject_GetAttrString((PyObject*)self, "dest"),
PyObject_GetAttrString((PyObject*)self, "text"),
PyObject_GetAttrString((PyObject*)self, "media"),
PyObject_GetAttrString((PyObject*)self, "date"),
PyObject_GetAttrString((PyObject*)self, "fwd_src"),
PyObject_GetAttrString((PyObject*)self, "fwd_date"),
PyObject_GetAttrString((PyObject*)self, "reply_id"),
PyObject_GetAttrString((PyObject*)self, "reply")
);
return ret;
}
static PyGetSetDef tgl_Msg_getseters[] = { static PyGetSetDef tgl_Msg_getseters[] = {
@ -753,7 +829,7 @@ PyTypeObject tgl_MsgType = {
0, /* tp_getattr */ 0, /* tp_getattr */
0, /* tp_setattr */ 0, /* tp_setattr */
0, /* tp_reserved */ 0, /* tp_reserved */
0, /* tp_repr */ (reprfunc)tgl_Msg_repr, /* tp_repr */
0, /* tp_as_number */ 0, /* tp_as_number */
0, /* tp_as_sequence */ 0, /* tp_as_sequence */
0, /* tp_as_mapping */ 0, /* tp_as_mapping */
@ -764,7 +840,7 @@ PyTypeObject tgl_MsgType = {
0, /* tp_setattro */ 0, /* tp_setattro */
0, /* tp_as_buffer */ 0, /* tp_as_buffer */
Py_TPFLAGS_DEFAULT, /* tp_flags */ Py_TPFLAGS_DEFAULT, /* tp_flags */
"tgl Message", /* tp_doc */ "tgl Message", /* tp_doc */
0, /* tp_traverse */ 0, /* tp_traverse */
0, /* tp_clear */ 0, /* tp_clear */
0, /* tp_richcompare */ 0, /* tp_richcompare */

View File

@ -42,6 +42,7 @@ def on_msg_receive(msg):
else: # chatroom else: # chatroom
peer = msg.dest peer = msg.dest
print(msg)
if msg.text.startswith("!ping"): if msg.text.startswith("!ping"):
print("SENDING PONG") print("SENDING PONG")
tgl.send_msg(peer, "PONG!", msg_cb) tgl.send_msg(peer, "PONG!", msg_cb)