host, timestamp);
return TRUE;
}
- if (timestamp == ioloop_time && user->timestamp != timestamp) {
+ if (timestamp == ioloop_time && (time_t)user->timestamp != timestamp) {
user_directory_refresh(dir->users, user);
ret = TRUE;
}
static void user_directory_drop_expired(struct user_directory *dir)
{
while (dir->head != NULL &&
- ioloop_time > dir->head->timestamp + dir->timeout_secs)
+ ioloop_time > (time_t)(dir->head->timestamp + dir->timeout_secs))
user_free(dir, dir->head);
}
bool user_directory_user_has_connections(struct user_directory *dir,
struct user *user)
{
- return user->timestamp +
- dir->timeout_secs - MAX_CLOCK_DRIFT_SECS >= ioloop_time;
+ time_t expire_timestamp = user->timestamp + dir->timeout_secs;
+
+ return expire_timestamp - MAX_CLOCK_DRIFT_SECS >= ioloop_time;
}
struct user_directory *user_directory_init(unsigned int timeout_secs)
ret = write(state->notify_fd, cmd, len);
} T_END;
- if (ret != len) {
+ if (ret != (ssize_t)len) {
if (ret < 0)
i_error("write(%s) failed: %m", state->notify_path);
else {