1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Merge pull request #1570 from xenrox/restore-status

Restore last status string when connecting
This commit is contained in:
Michael Vetter 2021-07-01 16:23:09 +02:00 committed by GitHub
commit 5f9eda9735
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 23 additions and 5 deletions

View File

@ -844,8 +844,6 @@ accounts_set_last_status(const char* const account_name, const char* const value
if (accounts_account_exists(account_name)) {
if (value) {
g_key_file_set_string(accounts, account_name, "presence.laststatus", value);
} else {
g_key_file_remove_key(accounts, account_name, "presence.laststatus", NULL);
}
_save_accounts();
}
@ -952,6 +950,17 @@ accounts_get_login_presence(const char* const account_name)
return result;
}
char*
accounts_get_login_status(const char* const account_name)
{
gchar* setting = g_key_file_get_string(accounts, account_name, "presence.login", NULL);
gchar* status = NULL;
if (g_strcmp0(setting, "last") == 0) {
status = accounts_get_last_status(account_name);
}
return status;
}
static void
_save_accounts(void)
{

View File

@ -76,6 +76,7 @@ void accounts_set_login_presence(const char* const account_name, const char* con
resource_presence_t accounts_get_login_presence(const char* const account_name);
char* accounts_get_last_status(const char* const account_name);
resource_presence_t accounts_get_last_presence(const char* const account_name);
char* accounts_get_login_status(const char* const account_name);
void accounts_set_priority_online(const char* const account_name, const gint value);
void accounts_set_priority_chat(const char* const account_name, const gint value);
void accounts_set_priority_away(const char* const account_name, const gint value);

View File

@ -40,6 +40,7 @@
#include <stdlib.h>
#include <assert.h>
#include "config/accounts.h"
#include "profanity.h"
#include "log.h"
#include "database.h"
@ -166,6 +167,7 @@ sv_ev_roster_received(void)
// send initial presence
resource_presence_t conn_presence = accounts_get_login_presence(account_name);
char* last_activity_str = accounts_get_last_activity(account_name);
char* status_message = accounts_get_login_status(account_name);
if (prefs_get_boolean(PREF_LASTACTIVITY) && last_activity_str) {
GTimeVal lasttv;
@ -177,17 +179,17 @@ sv_ev_roster_received(void)
GTimeSpan diff_micros = g_date_time_difference(nowdt, lastdt);
int diff_secs = (diff_micros / 1000) / 1000;
connection_set_presence_msg(NULL);
connection_set_presence_msg(status_message);
cl_ev_presence_send(conn_presence, diff_secs);
g_date_time_unref(lastdt);
} else {
connection_set_presence_msg(NULL);
connection_set_presence_msg(status_message);
cl_ev_presence_send(conn_presence, 0);
}
g_date_time_unref(nowdt);
} else {
connection_set_presence_msg(NULL);
connection_set_presence_msg(status_message);
cl_ev_presence_send(conn_presence, 0);
}

View File

@ -213,6 +213,12 @@ accounts_get_last_presence(const char* const account_name)
return mock_type(resource_presence_t);
}
char*
accounts_get_login_status(const char* const account_name)
{
return NULL;
}
void
accounts_set_priority_online(const char* const account_name, const gint value)
{