Notes |
|
(0003144)
|
Brad King
|
2005-10-17 10:04
|
|
The lexer was taken with permission from another author who did not include case-insensitive regular expressions. I think the mistake was that flex was not run with the "-i" option to make the lexer case insensitive. I have re-run flex with this additional option and committed the changes:
/cvsroot/CMake/CMake/Source/cmDependsFortranLexer.in.l,v <-- cmDependsFortranLexer.in.l
new revision: 1.5; previous revision: 1.4
/cvsroot/CMake/CMake/Source/cmDependsFortranLexer.cxx,v <-- cmDependsFortranLexer.cxx
new revision: 1.3; previous revision: 1.2
This should address problem #1.
|
|
|
(0003145)
|
Brad King
|
2005-10-17 10:08
|
|
For problem 0000002 the same issue exists in the C and C++ dependency scanners:
#ifdef FOO
# include "foo.h"
#else
# include "bar.h"
#endif
will result in a dependency on both foo.h and bar.h. Fixing this is non-trivial. Does the extra module dependency actually prevent things from building or does it just make them rebuild a little too often?
|
|
|
(0004785)
|
Warren Turkal
|
2006-08-28 19:54
|
|
For fortran90 at least, this problem causes failures in build. Basically, it looks like the generated makefiles don't know how to make the modules that are not supposed to be made. When a source file is erroneously marked as depending on one of those modules, the build fails.
For the first comment, if DVF is defined, you get a module called dflib, and you don't get iolib. If does not get built when DVF is defined, the generated makefiles can fill the presumed dependency of iolib for the source file.
|
|
|
(0010160)
|
Brad King
|
2008-01-15 21:10
|
|
This bug has been fixed by changes described in bug 0005809. |
|