I\'m using gcov for the first time and I\'m having a problem which is similar to the one reported in this thread. However, I wasn\'t able to solve my problem following the comme
Thank you very much Tony!! That link had the solution. I just changed the optimization from -O2 to -O0 and now the result is:
1: 192: const QString& institutionId(void) const {
1: 193: return m_institution;
-: 194: }
I have to note that to obtain "mymoneyaccount.cpp.gcov" I execute "gcov mymoneyaccount.cpp", but to obtain "mymoneyaccount.h.gcov" I have to execute "gcov mymoneyaccounttest.cpp". Do you know why? Both files include "mymoneyaccount.h".
has coverage information but not what I was expecting.
This is maybe an XY problem, because you think that your program executes in a way you believe but it simply runs totally different.
I will show you a very simple program:
class Example
{
private:
int value;
public:
Example(const Example& in): value(in.value)
{
std::cout << "Here we copy" << std::endl;
}
Example(int _value): value(_value)
{
std::cout << "Runs with default" << std::endl;
}
Example( Example&& in): value( in.value)
{
std::cout << "Moved away" << std::endl;
}
void show()
{
std::cout << "value " << value << std::endl;
}
};
Example GetIt()
{
return Example(2);
}
int main()
{
Example ex(Example(1));
ex.show();
std::cout << "----------------" << std::endl;
Example ex2( GetIt());
ex2.show();
}
The output is:
Runs with default
value 1
Runs with default
value 2
As you can see, there is no copy constructor called as you could expect and also there is no move constructor called. The construction is simply elided! So what do you expect gcov prints out? Simply it prints the call to the direct call to the constructor with int parameter. Nothing else!
You say:
I require to have the full coverage information...
There is simply no way to get more information as the truth!
If your expectation is completely different to what you get from your analyzing tool, check if your assumptions are true. For my expectations the tools gcov and gprof are really good and the instrumentation of code works nearly perfect. But code which will optimized away will not generate any debug/profiling/coverage information. With debug it is not always true, because newer versions of gcc generate some meta information which give a link to the original source code which enables to set breakpoints also if the code is not longer present in the executable. But for elided constructors there is nothing present also while debugging because the program flow is simply changed! No cout
, no call to the constructor and no further information for profiling/coverage. The code is simply not executed and simply not in use. As you can see, the cout
is not called! This simply tells you that the code is "modified" to operate in an other way as you have coded it!
My example shows only one aspect of optimizing! This is only eliding! There are a lot of other optimizing steps and strategies, also with O0
! Remark that my code was compiled with O0
and the copy construction was moved away!
Hints:
If your debug/coverage/profiling looks different to your expectations: Look at the assembly to find out what is really executed and which source lines are involved. You can call objdump to get the source and assembler intermixed for this!
If you scale down your optimizer, keep in mind your program simply runs different code. Results can not be taken without a "intelligent" interpretation. This needs a bit of experience how to deal with such data.
If you are really have a need for "full" information, ask why!
If you think you get not enough information on a program execution path, you should be happy! Normally this exactly tells you, that your execution is shortened a bit by optimzing.
And if you get no profiling information on a single line/method: Simply look at the block which uses/calls this functionality. Mostly the time consumption is as short that further investigation is useless.
I want to complete the answer that I gave to @Klaus.
Both combinations "-O2 -g" and "-O2" gives the following coverage information for this method (I inserted the message only to be sure that the method was being executed in the tests):
-: 192: const QString& institutionId(void) const {
1: 193: std::cout << "Inside institutionId\n";
-: 194: return m_institution;
-: 195: }
That means that the lines 192 and 194 are not considered as executable, but only the cout. The flag -g does not affect the result (at least in this case).
If I build the program using "-O0", the result is:
1: 192: const QString& institutionId(void) const {
1: 193: std::cout << "Inside institutionId\n";
1: 194: return m_institution;
-: 195: }