graphicsdeviceinterface/directgdiinterface/inc/directgdipanics.inl
changeset 0 5d03bc08d59c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/graphicsdeviceinterface/directgdiinterface/inc/directgdipanics.inl	Tue Feb 02 01:47:50 2010 +0200
@@ -0,0 +1,77 @@
+// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// General inline utility and logging functions for use with DirectGDI.
+// 
+//
+
+/**
+ @file
+ @publishedPartner
+ @prototype
+*/
+
+#ifndef DIRECTGDIPANICS_INL
+#define DIRECTGDIPANICS_INL
+
+#include <e32std.h>
+#include <e32debug.h>
+
+_LIT(KDGDILogFormat, "File %S +%i: %S");
+_LIT(KDGDINonConditionalPanicFormat, "Panic: %S %i.");
+_LIT(KDGDIConditionalPanicFormat, "Panic: %S %i, assert \"%S\" failed.");
+
+namespace DirectGdi
+	{
+
+/**
+Helper function used by the GRAPHICS_LOG_ALWAYS and GRAPHICS_LOGD_ALWAYS macros.
+ */
+inline void Log(const TDesC& aFileName, TInt aLine, const TDesC& aLogMessage)
+	{
+	TBuf<256> buf;
+	buf.Format(KDGDILogFormat, &aFileName, aLine, &aLogMessage);
+	RDebug::Print(buf);
+	}
+
+/**
+Helper function used by GRAPHICS_ASSERT_ALWAYS and GRAPHICS_PANIC_ALWAYS macros
+which allows a panic category and code to be logged.
+ */
+inline void PanicWithDebugLog (
+		const TDesC& aPanicCategory, 
+		TInt aPanicCode,
+		const TDesC& aFileName,
+		TInt aLine,
+		const TDesC* aCondition)
+	{
+	TBuf<256> message;
+
+	if (aCondition)
+		{
+		message.Format(KDGDIConditionalPanicFormat, &aPanicCategory, aPanicCode, aCondition);
+		}
+	else
+		{
+		message.Format(KDGDINonConditionalPanicFormat, &aPanicCategory, aPanicCode);
+		}
+	
+	Log(aFileName, aLine, message);
+
+	User::Panic(aPanicCategory, aPanicCode);
+	}
+	}
+
+#endif // DIRECTGDIPANICS_INL
+
+