VC++ Visual Studio added .hpp files in subdirectory but get "Error: cannot open source file ..." - visual-studio

This is driving me nuts - I've added a number of .hpp files in subdirectories in the root of an existing VC++ projects source directory.
Visual Studio complains "Error: cannot open source file ..." but if I right click on the and select open document, VS can display it.
I've tried:
"Rescan solution" which appears to do nothing.
Adding existing item (both on it's own and with a "filter" - which appears to be a directory?)
Closing the project and VStudio in the vain hope it would eventually discover the directories/files I'd added
VStudio complains it cannot find these files when it is capable of opening them? My question is simply this: "How can I add a directory containing source files to a VC++ project such that the linker/complier can see them?
(disclaimer; i've never used Visual Studio before or many Microsoft products, so am finding this all very alien)

Workaround;
Add the files to a directory outside of the project and then reference those directories in the "Additional Include Directories" in Properties -> Configuration Properties -> C/C++ -> General.
Why I can't add additional directories within the project and have Visual Studio rescan them (like an Eclipse refresh) is beyond me.

Please see the answer at the following question. This answer fixed the problem for me. It has to do with adding $(ProjectDir) in the "C/C++ Include Directory" in the project settings.
"Cannot open include file" error in VS2010
The answer linked above, fixed my issue with not being able to include subdirectory files inside of the project. I hope this helps anyone else having this issue.
Thanks,

first you need to include any header file you'd like to use into your cpp files by #include "path/file.hpp". in your case your probably didn't specify path, e.g. "subdir/file.hpp"

Related

Visual Studio dotted folder

In the Visual Studio (2010) Solution Explorer, what do the dotted "ghost" folders mean? I can still open them up and open contents within them, so how do they differ from the rest of the normal yellow folders? My reason for asking is that currently my project is missing a file that it expects to be in one of the dotted folders, so I was hoping that some insight into exactly what they mean would be helpful.
Thanks!
Also this can refer to a file/folder that is not included in the project. This can be included by right clicking and selecting 'Include In Project'.
It means it is showing you a file or folder that typically would be hidden by Visual Studio. For example, the bin folder isn't something you typically interface with directly - when you build in VS, it adds the files into the bin folder. So, you don't really need to have access to it as it doesn't contain any editable files. However, it does still exist within the directory.

Visual Studio Makefile Project makes extraneous 'obj' folder

I'm using a Makefile project in Visual Studio 2012 express just fine. However, regardless of the Build Command specified, Visual Studio always makes an 'obj' folder containing empty subfolders obj\Win32\Debug and obj\Win32\Release.
To reproduce the problem, simply create a "Visual C++ - General - Makefile Project" and use a DOS command like 'dir' in the Build Command Line. As soon as you build, the empty obj\Win32\Debug folder will show up.
I can simply skip these in my Mercurial ignore file but it'd be nice to find a fix. Anyone know how to make Visual Studio not generate these empty folders?
Found a trick: to set the intermediate output directory on an existing directory. I modified the project file by hand and added this:
<IntermediateOutputPath>$(ProjectDir)</IntermediateOutputPath>
inside the configuration PropertyGroup. I used the project directory, which obviously already exists. No more useless obj directory!
The obj folder represents VS' own metadata about your project for intellisense support and designer support (for WF/WPF apps). For the most part you can ignore the folder completely without issue.
On occasion though this data can become corrupt and cause VS to show invalid Intellisense options and the workflow/WPF designer can cause errors. Closing VS and deleting the obj folder will quickly resolve this though.

How can I tell Visual Studio to exclude folders from the Find in Files?

We use subversion so we have subfolders named _svn in our solution. Doing a Find in Files returns strings from these subfolders.
Is there any way to tell Visual Studio to ignore these files?
From "Find in Files", in "File Types" or "Look at these file types", you can use:
!*\ExcludeFolder\*
Example:
!*\bin\*;!*\obj\*;!*\.*;!*\ExcludeFolder\*
What you can do is to setup a set of folders that will be used for searching. In Find and Replace window, on the right hand side of "Look In" input you have a "Choose Search Folders" option where you can setup those sets of folders.
Just remember to turn off "Include sub folders" options if you have added root project folder.
If you don't have hundreds of folders this solution should work.
Never had an issue with the global find until we moved to Visual Studio 2017 and started with Angular + .net Core applications... (mostly problems with the HUGE node_modules folder being searched)
I found that using the MSBuild exclusion property DefaultItemExcludes is working fine to exclude from global find in Visual studio 2017..
I now by default open up the project file (.csproj) for a new core project in VS2017 and adjust the property as follows to exclude the node_modules (sometimes I add the wwwroot too):
<DefaultItemExcludes>$(DefaultItemExcludes);node_modules\**</DefaultItemExcludes>
See also
https://github.com/dotnet/cli/issues/7525 , there they advise to prepend the folders to exclude and seem to use a forward slash instead of backward slash, like this :
<PropertyGroup>
<DefaultItemExcludes>node_modules/**;$(DefaultItemExcludes)</DefaultItemExcludes>
</PropertyGroup>
Hope this helps anyone experiencing issues with VS2017 global find / search .
I had this problem when moving to Windows 10 using Visual Studio 2015 and TortoiseSVN. Previously the .svn folders were all hidden so did not appear in search results. To solve this I simply went to the folder properties in Windows Explorer and checked the 'Hidden' attribute for the .svn folder. After refreshing the folder view in Visual Studio the .svn folder no longer appeared and is ignored when using Find!
Instead of searching for files in a directory (your solution's directory, in this case), you could limit your search to the files that are part of the project or the solution. Those in the _svn directories will thus be ignored.
I found in Visual Studio 2017 especially when using Angular Cli that the generated javascript files or other build files can be added to your project sometimes unknowingly. This can cause several headaches including adding a bunch of files to the searches and really slowing things down, especially intellisense because it is searching all of the generated files on top of the source files.
The easiest way I have found to correct this is to simply right click on the build folder (i.e. {Project}/dist) and select Exclude from Project. This will remove the folder from the project but the generated contents will still be available for runtime, it is just hidden from the UI.
If you need to still see the files, you can show hidden directories and files by selecting Show all Files or
click on the Icon:
on the top of the Solution Explorer.
Basically you want to exclude all build folders from your project/solution.
I don't think you can set this (after all, you are asking for "Entire Solution" search), but often you can remove the folder from the project / hide the directory in filesystem (for Web Site project type).
If you are not using VS2019 or VS Code (for which the solution has already been found in other answers), as a workaround you can use the search in Far Manager, it supports masks to exclude certain files or folders from the search.

Visual Studio project is placing object files in unrelated project directory. help

I have a visual studio solution that contains a project that builds a joystick handling library. Unfortunately, the output .lib file is placed in an unrelated folder on the drive. It is placed in another project. I noticed that $(TargetDir) is expanding to the unrelated project's path and not the current solutions path. How do I change this? I searched the visual studio project files for any matching path text and nothing turns up so I can't see how it is pointing to the wrong directory.
Ok, I screwed up. The project was pointing to the wrong directory (obviously) :-)

How can I rename a project folder from within Visual Studio?

My current solution for renaming the project folder is:
Remove the project from the solution.
Rename the folder outside Visual Studio.
Re-add the project to the solution.
Is there a better way?
TFS users: If you are using source control that requires you to warn it before your rename files/folders then look at this answer instead which covers the extra steps required.
To rename a project's folder, file (.*proj) and display name in Visual Studio:
Close the solution.
Rename the folder(s) outside Visual Studio. (Rename in TFS if using source control)
Open the solution, ignoring the warnings (answer "no" if asked to load a project from source control).
Go through all the unavailable projects and...
Open the properties window for the project (highlight the project and press Alt+Enter or F4, or right-click > properties).
Set the property 'File Path' to the new location.
If the property is not editable (as in Visual Studio 2012), then open the .sln file directly in another editor such as Notepad++ and update the paths there instead. (You may need to check-out the solution first in TFS, etc.)
Reload the project - right-click > reload project.
Change the display name of the project, by highlighting it and pressing F2, or right-click > rename.
Note: Other suggested solutions that involve removing and then re-adding the project to the solution will break project references.
If you perform these steps then you might also consider renaming the following to match:
Assembly
Default/Root Namespace
Namespace of existing files (use the refactor tools in Visual Studio or ReSharper's inconsistent namespaces tool)
Also consider modifying the values of the following assembly attributes:
AssemblyProductAttribute
AssemblyDescriptionAttribute
AssemblyTitleAttribute
This is straightforward in Visual Studio 2015 (possibly works in older versions)
In Solution Explorer, right click on Main solution → Rename
In Solution Explorer, right click on project (under solution) → Rename
In Solution Explorer, double click, or right click on Properties → goto Application Tab, rename Assembly name and Default namespace to match.
If you wish to also rename the namespace, open one of your class files. Right click the namespace → Rename.... This should search and replace all references to your namespace throughout the project.
Close the project → rename the project folder.
Edit the .sln file in Notepad, and change the path to the csproj, i.e., fu\bar.csproj → bar\bar.csproj.
There is another way doing this, using the *.sol, *csproj files.
Open your solution file.
Search for the *.csproj you would like to change.
It will be like this (relative to the *.sol file):
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Shani.Commands.Impl", "Shani.Commands.Impl\Shani.Commands.Impl.csproj", "{747CFA4B-FC83-419A-858E-5E2DE2B948EE}"
And just change the first part to the new diretory for example:
Impl\Shani.Commands.Impl\Shani.Commands.Impl.csproj
Of course, don't forget to move the whole project to that directory.
Man, have I struggled with this. Unfortunately there isn't a one click solution in Visual Studio, but if you're running Visual Studio 2012 and your project is under source control with Team Foundation Server, here is how I got it to work, while keeping the source history:
(Make sure you read #mjv's comment below, as he notes that you can skip step 5-10)
Make sure you have checked in all changes, so you have no pending changes.
Remove the project from the solution, by right clicking and selecting Remove.
Now, in Windows Explorer, rename the project folder.
Go back to Visual Studio, and in Solution Explorer, right click the solution and choose Add -> Existing project. Select the project file for the project you removed in step 2, which should be located in the renamed folder.
Now the project is back in the solution, but the project doesn't seem to be added to source control. To fix that, open Source Control Explorer.
Find the project folder in Source Control Explorer, that corresponds with the project folder on your disk, that you renamed in step 3.
Rename the folder in Source Control Explorer, so it has the same name as the project folder on disk.
Now take a look at your pending changes. You should have changes to the solution file and a rename operation on the project folder.
Do a rebuild and make sure everything compiles correctly. If you had inter-project references to the project you renamed, you need to add them again to the individual projects that referenced it.
You should be all set now. Go and check everything in.
The above guide worked for me. If it doesn't work for you, try and delete your local solution completely, and remove the folder mapping in your workspace. Restart Visual Studio just in case. Make sure you actually deleted the whole solution from your computer. Now readd the solution mapping to your workspace and get the latest version. Now try the above steps. The same applies if something goes wrong while following the above steps. Just delete your solution locally and get the latest source, and you'll have a clean slate to work with.
If you're still having problems, make sure that you haven't changed anything manually in the solution file, or trying other 'tricks' before trying the above steps. If you have changed something and checked it in, you might want to consider doing a rollback to the point just before you started messing with the renaming of the project.
Of course, you'd also want to rename the project itself, in Solution Explorer. You can do this before the steps above, but in that case, make sure you check in that change before applying the steps above. You can also do it afterwards, but make sure you follow all the steps above first, and check in your changes before trying to rename the project name in Solution Explorer. I don't recommend trying to mix the above steps with a rename of the project name in Solution Explorer. It might work though, but I would recommand doing it in 2 separate changesets.
Currently, no. Well, actually you can click the broken project node and in the properties pane look for the property 'Path', click the small browse icon, and select the new path.
Voilà :)
The simpler solution is the following:
Right-click the project and rename it.
(optional) Open the project’s property settings and modify the assembly name (and optionally the default namespace) to use the new project name.
(optional) Select the namespace name in a source file, right click and select Refactor/Rename to globally rename the namespace to the new project name.
(optional) Open the AssemblyInfo.cs file and change the assembly name to match.
Save and close the solution.
Using Windows Explorer, rename the project folder to the new name.
Open the SLN file in a text editor and find the one reference to the project path and change it to use the new folder name.
There are four needed steps, but seven recommended. At the end of the day though the project is renamed completely. Technically, the folder name for the project doesn’t have to match the project itself, so even that step is optional, but it can be confusing if they don’t match. The same for the assembly and namespace names.
In andersjanmyr's answer it's easier to rename the project first.
Rename the project.
Close the solution (save it).
Rename the folders outside Visual Studio.
Open the solution, ignoring the warnings.
Go through all unavailable projects and set the property 'File Path' to the new location of your project file, i.e. someproject.csproj.
Reload the project.
Also, after those steps are carried out, you might want to rename other references to your old project name.
In project properties, update the Assembly Name and Default Namespace.
This will update the following in the project file...
<RootNamespace>SomeProjectName</RootNamespace>
<AssemblyName>SomeProjectName</AssemblyName>
...and will get rid of the error "Namespace does not correspond to file location, should be: 'SomeProjectName'"
Rename your root namespace (if you have ReSharper right click the Namespace and go Refactor -> Rename).
Change all occurrences of your old project name in AssemblyInfo.cs.
For those using Visual Studio + Git and wanting to keep the file history (works renaming both projects and/or solutions):
Close Visual Studio
In the .gitignore file, duplicate all ignore paths of the project you want to rename with renamed versions of those paths.
Use the Git move command like this:
git mv <old_folder_name> <new_folder_name>
See documentation for additional options: https://git-scm.com/docs/git-mv
In your .sln file: Find the line defining your project and change the folder name in path. The line should look something like:
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "<Project name>", "<path-to-project>\<project>.csproj"
Open Visual Studio, and right click on project → Rename
Afterwards, rename the namespaces.
I read that ReSharper has some options for this. But simple find/replace did the job for me.
Remove old .gitignore paths.
For Visual Studio 2017 you can use my Visual Studio extension:
Download
It will rename the project in:
The project location folder
The solution file
References in other projects
The assembly name, information
The default namespace
I just had to do this myself (using Visual Studio 2010). As some folks have answered, the simplest step seems to be:
Close the Visual Studio project.
Open the .sln file and rename the project directory prefix for each of the .csproj occurrences.
Save the .sln file
Rename the actual project folder directory on your hard drive to match your changes in the .sln file.
Open the .sln (in Visual Studio) and rebuild
Using Visual Studio 2019, I followed below steps to make the project name change successful:
Close the solution
Rename the project folder to match with new project name
Open solution file in notepad++ kind of editor and edit the FilePath with new project name folder
Open the solution and click No if it ask whether you want to open from source control
Right click the project which you want renaming and click Properties then change below:
Change Assembly Name,
Default Assembly namespace and
Assembly information with new name
Open any of the file and move the file to new namespace which will be done by all files
If you have app.config kind of files then make sure to move them also in new namespace
Rebuild it which will work successfully
A proven solution for Visual Studio extension for Data Tools for Business Intelligence (SSDT-BI 2013):
Move the Project folder to its new location (don't rename anything yet)
In Solution Explorer, rename the Project / Solution.
Close (and save) the newly-renamed project.
Rename the project's folder and .sln file.
Use a text editor and open the newly-renamed project solution file (.sln) (I used Notepad++)
In line number 6 you'll see: "Project {fdjfksdjk4387!...} = "OLDPROJECT", "OLDFOLDER\OLDPROJECT.rptproj". Rename everything with the new names used in step 4. (i.e. ... = "NEWPROJECT", "NEWFOLDER\NEWPROJECT.rptproj"... )
That's it!
It was tested 100% and worked flawlessly in my case.
NOTE: I can't confirm if it works under different project templates and other Visual Studio versions. As always, do backup everything beforehand.
What worked for me in Visual Studio 2017:
Close solution in Visual Studio
Rename the directories of projects in the solution.
(push change in source control - Git in my case)
Edit the .sln file in a text editor (outside Visual Studio 2017) changing the name of the directory.
Reopen the solution in Visual Studio
It said something like "re-adding project". I rebuilt everything and everything was good to go.
See item 3 in the linked article.
Close the solution and the IDE.
In Windows Explorer: Change the directory name to the new name.
In Windows Explorer: Open the .sln file with a text editor.
Change the directory name to the new name and save.
Restart the IDE and open the solution from menu File → Recent Files menu if it doesn't start automatically.
Click on the project folder in Solution Explorer and check the path property in the properties at the bottom. It will now be referencing to the new project folder.
It worked for me.
I've had to do this lots of times. It's really useful to be able to repurpose an existing project, but be able to rename text in namespaces, files, and folders (including file / directory names).
Using a recursive find and replace starting at the root folder means the rename doesn't break links to projects in the solution files and project references.
To this end, I have created a project to do just this. The application also makes an effort to ignore version control folders such as .git, .svn and the .vs settings file. More information is in the README.
https://github.com/garethrbrown/vs-project-rename
I am recently working on .Net 6 project with VS2022. and I need to rename my templatemicroservice to my UserMicroservice.
.Net 6 changes most of the things for you. like AssemblyNames and NameSpaces. Also, it changes the ProjectName references in .sln automatically. So, this answer will really help you to rename your service with no hurdles.
So, Steps I followed:
Open the solution in Visual Studio and did these steps:
I renamed my solution by right clicking on it. like, TemplateServiceSolution to UserServiceSolution.
Renamed all the Projects in solution by right clicking on them. like, TemplateService to UserService.
In a specific project, I searched the namespaces like: namespace TemplateService and replaced all by namespace UserService. Do this step in each project. Also relplace using TemplateService to using UserService.
Open your launchsettings.json, and rename anything related to old service, as I had few things in profiles of launchsettings.json.
Just to be sure, please check your startup and program.cs files as well, I didn't have any changes in them.
Closed the solution from Visual Studio and did these steps:
Closed the solution, and opened the File Explorer. Renamed all my project folders from TemplateService to UserService.
Open the .sln in notepad/notepad++, and must change the Folder Structure name. like for a particular project, I should give the correct .csproj paths. as shown in image, I need to rename TemplateService to UserService.
Open the solution in Visual Studio. Most of your Dependencies will be loaded as soon as you Load your solution in Visual Studio Code. and you are ready.
I just solved this problem for myself writing a global dotnet tool (that also takes into account git+history).
Install via
dotnet tool install -g ModernRonin.ProjectRenamer, use with renameproject <oldName> <newName>.
Documentation/Tinkering/PRs at
https://github.com/ModernRonin/ProjectRenamer
This worked well for me in Visual Studio 2019.
Rename the solution, projects in Visual Studio by simply single
clicking on the file names as normal.
Rename the namespaces in Visual Studio.
Rename the desired elements on the main project page (publish location, application, default namespace, whatever). As noted correctly, this does nothing for the folders, but it does rename the project files and keeps everything tied together in Visual Studio.
Close Visual Studio.
Rename the folders.
Open Visual Studio and reply 'no' to getting projects from Source Control.
Delete the unloaded project references.
Add each project back in using Add existing project from Solution. This tied everything together and the project built for me.
Please comment on and correct anything above that does not work.
This is how I renamed my existing project in VS19.
Close the visual studio project
Rename and open the each project folder name on your drive
Rename each .csproj
Open .sln file and rename the project directory prefix for each of the .csproj occurrences.
Open the .sln file in visual studio and rebuild
Update prevoius nameSpace refrence with new one by going through each file or using ReplaceAll
Note: This fix is for Visual Studio 2008, but it should work here.
Using Windows Explorer, rename both the solution folders (the parent folder and the child folder) to the new solution name.
Delete the .sln file located in the parent folder.
In Visual Studio, select menu File ► Open Project.
Drill into the new folder you just renamed and open the .csproj file (located in the child folder).
Right-click the project name and rename it to what you want. (It should be the same name as the folder in step 1.)
Select menu File ► Close Solution. A dialog will ask if you want to save changes to the .sln file. Click Yes.
In the Save File As dialog, point to the newly renamed parent folder and click Save.
(Note: Make sure the .sln file has the same name as the folder. It is not required, but it maintains consistency.)
Done.
I have written a small tool that automates all these steps. It also supports Subversion for now.
Information about current releases can be found at Visual Studio Project Renamer Infos.
The latest releases can now be downloaded from the Visual Studio Project Renamer Download Page.
Feedback is much appreciated.
I often had the same problem of renaming a project in Visual Studio and editing the folder name, project name, and .sln file in order to accomplish that. I just wrote a VBScript script that accomplishes all that. You have to be careful with the strings you choose for replacing.
You just have to put the .vbs file in the same directory as the .sln file of the solution.
' Script parameters'
Solution = "Rename_Visual_Studio_Project" '.sln'
Project = "Rename_Visual_Studio_Project" '.csproj'
NewProject = "SUCCESS"
Const ForReading = 1
Const ForWriting = 2
Set objFso = CreateObject("Scripting.FileSystemObject")
scriptDirr = objFso.GetParentFolderName(wscript.ScriptFullName)
' Rename the all project references in the .sln file'
Set objFile = objFso.OpenTextFile(scriptDirr + "\" + Solution + ".sln", ForReading)
fileText = objFile.ReadAll
newFileText = Replace(fileText, Project, NewProject)
Set objFile = objFSO.OpenTextFile(scriptDirr + "\" + Solution + ".sln", ForWriting)
objFile.WriteLine(newFileText)
objFile.Close
' Rename the .csproj file'
objFso.MoveFile scriptDirr + "\" + Project + "\" + Project + ".csproj", scriptDirr + "\" + Project + "\" + NewProject + ".csproj"
' Rename the folder of the .csproj file'
objFso.MoveFolder scriptDirr + "\" + Project, scriptDirr + "\" + NewProject
Rename the project in the solution and the project folder
Delete the project from the solution
Add the existing project to the solution (your renamed project)
It works for me. TFS will also track the new project.
You cannot rename a folder if your project is currently running
Stop your application Shift+F5
Rename your folder from the Solution Explorer (right-click > rename or F2)
When using TFS, step 2 is actually to rename the folder in source control and then get the latest before reopening the solution.
There's a simpler approach which was tested in Visual Studio 2013 Update 1 and applicable for TFS-connected projects:
Open Visual Studio, but let the solution be closed.
Open Source Explorer and rename the desired folder (the solution will be closed for you if you didn't already close it first).
Right-click on the solution (from Source Explorer also) and select check-in.
Open the solution. You'll be told that there're new projects added. Accept to get the changes.
Remove the project from the solution and add it again, and then check-in.
Check that the internal references are OK.
We recently uploaded a beta of a free Visual Studio extension which does this stuff for you.
Have a look at Visual Studio Gallery: Gallery Download
Well, I did it my way
Close Visual Studio 2012
Rename your subdirectory to the preferred name under .sln
Delete the *.suo file
Open the solution again, and fix any properties of Project(s) loaded to meet the new subdirectory name
Rename the project outside Visual Studio.
Edit your_project_name.sln with a text editor, and rename the path to the new path.
Open .sln in a text editor, and in the following line change <FolderName> to your new folder name
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Ricky", "\.csproj", "{021CC6B0-8CFB-4194-A103-C19AF869D965}"

Resources