Coder Social home page Coder Social logo

Comments (2)

dsigitov avatar dsigitov commented on June 19, 2024

Hi!

but would adding a line such as:
if (enumerableType == null) enumerableType = collectionType;
be acceptable? If it is, I'll get on and write a unit test and send a pull request.

I wouldn't recommend doing that. It will totally break the logic of this method.

The problem is that method doesn't handle correctly the case when collectionType is IEnumerable<T> itself.

Instead, change the method as follows:

public static System.Type TryGetCollectionItemType(System.Type collectionType)
{
    if (collectionType == null)
        return null;

    System.Type enumerableType;
    if (collectionType.IsGenericType && collectionType.GetGenericTypeDefinition() == typeof(IEnumerable<>))
        enumerableType = collectionType;
    else
        enumerableType = collectionType.GetInterfaces().FirstOrDefault(x => x.IsGenericType && x.GetGenericTypeDefinition() == typeof(IEnumerable<>));

    if (enumerableType == null)
        return null;

    return enumerableType.GetGenericArguments().Single();
}

It will first check whether the value of collectionType is IEnumerable<T> itself, then it will check all interfaces, so this test will pass:

Assert.AreEqual(typeof(int), OData.TypeUtil.TryGetCollectionItemType(typeof(IEnumerable<int>)));

from nhibernate.odata.

pvginkel avatar pvginkel commented on June 19, 2024

Sorry for the late reply. I'll push a new version to NuGet in a moment with this fix.

from nhibernate.odata.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.