size_t SourceModBase::FormatArgs(char *buffer, size_t maxlength, const char *fmt, va_list ap) { return UTIL_FormatArgs(buffer, maxlength, fmt, ap); }
void DebugReport::GenerateErrorVA(IPluginContext *ctx, cell_t func_idx, int err, const char *message, va_list ap) { char buffer[512]; UTIL_FormatArgs(buffer, sizeof(buffer), message, ap); const char *plname = g_PluginSys.FindPluginByContext(ctx->GetContext())->GetFilename(); const char *error = g_pSourcePawn2->GetErrorString(err); if (error) { g_Logger.LogError("[SM] Plugin \"%s\" encountered error %d: %s", plname, err, error); } else { g_Logger.LogError("[SM] Plugin \"%s\" encountered unknown error %d", plname, err); } g_Logger.LogError("[SM] %s", buffer); if (func_idx != -1) { if (func_idx & 1) { func_idx >>= 1; sp_public_t *function; if (ctx->GetRuntime()->GetPublicByIndex(func_idx, &function) == SP_ERROR_NONE) { g_Logger.LogError("[SM] Unable to call function \"%s\" due to above error(s).", function->name); } } }
void DebugReport::OnDebugSpew(const char *msg, ...) { va_list ap; char buffer[512]; va_start(ap, msg); UTIL_FormatArgs(buffer, sizeof(buffer), msg, ap); va_end(ap); g_Logger.LogMessage("[SM] %s", buffer); }
void BaseProvider::DisplayWarning(const char *fmt, ...) { va_list ap; char buffer[2048]; va_start(ap, fmt); UTIL_FormatArgs(buffer, sizeof(buffer), fmt, ap); va_end(ap); Warning("%s", buffer); }
void ParseError(const SMCStates *states, const char *message, ...) { va_list ap; char buffer[256]; va_start(ap, message); UTIL_FormatArgs(buffer, sizeof(buffer), message, ap); va_end(ap); if (!m_bFileNameLogged) { g_Logger.LogError("[SM] Parse error(s) detected in file \"%s\":", m_File); m_bFileNameLogged = true; } g_Logger.LogError("[SM] (Line %d): %s", states ? states->line : 0, buffer); }