From 618c038448a0676464aed0d46c962e467c9fc1a9 Mon Sep 17 00:00:00 2001 From: Dmitry-Me Date: Tue, 24 Mar 2015 17:59:24 +0300 Subject: [PATCH] Resolve CID 1288510 --- cli/cppcheckexecutor.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/cli/cppcheckexecutor.cpp b/cli/cppcheckexecutor.cpp index 225900668..76b3bf4a6 100644 --- a/cli/cppcheckexecutor.cpp +++ b/cli/cppcheckexecutor.cpp @@ -596,17 +596,20 @@ static void PrintCallstack(FILE* f, PEXCEPTION_POINTERS ex) static void writeMemoryErrorDetails(FILE* f, PEXCEPTION_POINTERS ex, const char* description) { fputs(description, f); + // Using %p for ULONG_PTR later on, so it must have size identical to size of pointer + // This is not the universally portable solution but good enough for Win32/64 + C_ASSERT(sizeof(void*) == sizeof(ex->ExceptionRecord->ExceptionInformation[1])); switch (ex->ExceptionRecord->ExceptionInformation[0]) { case 0: - fprintf(f, " reading from 0x%x", + fprintf(f, " reading from 0x%p", ex->ExceptionRecord->ExceptionInformation[1]); break; case 1: - fprintf(f, " writing at 0x%x", + fprintf(f, " writing at 0x%p", ex->ExceptionRecord->ExceptionInformation[1]); break; case 8: - fprintf(f, " data execution prevention at 0x%x", + fprintf(f, " data execution prevention at 0x%p", ex->ExceptionRecord->ExceptionInformation[1]); break; default: