Interface (contract), Generics (universality), and extension methods (ease of use). Is it a right design?

Posted by Saeed Neamati on Programmers See other posts from Programmers or by Saeed Neamati
Published on 2014-08-21T10:26:00Z Indexed on 2014/08/21 10:29 UTC
Read the original article Hit count: 222

Filed under:
|
|

I'm trying to design a simple conversion framework based on these requirements:

  1. All developers should follow a predefined set of rules to convert from the source entity to the target entity
  2. Some overall policies should be able to be applied in a central place, without interference with developers' code
  3. Both the creation of converters and usage of converter classes should be easy

To solve these problems in C# language, A thought came to my mind. I'm writing it here, though it doesn't compile at all. But let's assume that C# compiles this code:

I'll create a generic interface called IConverter

public interface IConverter<TSource, TTarget>
    where TSource : class, new()
    where TTarget : class, new()
{
    TTarget Convert(TSource source);

    List<TTarget> Convert(List<TSource> sourceItems);
}

Developers would implement this interface to create converters. For example:

public class PhoneToCommunicationChannelConverter : IConverter<Phone, CommunicationChannle>
{
    public CommunicationChannel Convert(Phone phone)
    {
        // conversion logic
    }

    public List<CommunicationChannel> Convert(List<Phone> phones)
    {
        // conversion logic
    }
}

And to make the usage of this conversion class easier, imagine that we add static and this keywords to methods to turn them into Extension Methods, and use them this way:

List<Phone> phones = GetPhones();
List<CommunicationChannel> channels = phones.Convert();

However, this doesn't even compile. With those requirements, I can think of some other designs, but they each lack an aspect. Either the implementation would become more difficult or chaotic and out of control, or the usage would become truly hard. Is this design right at all? What alternatives I might have to achieve those requirements?

© Programmers or respective owner

Related posts about c#

Related posts about design