Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
T
tg
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
tg
Commits
5f7b5e40
Commit
5f7b5e40
authored
Jun 02, 2015
by
vysheng
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #589 from datamachine/master
New Python Binding Changes
parents
77cfd51d
5af46bdc
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
135 additions
and
16 deletions
+135
-16
python-tg.c
python-tg.c
+66
-16
python-types.c
python-types.c
+69
-0
No files found.
python-tg.c
View file @
5f7b5e40
...
@@ -774,16 +774,21 @@ void py_do_all (void) {
...
@@ -774,16 +774,21 @@ void py_do_all (void) {
int
preview
=
0
;
int
preview
=
0
;
int
reply_id
=
0
;
int
reply_id
=
0
;
unsigned
long
long
flags
=
0
;
unsigned
long
long
flags
=
0
;
Py_ssize_t
i
;
Py_ssize_t
i
;
tgl_user_id_t
*
ids
;
tgl_user_id_t
*
ids
;
struct
tgl_message
*
M
;
int
len
,
len1
,
len2
,
len3
;
int
len
,
len1
,
len2
,
len3
;
int
limit
,
offset
;
int
limit
,
offset
;
long
msg_id
=
0
;
long
msg_id
=
0
;
PyObject
*
pyObj1
=
NULL
;
PyObject
*
pyObj1
=
NULL
;
PyObject
*
pyObj2
=
NULL
;
PyObject
*
pyObj2
=
NULL
;
PyObject
*
cb_extra
=
NULL
;
PyObject
*
cb_extra
=
NULL
;
PyObject
*
msg
=
NULL
;
PyObject
*
peer
=
NULL
;
PyObject
*
peer
=
NULL
;
PyObject
*
peer1
=
NULL
;
PyObject
*
peer1
=
NULL
;
...
@@ -877,33 +882,40 @@ void py_do_all (void) {
...
@@ -877,33 +882,40 @@ void py_do_all (void) {
else
else
PyErr_Print
();
PyErr_Print
();
break
;
break
;
/*
case pq_load_photo:
case
pq_load_photo
:
case
pq_load_video
:
case
pq_load_video
:
case
pq_load_audio
:
case
pq_load_audio
:
case
pq_load_document
:
case
pq_load_document
:
M = py_ptr[p + 1];
if
(
PyArg_ParseTuple
(
args
,
"O!O"
,
&
tgl_MsgType
,
&
msg
,
&
cb_extra
))
if (!M || (M->media.type != tgl_message_media_photo && M->media.type != tgl_message_media_photo_encr && M->media.type != tgl_message_media_document && M->media.type != tgl_message_media_document_encr)) {
{
py_file_cb (TLS, py_ptr[p], 0, 0);
M
=
((
tgl_Msg
*
)
msg
)
->
msg
;
} else {
if
(
!
M
||
(
M
->
media
.
type
!=
tgl_message_media_photo
&&
M
->
media
.
type
!=
tgl_message_media_document
&&
M
->
media
.
type
!=
tgl_message_media_document_encr
))
{
, limit, offse, limit, offsettif (M->media.type == tgl_message_media_photo) {
py_file_cb
(
TLS
,
cb_extra
,
0
,
0
);
tgl_do_load_photo (TLS, &M->media.photo, py_file_cb, py_ptr[p]);
} else if (M->media.type == tgl_message_media_document) {
tgl_do_load_document (TLS, &M->media.document, py_file_cb, py_ptr[p]);
}
else
{
}
else
{
tgl_do_load_encr_document (TLS, &M->media.encr_document, py_file_cb, py_ptr[p]);
if
(
M
->
media
.
type
==
tgl_message_media_photo
)
{
assert
(
M
->
media
.
photo
);
tgl_do_load_photo
(
TLS
,
M
->
media
.
photo
,
py_file_cb
,
cb_extra
);
}
else
if
(
M
->
media
.
type
==
tgl_message_media_document
)
{
tgl_do_load_document
(
TLS
,
M
->
media
.
document
,
py_file_cb
,
cb_extra
);
}
else
{
tgl_do_load_encr_document
(
TLS
,
M
->
media
.
encr_document
,
py_file_cb
,
cb_extra
);
}
}
}
}
}
break
;
break
;
case
pq_load_video_thumb
:
case
pq_load_video_thumb
:
case
pq_load_document_thumb
:
case
pq_load_document_thumb
:
M = py_ptr[p + 1];
if
(
PyArg_ParseTuple
(
args
,
"O!O"
,
&
tgl_MsgType
,
&
msg
,
&
cb_extra
))
if (!M || (M->media.type != tgl_message_media_document)) {
{
py_file_cb (TLS, py_ptr[p], 0, 0);
M
=
((
tgl_Msg
*
)
msg
)
->
msg
;
} else {
if
(
!
M
||
(
M
->
media
.
type
!=
tgl_message_media_document
))
{
tgl_do_load_document_thumb (TLS, &M->media.document, py_file_cb, py_ptr[p]);
py_file_cb
(
TLS
,
cb_extra
,
0
,
0
);
}
else
{
tgl_do_load_document_thumb
(
TLS
,
M
->
media
.
document
,
py_file_cb
,
cb_extra
);
}
}
}
break
;
break
;
*/
case
pq_fwd
:
case
pq_fwd
:
if
(
PyArg_ParseTuple
(
args
,
"O!l|O"
,
&
tgl_PeerType
,
&
peer
,
&
msg_id
,
&
cb_extra
))
if
(
PyArg_ParseTuple
(
args
,
"O!l|O"
,
&
tgl_PeerType
,
&
peer
,
&
msg_id
,
&
cb_extra
))
tgl_do_forward_message
(
TLS
,
PY_PEER_ID
(
peer
),
msg_id
,
0
,
py_msg_cb
,
cb_extra
);
tgl_do_forward_message
(
TLS
,
PY_PEER_ID
(
peer
),
msg_id
,
0
,
py_msg_cb
,
cb_extra
);
...
@@ -1234,6 +1246,41 @@ static PyMethodDef py_tgl_methods[] = {
...
@@ -1234,6 +1246,41 @@ static PyMethodDef py_tgl_methods[] = {
{
NULL
,
NULL
,
0
,
NULL
}
{
NULL
,
NULL
,
0
,
NULL
}
};
};
void
py_add_action_enums
(
PyObject
*
m
)
{
PyModule_AddIntConstant
(
m
,
"ACTION_NONE"
,
tgl_message_action_none
);
PyModule_AddIntConstant
(
m
,
"ACTION_GEO_CHAT_CREATE"
,
tgl_message_action_geo_chat_create
);
PyModule_AddIntConstant
(
m
,
"ACTION_GEO_CHAT_CHECKIN"
,
tgl_message_action_geo_chat_checkin
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_CREATE"
,
tgl_message_action_chat_create
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_EDIT_TITLE"
,
tgl_message_action_chat_edit_title
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_EDIT_PHOTO"
,
tgl_message_action_chat_edit_photo
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_DELETE_PHOTO"
,
tgl_message_action_chat_delete_photo
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_ADD_USER"
,
tgl_message_action_chat_add_user
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_ADD_USER_BY_LINK"
,
tgl_message_action_chat_add_user_by_link
);
PyModule_AddIntConstant
(
m
,
"ACTION_CHAT_DELETE_USER"
,
tgl_message_action_chat_delete_user
);
PyModule_AddIntConstant
(
m
,
"ACTION_SET_MESSAGE_TTL"
,
tgl_message_action_set_message_ttl
);
PyModule_AddIntConstant
(
m
,
"ACTION_READ_MESSAGES"
,
tgl_message_action_read_messages
);
PyModule_AddIntConstant
(
m
,
"ACTION_DELETE_MESSAGES"
,
tgl_message_action_delete_messages
);
PyModule_AddIntConstant
(
m
,
"ACTION_SCREENSHOT_MESSAGES"
,
tgl_message_action_screenshot_messages
);
PyModule_AddIntConstant
(
m
,
"ACTION_FLUSH_HISTORY"
,
tgl_message_action_flush_history
);
PyModule_AddIntConstant
(
m
,
"ACTION_RESEND"
,
tgl_message_action_resend
);
PyModule_AddIntConstant
(
m
,
"ACTION_NOTIFY_LAYER"
,
tgl_message_action_notify_layer
);
PyModule_AddIntConstant
(
m
,
"ACTION_TYPING"
,
tgl_message_action_typing
);
PyModule_AddIntConstant
(
m
,
"ACTION_NOOP"
,
tgl_message_action_noop
);
PyModule_AddIntConstant
(
m
,
"ACTION_COMMIT_KEY"
,
tgl_message_action_commit_key
);
PyModule_AddIntConstant
(
m
,
"ACTION_ABORT_KEY"
,
tgl_message_action_abort_key
);
PyModule_AddIntConstant
(
m
,
"ACTION_REQUEST_KEY"
,
tgl_message_action_request_key
);
PyModule_AddIntConstant
(
m
,
"ACTION_ACCEPT_KEY"
,
tgl_message_action_accept_key
);
}
void
py_add_peer_type_enums
(
PyObject
*
m
)
{
PyModule_AddIntConstant
(
m
,
"PEER_USER"
,
TGL_PEER_USER
);
PyModule_AddIntConstant
(
m
,
"PEER_USER"
,
TGL_PEER_CHAT
);
PyModule_AddIntConstant
(
m
,
"PEER_ENCR_CHAT"
,
TGL_PEER_ENCR_CHAT
);
}
MOD_INIT
(
tgl
)
MOD_INIT
(
tgl
)
{
{
PyObject
*
m
;
PyObject
*
m
;
...
@@ -1243,6 +1290,9 @@ MOD_INIT(tgl)
...
@@ -1243,6 +1290,9 @@ MOD_INIT(tgl)
if
(
m
==
NULL
)
if
(
m
==
NULL
)
return
MOD_ERROR_VAL
;
return
MOD_ERROR_VAL
;
py_add_action_enums
(
m
);
py_add_peer_type_enums
(
m
);
if
(
PyType_Ready
(
&
tgl_PeerType
)
<
0
)
if
(
PyType_Ready
(
&
tgl_PeerType
)
<
0
)
return
MOD_ERROR_VAL
;
return
MOD_ERROR_VAL
;
...
...
python-types.c
View file @
5f7b5e40
...
@@ -1151,6 +1151,17 @@ tgl_Msg_getservice (tgl_Msg *self, void *closure)
...
@@ -1151,6 +1151,17 @@ tgl_Msg_getservice (tgl_Msg *self, void *closure)
return
ret
;
return
ret
;
}
}
static
PyObject
*
tgl_Msg_getaction
(
tgl_Msg
*
self
,
void
*
closure
)
{
PyObject
*
ret
;
ret
=
PyLong_FromLong
(
self
->
msg
->
action
.
type
);
Py_XINCREF
(
ret
);
return
ret
;
}
static
PyObject
*
static
PyObject
*
tgl_Msg_getsrc
(
tgl_Msg
*
self
,
void
*
closure
)
tgl_Msg_getsrc
(
tgl_Msg
*
self
,
void
*
closure
)
...
@@ -1210,6 +1221,8 @@ tgl_Msg_gettext (tgl_Msg *self, void *closure)
...
@@ -1210,6 +1221,8 @@ tgl_Msg_gettext (tgl_Msg *self, void *closure)
return
ret
;
return
ret
;
}
}
static
PyObject
*
static
PyObject
*
tgl_Msg_getmedia
(
tgl_Msg
*
self
,
void
*
closure
)
tgl_Msg_getmedia
(
tgl_Msg
*
self
,
void
*
closure
)
{
{
...
@@ -1357,6 +1370,55 @@ tgl_Msg_getreply_id (tgl_Msg *self, void *closure)
...
@@ -1357,6 +1370,55 @@ tgl_Msg_getreply_id (tgl_Msg *self, void *closure)
return
ret
;
return
ret
;
}
}
// All load methods are implemented the same, just alias load_document
static
PyObject
*
tgl_Msg_load_document
(
tgl_Msg
*
self
,
PyObject
*
args
,
PyObject
*
kwargs
)
{
static
char
*
kwlist
[]
=
{
"callback"
,
NULL
};
PyObject
*
callback
=
NULL
;
if
(
PyArg_ParseTupleAndKeywords
(
args
,
kwargs
,
"O"
,
kwlist
,
&
callback
))
{
PyObject
*
api_call
;
api_call
=
Py_BuildValue
(
"OO"
,
(
PyObject
*
)
self
,
callback
);
Py_INCREF
(
Py_None
);
Py_XINCREF
(
api_call
);
return
py_load_document
(
Py_None
,
api_call
);
}
else
{
PyErr_Print
();
Py_XINCREF
(
Py_False
);
return
Py_False
;
}
}
static
PyObject
*
tgl_Msg_load_document_thumb
(
tgl_Msg
*
self
,
PyObject
*
args
,
PyObject
*
kwargs
)
{
static
char
*
kwlist
[]
=
{
"callback"
,
NULL
};
PyObject
*
callback
=
NULL
;
if
(
PyArg_ParseTupleAndKeywords
(
args
,
kwargs
,
"O"
,
kwlist
,
&
callback
))
{
PyObject
*
api_call
;
api_call
=
Py_BuildValue
(
"OO"
,
(
PyObject
*
)
self
,
callback
);
Py_INCREF
(
Py_None
);
Py_XINCREF
(
api_call
);
return
py_load_document_thumb
(
Py_None
,
api_call
);
}
else
{
PyErr_Print
();
Py_XINCREF
(
Py_False
);
return
Py_False
;
}
}
static
PyObject
*
static
PyObject
*
tgl_Msg_repr
(
tgl_Msg
*
self
)
tgl_Msg_repr
(
tgl_Msg
*
self
)
{
{
...
@@ -1400,6 +1462,7 @@ static PyGetSetDef tgl_Msg_getseters[] = {
...
@@ -1400,6 +1462,7 @@ static PyGetSetDef tgl_Msg_getseters[] = {
{
"fwd_date"
,
(
getter
)
tgl_Msg_getfwd_date
,
NULL
,
""
,
NULL
},
{
"fwd_date"
,
(
getter
)
tgl_Msg_getfwd_date
,
NULL
,
""
,
NULL
},
{
"reply"
,
(
getter
)
tgl_Msg_getreply
,
NULL
,
""
,
NULL
},
{
"reply"
,
(
getter
)
tgl_Msg_getreply
,
NULL
,
""
,
NULL
},
{
"reply_id"
,
(
getter
)
tgl_Msg_getreply_id
,
NULL
,
""
,
NULL
},
{
"reply_id"
,
(
getter
)
tgl_Msg_getreply_id
,
NULL
,
""
,
NULL
},
{
"action"
,
(
getter
)
tgl_Msg_getaction
,
NULL
,
""
,
NULL
},
{
NULL
}
/* Sentinel */
{
NULL
}
/* Sentinel */
};
};
...
@@ -1410,6 +1473,12 @@ static PyMemberDef tgl_Msg_members[] = {
...
@@ -1410,6 +1473,12 @@ static PyMemberDef tgl_Msg_members[] = {
static
PyMethodDef
tgl_Msg_methods
[]
=
{
static
PyMethodDef
tgl_Msg_methods
[]
=
{
{
"load_document"
,
(
PyCFunction
)
tgl_Msg_load_document
,
METH_VARARGS
|
METH_KEYWORDS
,
""
},
{
"load_photo"
,
(
PyCFunction
)
tgl_Msg_load_document
,
METH_VARARGS
|
METH_KEYWORDS
,
""
},
{
"load_audio"
,
(
PyCFunction
)
tgl_Msg_load_document
,
METH_VARARGS
|
METH_KEYWORDS
,
""
},
{
"load_video"
,
(
PyCFunction
)
tgl_Msg_load_document
,
METH_VARARGS
|
METH_KEYWORDS
,
""
},
{
"load_document_thumb"
,
(
PyCFunction
)
tgl_Msg_load_document_thumb
,
METH_VARARGS
|
METH_KEYWORDS
,
""
},
{
"load_video_thumb"
,
(
PyCFunction
)
tgl_Msg_load_document_thumb
,
METH_VARARGS
|
METH_KEYWORDS
,
""
},
{
NULL
}
/* Sentinel */
{
NULL
}
/* Sentinel */
};
};
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment