|  |  | 
 
 
                  
                     | 
                           
                              | 
                                    
                                       | Classification: | C++ | Category: | Development |  
                                       | Created: | 09/01/2000 | Modified: | 09/12/2001 |  
                                       | Number: | FAQ-0673 |  
                                       | Platform: | Not Applicable |  |  Question:
 Visual C++ comes with profiling tools - can I use these tools with the WINS emulator to check the coverage of my test
 programs?
 
 Answer:
 You need to use the MSVC++ PREP program (see the MSDN documentation for details). One major limitation is that profiling of
                           dynamically loaded DLLs will be wrong if the DLL is loaded, released and loaded again, so you should probably consider profiling
                           simple test programs rather than EPOC.EXE
 
 The sequence of operations is fairly easy:
 cd \epoc32\release\wins\udeb
 prep /LV testprog.exe interesting.dll [interesting2.dll ...]
 profile testprog
 prep /M testprog
 This produces "testprog.pbt" which contains the result of the profiling run(s), and would be repeated for all of the test
                        programs you are interested in.
 
 Another limitation of the system is that PREP can only combine profile output from multiple runs if the same executable is
                        used each time. For a DLL with a wide range of functions (e.g. ESTLIB.DLL or GSMBSC.TSY) this means that the coverage report
                        can only be generated for each separate test program, and can't be directly combined to produce an overall figure.
 
 This could be fixed by combining the PLIST output from each separate test to report lines covered in the DLL by any of the
                        tests. This could be achieved using a Perl script, for example.
 
 The best form of plist output for this would be "plist /t /f", which looks like
 0 168 Microsoft 32-bit PLIST Version 1.00
 1 324 Profile: Line coverage, sorted by line
 3 1273 7917 1273
 4 2000 Jun 05 15:25 tmisc
 7 tmisc.exe \stdlib\tstlib\tmisc.c 23 1
 7 tmisc.exe \stdlib\tstlib\tmisc.c 27 1
 7 tmisc.exe \stdlib\tstlib\tmisc.c 29 1
 ...
 7 estlib.dll \e32\include\k32addr.h 81 1
 7 estlib.dll \stdlib\lstdio\wsetup.c 37 1
 7 estlib.dll \stdlib\lstdio\wsetup.c 46 1
 7 estlib.dll \stdlib\lstdio\wsetup.c 48 0
 7 estlib.dll \stdlib\lstdio\wsetup.c 49 0
 7 estlib.dll \stdlib\lstdio\wsetup.c 50 0
 The "7" lines are coverage records, and the 0 or 1 at the end of the line indicates if the line has been hit. The Perl script
                        would have to accumulate this information updating the 0s with 1s, then display the information nicely along the lines of
                        the normal plist output, or as a coverage % for each source file in the relevant modules.
 
 It only works if the relevant executable has been compiled for debugging, so it would only apply to \epoc32\release\wins\udeb\
 |  
                     |  |  |