I have written a class that will handle internal logging in my application. Now I want to use this c开发者_运维百科lass in another new and totally separate project.
I could simply copy the file to the new project folder, but I would like to only have one copy of it to maintain so that all changes in it will apply to both projects over time.
I can use the "add existing file", but where do I put the file so that the next developer knows that it is required. I have once had a "shared" folder for this but one time that folder was not brought into the next development computer.
What is the best way to organize this so that it makes most sense for new maintainers and minimizes the risk for broken links in projects.
You could create a library project that has this class this way all you have to do is add a reference to that project.
If that is no option you could use "Right click -> add existing item -> Add as link" this way you only have one copy of the code but it can exist in multiple projects.
A class library to share is the best solution.
But you can add a file to a VS project as a link rather than copying. To do this use the drop down on the Add button of the add existing item dialogue.
If you actually need to share the source code, for instance if you have a simultaneous 32-bit and a 64-bit build of the same assembly (which is some times required if you depend on native code), you can use the answer given in this thread: How do you share code between projects/solutions in Visual Studio?
(Look for '"link" a code file between two projects'.)
Break your logging code to a seperate assembly.
You can then include that assembly in the projects that should use that logger.
It keeps everything nice and clean and you'll only have to maintain one set of code rather than having to worry about each copy.
Create a new assembly that contains this class.
Then all your other projects can refer to this assembly and use the class within.
Put the class in a unique namespace, then add the file as a link to all projects you need to use it. Make sure you place a using statement for that unique namespace where you will be using the class, or you will have to fully qualify every use of it. For situations like this, I think this is much preferable than an assemply, since it does not generate needless cross-assemply references, for something that is part of your own code that you just wish to share between your projects.
You can also use use your versioning system to do this.
We usually create Directory with Solution and Main Project and then commit this directory to SVN. Then all shared libraries are linked using svn:external - so all Projects exists in same solution directory.
After commit anyone can checkout working solution with all external dependencies.
精彩评论