First, a little background.
Currently namespaces and assemblies in our codebase (~60 assemblies, thousands of classes) looks like
WidgetCompany.Department.Something
We have now been spun off such that we are selling the software that drives a WidgetCompany, so we 'd like to rename the namespaces & assemblies
NewCompany.Something
Under normal circumstances I'd probably just stick with the old namespace, but the problem is our customers don't want to see the name of one of their competitors anywhere in the application. In the off chance that they see a stack trace, assembly properties etc, it shouldn't show up. It's not meant to hide our associates or do anything sinister, we just need to make sure that people know we are a separate entity, separate management, and they don't need to worry about data being shared etc.
Now the question. What is the best way to perform this type of all encompassing rename?
The following would need to change:
- Namespace for (almost) every class in
the application
- Every
using
statement in the application which references the old names
- Folder structure for each project
- References between projects which rely on changed folder structure
- .Sln files which reference the changed folder structure
- Any references to
those classes which are fully
qualified (should be few and far
between)
- Any references to those
classes in xml config files (config
sections etc)
- AssemblyInfo.cs files for every assembly
- AssemblyName in every .csproj file
Am I stuck with the find-replace-pray strategy or is there something better?
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…