After things have gone from bad to worse, the cycle will repeat itself.
Farnsdick’s corollary
As you saw in Chapter 15, reuse is an obvious source of medium- and long-term benefits to an organization. Visual Basic 5 provides a series of new features to help in this area. These new features require investment of time and, as a result, money for a business to benefit from them. This is where we hit the tired old argument about “Who will pay for reuse?” It should be recognized that reusability is a function of good design. This is true regardless of whether or not reuse is a design objective. A good design supports change, it supports the unknown future, and it is flexible. These characteristics give reusability.
The required investment in many major organizations is in design and designers. This is often an unpalatable truth to be faced. You need to actively look for things that can be reused from other applications. Each project should have a task attached to it for “trawling” or “scavenging” for reuse. If the organization has an organized reuse catalog of components and patterns, this is an obvious starting point. However, few organizations appear to have done such cataloging well, if at all.
An effective approach is to schedule a series of short meetings with the design leaders in other projects. At these meetings, discuss the existing application and the new application both technically and from the business point of view and identify similarities. These areas of similarity should point to reuse. Then take a guided tour of the similar parts of each application. Reuse any applicable code, ideas, or good practices. Generally speaking, one workweek should be sufficient for trawling.
Contribute to the reuse catalog, or start one. Reuse comes for free with good design. Duplication is a product of politics.