Is it a best practice to commit a .sln file to source control? When is it appropriate or inappropriate to do so?
Update There were several good points made in the answers. Thanks for the responses!
Is it a best practice to commit a .sln file to source control? When is it appropriate or inappropriate to do so?
Update There were several good points made in the answers. Thanks for the responses!
Yes, things you should commit are:
Things you should not commit are:
Regarding other automatically generated files, there is a separate thread.
1) Create a new project in VS
2) Right click on the solution in Solution Explorer, select Add to Source Control
Is the sln added to source control? That's your answer.
I generally agree that solution files should be checked in, however, at the company I work for we have done something different. We have a fairly large repository and developers work on different parts of the system from time to time. To support the way we work we would either have one big solution file or several smaller. Both of these have a few shortcomings and require manual work on the developers part. To avoid this, we have made a plug-in that handles all that.
The plug-in let each developer check out a subset of the source tree to work on simply by selecting the relevant projects from the repository. The plugin then generates a solution file and modifies project files on the fly for the given solution. It also handles references. In other words, all the developer has to do is to select the appropriate projects and then the necessary files are generated/modified. This also allows us to customize various other settings to ensure company standards.
Additionally we use the plug-in to support various check-in policies, which generally prevents users from submitting faulty/non-compliant code to the repository.
Yes - Everything used to generate your product should be in source control.
Yes, you always want to include the .sln file, it includes the links to all the projects that are in the solution.
Under most circumstances, it's a good idea to commit .sln files to source control.
If your .sln files are generated by another tool (such as CMake) then it's probably inappropriate to put them into source control.