mirror of
https://github.com/status-im/status-go.git
synced 2025-02-10 22:06:36 +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.
22 lines
508 B
C
22 lines
508 B
C
#define _GNU_SOURCE
|
|
#include "time32.h"
|
|
#include <time.h>
|
|
#include <sys/time.h>
|
|
#include <sys/timex.h>
|
|
|
|
int __adjtime32(const struct timeval32 *in32, struct timeval32 *out32)
|
|
{
|
|
struct timeval out;
|
|
int r = adjtime((&(struct timeval){
|
|
.tv_sec = in32->tv_sec,
|
|
.tv_usec = in32->tv_usec}), &out);
|
|
if (r) return r;
|
|
/* We can't range-check the result because success was already
|
|
* committed by the above call. */
|
|
if (out32) {
|
|
out32->tv_sec = out.tv_sec;
|
|
out32->tv_usec = out.tv_usec;
|
|
}
|
|
return r;
|
|
}
|