Your userstatus and message are now saved with tox_save().

This commit is contained in:
irungentoo 2014-03-06 15:35:52 -05:00
parent 51393e6222
commit 71284fabf8

View File

@ -2330,6 +2330,8 @@ void wait_cleanup_messenger(Messenger *m, uint8_t *data, uint16_t len)
#define MESSENGER_STATE_TYPE_DHT 2
#define MESSENGER_STATE_TYPE_FRIENDS 3
#define MESSENGER_STATE_TYPE_NAME 4
#define MESSENGER_STATE_TYPE_STATUSMESSAGE 5
#define MESSENGER_STATE_TYPE_STATUS 6
struct SAVED_FRIEND {
uint8_t status;
@ -2421,6 +2423,8 @@ uint32_t messenger_size(Messenger *m)
+ sizesubhead + DHT_size(m->dht) // DHT
+ sizesubhead + saved_friendslist_size(m) // Friendlist itself.
+ sizesubhead + m->name_length // Own nickname.
+ sizesubhead + m->statusmessage_length // status message
+ sizesubhead + 1 // status
;
}
@ -2473,6 +2477,18 @@ void messenger_save(Messenger *m, uint8_t *data)
data = z_state_save_subheader(data, len, type);
memcpy(data, m->name, len);
data += len;
len = m->statusmessage_length;
type = MESSENGER_STATE_TYPE_STATUSMESSAGE;
data = z_state_save_subheader(data, len, type);
memcpy(data, m->statusmessage, len);
data += len;
len = 1;
type = MESSENGER_STATE_TYPE_STATUS;
data = z_state_save_subheader(data, len, type);
*data = m->userstatus;
data += len;
}
static int messenger_load_state_callback_old(void *outer, uint8_t *data, uint32_t length, uint16_t type)
@ -2578,6 +2594,19 @@ static int messenger_load_state_callback(void *outer, uint8_t *data, uint32_t le
break;
case MESSENGER_STATE_TYPE_STATUSMESSAGE:
if ((length > 0) && (length < MAX_STATUSMESSAGE_LENGTH)) {
m_set_statusmessage(m, data, length);
}
break;
case MESSENGER_STATE_TYPE_STATUS:
if (length == 1) {
m_set_userstatus(m, *data);
}
break;
#ifdef DEBUG
default: