I have a C project which contains two functions with the same name, but each is within a different group/module (@defgroup
).
These functions each compile into a different binary, but I need the documentation to be closely cross-referenced, so I need to refer (@ref
) to these functions (among other places) from each other's module.
When I do simple @ref name-of-the-function
, it always links to the one which resides in file which is earlier in the file tree. How can I link to the other one?
As far as I can see: doxygen's autolinking does not support having multiple functions with the same name.
If there are multiple functions/methods with the same name, doxygen will simply link the first one it finds, as described in the question. The call graphs will also be incorrect. This seems to apply to all languages, not just to C.
This has been reported as a bug multiple times:
The section "Known problems" in doxygen's docs also describes a similar problem:
It is not possible to insert a non-member function f in a class A using the \relates or \relatesalso command, if class A already has a member with name f and the same argument list.
There is some hope; someone proposed a patch to better handle functions with the same name: #4365 getDefs fails to resolve local function names if same global name exist.
This patch implements the following two strategies for resolving duplicated names. First, is the name is defined in current file, use the local name. Secondly try to match the names using the prototype definition.
This would partly solve the problem. Unfortunately, the ticket has seen no activity since 2012...
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With