examples/PIPS/redirectprintf/src/redirectprintf.c

00001 /*
00002 Copyright (c) 2007-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 */
00029 
00030 // system include
00031 #include <stdio.h>
00032 // GCCE specific header file
00033 //#include <staticlibinit_gcce.h>
00034 
00035 
00036 // Debug message
00037 FILE* fpDebug = NULL;
00038 char* logFileName = "c:\\logs\\trace.txt";
00039 const char* anotherLogFile = "c:\\logs\\newlog.txt";
00040 
00047 int RedirectPrintf(char* aMessagePtr, ...)
00048 {
00049     va_list marker;
00050     int printChar;
00051     if(fpDebug == NULL)
00052     {
00053         fpDebug = freopen(logFileName, "a+", stdout);
00054     }
00055     if(fpDebug != NULL)
00056     {
00057         va_start(marker, aMessagePtr);
00058         printChar = vprintf(aMessagePtr, marker);
00059         va_end(marker);
00060     }
00061     return printChar;
00062 }
00063 
00068 int main(void)
00069 {
00070         int printInt = 10;
00071     // this will print in console
00072     printf("Redirecting printf to - %s\n", logFileName);
00073     // from this statement onwards, printf statement will be redirected to file
00074     printf("You wnt be able to see the message within the \nconsole.\n");
00075     // put this message first. Once RedirectPrintf statement is called, printf statement will be redirect to file.
00076     printf("Press enter to exit.");
00077     RedirectPrintf("Printing something using trace.\n");
00078     if(fpDebug != NULL)
00079     {
00080         printf("printing using printf method.\n");
00081         printf("Printing an integer - %d.\n", printInt);
00082 
00083         printf("Redirecting printf to another file - %s\n", anotherLogFile);
00084         fpDebug = freopen(anotherLogFile, "a+", fpDebug);
00085         if(fpDebug != NULL)
00086         {
00087             printf("Start redirecting printf to - %s\n", anotherLogFile);
00088             printf("Closing the printf stream.\n");
00089             fclose(fpDebug);
00090         }
00091     }
00092     fflush(stdin);
00093     getchar(); // wait for user input before terminate
00094     return 0;
00095 }
00096 
00097 
00098 //End of file

Generated by  doxygen 1.6.2