views:

2017

answers:

15

Do you have any sugestions of tools to ease the task of understanding C/C++ code? We just inherited a large piece of software written by others and we need to quickly get up to speed on it. Any advice on tools that might simplify this task?

+5  A: 

Personally, I use the debugger. Run through the code and see what its doing, and where its going is the only way.

However, you can run it through some documentation-gneerators which (sometimes) help. A good example is doxygen.

gbjbaanb
+2  A: 

Doxygen will give you class relationship diagrams if you use graphviz, even if you haven't specifically prepared for it.

Douglas Mayle
+4  A: 

Profiling software gives you an idea of which functions have been called.

If you can use Linux, try KCachegrind

Thorsten79
A: 

Doxygen is a free doc-generating tool (similar to Javadoc) that'll also produce relationship graphs as well.

luke
+1  A: 

I personnaly use Visual Studio debugger tools.

It comes with the "Caller Graph" feature which will allow you to visualize stuff in little boxes. Also the Call Stack and the usual watch features are usually all I need

Eric
A: 

Doxygen, the good thing about it is it will let you know hoe ugly/good is your code in terms of cyclic dependency of classes. So you will be forced to re-factor your code, though you may not like it :-)

rptony
+6  A: 

SourceInsight and Understand for C++ are the best tools you can get for c/c++ code analysis including flow charts.

aku
+1  A: 

There's also AspectBrowser which doesn't work very good with Eclipse 3.4.0

+1  A: 

try AQtime, It's a profiling tool that displays all the functions that got called (and the time it took), you can set the start and end points for the analysis. They have a 30 day trial.

rec
AQtime's call graphs are sometimes very illuminating even if you think you know the code.
bk1e
+2  A: 

There are some tools like Egypt http://www.gson.org/egypt/egypt.html that work, but only if you match the expected GCC version used to compile the code and the exact version of the callgraph generator. The same can be said about codeviz http://www.csn.ul.ie/~mel/projects/codeviz/

Other option is valgrind used in cachegrind mode (it generates a type of callgraph that you can follow from kcachegrind program.

OldMan
+1  A: 

I used Borland Together a while back and it did a decent job of generating models from code. I believe it will even generate sequence diagrams from code. Keep in mind if your code is a mess your model will be too. And as I recall it isn't cheap but sometimes you can catch a special.

Craig Tyler
+1  A: 

Rational Quantify also presents a nice call graph.

QBziZ
+3  A: 

KScope, built upon the cscope utility, if you're on linux (KDE). The best thing I ever used (and use all the time) to deleve into some huge piece of unfamiliar code which I have to modify somehow or which API I'm to employ for my needs. Among its features are the cross-reference database, which can be searched in a plenty of ways: you can find all references of a symbol, its global definition, find callers/callees of a function and much more. It even has a built-in IDE and an ability to show a call-graph.

A: 

Doxygen is very good at generating diagrams from code without applying markup, if you turn on the EXTRACT_ALL option. You need GraphViz installed to get diagrams generated with the HAVE_DOT setting. I find having it installed and leaving the DOT_PATH blank works fine on Windows but on OS/X keep having to point directly to the dot tool location.

There's an excellent Code Spelunking article in ACM Queue which talks more about using Doxygen and DTrace.

Andy Dent
A: 

CppDepend could be very useful for this kind of needs, it provides usefule views like dependency graph, DSM and metric view.

CppDepend provides also a CQL language to query code base easily.

Issam