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
4734c8ba
Commit
4734c8ba
authored
May 05, 2015
by
vvaltman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
some fixes in LUA. some fixes in readline completion
parent
3f22df2a
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
153 additions
and
43 deletions
+153
-43
interface.c
interface.c
+5
-6
lua-tg.c
lua-tg.c
+148
-37
No files found.
interface.c
View file @
4734c8ba
...
@@ -1525,7 +1525,7 @@ char *command_generator (const char *text, int state) {
...
@@ -1525,7 +1525,7 @@ char *command_generator (const char *text, int state) {
command_pos
=
cur_token
;
command_pos
=
cur_token
;
command_len
=
cur_token_len
;
command_len
=
cur_token_len
;
}
else
{
}
else
{
if
(
index
==
-
1
)
{
return
0
;
}
if
(
mode
!=
ca_file_name
&&
mode
!=
ca_file_name_end
&&
index
==
-
1
)
{
return
0
;
}
}
}
if
(
mode
==
ca_none
||
mode
==
ca_string
||
mode
==
ca_string_end
||
mode
==
ca_number
||
mode
==
ca_double
)
{
if
(
mode
==
ca_none
||
mode
==
ca_string
||
mode
==
ca_string_end
||
mode
==
ca_number
||
mode
==
ca_double
)
{
...
@@ -1577,10 +1577,6 @@ char *command_generator (const char *text, int state) {
...
@@ -1577,10 +1577,6 @@ char *command_generator (const char *text, int state) {
}
}
}
}
char
**
complete_text
(
char
*
text
,
int
start
,
int
end
)
{
return
(
char
**
)
rl_completion_matches
(
text
,
command_generator
);
}
int
count
=
1
;
int
count
=
1
;
void
work_modifier
(
const
char
*
s
,
int
l
)
{
void
work_modifier
(
const
char
*
s
,
int
l
)
{
if
(
is_same_word
(
s
,
l
,
"[offline]"
))
{
if
(
is_same_word
(
s
,
l
,
"[offline]"
))
{
...
@@ -3174,7 +3170,10 @@ void play_sound (void) {
...
@@ -3174,7 +3170,10 @@ void play_sound (void) {
void
set_interface_callbacks
(
void
)
{
void
set_interface_callbacks
(
void
)
{
if
(
readline_disabled
)
{
return
;
}
if
(
readline_disabled
)
{
return
;
}
readline_active
=
1
;
readline_active
=
1
;
rl_filename_quote_characters
=
strdup
(
" "
);
rl_basic_word_break_characters
=
strdup
(
" "
);
rl_callback_handler_install
(
get_default_prompt
(),
interpreter
);
rl_callback_handler_install
(
get_default_prompt
(),
interpreter
);
//rl_attempted_completion_function = (void *) complete_text;
rl_completion_entry_function
=
command_generator
;
rl_completion_entry_function
=
command_generator
;
}
}
lua-tg.c
View file @
4734c8ba
...
@@ -244,21 +244,11 @@ void push_media (struct tgl_message_media *M) {
...
@@ -244,21 +244,11 @@ void push_media (struct tgl_message_media *M) {
my_lua_checkstack
(
luaState
,
4
);
my_lua_checkstack
(
luaState
,
4
);
switch
(
M
->
type
)
{
switch
(
M
->
type
)
{
//case tgl_message_media_photo_encr:
case
tgl_message_media_photo
:
case
tgl_message_media_photo
:
lua_newtable
(
luaState
);
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"photo"
);
lua_add_string_field
(
"type"
,
"photo"
);
lua_add_string_field
(
"caption"
,
M
->
caption
);
break
;
break
;
/*case tgl_message_media_video:
case tgl_message_media_video_encr:
lua_newtable (luaState);
lua_add_string_field ("type", "video");
break;
case tgl_message_media_audio:
case tgl_message_media_audio_encr:
lua_newtable (luaState);
lua_add_string_field ("type", "audio");
break;*/
case
tgl_message_media_document
:
case
tgl_message_media_document
:
case
tgl_message_media_document_encr
:
case
tgl_message_media_document_encr
:
lua_newtable
(
luaState
);
lua_newtable
(
luaState
);
...
@@ -282,8 +272,142 @@ void push_media (struct tgl_message_media *M) {
...
@@ -282,8 +272,142 @@ void push_media (struct tgl_message_media *M) {
lua_add_string_field
(
"last_name"
,
M
->
last_name
);
lua_add_string_field
(
"last_name"
,
M
->
last_name
);
lua_add_num_field
(
"user_id"
,
M
->
user_id
);
lua_add_num_field
(
"user_id"
,
M
->
user_id
);
break
;
break
;
case
tgl_message_media_webpage
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"webpage"
);
lua_add_string_field
(
"url"
,
M
->
webpage
->
url
);
lua_add_string_field
(
"title"
,
M
->
webpage
->
title
);
lua_add_string_field
(
"description"
,
M
->
webpage
->
description
);
lua_add_string_field
(
"author"
,
M
->
webpage
->
author
);
break
;
case
tgl_message_media_venue
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"venue"
);
lua_add_num_field
(
"longitude"
,
M
->
venue
.
geo
.
longitude
);
lua_add_num_field
(
"latitude"
,
M
->
venue
.
geo
.
latitude
);
lua_add_string_field
(
"title"
,
M
->
venue
.
title
);
lua_add_string_field
(
"address"
,
M
->
venue
.
address
);
lua_add_string_field
(
"provider"
,
M
->
venue
.
provider
);
lua_add_string_field
(
"venue_id"
,
M
->
venue
.
venue_id
);
break
;
default:
lua_pushstring
(
luaState
,
"???"
);
}
}
void
push_service
(
struct
tgl_message
*
M
)
{
my_lua_checkstack
(
luaState
,
4
);
switch
(
M
->
action
.
type
)
{
case
tgl_message_action_geo_chat_create
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"geo_created"
);
break
;
case
tgl_message_action_geo_chat_checkin
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"geo_checkin"
);
break
;
case
tgl_message_action_chat_create
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_created"
);
lua_add_string_field
(
"title"
,
M
->
action
.
title
);
break
;
case
tgl_message_action_chat_edit_title
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_rename"
);
lua_add_string_field
(
"title"
,
M
->
action
.
title
);
break
;
case
tgl_message_action_chat_edit_photo
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_change_photo"
);
break
;
case
tgl_message_action_chat_delete_photo
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_delete_photo"
);
break
;
case
tgl_message_action_chat_add_user
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_add_user"
);
lua_pushstring
(
luaState
,
"user"
);
push_peer
(
tgl_set_peer_id
(
TGL_PEER_USER
,
M
->
action
.
user
),
tgl_peer_get
(
TLS
,
tgl_set_peer_id
(
TGL_PEER_USER
,
M
->
action
.
user
)));
lua_settable
(
luaState
,
-
3
);
break
;
case
tgl_message_action_chat_add_user_by_link
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_add_user_link"
);
lua_pushstring
(
luaState
,
"link_issuer"
);
push_peer
(
tgl_set_peer_id
(
TGL_PEER_USER
,
M
->
action
.
user
),
tgl_peer_get
(
TLS
,
tgl_set_peer_id
(
TGL_PEER_USER
,
M
->
action
.
user
)));
lua_settable
(
luaState
,
-
3
);
break
;
case
tgl_message_action_chat_delete_user
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"chat_del_user"
);
lua_pushstring
(
luaState
,
"user"
);
push_peer
(
tgl_set_peer_id
(
TGL_PEER_USER
,
M
->
action
.
user
),
tgl_peer_get
(
TLS
,
tgl_set_peer_id
(
TGL_PEER_USER
,
M
->
action
.
user
)));
lua_settable
(
luaState
,
-
3
);
break
;
case
tgl_message_action_set_message_ttl
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"set_ttl"
);
lua_add_num_field
(
"ttl"
,
M
->
action
.
ttl
);
break
;
case
tgl_message_action_read_messages
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"read"
);
lua_add_num_field
(
"count"
,
M
->
action
.
read_cnt
);
break
;
case
tgl_message_action_delete_messages
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"delete"
);
lua_add_num_field
(
"count"
,
M
->
action
.
delete_cnt
);
break
;
case
tgl_message_action_screenshot_messages
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"screenshot"
);
lua_add_num_field
(
"count"
,
M
->
action
.
screenshot_cnt
);
break
;
case
tgl_message_action_flush_history
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"flush"
);
break
;
case
tgl_message_action_resend
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"resend"
);
break
;
case
tgl_message_action_notify_layer
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"set_layer"
);
lua_add_num_field
(
"layer"
,
M
->
action
.
layer
);
break
;
case
tgl_message_action_typing
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"typing"
);
break
;
case
tgl_message_action_noop
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"nop"
);
break
;
case
tgl_message_action_request_key
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"request_rekey"
);
break
;
case
tgl_message_action_accept_key
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"accept_rekey"
);
break
;
case
tgl_message_action_commit_key
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"commit_rekey"
);
break
;
case
tgl_message_action_abort_key
:
lua_newtable
(
luaState
);
lua_add_string_field
(
"type"
,
"abort_rekey"
);
break
;
default:
default:
lua_pushstring
(
luaState
,
"???"
);
lua_pushstring
(
luaState
,
"???"
);
break
;
}
}
}
}
...
@@ -305,6 +429,14 @@ void push_message (struct tgl_message *M) {
...
@@ -305,6 +429,14 @@ void push_message (struct tgl_message *M) {
lua_add_num_field
(
"fwd_date"
,
M
->
fwd_date
);
lua_add_num_field
(
"fwd_date"
,
M
->
fwd_date
);
}
}
if
(
M
->
reply_id
)
{
lua_add_num_field
(
"reply_id"
,
M
->
reply_id
);
}
if
(
M
->
flags
&
TGLMF_MENTION
)
{
lua_add_num_field
(
"mention"
,
1
);
}
lua_pushstring
(
luaState
,
"from"
);
lua_pushstring
(
luaState
,
"from"
);
push_peer
(
M
->
from_id
,
tgl_peer_get
(
TLS
,
M
->
from_id
));
push_peer
(
M
->
from_id
,
tgl_peer_get
(
TLS
,
M
->
from_id
));
...
@@ -341,6 +473,10 @@ void push_message (struct tgl_message *M) {
...
@@ -341,6 +473,10 @@ void push_message (struct tgl_message *M) {
push_media
(
&
M
->
media
);
push_media
(
&
M
->
media
);
lua_settable
(
luaState
,
-
3
);
lua_settable
(
luaState
,
-
3
);
}
}
}
else
{
lua_pushstring
(
luaState
,
"action"
);
push_service
(
M
);
lua_settable
(
luaState
,
-
3
);
}
}
}
}
...
@@ -1459,34 +1595,9 @@ void lua_init (const char *file) {
...
@@ -1459,34 +1595,9 @@ void lua_init (const char *file) {
my_lua_register
(
luaState
,
functions
[
i
].
name
,
universal_from_lua
);
my_lua_register
(
luaState
,
functions
[
i
].
name
,
universal_from_lua
);
i
++
;
i
++
;
}
}
//lua_register (luaState, "fwd_msg", fwd_msg_from_lua);
//lua_register (luaState, "mark_read", mark_read_from_lua);
lua_register
(
luaState
,
"postpone"
,
postpone_from_lua
);
lua_register
(
luaState
,
"postpone"
,
postpone_from_lua
);
lua_register
(
luaState
,
"safe_quit"
,
safe_quit_from_lua
);
lua_register
(
luaState
,
"safe_quit"
,
safe_quit_from_lua
);
//lua_register (luaState, "get_contact_list", get_contacts_from_lua);
/*lua_register (luaState, "get_dialog_list", get_dialog_list_from_lua);
lua_register (luaState, "send_msg", send_msg_from_lua);
lua_register (luaState, "rename_chat", rename_chat_from_lua);
lua_register (luaState, "send_photo", send_photo_from_lua);
lua_register (luaState, "send_video", send_video_from_lua);
lua_register (luaState, "send_audio", send_audio_from_lua);
lua_register (luaState, "send_document", send_document_from_lua);
lua_register (luaState, "send_text", send_text_from_lua);
lua_register (luaState, "chat_set_photo", chat_set_photo_from_lua);
lua_register (luaState, "load_photo", load_photo_from_lua);
lua_register (luaState, "load_video", load_video_from_lua);
lua_register (luaState, "load_video_thumb", load_video_thumb_from_lua);
lua_register (luaState, "load_audio", load_audio_from_lua);
lua_register (luaState, "load_document", load_document_from_lua);
lua_register (luaState, "load_document_thumb", load_document_thumb_from_lua);
lua_register (luaState, "fwd_msg", message_forward_from_lua);
lua_register (luaState, "chat_info", chat_info_from_lua);
lua_register (luaState, "user_info", user_info_from_lua);
lua_register (luaState, "get_history", get_history_from_lua);
lua_register (luaState, "chat_add_user", chat_add_user_from_lua);
lua_register (luaState, "chat_del_user", chat_del_user_from_lua);
lua_register (luaState, "add_contact", add_contact_from_lua);
lua_register (luaState, "rename_contact", rename_contact_from_lua);*/
int
ret
=
luaL_dofile
(
luaState
,
file
);
int
ret
=
luaL_dofile
(
luaState
,
file
);
if
(
ret
)
{
if
(
ret
)
{
...
...
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