examples/Base/MemMan/Cleanup/LeaveOnFail/LeaveOnFail.cpp

00001 /*
00002 Copyright (c) 2000-2010 Nokia Corporation and/or its subsidiary(-ies). All rights reserved.
00003 
00004 Redistribution and use in source and binary forms, with or without
00005 modification, are permitted provided that the following conditions are met:
00006 
00007 * Redistributions of source code must retain the above copyright notice, this
00008 � list of conditions and the following disclaimer.
00009 * Redistributions in binary form must reproduce the above copyright notice,
00010 � this list of conditions and the following disclaimer in the documentation
00011 � and/or other materials provided with the distribution.
00012 * Neither the name of Nokia Corporation nor the names of its contributors
00013 � may be used to endorse or promote products derived from this software
00014 � without specific prior written permission.
00015 
00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00017 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00018 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00019 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
00020 FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
00021 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
00022 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00023 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00024 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00025 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00026 
00027 Description:�
00028 Example shows attempt to construct an object and leaves on failure. 
00029 NOTE: the structure of this example is different to standard E32 examples 
00030 */
00031 
00032 
00033 
00034 
00035 #include <e32cons.h>
00036 
00037 //
00038 // Common literal text
00039 //
00040 
00041 
00042 _LIT(KCommonFormat1,"Value of iInt is %d.\n");
00043 
00044 
00045   // All messages written to this
00046 LOCAL_D CConsoleBase* console;
00047   
00048   // Flag which determines whether the doSomething() member function
00049   // of the CExample class should leave when called.
00050 LOCAL_D TBool leaveFlag = ETrue;
00051 
00052   // Parameter for __UHEAP_SETFAIL
00053   // Allocation guaranteed to fail at this number of allocation attempts;
00054   // i.e. if set to n, allocation fails on the nth attempt. 
00055   // NB only used in debug mode
00056 #ifdef _DEBUG
00057 LOCAL_D TInt allocFailNumber = 1;
00058 #endif
00059   
00060   // Function prototypes
00061 LOCAL_C void doExampleL();      
00062 LOCAL_C void callExampleL();
00063 
00064 
00066 //
00067 // -----> CExample (definition)
00068 //
00069 // The class is used by the example code
00070 //
00072 class CExample : public CBase
00073         {
00074 public :
00075         void DoSomethingL();
00076 public :
00077         TInt iInt;
00078         };
00079 
00080 
00082 //
00083 // -----> CExample (implementation)
00084 //
00086 void CExample::DoSomethingL() 
00087         {
00088           // Leave if the global flag is set
00089         if (leaveFlag)
00090                 {
00091                 _LIT(KMsgLeaving,"DoSomethingL leaving.\n");
00092                 console->Printf(KMsgLeaving);
00093                 User::Leave(KErrGeneral);               
00094                 }
00095         console->Printf(KCommonFormat1,iInt);
00096         }
00097 
00099 //
00100 // Main function called by E32
00101 //
00103 GLDEF_C TInt E32Main()
00104     {
00105           // Get cleanup stack
00106         CTrapCleanup* cleanup=CTrapCleanup::New();
00107 
00108           // Some more initialization, then do the example
00109         TRAPD(error,callExampleL());
00110           
00111           // callExampleL() should never leave.
00112         _LIT(KMsgPanicEpoc32ex,"EPOC32EX");
00113         __ASSERT_ALWAYS(!error,User::Panic(KMsgPanicEpoc32ex,error));
00114 
00115           // destroy the cleanup stack
00116         delete cleanup;
00117         
00118           // return
00119         return 0;
00120     }
00121 
00122 
00124 //
00125 //
00126 //
00128 LOCAL_C void callExampleL() 
00129     {
00130           // Initialize and call the example code under cleanup stack.
00131         _LIT(KMsgExampleCode,"Symbian platform Example Code");
00132         console = Console::NewL(KMsgExampleCode,TSize(KConsFullScreen,KConsFullScreen));
00133           // Put console onto the cleanup stack.
00134         CleanupStack::PushL(console);
00135 
00136           // Perform the example function under the protection of a 
00137           // TRAP harness.
00138         TRAPD(error,doExampleL());
00139         _LIT(KFormat2,"failed: leave code = %d");
00140         _LIT(KMsgOK,"ok");
00141         if (error)
00142                 console->Printf(KFormat2,error);
00143         else
00144                 console->Printf(KMsgOK);
00145           
00146           // Continue
00147         _LIT(KMsgPressAnyKey," [press any key]");
00148         console->Printf(KMsgPressAnyKey);
00149         console->Getch();
00150 
00151           // Remove the console object from the cleanupstack
00152           // and destroy it. 
00153         CleanupStack::PopAndDestroy();
00154     }
00155 
00156 
00158 //
00159 // Do the example
00160 //
00162 void doExampleL()
00163         {
00164           // Memory alloc fails on the 'allocFailNumber' attempt. 
00165         __UHEAP_SETFAIL(RHeap::EDeterministic,allocFailNumber);
00166           // Allocate - leave if allocation fails.
00167           // Leave is used in place of return to indicate an error.
00168           //
00169           // Could also use - User::LeaveIfNull(myExample);
00170         CExample* myExample = new CExample;
00171         if (!myExample) User::Leave(KErrNoMemory); 
00172           // Do something with the CExample object
00173         myExample->iInt = 5;
00174           //
00175         console->Printf(KCommonFormat1,myExample->iInt);
00176           // Delete the CExample object
00177         delete myExample;
00178         }
00179 
00180 
00181 
00182 
00183 
00184 
00185 
00186 

Generated by  doxygen 1.6.2