mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Merge pull request #1884 from profanity-im/refactor-some-stuff
Refactor some internals
This commit is contained in:
commit
d75b263b39
53
src/common.c
53
src/common.c
@ -174,9 +174,12 @@ char*
|
|||||||
str_replace(const char* string, const char* substr,
|
str_replace(const char* string, const char* substr,
|
||||||
const char* replacement)
|
const char* replacement)
|
||||||
{
|
{
|
||||||
char* tok = NULL;
|
const char* head = NULL;
|
||||||
|
const char* tok = NULL;
|
||||||
char* newstr = NULL;
|
char* newstr = NULL;
|
||||||
char* head = NULL;
|
char* wr = NULL;
|
||||||
|
size_t num_substr = 0;
|
||||||
|
size_t len_string, len_substr, len_replacement, len_string_remains, len_newstr;
|
||||||
|
|
||||||
if (string == NULL)
|
if (string == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -184,26 +187,40 @@ str_replace(const char* string, const char* substr,
|
|||||||
if (substr == NULL || replacement == NULL || (strcmp(substr, "") == 0))
|
if (substr == NULL || replacement == NULL || (strcmp(substr, "") == 0))
|
||||||
return strdup(string);
|
return strdup(string);
|
||||||
|
|
||||||
newstr = strdup(string);
|
tok = string;
|
||||||
head = newstr;
|
while ((tok = strstr(tok, substr))) {
|
||||||
|
num_substr++;
|
||||||
|
tok++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (num_substr == 0)
|
||||||
|
return strdup(string);
|
||||||
|
|
||||||
|
len_string = strlen(string);
|
||||||
|
len_substr = strlen(substr);
|
||||||
|
len_replacement = strlen(replacement);
|
||||||
|
len_newstr = len_string - (num_substr * len_substr) + (num_substr * len_replacement);
|
||||||
|
newstr = malloc(len_newstr + 1);
|
||||||
|
if (newstr == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
len_string_remains = len_string;
|
||||||
|
|
||||||
|
head = string;
|
||||||
|
wr = newstr;
|
||||||
|
|
||||||
while ((tok = strstr(head, substr))) {
|
while ((tok = strstr(head, substr))) {
|
||||||
auto_char char* oldstr = newstr;
|
size_t l = tok - head;
|
||||||
newstr = malloc(strlen(oldstr) - strlen(substr) + strlen(replacement) + 1);
|
memcpy(wr, head, l);
|
||||||
|
wr += l;
|
||||||
|
memcpy(wr, replacement, len_replacement);
|
||||||
|
wr += len_replacement;
|
||||||
|
len_string_remains -= len_substr + l;
|
||||||
|
|
||||||
if (newstr == NULL) {
|
head = tok + len_substr;
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
memcpy(newstr, oldstr, tok - oldstr);
|
|
||||||
memcpy(newstr + (tok - oldstr), replacement, strlen(replacement));
|
|
||||||
memcpy(newstr + (tok - oldstr) + strlen(replacement),
|
|
||||||
tok + strlen(substr),
|
|
||||||
strlen(oldstr) - strlen(substr) - (tok - oldstr));
|
|
||||||
memset(newstr + strlen(oldstr) - strlen(substr) + strlen(replacement), 0, 1);
|
|
||||||
|
|
||||||
head = newstr + (tok - oldstr) + strlen(replacement);
|
|
||||||
}
|
}
|
||||||
|
memcpy(wr, head, len_string_remains);
|
||||||
|
newstr[len_newstr] = '\0';
|
||||||
|
|
||||||
return newstr;
|
return newstr;
|
||||||
}
|
}
|
||||||
|
@ -73,14 +73,10 @@ static GList* alert_list;
|
|||||||
void
|
void
|
||||||
cons_debug(const char* const msg, ...)
|
cons_debug(const char* const msg, ...)
|
||||||
{
|
{
|
||||||
ProfWin* console = wins_get_console();
|
|
||||||
if (strcmp(PACKAGE_STATUS, "development") == 0) {
|
if (strcmp(PACKAGE_STATUS, "development") == 0) {
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, msg);
|
va_start(arg, msg);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va(wins_get_console(), THEME_DEFAULT, "-", msg, arg);
|
||||||
g_string_vprintf(fmt_msg, msg, arg);
|
|
||||||
win_println(console, THEME_DEFAULT, "-", "%s", fmt_msg->str);
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -88,25 +84,20 @@ cons_debug(const char* const msg, ...)
|
|||||||
void
|
void
|
||||||
cons_show(const char* const msg, ...)
|
cons_show(const char* const msg, ...)
|
||||||
{
|
{
|
||||||
ProfWin* console = wins_get_console();
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, msg);
|
va_start(arg, msg);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va(wins_get_console(), THEME_DEFAULT, "-", msg, arg);
|
||||||
g_string_vprintf(fmt_msg, msg, arg);
|
|
||||||
win_println(console, THEME_DEFAULT, "-", "%s", fmt_msg->str);
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
cons_show_padded(int pad, const char* const msg, ...)
|
cons_show_padded(int pad, const char* const msg, ...)
|
||||||
{
|
{
|
||||||
ProfWin* console = wins_get_console();
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, msg);
|
va_start(arg, msg);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
GString* fmt_msg = g_string_new(NULL);
|
||||||
g_string_vprintf(fmt_msg, msg, arg);
|
g_string_vprintf(fmt_msg, msg, arg);
|
||||||
win_println_indent(console, pad, "%s", fmt_msg->str);
|
win_println_indent(wins_get_console(), pad, "%s", fmt_msg->str);
|
||||||
g_string_free(fmt_msg, TRUE);
|
g_string_free(fmt_msg, TRUE);
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
@ -393,6 +393,8 @@ void win_print(ProfWin* window, theme_item_t theme_item, const char* show_char,
|
|||||||
void win_println(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, ...);
|
void win_println(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, ...);
|
||||||
void win_println_indent(ProfWin* window, int pad, const char* const message, ...);
|
void win_println_indent(ProfWin* window, int pad, const char* const message, ...);
|
||||||
|
|
||||||
|
void win_println_va(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, va_list arg);
|
||||||
|
|
||||||
void win_append(ProfWin* window, theme_item_t theme_item, const char* const message, ...);
|
void win_append(ProfWin* window, theme_item_t theme_item, const char* const message, ...);
|
||||||
void win_appendln(ProfWin* window, theme_item_t theme_item, const char* const message, ...);
|
void win_appendln(ProfWin* window, theme_item_t theme_item, const char* const message, ...);
|
||||||
|
|
||||||
|
140
src/ui/window.c
140
src/ui/window.c
@ -340,17 +340,17 @@ win_get_title(ProfWin* window)
|
|||||||
|
|
||||||
gboolean show_titlebar_jid = prefs_get_boolean(PREF_TITLEBAR_MUC_TITLE_JID);
|
gboolean show_titlebar_jid = prefs_get_boolean(PREF_TITLEBAR_MUC_TITLE_JID);
|
||||||
gboolean show_titlebar_name = prefs_get_boolean(PREF_TITLEBAR_MUC_TITLE_NAME);
|
gboolean show_titlebar_name = prefs_get_boolean(PREF_TITLEBAR_MUC_TITLE_NAME);
|
||||||
GString* title = g_string_new("");
|
|
||||||
|
|
||||||
if (show_titlebar_name && mucwin->room_name) {
|
if (show_titlebar_name && mucwin->room_name) {
|
||||||
g_string_append(title, mucwin->room_name);
|
if (show_titlebar_jid)
|
||||||
g_string_append(title, " ");
|
return g_strdup_printf("%s %s", mucwin->room_name, mucwin->roomjid);
|
||||||
}
|
else
|
||||||
if (show_titlebar_jid) {
|
return g_strdup(mucwin->room_name);
|
||||||
g_string_append(title, mucwin->roomjid);
|
|
||||||
}
|
}
|
||||||
|
if (show_titlebar_jid)
|
||||||
|
return g_strdup(mucwin->roomjid);
|
||||||
|
|
||||||
return g_string_free(title, FALSE);
|
return g_strdup("");
|
||||||
}
|
}
|
||||||
case WIN_CONFIG:
|
case WIN_CONFIG:
|
||||||
{
|
{
|
||||||
@ -1536,143 +1536,86 @@ win_print_old_history(ProfWin* window, const ProfMessage* const message)
|
|||||||
g_date_time_unref(message->timestamp);
|
g_date_time_unref(message->timestamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
win_print(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, ...)
|
win_println_va_internal(ProfWin* window, theme_item_t theme_item, int pad, int flags, const char* show_char, const char* const message, va_list arg)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
GDateTime* timestamp = g_date_time_new_now_local();
|
||||||
|
|
||||||
va_list arg;
|
auto_gchar gchar* msg = g_strdup_vprintf(message, arg);
|
||||||
va_start(arg, message);
|
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, show_char, 0, timestamp, NO_EOL, theme_item, "", NULL, fmt_msg->str, NULL, NULL);
|
buffer_append(window->layout->buffer, show_char, pad, timestamp, flags, theme_item, "", NULL, msg, NULL, NULL);
|
||||||
_win_print_internal(window, show_char, 0, timestamp, NO_EOL, theme_item, "", fmt_msg->str, NULL);
|
_win_print_internal(window, show_char, pad, timestamp, flags, theme_item, "", msg, NULL);
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
inp_nonblocking(TRUE);
|
||||||
g_date_time_unref(timestamp);
|
g_date_time_unref(timestamp);
|
||||||
|
}
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
void
|
||||||
|
win_print(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, ...)
|
||||||
|
{
|
||||||
|
va_list arg;
|
||||||
|
va_start(arg, message);
|
||||||
|
win_println_va_internal(window, theme_item, 0, NO_EOL, show_char, message, arg);
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
win_println_va(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, va_list arg)
|
||||||
|
{
|
||||||
|
win_println_va_internal(window, theme_item, 0, 0, show_char, message, arg);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_println(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, ...)
|
win_println(ProfWin* window, theme_item_t theme_item, const char* show_char, const char* const message, ...)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
|
||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va_internal(window, theme_item, 0, 0, show_char, message, arg);
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, show_char, 0, timestamp, 0, theme_item, "", NULL, fmt_msg->str, NULL, NULL);
|
|
||||||
_win_print_internal(window, show_char, 0, timestamp, 0, theme_item, "", fmt_msg->str, NULL);
|
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
|
||||||
g_date_time_unref(timestamp);
|
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_println_indent(ProfWin* window, int pad, const char* const message, ...)
|
win_println_indent(ProfWin* window, int pad, const char* const message, ...)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
|
||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va_internal(window, THEME_DEFAULT, pad, 0, "-", message, arg);
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, "-", pad, timestamp, 0, THEME_DEFAULT, "", NULL, fmt_msg->str, NULL, NULL);
|
|
||||||
_win_print_internal(window, "-", pad, timestamp, 0, THEME_DEFAULT, "", fmt_msg->str, NULL);
|
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
|
||||||
g_date_time_unref(timestamp);
|
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_append(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
win_append(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
|
||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va_internal(window, theme_item, 0, NO_DATE | NO_EOL, "-", message, arg);
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, "-", 0, timestamp, NO_DATE | NO_EOL, theme_item, "", NULL, fmt_msg->str, NULL, NULL);
|
|
||||||
_win_print_internal(window, "-", 0, timestamp, NO_DATE | NO_EOL, theme_item, "", fmt_msg->str, NULL);
|
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
|
||||||
g_date_time_unref(timestamp);
|
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_appendln(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
win_appendln(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
|
||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va_internal(window, theme_item, 0, NO_DATE, "-", message, arg);
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, "-", 0, timestamp, NO_DATE, theme_item, "", NULL, fmt_msg->str, NULL, NULL);
|
|
||||||
_win_print_internal(window, "-", 0, timestamp, NO_DATE, theme_item, "", fmt_msg->str, NULL);
|
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
|
||||||
g_date_time_unref(timestamp);
|
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_append_highlight(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
win_append_highlight(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
|
||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va_internal(window, theme_item, 0, NO_DATE | NO_ME | NO_EOL, "-", message, arg);
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, "-", 0, timestamp, NO_DATE | NO_ME | NO_EOL, theme_item, "", NULL, fmt_msg->str, NULL, NULL);
|
|
||||||
_win_print_internal(window, "-", 0, timestamp, NO_DATE | NO_ME | NO_EOL, theme_item, "", fmt_msg->str, NULL);
|
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
|
||||||
g_date_time_unref(timestamp);
|
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_appendln_highlight(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
win_appendln_highlight(ProfWin* window, theme_item_t theme_item, const char* const message, ...)
|
||||||
{
|
{
|
||||||
GDateTime* timestamp = g_date_time_new_now_local();
|
|
||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
win_println_va_internal(window, theme_item, 0, NO_DATE | NO_ME, "-", message, arg);
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, "-", 0, timestamp, NO_DATE | NO_ME, theme_item, "", NULL, fmt_msg->str, NULL, NULL);
|
|
||||||
_win_print_internal(window, "-", 0, timestamp, NO_DATE | NO_ME, theme_item, "", fmt_msg->str, NULL);
|
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
|
||||||
g_date_time_unref(timestamp);
|
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1752,16 +1695,15 @@ _win_printf(ProfWin* window, const char* show_char, int pad_indent, GDateTime* t
|
|||||||
|
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, message);
|
va_start(arg, message);
|
||||||
GString* fmt_msg = g_string_new(NULL);
|
|
||||||
g_string_vprintf(fmt_msg, message, arg);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, show_char, pad_indent, timestamp, flags, theme_item, display_from, from_jid, fmt_msg->str, NULL, message_id);
|
auto_gchar gchar* msg = g_strdup_vprintf(message, arg);
|
||||||
_win_print_internal(window, show_char, pad_indent, timestamp, flags, theme_item, display_from, fmt_msg->str, NULL);
|
|
||||||
|
buffer_append(window->layout->buffer, show_char, pad_indent, timestamp, flags, theme_item, display_from, from_jid, msg, NULL, message_id);
|
||||||
|
_win_print_internal(window, show_char, pad_indent, timestamp, flags, theme_item, display_from, msg, NULL);
|
||||||
|
|
||||||
inp_nonblocking(TRUE);
|
inp_nonblocking(TRUE);
|
||||||
g_date_time_unref(timestamp);
|
g_date_time_unref(timestamp);
|
||||||
|
|
||||||
g_string_free(fmt_msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2221,12 +2163,10 @@ win_command_exec_error(ProfWin* window, const char* const command, const char* c
|
|||||||
assert(window != NULL);
|
assert(window != NULL);
|
||||||
va_list arg;
|
va_list arg;
|
||||||
va_start(arg, error);
|
va_start(arg, error);
|
||||||
GString* msg = g_string_new(NULL);
|
auto_gchar gchar* msg = g_strdup_vprintf(error, arg);
|
||||||
g_string_vprintf(msg, error, arg);
|
|
||||||
|
|
||||||
win_println(window, THEME_ERROR, "!", "Error executing command %s: %s", command, msg->str);
|
win_println(window, THEME_ERROR, "!", "Error executing command %s: %s", command, msg);
|
||||||
|
|
||||||
g_string_free(msg, TRUE);
|
|
||||||
va_end(arg);
|
va_end(arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2306,9 +2246,5 @@ win_quote_autocomplete(ProfWin* window, const char* const input, gboolean previo
|
|||||||
auto_gcharv gchar** parts = g_strsplit(result, "\n", -1);
|
auto_gcharv gchar** parts = g_strsplit(result, "\n", -1);
|
||||||
auto_gchar gchar* quoted_result = g_strjoinv("\n> ", parts);
|
auto_gchar gchar* quoted_result = g_strjoinv("\n> ", parts);
|
||||||
|
|
||||||
GString* replace_with = g_string_new("> ");
|
return g_strdup_printf("> %s\n", quoted_result);
|
||||||
g_string_append(replace_with, quoted_result);
|
|
||||||
g_string_append(replace_with, "\n");
|
|
||||||
|
|
||||||
return g_string_free(replace_with, FALSE);
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user