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
8fd26130
Commit
8fd26130
authored
Sep 09, 2014
by
Vysheng
Browse files
Options
Browse Files
Download
Plain Diff
Merge github.com:vysheng/tg
parents
4e33b40d
b44d7d32
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
111 additions
and
39 deletions
+111
-39
queries.c
queries.c
+109
-21
test.lua
test.lua
+2
-18
No files found.
queries.c
View file @
8fd26130
...
...
@@ -1152,20 +1152,49 @@ void tgl_do_mark_read (tgl_peer_id_t id, void (*callback)(void *callback_extra,
/* }}} */
/* {{{ Get history */
void
_tgl_do_get_history
(
tgl_peer_id_t
id
,
int
limit
,
int
offset
,
int
list_offset
,
int
list_size
,
struct
tgl_message
*
ML
[],
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
int
size
,
struct
tgl_message
*
list
[]),
void
*
callback_extra
);
static
int
get_history_on_answer
(
struct
query
*
q
UU
)
{
int
count
=
-
1
;
int
i
;
int
x
=
fetch_int
();
assert
(
x
==
(
int
)
CODE_messages_messages_slice
||
x
==
(
int
)
CODE_messages_messages
);
if
(
x
==
(
int
)
CODE_messages_messages_slice
)
{
fetch_int
();
count
=
fetch_int
();
//fetch_int ();
}
assert
(
fetch_int
()
==
CODE_vector
);
void
**
T
=
q
->
extra
;
struct
tgl_message
**
ML
=
T
[
0
];
int
list_offset
=
(
long
)
T
[
1
];
int
list_size
=
(
long
)
T
[
2
];
tgl_peer_id_t
id
=
tgl_set_peer_id
((
long
)
T
[
4
],
(
long
)
T
[
3
]);
int
limit
=
(
long
)
T
[
5
];
int
offset
=
(
long
)
T
[
6
];
tfree
(
T
,
sizeof
(
void
*
)
*
7
);
int
n
=
fetch_int
();
struct
tgl_message
**
ML
=
talloc
(
sizeof
(
void
*
)
*
n
);
if
(
list_size
-
list_offset
<
n
)
{
int
new_list_size
=
2
*
list_size
;
if
(
new_list_size
-
list_offset
<
n
)
{
new_list_size
=
n
+
list_offset
;
}
ML
=
trealloc
(
ML
,
list_size
*
sizeof
(
void
*
),
new_list_size
*
sizeof
(
void
*
));
assert
(
ML
);
list_size
=
new_list_size
;
}
//struct tgl_message **ML = talloc (sizeof (void *) * n);
for
(
i
=
0
;
i
<
n
;
i
++
)
{
ML
[
i
]
=
tglf_fetch_alloc_message
();
ML
[
i
+
list_offset
]
=
tglf_fetch_alloc_message
();
}
list_offset
+=
n
;
offset
+=
n
;
limit
-=
n
;
if
(
count
>=
0
&&
limit
+
offset
>=
count
)
{
limit
=
count
-
offset
;
if
(
limit
<
0
)
{
limit
=
0
;
}
}
int
sn
=
n
;
assert
(
limit
>=
0
)
;
assert
(
fetch_int
()
==
CODE_vector
);
n
=
fetch_int
();
...
...
@@ -1178,18 +1207,20 @@ static int get_history_on_answer (struct query *q UU) {
tglf_fetch_alloc_user
();
}
if
(
limit
<=
0
||
x
==
(
int
)
CODE_messages_messages
)
{
if
(
q
->
callback
)
{
((
void
(
*
)(
void
*
,
int
,
int
,
struct
tgl_message
**
))
q
->
callback
)
(
q
->
callback_extra
,
1
,
sn
,
ML
);
((
void
(
*
)(
void
*
,
int
,
int
,
struct
tgl_message
**
))
q
->
callback
)
(
q
->
callback_extra
,
1
,
list_offset
,
ML
);
}
/*for (i = n - 1; i >= 0; i--) {
print_message (ML[i]);
}*/
if
(
sn
>
0
&&
q
->
extra
)
{
tgl_do_messages_mark_read
(
*
(
tgl_peer_id_t
*
)
&
(
q
->
extra
),
ML
[
0
]
->
id
,
0
,
0
,
0
);
if
(
list_offset
>
0
)
{
tgl_do_messages_mark_read
(
id
,
ML
[
0
]
->
id
,
0
,
0
,
0
);
}
tfree
(
ML
,
sizeof
(
void
*
)
*
n
);
tfree
(
ML
,
sizeof
(
void
*
)
*
list_size
);
}
else
{
_tgl_do_get_history
(
id
,
limit
,
offset
,
list_offset
,
list_size
,
ML
,
q
->
callback
,
q
->
callback_extra
);
}
return
0
;
}
...
...
@@ -1224,19 +1255,76 @@ void tgl_do_get_local_history (tgl_peer_id_t id, int limit, void (*callback)(voi
tfree
(
ML
,
sizeof
(
void
*
)
*
count
);
}
void
tgl_do_get_
history
(
tgl_peer_id_t
id
,
int
limit
,
int
offline_mode
,
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
int
size
,
struct
tgl_message
*
list
[]),
void
*
callback_extra
)
{
if
(
tgl_get_peer_type
(
id
)
==
TGL_PEER_ENCR_CHAT
||
offline_mode
)
{
tgl_do_get_local_history
(
id
,
limit
,
callback
,
callback_extra
);
tgl_do_mark_read
(
id
,
0
,
0
);
void
tgl_do_get_
local_history_ext
(
tgl_peer_id_t
id
,
int
offset
,
int
limit
,
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
int
size
,
struct
tgl_message
*
list
[]),
void
*
callback_extra
)
{
tgl_peer_t
*
P
=
tgl_peer_get
(
id
);
if
(
!
P
||
!
P
->
last
)
{
callback
(
callback_extra
,
0
,
0
,
0
);
return
;
}
struct
tgl_message
*
M
=
P
->
last
;
int
count
=
1
;
assert
(
!
M
->
prev
);
while
(
count
<
limit
+
offset
&&
M
->
next
)
{
M
=
M
->
next
;
count
++
;
}
if
(
count
<=
offset
)
{
callback
(
callback_extra
,
1
,
0
,
0
);
return
;
}
struct
tgl_message
**
ML
=
talloc
(
sizeof
(
void
*
)
*
(
count
-
offset
));
M
=
P
->
last
;
ML
[
0
]
=
M
;
count
=
1
;
while
(
count
<
limit
&&
M
->
next
)
{
M
=
M
->
next
;
if
(
count
>=
offset
)
{
ML
[
count
-
offset
]
=
M
;
}
count
++
;
}
callback
(
callback_extra
,
1
,
count
-
offset
,
ML
);
tfree
(
ML
,
sizeof
(
void
*
)
*
(
count
)
-
offset
);
}
void
_tgl_do_get_history
(
tgl_peer_id_t
id
,
int
limit
,
int
offset
,
int
list_offset
,
int
list_size
,
struct
tgl_message
*
ML
[],
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
int
size
,
struct
tgl_message
*
list
[]),
void
*
callback_extra
)
{
void
**
T
=
talloc
(
sizeof
(
void
*
)
*
7
);
T
[
0
]
=
ML
;
T
[
1
]
=
(
void
*
)(
long
)
list_offset
;
T
[
2
]
=
(
void
*
)(
long
)
list_size
;
T
[
3
]
=
(
void
*
)(
long
)
tgl_get_peer_id
(
id
);
T
[
4
]
=
(
void
*
)(
long
)
tgl_get_peer_type
(
id
);
T
[
5
]
=
(
void
*
)(
long
)
limit
;
T
[
6
]
=
(
void
*
)(
long
)
offset
;
clear_packet
();
out_int
(
CODE_messages_get_history
);
out_peer_id
(
id
);
out_int
(
0
);
out_int
(
offset
);
out_int
(
0
);
out_int
(
limit
);
tglq_send_query
(
tgl_state
.
DC_working
,
packet_ptr
-
packet_buffer
,
packet_buffer
,
&
get_history_methods
,
(
void
*
)
*
(
long
*
)
&
id
,
callback
,
callback_extra
);
tglq_send_query
(
tgl_state
.
DC_working
,
packet_ptr
-
packet_buffer
,
packet_buffer
,
&
get_history_methods
,
T
,
callback
,
callback_extra
);
}
void
tgl_do_get_history
(
tgl_peer_id_t
id
,
int
limit
,
int
offline_mode
,
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
int
size
,
struct
tgl_message
*
list
[]),
void
*
callback_extra
)
{
if
(
tgl_get_peer_type
(
id
)
==
TGL_PEER_ENCR_CHAT
||
offline_mode
)
{
tgl_do_get_local_history
(
id
,
limit
,
callback
,
callback_extra
);
tgl_do_mark_read
(
id
,
0
,
0
);
return
;
}
_tgl_do_get_history
(
id
,
limit
,
0
,
0
,
0
,
0
,
callback
,
callback_extra
);
}
void
tgl_do_get_history_ext
(
tgl_peer_id_t
id
,
int
offset
,
int
limit
,
int
offline_mode
,
void
(
*
callback
)(
void
*
callback_extra
,
int
success
,
int
size
,
struct
tgl_message
*
list
[]),
void
*
callback_extra
)
{
if
(
tgl_get_peer_type
(
id
)
==
TGL_PEER_ENCR_CHAT
||
offline_mode
)
{
tgl_do_get_local_history
(
id
,
limit
,
callback
,
callback_extra
);
tgl_do_mark_read
(
id
,
0
,
0
);
return
;
}
_tgl_do_get_history
(
id
,
limit
,
offset
,
0
,
0
,
0
,
callback
,
callback_extra
);
}
/* }}} */
...
...
test.lua
View file @
8fd26130
...
...
@@ -41,15 +41,6 @@ end
print
(
"HI, this is lua script"
)
function
ok_cb
(
extra
,
success
,
result
)
if
success
then
print
(
"SUCCESS!\n"
)
end
end
function
my_set_chat_photo
(
extra
,
success
,
file
)
if
success
then
chat_set_photo
(
extra
,
file
,
ok_cb
,
false
)
end
end
function
on_msg_receive
(
msg
)
...
...
@@ -60,16 +51,11 @@ function on_msg_receive (msg)
return
end
if
msg
.
media
==
'photo'
and
msg
.
to
.
type
==
'chat'
then
load_photo
(
msg
.
id
,
my_set_chat_photo
,
msg
.
to
.
print_name
)
end
if
(
msg
.
text
==
'ping'
)
then
if
(
msg
.
to
.
id
==
our_id
)
then
print
(
'sending pong to '
..
tostring
(
msg
.
from
.
print_name
))
send_msg
(
msg
.
from
.
print_name
,
'pong'
)
send_msg
(
msg
.
from
.
print_name
,
'pong'
,
ok_cb
,
false
)
else
print
(
'sending pong to '
..
tostring
(
msg
.
to
.
print_name
))
send_msg
(
msg
.
to
.
print_name
,
'pong'
)
send_msg
(
msg
.
to
.
print_name
,
'pong'
,
ok_cb
,
false
)
end
return
end
...
...
@@ -81,8 +67,6 @@ function on_msg_receive (msg)
end
return
end
--vardump (msg)
--print ( "Message # " .. msg.id .. " (flags " .. msg.flags .. ")")
end
function
on_our_id
(
id
)
...
...
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