update deps and last seen first seen

This commit is contained in:
Green Sky 2025-01-07 21:30:40 +01:00
parent 0fb985c4f9
commit 3647ff3d54
No known key found for this signature in database
16 changed files with 55 additions and 63 deletions

@ -1 +1 @@
Subproject commit 2401079c1daaa4b8fdae378a8cad8d429c619565 Subproject commit e2917c497c91f91f8febcd1f43e462fad8359305

@ -1 +1 @@
Subproject commit 3e6c857c8ad509a94e5a309a5061c5729fbcc439 Subproject commit e55fb46027f16a1bc078f797ae9fcc7609d15659

@ -1 +1 @@
Subproject commit c5ee5ac3f9f0f9239d8b05be9c2d392f439dfa30 Subproject commit b1becb2128224fe63b7dff2218ecc66e9b92bc5b

@ -1 +1 @@
Subproject commit cd196562aff9b39e11a415bfb7a33f2066bf86c4 Subproject commit 8ad10978b96837eb7949f32ef433c5b37c2aa458

@ -1 +1 @@
Subproject commit 85bbbb0e5a572b61067f3db188f3cfbda0948e7e Subproject commit 6cbcc9463ce3c4344e06d74d7df67175ada83b5f

View File

@ -11,11 +11,6 @@
#include <iostream> #include <iostream>
// fwd
namespace Message {
uint64_t getTimeMS(void);
}
std::optional<TextureEntry> BitsetImageLoader::haveToTexture(TextureUploaderI& tu, BitSet& have, ObjectHandle o) { std::optional<TextureEntry> BitsetImageLoader::haveToTexture(TextureUploaderI& tu, BitSet& have, ObjectHandle o) {
assert(have.size_bits() > 0); assert(have.size_bits() > 0);
@ -50,7 +45,7 @@ std::optional<TextureEntry> BitsetImageLoader::haveToTexture(TextureUploaderI& t
SDL_LockSurface(conv_surf); SDL_LockSurface(conv_surf);
TextureEntry new_entry; TextureEntry new_entry;
new_entry.timestamp_last_rendered = Message::getTimeMS(); new_entry.timestamp_last_rendered = getTimeMS();
new_entry.width = have.size_bits(); new_entry.width = have.size_bits();
new_entry.height = 1; new_entry.height = 1;

View File

@ -2,6 +2,7 @@
#include <solanaceae/contact/components.hpp> #include <solanaceae/contact/components.hpp>
#include <solanaceae/util/utils.hpp> #include <solanaceae/util/utils.hpp>
#include <solanaceae/util/time.hpp>
#include <imgui/imgui.h> #include <imgui/imgui.h>
//#include <imgui/imgui_internal.h> //#include <imgui/imgui_internal.h>
@ -12,6 +13,8 @@
#include "./icons/person.hpp" #include "./icons/person.hpp"
#include "./icons/group.hpp" #include "./icons/group.hpp"
#include <cinttypes>
void renderAvatar( void renderAvatar(
const Theme& th, const Theme& th,
ContactTextureCache& contact_tc, ContactTextureCache& contact_tc,
@ -114,6 +117,22 @@ bool renderContactBig(
ImGui::TextUnformatted("Connection state: unknown"); ImGui::TextUnformatted("Connection state: unknown");
} }
// TODO: better time formatter
const int64_t ts_now = getTimeMS();
if (const auto* cfirst = c.try_get<Contact::Components::FirstSeen>(); cfirst != nullptr) {
ImGui::Text("First seen: %" PRId64 "s ago", (ts_now - int64_t(cfirst->ts))/1000);
}
// TODO: fill with useful values periodically, maybe only show if not online?
//if (const auto* clast = c.try_get<Contact::Components::LastSeen>(); clast != nullptr) {
// ImGui::Text("Last seen: %" PRId64 "s ago", (ts_now - int64_t(clast->ts))/1000);
//}
if (const auto* clasta = c.try_get<Contact::Components::LastActivity>(); clasta != nullptr) {
ImGui::Text("Last Activity: %" PRId64 "s ago", (ts_now - int64_t(clasta->ts))/1000);
}
if ( if (
const auto* slt = c.try_get<Contact::Components::StatusText>(); const auto* slt = c.try_get<Contact::Components::StatusText>();
slt != nullptr && slt != nullptr &&

View File

@ -6,6 +6,8 @@
#include "../image_loader_qoi.hpp" #include "../image_loader_qoi.hpp"
#include "../image_loader_sdl_image.hpp" #include "../image_loader_sdl_image.hpp"
#include <solanaceae/util/time.hpp>
#include <filesystem> #include <filesystem>
#include <solanaceae/file/file2_std.hpp> #include <solanaceae/file/file2_std.hpp>
@ -13,11 +15,6 @@
#include <cmath> #include <cmath>
// fwd
namespace Message {
uint64_t getTimeMS(void);
}
SendImagePopup::SendImagePopup(TextureUploaderI& tu) : _tu(tu) { SendImagePopup::SendImagePopup(TextureUploaderI& tu) : _tu(tu) {
_image_loaders.push_back(std::make_unique<ImageLoaderSDLBMP>()); _image_loaders.push_back(std::make_unique<ImageLoaderSDLBMP>());
_image_loaders.push_back(std::make_unique<ImageLoaderQOI>()); _image_loaders.push_back(std::make_unique<ImageLoaderQOI>());
@ -90,7 +87,7 @@ bool SendImagePopup::load(void) {
} }
assert(preview_image.textures.empty()); assert(preview_image.textures.empty());
preview_image.timestamp_last_rendered = Message::getTimeMS(); preview_image.timestamp_last_rendered = getTimeMS();
preview_image.current_texture = 0; preview_image.current_texture = 0;
for (const auto& [ms, data] : original_image.frames) { for (const auto& [ms, data] : original_image.frames) {
const auto n_t = _tu.upload(data.data(), original_image.width, original_image.height); const auto n_t = _tu.upload(data.data(), original_image.width, original_image.height);
@ -226,7 +223,7 @@ void SendImagePopup::render(float time_delta) {
//const auto TEXT_BASE_WIDTH = ImGui::CalcTextSize("A").x; //const auto TEXT_BASE_WIDTH = ImGui::CalcTextSize("A").x;
const auto TEXT_BASE_HEIGHT = ImGui::GetTextLineHeightWithSpacing(); const auto TEXT_BASE_HEIGHT = ImGui::GetTextLineHeightWithSpacing();
preview_image.doAnimation(Message::getTimeMS()); preview_image.doAnimation(getTimeMS());
time += time_delta; time += time_delta;
time = fmod(time, 1.f); // fract() time = fmod(time, 1.f); // fract()

View File

@ -694,7 +694,7 @@ float ChatGui4::render(float time_delta) {
if (ImGui::BeginItemTooltip()) { if (ImGui::BeginItemTooltip()) {
std::string synced_by_text {"delivery confirmed by:"}; std::string synced_by_text {"delivery confirmed by:"};
const int64_t now_ts_s = int64_t(Message::getTimeMS() / 1000u); const int64_t now_ts_s = int64_t(getTimeMS() / 1000u);
size_t other_contacts {0}; size_t other_contacts {0};
for (const auto& [c, syned_ts] : list) { for (const auto& [c, syned_ts] : list) {
@ -737,7 +737,7 @@ float ChatGui4::render(float time_delta) {
if (ImGui::BeginItemTooltip()) { if (ImGui::BeginItemTooltip()) {
std::string synced_by_text {"read confirmed by:"}; std::string synced_by_text {"read confirmed by:"};
const int64_t now_ts_s = int64_t(Message::getTimeMS() / 1000u); const int64_t now_ts_s = int64_t(getTimeMS() / 1000u);
for (const auto& [c, syned_ts] : list) { for (const auto& [c, syned_ts] : list) {
if (_cr.all_of<Contact::Components::TagSelfStrong>(c)) { if (_cr.all_of<Contact::Components::TagSelfStrong>(c)) {
@ -823,8 +823,8 @@ float ChatGui4::render(float time_delta) {
cg_view.begin.emplace_or_replace<Message::Components::ViewCurserBegin>(cg_view.end); cg_view.begin.emplace_or_replace<Message::Components::ViewCurserBegin>(cg_view.end);
cg_view.end.emplace_or_replace<Message::Components::ViewCurserEnd>(cg_view.begin); cg_view.end.emplace_or_replace<Message::Components::ViewCurserEnd>(cg_view.begin);
cg_view.begin.get_or_emplace<Message::Components::Timestamp>().ts = Message::getTimeMS(); cg_view.begin.get_or_emplace<Message::Components::Timestamp>().ts = getTimeMS();
cg_view.end.get_or_emplace<Message::Components::Timestamp>().ts = Message::getTimeMS(); cg_view.end.get_or_emplace<Message::Components::Timestamp>().ts = getTimeMS();
std::cout << "CG: created view FRONT begin ts\n"; std::cout << "CG: created view FRONT begin ts\n";
_rmm.throwEventConstruct(cg_view.begin); _rmm.throwEventConstruct(cg_view.begin);
@ -1546,7 +1546,7 @@ void ChatGui4::renderMessageExtra(Message3Registry& reg, const Message3 e) {
if (reg.all_of<Message::Components::SyncedBy>(e)) { if (reg.all_of<Message::Components::SyncedBy>(e)) {
std::string synced_by_text {"syncedBy:"}; std::string synced_by_text {"syncedBy:"};
const int64_t now_ts_s = int64_t(Message::getTimeMS() / 1000u); const int64_t now_ts_s = int64_t(getTimeMS() / 1000u);
for (const auto& [c, syned_ts] : reg.get<Message::Components::SyncedBy>(e).ts) { for (const auto& [c, syned_ts] : reg.get<Message::Components::SyncedBy>(e).ts) {
if (_cr.all_of<Contact::Components::TagSelfStrong>(c)) { if (_cr.all_of<Contact::Components::TagSelfStrong>(c)) {
@ -1566,7 +1566,7 @@ void ChatGui4::renderMessageExtra(Message3Registry& reg, const Message3 e) {
// TODO: remove? // TODO: remove?
if (reg.all_of<Message::Components::ReceivedBy>(e)) { if (reg.all_of<Message::Components::ReceivedBy>(e)) {
std::string synced_by_text {"receivedBy:"}; std::string synced_by_text {"receivedBy:"};
const int64_t now_ts_s = int64_t(Message::getTimeMS() / 1000u); const int64_t now_ts_s = int64_t(getTimeMS() / 1000u);
for (const auto& [c, syned_ts] : reg.get<Message::Components::ReceivedBy>(e).ts) { for (const auto& [c, syned_ts] : reg.get<Message::Components::ReceivedBy>(e).ts) {
if (_cr.all_of<Contact::Components::TagSelfStrong>(c)) { if (_cr.all_of<Contact::Components::TagSelfStrong>(c)) {

View File

@ -1,5 +1,7 @@
#include "./debug_video_tap.hpp" #include "./debug_video_tap.hpp"
#include <solanaceae/util/time.hpp>
#include <solanaceae/object_store/object_store.hpp> #include <solanaceae/object_store/object_store.hpp>
#include <entt/entity/entity.hpp> #include <entt/entity/entity.hpp>
@ -24,11 +26,6 @@
#include <iostream> #include <iostream>
// fwd
namespace Message {
uint64_t getTimeMS(void);
}
struct DebugVideoTapSink : public FrameStream2SinkI<SDLVideoFrame> { struct DebugVideoTapSink : public FrameStream2SinkI<SDLVideoFrame> {
TextureUploaderI& _tu; TextureUploaderI& _tu;
@ -102,12 +99,12 @@ struct DebugVideoTestSource : public FrameStream2SourceI<SDLVideoFrame> {
auto* surf = SDL_CreateSurface(960, 720, SDL_PIXELFORMAT_RGBA32); auto* surf = SDL_CreateSurface(960, 720, SDL_PIXELFORMAT_RGBA32);
// color // color
static auto start_time = Message::getTimeMS(); static auto start_time = getTimeMS();
const float time = (Message::getTimeMS() - start_time)/1000.f; const float time = (getTimeMS() - start_time)/1000.f;
SDL_ClearSurface(surf, std::sin(time), std::cos(time), 0.5f, 1.f); SDL_ClearSurface(surf, std::sin(time), std::cos(time), 0.5f, 1.f);
SDLVideoFrame frame{ // non-owning SDLVideoFrame frame{ // non-owning
Message::getTimeMS()*1000, getTimeMS()*1000,
surf, surf,
}; };

View File

@ -18,11 +18,6 @@
#include <iostream> #include <iostream>
// fwd
namespace Message {
uint64_t getTimeMS(void);
}
MessageImageLoader::MessageImageLoader(void) { MessageImageLoader::MessageImageLoader(void) {
_image_loaders.push_back(std::make_unique<ImageLoaderSDLBMP>()); _image_loaders.push_back(std::make_unique<ImageLoaderSDLBMP>());
_image_loaders.push_back(std::make_unique<ImageLoaderQOI>()); _image_loaders.push_back(std::make_unique<ImageLoaderQOI>());
@ -104,7 +99,7 @@ TextureLoaderResult MessageImageLoader::load(TextureUploaderI& tu, Message3Handl
} }
TextureEntry new_entry; TextureEntry new_entry;
new_entry.timestamp_last_rendered = Message::getTimeMS(); new_entry.timestamp_last_rendered = getTimeMS();
new_entry.current_texture = 0; new_entry.current_texture = 0;
for (const auto& [ms, data] : res.frames) { for (const auto& [ms, data] : res.frames) {
const auto n_t = tu.upload(data.data(), res.width, res.height); const auto n_t = tu.upload(data.data(), res.width, res.height);

View File

@ -1,6 +1,5 @@
#include "./texture_cache.hpp" #include "./texture_cache.hpp"
#include <chrono>
#include <array> #include <array>
#include <limits> #include <limits>
@ -24,7 +23,7 @@ int64_t TextureEntry::doAnimation(const int64_t ts_now) {
TextureEntry generateTestAnim(TextureUploaderI& tu) { TextureEntry generateTestAnim(TextureUploaderI& tu) {
TextureEntry new_entry; TextureEntry new_entry;
new_entry.timestamp_last_rendered = Message::getTimeMS(); new_entry.timestamp_last_rendered = getTimeMS();
new_entry.current_texture = 0; new_entry.current_texture = 0;
for (size_t i = 0; i < 4; i++) { for (size_t i = 0; i < 4; i++) {
// hack // hack

View File

@ -5,6 +5,8 @@
#include <entt/container/dense_map.hpp> #include <entt/container/dense_map.hpp>
#include <entt/container/dense_set.hpp> #include <entt/container/dense_set.hpp>
#include <solanaceae/util/time.hpp>
#include <optional> #include <optional>
#include <vector> #include <vector>
#include <cassert> #include <cassert>
@ -81,11 +83,6 @@ struct TextureLoaderResult {
TextureEntry generateTestAnim(TextureUploaderI& tu); TextureEntry generateTestAnim(TextureUploaderI& tu);
// fwd
namespace Message {
uint64_t getTimeMS(void);
}
template<typename TextureType, typename KeyType, class Loader> template<typename TextureType, typename KeyType, class Loader>
struct TextureCache { struct TextureCache {
static_assert( static_assert(
@ -157,7 +154,7 @@ struct TextureCache {
} }
float update(void) { float update(void) {
const uint64_t ts_now = Message::getTimeMS(); const uint64_t ts_now = getTimeMS();
uint64_t ts_min_next = ts_now + ms_before_purge; uint64_t ts_min_next = ts_now + ms_before_purge;
std::vector<KeyType> to_purge; std::vector<KeyType> to_purge;

View File

@ -2,6 +2,7 @@
#include <solanaceae/object_store/object_store.hpp> #include <solanaceae/object_store/object_store.hpp>
#include <solanaceae/tox_contacts/components.hpp> #include <solanaceae/tox_contacts/components.hpp>
#include <solanaceae/util/time.hpp>
#include "./frame_streams/stream_manager.hpp" #include "./frame_streams/stream_manager.hpp"
#include "./frame_streams/audio_stream2.hpp" #include "./frame_streams/audio_stream2.hpp"
@ -16,11 +17,6 @@
#include <iostream> #include <iostream>
// fwd
namespace Message {
uint64_t getTimeMS(void);
} // Message
namespace Components { namespace Components {
struct ToxAVIncomingAV { struct ToxAVIncomingAV {
bool incoming_audio {false}; bool incoming_audio {false};
@ -771,7 +767,7 @@ bool ToxAVVoIPModel::onEvent(const Events::FriendVideoFrame& e) {
// ms -> us // ms -> us
// would be nice if we had been giving this from toxcore // would be nice if we had been giving this from toxcore
// TODO: make more precise // TODO: make more precise
Message::getTimeMS() * 1000, getTimeMS() * 1000,
new_surf new_surf
}); });

View File

@ -16,11 +16,6 @@
#include <cassert> #include <cassert>
#include <vector> #include <vector>
// fwd
namespace Message {
uint64_t getTimeMS(void);
}
ToxAvatarLoader::ToxAvatarLoader(Contact3Registry& cr) : _cr(cr) { ToxAvatarLoader::ToxAvatarLoader(Contact3Registry& cr) : _cr(cr) {
_image_loaders.push_back(std::make_unique<ImageLoaderSDLBMP>()); _image_loaders.push_back(std::make_unique<ImageLoaderSDLBMP>());
_image_loaders.push_back(std::make_unique<ImageLoaderQOI>()); _image_loaders.push_back(std::make_unique<ImageLoaderQOI>());
@ -129,7 +124,7 @@ TextureLoaderResult ToxAvatarLoader::load(TextureUploaderI& tu, Contact3 c) {
const auto& a_m = _cr.get<Contact::Components::AvatarMemory>(c); const auto& a_m = _cr.get<Contact::Components::AvatarMemory>(c);
TextureEntry new_entry; TextureEntry new_entry;
new_entry.timestamp_last_rendered = Message::getTimeMS(); new_entry.timestamp_last_rendered = getTimeMS();
new_entry.current_texture = 0; new_entry.current_texture = 0;
new_entry.width = a_m.width; new_entry.width = a_m.width;
@ -167,7 +162,7 @@ TextureLoaderResult ToxAvatarLoader::load(TextureUploaderI& tu, Contact3 c) {
} }
TextureEntry new_entry; TextureEntry new_entry;
new_entry.timestamp_last_rendered = Message::getTimeMS(); new_entry.timestamp_last_rendered = getTimeMS();
new_entry.current_texture = 0; new_entry.current_texture = 0;
for (const auto& [ms, data] : res.frames) { for (const auto& [ms, data] : res.frames) {
const auto n_t = tu.upload(data.data(), res.width, res.height); const auto n_t = tu.upload(data.data(), res.width, res.height);
@ -210,7 +205,7 @@ TextureLoaderResult ToxAvatarLoader::load(TextureUploaderI& tu, Contact3 c) {
} }
TextureEntry new_entry; TextureEntry new_entry;
new_entry.timestamp_last_rendered = Message::getTimeMS(); new_entry.timestamp_last_rendered = getTimeMS();
new_entry.current_texture = 0; new_entry.current_texture = 0;
const auto n_t = tu.upload(pixels.data(), 5, 5, TextureUploaderI::RGBA, TextureUploaderI::NEAREST); const auto n_t = tu.upload(pixels.data(), 5, 5, TextureUploaderI::RGBA, TextureUploaderI::NEAREST);

View File

@ -1,5 +1,7 @@
#include "./tox_friend_faux_offline_messaging.hpp" #include "./tox_friend_faux_offline_messaging.hpp"
#include <solanaceae/util/time.hpp>
#include <solanaceae/toxcore/tox_interface.hpp> #include <solanaceae/toxcore/tox_interface.hpp>
#include <solanaceae/contact/components.hpp> #include <solanaceae/contact/components.hpp>
@ -43,7 +45,7 @@ float ToxFriendFauxOfflineMessaging::tick(float time_delta) {
_interval_timer = 60.f; _interval_timer = 60.f;
const uint64_t ts_now = Message::getTimeMS(); const uint64_t ts_now = getTimeMS();
// check ALL // check ALL
// for each online tox friend // for each online tox friend
@ -105,7 +107,7 @@ ToxFriendFauxOfflineMessaging::dfmc_Ret ToxFriendFauxOfflineMessaging::doFriendM
return dfmc_Ret::NO_MSG; return dfmc_Ret::NO_MSG;
} }
const uint64_t ts_now = Message::getTimeMS(); const uint64_t ts_now = getTimeMS();
if (!_cr.all_of<Contact::Components::Self>(c)) { if (!_cr.all_of<Contact::Components::Self>(c)) {
return dfmc_Ret::NO_MSG; // error return dfmc_Ret::NO_MSG; // error
@ -220,7 +222,7 @@ bool ToxFriendFauxOfflineMessaging::onToxEvent(const Tox_Event_Friend_Connection
return false; return false;
} }
_cr.emplace_or_replace<Contact::Components::NextSendAttempt>(c, Message::getTimeMS() + uint64_t(_delay_after_cc*1000)); // wait before first message is sent _cr.emplace_or_replace<Contact::Components::NextSendAttempt>(c, getTimeMS() + uint64_t(_delay_after_cc*1000)); // wait before first message is sent
_interval_timer = 0.f; _interval_timer = 0.f;