Author |
Topic |
|
JFD
New Member
Belgium
7 Posts |
Posted - Jun 30 2020 : 03:46:41 AM
|
Hello, There is a long time I'm using visual assist and I would like to use the new functionality "Code Inspection". When I try to inspect my code, I have no results and I can see in REsult window the message "Parsing skipped ...". I'm under VS2010, my code is standard C++ (no /clr, ...) Do you habve an idea of the reason of this "not parsed" file?
JF |
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Jun 30 2020 : 05:27:58 AM
|
What file extensions are you seeing this in?
What happens if you create a new, default C++ solution? I have just created a new, default C++ Win32 console application, and added the following function to the main cpp file:
// redundant parameter
static void testRedundantChecks(void)
{
for(int nScan = 1; nScan < 10; ++nScan)
{
continue; // redundant continue
}
return; // redundant return
} code inspection is picking up 3 issues in this function, as listed by the comments. Do you get the same results on your system? |
zen is the art of being at one with the two'ness |
|
|
JFD
New Member
Belgium
7 Posts |
Posted - Jun 30 2020 : 05:46:22 AM
|
it works in new project, ... , I have advice in code inspection result. It s just in my actual project (a big one 600000 code line) that I have parsing skipped but I don't know why and I don't see how to "force" a parsing |
Edited by - JFD on Jun 30 2020 06:39:16 AM |
|
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Jun 30 2020 : 11:26:05 AM
|
There is no force parse button, the parsing should be happening automatically.
What directory is your main solution located in?
If you go to:
VA Options -> C/C++ Directories
and look at the list of directories, does this directory list overlap with the directories your solution sits in? If VA thinks that your project is a stable system library then it won't attempt to scan for Code Inspection. |
zen is the art of being at one with the two'ness |
|
|
JFD
New Member
Belgium
7 Posts |
Posted - Jul 01 2020 : 01:16:52 AM
|
The directory of the cpp file is not directly in the list, but well his parent (in mode project defined). but the folder of the parent is not in VC++ Directories of the project in VS. I tired to change the platform to custom (and restart VS) but I still have the problem : Parsing Skipped
|
|
|
JFD
New Member
Belgium
7 Posts |
Posted - Jul 01 2020 : 01:20:52 AM
|
I found the solution, the parent folder was in "include Directories", I removed from this list and my file is parsed. Thanks for help |
|
|
JFD
New Member
Belgium
7 Posts |
Posted - Jul 01 2020 : 01:52:00 AM
|
SO now I have an other problem. In mmy solution I have different project in different folder. C:\Pgm\FD1\Project1 C:\Pgm\FD2\Project2 I added in the include dir (from VS) the dir "c:\Pgm", so I'm able to do include "FD2/Project" If I do so, I have the message "Parsing Skipped" in project FD1, because FD1 is in Pgm folder too. I can't use ..\FD2, because it s a very big project so I must use the father in include dir. Do you know a solution to use the parent folder in include but have the parse too? (I tried custom withjout any dir but it doesn't work.) |
|
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Jul 01 2020 : 04:40:19 AM
|
How have you set these include directories?
In the Visual Studio 2010 Project Properties you can set include directories via either:
Project properties -> C/C++ -> General -> Additional Include Directories
which is for general include directories, or
Project properties -> VC++ Directories -> Include Directories
directories listed here will be treated by VA as stable 3rd party library code, so probably not parsed by Code Inspection either. |
zen is the art of being at one with the two'ness |
|
|
JFD
New Member
Belgium
7 Posts |
Posted - Jul 01 2020 : 05:11:14 AM
|
thanks for the information, it works |
|
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Jul 01 2020 : 06:06:35 AM
|
The include directory settings in Visual Studio can be a little confusing, until you know that the include paths are treated slightly differently. I am glad this is now working well for you. |
zen is the art of being at one with the two'ness |
|
|
mintonla
New Member
USA
6 Posts |
Posted - Jan 21 2022 : 10:26:53 AM
|
Piggy-backing on this thread since same issue, and I am not sure if what I am seeing is expected behavior. Running 10.92440.0, VS2019. I'm trying to clean up headers in our public SDK folder. So a project's 'C/C++ properties, Additional Include Directories' includes the root folder of the headers I am cleaning. It is not specified in the VC++ Directories. If a SDK header file is listed in the project's file list, then I can parse the file. If not, I can't parse the file (get 'Parsing skipped' message). This is true for both automatic and manual reparsing. It seems like, especially for manual reparsing, that parsing should occur in this case. Having to move the header files into the project definition just to parse them will be a pretty major pain point. We have more than 1000 header files in the public sdk, and more in the internal private sdk folder. Thanks, Larry |
|
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Jan 24 2022 : 09:55:28 AM
|
Code Inspection is designed not to parse stable include / library header files, since you are not expected to be editing these.
Have you considered opening an IDE instance, not opening your main solution, and instead using Open Folder for the root folder of the SDK you want VA to help you with? |
zen is the art of being at one with the two'ness |
|
|
mintonla
New Member
USA
6 Posts |
Posted - Jan 24 2022 : 5:06:39 PM
|
Yes, I can work around this. Just saying that your definition of 'stable include / library header files' may not always reflect user's definition. Particularly with an explicit manual reparse, if I'm saying to do it it means I want to do it. And until I found this thread, I had no idea why some headers would parse and others wouldn't. It just so happened that the ones that would just happened to be listed in the .vcxproj file. (20 year old proj files tend to be a bit inconsistent [g].) Confusion reigned....
And if I am creating a new header file in my public sdk folder, I most definitely want Code Inspection to be functional. For some of the issues (like adding 'override' keyword), that's one of the primary places the issue will occur.
Larry |
Edited by - mintonla on Jan 24 2022 5:09:45 PM |
|
|
JFD
New Member
Belgium
7 Posts |
Posted - Jan 25 2022 : 02:15:44 AM
|
Yes the definition of stable include was not the same for us too, as exemple, we have a library (dll) with some tools (our toolbox) to work on date, string, ....) that we use in every project. Ok it s stable but we must often add new tools, rewrite, ... so it s not so stable but it s in include directories. For me it s better to have the possibility to include/Exclude folder for the scan and not do it totally automatically.
|
|
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Jan 27 2022 : 11:01:48 AM
|
I have set up a test case, to get a better feel for what is going on here, and so far I am not able to reproduce the problem.
Starting with the folder:
C:\src_2019\code_inspect_library I have:
C:\src_2019\code_inspect_library\cpp_console_code_inspect_library\cpp_console_code_inspect_library.sln
which contains:
C:\src_2019\code_inspect_library\cpp_console_code_inspect_library\cpp_console_code_inspect_library\cpp_console_code_inspect_library.vcxproj
and a single main cpp file. Open the solution, and go into project properties, and I have set:
Project properties -> C/C++ -> General -> Additional Include Directories = ..\..\local_sdk_library;
which points to the folder, and file:
C:\src_2019\code_inspect_library\local_sdk_library\library_one.h
this library header file is not part of the solution. But it is visible and can be included via:
#include "library_one.h"
from a cpp file inside the solution. Alt-G takes me to this library header file, and Code Inspection is active and works normally in this file.
Now if you are talking about files inside directories that are listed in:
VA Options -> C/C++ Directories
then these are not parsed by Code Inspection, by design. We are expecting to find Windows SDK's, 3rd party libraries like Boost, and similar here. Also, unless you manually trigger a full VA symbol database rebuild, VA doesn't check these files for changes, since they are defined as "stable", and thus not prone to changing.
If I understand correct you have "stable" library's that are not actually stable. Which brings up a separate point, that VA probably won't work as well as normal when editing these files, since we are not expecting you to be editing them. |
zen is the art of being at one with the two'ness |
|
|
mintonla
New Member
USA
6 Posts |
Posted - Jan 27 2022 : 12:42:23 PM
|
In the project you have for case 147740, remove windowstream.h from the list of files specified in the project and try to parse windowstream.h, you will get a 'Parsing skipped'. But interestingly, if you parse the charstream.h or value.h that it includes, those do parse.
Larry |
|
|
feline
Whole Tomato Software
United Kingdom
18931 Posts |
Posted - Feb 07 2022 : 1:22:52 PM
|
Sorry it has taken a while, but I have produced a "minimum" example. This bug requires one of the property sheet files, one #include line in the pch.h file and the copyright character.
I am left guessing that VA ends up thinking this is sort of a library header file, and that this combined with the copyright character is triggering the bug. But this is just how it looks from the simplified test case. Definitely a very "fragile" bug, things have to be just so to trigger it.
case=147806 |
zen is the art of being at one with the two'ness |
|
|
|
Topic |
|