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

Handling paused status

This commit is contained in:
James Booth 2012-10-31 23:08:26 +00:00
parent 81dd0a1556
commit 5792cd597d
5 changed files with 95 additions and 4 deletions

View File

@ -28,6 +28,7 @@
#include "chat_session.h" #include "chat_session.h"
#include "log.h" #include "log.h"
#define PAUSED_TIMOUT 10.0
#define INACTIVE_TIMOUT 120.0 #define INACTIVE_TIMOUT 120.0
#define GONE_TIMOUT 600.0 #define GONE_TIMOUT 600.0
@ -38,6 +39,8 @@ static void _chat_session_free(ChatSession session);
typedef enum { typedef enum {
CHAT_STATE_STARTED, CHAT_STATE_STARTED,
CHAT_STATE_ACTIVE, CHAT_STATE_ACTIVE,
CHAT_STATE_PAUSED,
CHAT_STATE_COMPOSING,
CHAT_STATE_INACTIVE, CHAT_STATE_INACTIVE,
CHAT_STATE_GONE CHAT_STATE_GONE
} chat_state_t; } chat_state_t;
@ -85,14 +88,17 @@ chat_session_start(const char * const recipient, gboolean recipient_supports)
} }
void void
chat_session_set_active(const char * const recipient) chat_session_set_composing(const char * const recipient)
{ {
ChatSession session = g_hash_table_lookup(sessions, recipient); ChatSession session = g_hash_table_lookup(sessions, recipient);
if (session == NULL) { if (session == NULL) {
log_error("No chat session found for %s.", recipient); log_error("No chat session found for %s.", recipient);
} else { } else {
session->state = CHAT_STATE_ACTIVE; if (session->state != CHAT_STATE_COMPOSING) {
session->sent = FALSE;
}
session->state = CHAT_STATE_COMPOSING;
g_timer_start(session->active_timer); g_timer_start(session->active_timer);
} }
} }
@ -118,6 +124,11 @@ chat_session_no_activity(const char * const recipient)
session->sent = FALSE; session->sent = FALSE;
} }
session->state = CHAT_STATE_INACTIVE; session->state = CHAT_STATE_INACTIVE;
} else if (elapsed > PAUSED_TIMOUT) {
if (session->state != CHAT_STATE_PAUSED) {
session->sent = FALSE;
}
session->state = CHAT_STATE_PAUSED;
} }
} }
} }
@ -167,6 +178,32 @@ chat_session_inactive(const char * const recipient)
} }
} }
void
chat_session_set_active(const char * const recipient)
{
ChatSession session = g_hash_table_lookup(sessions, recipient);
if (session == NULL) {
log_error("No chat session found for %s.", recipient);
} else {
session->state = CHAT_STATE_ACTIVE;
session->sent = FALSE;
}
}
gboolean
chat_session_paused(const char * const recipient)
{
ChatSession session = g_hash_table_lookup(sessions, recipient);
if (session == NULL) {
log_error("No chat session found for %s.", recipient);
return FALSE;
} else {
return (session->state == CHAT_STATE_PAUSED);
}
}
gboolean gboolean
chat_session_gone(const char * const recipient) chat_session_gone(const char * const recipient)
{ {

View File

@ -37,9 +37,11 @@ gboolean chat_session_get_recipient_supports(const char * const recipient);
void chat_session_set_recipient_supports(const char * const recipient, void chat_session_set_recipient_supports(const char * const recipient,
gboolean recipient_supports); gboolean recipient_supports);
void chat_session_set_active(const char * const recipient); void chat_session_set_composing(const char * const recipient);
void chat_session_no_activity(const char * const recipient); void chat_session_no_activity(const char * const recipient);
gboolean chat_session_inactive(const char * const recipient); gboolean chat_session_inactive(const char * const recipient);
void chat_session_set_active(const char * const recipient);
gboolean chat_session_paused(const char * const recipient);
gboolean chat_session_gone(const char * const recipient); gboolean chat_session_gone(const char * const recipient);
void chat_session_set_sent(const char * const recipient); void chat_session_set_sent(const char * const recipient);
gboolean chat_session_get_sent(const char * const recipient); gboolean chat_session_get_sent(const char * const recipient);

View File

@ -152,6 +152,9 @@ inp_get_char(int *ch, char *input, int *size)
} else if (chat_session_inactive(recipient) && } else if (chat_session_inactive(recipient) &&
!chat_session_get_sent(recipient)) { !chat_session_get_sent(recipient)) {
jabber_send_inactive(recipient); jabber_send_inactive(recipient);
} else if (chat_session_paused(recipient) &&
!chat_session_get_sent(recipient)) {
jabber_send_paused(recipient);
} }
} }
} }
@ -160,7 +163,11 @@ inp_get_char(int *ch, char *input, int *size)
if (*ch != ERR) { if (*ch != ERR) {
if (win_in_chat()) { if (win_in_chat()) {
char *recipient = win_get_recipient(); char *recipient = win_get_recipient();
chat_session_set_active(recipient); chat_session_set_composing(recipient);
if (!chat_session_get_sent(recipient) ||
chat_session_paused(recipient)) {
jabber_send_composing(recipient);
}
} }
} }
} }

View File

@ -164,6 +164,7 @@ jabber_send(const char * const msg, const char * const recipient)
// always send <active/> with messages when recipient supports chat states // always send <active/> with messages when recipient supports chat states
if (chat_session_get_recipient_supports(recipient)) { if (chat_session_get_recipient_supports(recipient)) {
chat_session_set_active(recipient);
active = xmpp_stanza_new(jabber_conn.ctx); active = xmpp_stanza_new(jabber_conn.ctx);
xmpp_stanza_set_name(active, "active"); xmpp_stanza_set_name(active, "active");
xmpp_stanza_set_ns(active, "http://jabber.org/protocol/chatstates"); xmpp_stanza_set_ns(active, "http://jabber.org/protocol/chatstates");
@ -202,6 +203,48 @@ jabber_send_inactive(const char * const recipient)
chat_session_set_sent(recipient); chat_session_set_sent(recipient);
} }
void
jabber_send_composing(const char * const recipient)
{
xmpp_stanza_t *message, *composing;
message = xmpp_stanza_new(jabber_conn.ctx);
xmpp_stanza_set_name(message, "message");
xmpp_stanza_set_type(message, "chat");
xmpp_stanza_set_attribute(message, "to", recipient);
composing = xmpp_stanza_new(jabber_conn.ctx);
xmpp_stanza_set_name(composing, "composing");
xmpp_stanza_set_ns(composing, "http://jabber.org/protocol/chatstates");
xmpp_stanza_add_child(message, composing);
xmpp_send(jabber_conn.conn, message);
xmpp_stanza_release(message);
chat_session_set_sent(recipient);
}
void
jabber_send_paused(const char * const recipient)
{
xmpp_stanza_t *message, *paused;
message = xmpp_stanza_new(jabber_conn.ctx);
xmpp_stanza_set_name(message, "message");
xmpp_stanza_set_type(message, "chat");
xmpp_stanza_set_attribute(message, "to", recipient);
paused = xmpp_stanza_new(jabber_conn.ctx);
xmpp_stanza_set_name(paused, "paused");
xmpp_stanza_set_ns(paused, "http://jabber.org/protocol/chatstates");
xmpp_stanza_add_child(message, paused);
xmpp_send(jabber_conn.conn, message);
xmpp_stanza_release(message);
chat_session_set_sent(recipient);
}
void void
jabber_send_gone(const char * const recipient) jabber_send_gone(const char * const recipient)
{ {

View File

@ -48,6 +48,8 @@ void jabber_process_events(void);
void jabber_subscribe(const char * const recipient); void jabber_subscribe(const char * const recipient);
void jabber_send(const char * const msg, const char * const recipient); void jabber_send(const char * const msg, const char * const recipient);
void jabber_send_inactive(const char * const recipient); void jabber_send_inactive(const char * const recipient);
void jabber_send_composing(const char * const recipient);
void jabber_send_paused(const char * const recipient);
void jabber_send_gone(const char * const recipient); void jabber_send_gone(const char * const recipient);
void jabber_update_presence(jabber_presence_t status, const char * const msg); void jabber_update_presence(jabber_presence_t status, const char * const msg);
const char * jabber_get_jid(void); const char * jabber_get_jid(void);