[ 
https://issues.apache.org/jira/browse/IBATISNET-283?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Gilles Bayon closed IBATISNET-283.
----------------------------------

       Resolution: Fixed
    Fix Version/s: DataMapper 3.0
                   DataMapper 1.6.2

in SVN

> Result mappings should work with interfaces when QueryForObject is passed an 
> existing object
> --------------------------------------------------------------------------------------------
>
>                 Key: IBATISNET-283
>                 URL: https://issues.apache.org/jira/browse/IBATISNET-283
>             Project: iBatis for .NET
>          Issue Type: Bug
>          Components: DataMapper
>    Affects Versions: DataMapper 1.6.1
>            Reporter: Richard Banks
>            Assignee: Gilles Bayon
>             Fix For: DataMapper 1.6.2, DataMapper 3.0
>
>
> In the IBatisNet.DataMapper.DataExchange.DotNetObjectDataExchange class the 
> method public override void SetData(ref object target, ResultProperty 
> mapping, object dataBaseValue)
>  does a check against types using this statement:
>    if ((type != this._parameterClass) && 
> !type.IsSubclassOf(this._parameterClass))
> The problem here is that IsSubclassOf doesn't check for interface 
> implementations.  When  _parameterClass is an interface you also need to 
> check using 
> type.GetInterfaces().Contains(this._parameterClass)
> This would then allow for result mappings to use interfaces, which is really 
> useful when you are using an IoC container to instantiate the class being 
> populated, for example:
> ISale sale = Container.Resolve<ISale>();
> ...
> Mapper.Instance().QueryForObject<ISale>("uspSelectSale", saleNumber, sale);
> Thanks

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to