Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

Generic Extension Method Problem

Posted on 2010-09-14
5
Medium Priority
?
424 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
  • 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 500 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 500 total points
ID: 33671411
Cloning is safer as your code just copies the reference unless you really intended that.
0

Featured Post

[Webinar] Database Backup and Recovery

Does your company store data on premises, off site, in the cloud, or a combination of these? If you answered “yes”, you need a data backup recovery plan that fits each and every platform. Watch now as as Percona teaches us how to build agile data backup recovery plan.

Question has a verified solution.

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

This article will inform Clients about common and important expectations from the freelancers (Experts) who are looking at your Gig.
Hello there! As a developer I have modified and refactored the unit tests which was written by fellow developers in the past. On the course, I have gone through various misconceptions and technical challenges when it comes to implementation. I would…
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 …
Loops Section Overview

580 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