kernel/eka/include/e32cons.h
changeset 9 96e5fb8b040d
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kernel/eka/include/e32cons.h	Thu Dec 17 09:24:54 2009 +0200
@@ -0,0 +1,243 @@
+// Copyright (c) 1995-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "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:
+// e32\include\e32cons.h
+// 
+//
+
+#ifndef __E32CONS_H__
+#define __E32CONS_H__
+#include <e32base.h>
+#include <e32keys.h>
+//
+
+/**
+@publishedAll
+@released
+
+Defines a default console width that can be used when creating a console.
+
+@see CConsoleBase::Create()
+*/
+const TInt KDefaultConsWidth=78;
+
+/**
+@publishedAll
+@released
+
+Defines a default console height that can be used when creating a console.
+
+@see CConsoleBase::Create()
+*/
+const TInt KDefaultConsHeight=18;
+
+/**
+@publishedAll
+@released
+
+Implies a full size screen console when passed as the width and height
+values when creating a console.
+
+@see CConsoleBase::Create()
+*/
+const TInt KConsFullScreen=-1;
+
+
+/**
+@publishedAll
+@released
+
+Defines a set of text attributes used for consoles that support colour.
+
+@see CColorConsoleBase::SetTextAttribute().
+*/
+enum TTextAttribute
+	{
+	ETextAttributeNormal,  /**< Defines the normal text attribute.   */
+	ETextAttributeBold,    /**< Defines the bold text attribute.     */
+	ETextAttributeInverse, /**< Defines the inverse text attribute.  */
+	ETextAttributeHighlight/**< Defines the highlight text attribute.*/
+	};
+
+
+/**
+@publishedAll
+@released
+
+A base class that defines a console interface.
+*/
+class CConsoleBase : public CBase
+	{
+public:
+	IMPORT_C virtual ~CConsoleBase();
+	IMPORT_C TKeyCode Getch();
+	IMPORT_C void Printf(TRefByValue<const TDesC> aFmt,...);
+	IMPORT_C void SetPos(TInt aX);
+	IMPORT_C void SetPos(TInt aX,TInt aY);
+	IMPORT_C TInt WhereX() const;
+	IMPORT_C TInt WhereY() const;
+// Pure virtual
+
+
+    /**
+    Creates a new console window.
+    
+    @param aTitle The title text for the console.
+                  This should not be longer than 256 characters.
+    @param aSize  The size of the console window.
+    
+    @return KErrNone, if successful; otherwise one of the other
+                      system wide error codes.
+    */
+	virtual TInt Create(const TDesC &aTitle,TSize aSize) =0;
+
+	
+    /**
+    Gets a keystroke from the console window, asynchronously.
+    
+    @param aStatus The request status object.
+    */
+	virtual void Read(TRequestStatus &aStatus) =0;
+	
+	
+	/**
+	Cancels any outstanding request to get a keystroke from the console window.
+	*/
+	virtual void ReadCancel() =0;
+	
+	
+	/**
+	Writes the content of the specified descriptor to the console window.
+	
+	@param aDes Descriptor containing the characters to be written to
+	            the console window.
+	*/
+	virtual void Write(const TDesC &aDes) =0;
+	
+	
+	/**
+	Gets the current cursor position relative to the console window.
+	
+	@return  The current cursor position.
+	*/
+	virtual TPoint CursorPos() const =0;
+	
+	
+	/**
+    Puts the cursor at the absolute position in the window.
+    
+    @param aPoint The cursor position.
+	*/
+	virtual void SetCursorPosAbs(const TPoint &aPoint) =0;
+	
+	
+	/**
+	Puts the cursor at the specified position relative
+	to the current cursor position.
+	
+	@param aPoint The cursor position.
+	*/
+	virtual void SetCursorPosRel(const TPoint &aPoint) =0;
+	
+	
+	/**
+	Sets the percentage height of the cursor.
+	
+    @param aPercentage The percentage height. This is a value from 0 to 100.
+                       If 0 is specified, then no cursor is displayed.
+	*/
+	virtual void SetCursorHeight(TInt aPercentage) =0;
+
+	
+	/**
+	Sets a new console title.
+	
+	@param aTitle The title text for the console.
+                  This should not be longer than 256 characters.
+	*/
+	virtual void SetTitle(const TDesC &aTitle) =0;
+
+	
+	/**
+	Clears the console.
+	*/
+	virtual void ClearScreen() =0;
+	
+	
+	/**
+	Clears the console from the current cursor position to
+	the end of the line.
+	*/
+	virtual void ClearToEndOfLine() =0;
+	
+	
+	/**
+	Gets the size of the console.
+	*/
+	virtual TSize ScreenSize() const =0;
+	
+	
+	/**
+	Gets the current key code value.
+	
+	@return The key code value.
+	*/
+	virtual TKeyCode KeyCode() const =0;
+	
+	/**
+	Gets the current key modifiers.
+	
+	@return The key modifiers.
+	*/
+	virtual TUint KeyModifiers() const =0;
+protected:
+	IMPORT_C CConsoleBase();
+protected:
+	IMPORT_C virtual TInt Extension_(TUint aExtensionId, TAny*& a0, TAny* a1);
+	};
+
+
+class CProxyConsole;
+
+/**
+@publishedAll
+@released
+
+Adds colour support to the basic console interface.
+*/
+class CColorConsoleBase : public CConsoleBase
+	{
+public:
+
+    /**
+    Sets the text attribute as defined by TTextAttribute.
+    
+    @param anAttribute The text attribute to be set.
+    */
+	virtual void SetTextAttribute(TTextAttribute /*anAttribute*/); 
+protected:
+	IMPORT_C virtual TInt Extension_(TUint aExtensionId, TAny*& a0, TAny* a1);
+
+	friend class CProxyConsole;
+	};
+//
+
+/**
+@publishedAll
+@released
+*/
+extern "C" {
+IMPORT_C TAny *NewConsole();
+}
+#endif
+