1
0
mirror of https://github.com/irssi/irssi.git synced 2025-01-03 14:56:47 -05:00

Merge pull request #754 from ailin-nemui/fix-752

add new function to set the position in bytes
This commit is contained in:
ailin-nemui 2017-10-05 11:31:44 +02:00 committed by GitHub
commit 92dbb1895b
4 changed files with 24 additions and 5 deletions

View File

@ -6,7 +6,7 @@
#define IRSSI_GLOBAL_CONFIG "irssi.conf" /* config file name in /etc/ */ #define IRSSI_GLOBAL_CONFIG "irssi.conf" /* config file name in /etc/ */
#define IRSSI_HOME_CONFIG "config" /* config file name in ~/.irssi/ */ #define IRSSI_HOME_CONFIG "config" /* config file name in ~/.irssi/ */
#define IRSSI_ABI_VERSION 10 #define IRSSI_ABI_VERSION 11
#define DEFAULT_SERVER_ADD_PORT 6667 #define DEFAULT_SERVER_ADD_PORT 6667
#define DEFAULT_SERVER_ADD_TLS_PORT 6697 #define DEFAULT_SERVER_ADD_TLS_PORT 6697

View File

@ -936,6 +936,26 @@ void gui_entry_set_pos(GUI_ENTRY_REC *entry, int pos)
gui_entry_draw(entry); gui_entry_draw(entry);
} }
void gui_entry_set_text_and_pos_bytes(GUI_ENTRY_REC *entry, const char *str, int pos_bytes)
{
int pos;
const char *ptr;
g_return_if_fail(entry != NULL);
gui_entry_set_text(entry, str);
if (entry->utf8) {
g_utf8_validate(str, pos_bytes, &ptr);
pos = g_utf8_pointer_to_offset(str, ptr);
} else if (term_type == TERM_TYPE_BIG5)
pos = strlen_big5((const unsigned char *)str) - strlen_big5((const unsigned char *)(str + pos_bytes));
else
pos = pos_bytes;
gui_entry_set_pos(entry, pos);
}
void gui_entry_move_pos(GUI_ENTRY_REC *entry, int pos) void gui_entry_move_pos(GUI_ENTRY_REC *entry, int pos)
{ {
g_return_if_fail(entry != NULL); g_return_if_fail(entry != NULL);

View File

@ -50,6 +50,7 @@ void gui_entry_set_utf8(GUI_ENTRY_REC *entry, int utf8);
void gui_entry_set_text(GUI_ENTRY_REC *entry, const char *str); void gui_entry_set_text(GUI_ENTRY_REC *entry, const char *str);
char *gui_entry_get_text(GUI_ENTRY_REC *entry); char *gui_entry_get_text(GUI_ENTRY_REC *entry);
char *gui_entry_get_text_and_pos(GUI_ENTRY_REC *entry, int *pos); char *gui_entry_get_text_and_pos(GUI_ENTRY_REC *entry, int *pos);
void gui_entry_set_text_and_pos_bytes(GUI_ENTRY_REC *entry, const char *str, int pos_bytes);
void gui_entry_insert_text(GUI_ENTRY_REC *entry, const char *str); void gui_entry_insert_text(GUI_ENTRY_REC *entry, const char *str);
void gui_entry_insert_char(GUI_ENTRY_REC *entry, unichar chr); void gui_entry_insert_char(GUI_ENTRY_REC *entry, unichar chr);

View File

@ -878,8 +878,7 @@ static void key_completion(int erase, int backward)
g_free(text); g_free(text);
if (line != NULL) { if (line != NULL) {
gui_entry_set_text(active_entry, line); gui_entry_set_text_and_pos_bytes(active_entry, line, pos);
gui_entry_set_pos(active_entry, pos);
g_free(line); g_free(line);
} }
} }
@ -909,8 +908,7 @@ static void key_check_replaces(void)
g_free(text); g_free(text);
if (line != NULL) { if (line != NULL) {
gui_entry_set_text(active_entry, line); gui_entry_set_text_and_pos_bytes(active_entry, line, pos);
gui_entry_set_pos(active_entry, pos);
g_free(line); g_free(line);
} }
} }