mirror of
https://github.com/robbert-vdh/yabridge.git
synced 2026-05-10 04:30:12 +02:00
Log cached audioMasterGetTime() calls
Just like we log cached VST3 function calls.
This commit is contained in:
@@ -449,7 +449,8 @@ void Vst2Logger::log_event_response(
|
|||||||
int opcode,
|
int opcode,
|
||||||
intptr_t return_value,
|
intptr_t return_value,
|
||||||
const EventResultPayload& payload,
|
const EventResultPayload& payload,
|
||||||
const std::optional<EventResultPayload>& value_payload) {
|
const std::optional<EventResultPayload>& value_payload,
|
||||||
|
bool from_cache) {
|
||||||
if (BOOST_UNLIKELY(logger.verbosity >= Logger::Verbosity::most_events)) {
|
if (BOOST_UNLIKELY(logger.verbosity >= Logger::Verbosity::most_events)) {
|
||||||
if (should_filter_event(is_dispatch, opcode)) {
|
if (should_filter_event(is_dispatch, opcode)) {
|
||||||
return;
|
return;
|
||||||
@@ -516,6 +517,10 @@ void Vst2Logger::log_event_response(
|
|||||||
}},
|
}},
|
||||||
payload);
|
payload);
|
||||||
|
|
||||||
|
if (from_cache) {
|
||||||
|
message << " (from cache)";
|
||||||
|
}
|
||||||
|
|
||||||
log(message.str());
|
log(message.str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -74,7 +74,8 @@ class Vst2Logger {
|
|||||||
int opcode,
|
int opcode,
|
||||||
intptr_t return_value,
|
intptr_t return_value,
|
||||||
const EventResultPayload& payload,
|
const EventResultPayload& payload,
|
||||||
const std::optional<EventResultPayload>& value_payload);
|
const std::optional<EventResultPayload>& value_payload,
|
||||||
|
bool from_cache = false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The underlying logger instance we're wrapping.
|
* The underlying logger instance we're wrapping.
|
||||||
|
|||||||
@@ -607,10 +607,17 @@ intptr_t Vst2Bridge::host_callback(AEffect* effect,
|
|||||||
if (cached_time_info) {
|
if (cached_time_info) {
|
||||||
// This cached value is temporary, so we'll still use the
|
// This cached value is temporary, so we'll still use the
|
||||||
// regular time info storing mechanism
|
// regular time info storing mechanism
|
||||||
// TODO: Log when we hit this cache so it doesn't get hidden
|
|
||||||
last_time_info = *cached_time_info;
|
last_time_info = *cached_time_info;
|
||||||
|
const intptr_t result =
|
||||||
|
reinterpret_cast<intptr_t>(&last_time_info);
|
||||||
|
|
||||||
return reinterpret_cast<intptr_t>(&last_time_info);
|
// Make sure that these cached events don't get lost in the logs
|
||||||
|
logger.log_event(false, opcode, index, value,
|
||||||
|
WantsVstTimeInfo{}, option, std::nullopt);
|
||||||
|
logger.log_event_response(false, opcode, result, last_time_info,
|
||||||
|
std::nullopt, true);
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
} break;
|
} break;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user