Solved

Generic Extension Method Problem

Posted on 2010-09-14
5
398 Views
Last Modified: 2012-05-10
I'm trying to extend a wrapper of generic objects ('Retreival' in the example below) to output as a generic list, but I can't get it to work. The generic identifiers aren't recognized?
public static class Exts
    {
        public static List<T> ToList(this  Retrieval<T> lstToUse)
        {
            List<T> lstRet = new List<T>();
            foreach(T item   in  lstToUse.Results<T>)
            {
                lstRet.Add(item);
            }
            return lstRet;
        }
    }
0
Comment
Question by:Silas2
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
5 Comments
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 33671248
are you getting any error ?
0
 
LVL 2

Expert Comment

by:SandyAgo
ID: 33671267
Hi Silas2,

I am a little unclear on what you are trying to achieve here. This might work for you. If not, can you please give some more info on the design and requirement behind this functionality?
public static class Exts
    {
        public static List<T> ToList<T>(List<T> input)
        {
            List<T> list = new List<T>();
            foreach (T item in input)
            {
                list.Add(item);
            }
            return list;
        }

    }

Open in new window

0
 
LVL 29

Accepted Solution

by:
Gautham Janardhan earned 125 total points
ID: 33671310
assuming your retrival class is something like
public class Retrieval<T>
    {
        public IEnumerable<T> Results
        {
            get;
            set;
        }
    }

seethe modified code below

public static class Ext
    {
        public static List<T> ToList<T>(this  Retrieval<T> lstToUse)
        {
            List<T> lstRet = new List<T>();
            foreach (T item in lstToUse.Results)
            {
                lstRet.Add(item);
            }
            return lstRet;
        }
    }

Open in new window

0
 
LVL 8

Expert Comment

by:Gururaj Badam
ID: 33671405

public static List<T> Clone<T>(this List<T> _list)
            where T : ICloneable
        {
            List<T> newList = new List<T>();

            foreach (T item in _list)
                newList.Add((T) item.Clone());

            return newList;
        }

public class Retreival : ICloneable
{
public object Clone()
        {
            return MemberwiseClone();
        }
}

Open in new window

0
 
LVL 8

Assisted Solution

by:Gururaj Badam
Gururaj Badam earned 125 total points
ID: 33671411
Cloning is safer as your code just copies the reference unless you really intended that.
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
The article shows the basic steps of integrating an HTML theme template into an ASP.NET MVC project
Viewers will learn how to properly install Eclipse with the necessary JDK, and will take a look at an introductory Java program. Download Eclipse installation zip file: Extract files from zip file: Download and install JDK 8: Open Eclipse and …

752 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question