mirror of
https://github.com/status-im/status-go.git
synced 2025-01-11 15:14:52 +00:00
e65760ca85
This commit adds basic syncing capabilities with peers if they are both online. It updates the work done on MVDS, but I decided to create the code in status-go instead, since it's very tight to the application (similarly the code that was the inspiration for mvds, bramble, is all tight together at the database level). I reused parts of the protobufs. The flow is: 1) An OFFER message is sent periodically with a bunch of message-ids and group-ids. 2) Anyone can REQUEST some of those messages if not present in their database. 3) The peer will then send over those messages. It's disabled by default, but I am planning to add a way to set up the flags.
26 lines
461 B
C
26 lines
461 B
C
#include "time32.h"
|
|
#include <sys/timeb.h>
|
|
#include <errno.h>
|
|
#include <stdint.h>
|
|
|
|
struct timeb32 {
|
|
int32_t time;
|
|
unsigned short millitm;
|
|
short timezone, dstflag;
|
|
};
|
|
|
|
int __ftime32(struct timeb32 *tp)
|
|
{
|
|
struct timeb tb;
|
|
if (ftime(&tb) < 0) return -1;
|
|
if (tb.time < INT32_MIN || tb.time > INT32_MAX) {
|
|
errno = EOVERFLOW;
|
|
return -1;
|
|
}
|
|
tp->time = tb.time;
|
|
tp->millitm = tb.millitm;
|
|
tp->timezone = tb.timezone;
|
|
tp->dstflag = tb.dstflag;
|
|
return 0;
|
|
}
|