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