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:
commit
92dbb1895b
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user