Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Code Project
  1. Home
  2. General Programming
  3. C#
  4. C# Extension method doesn't fit in this scenerio?

C# Extension method doesn't fit in this scenerio?

Scheduled Pinned Locked Moved C#
csharpvisual-studiowpfdata-structuresquestion
23 Posts 6 Posters 1 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • L Lost User

    Create a new class derive from Array. Then add a public method "Find" in it. Then you will see the method "Find" in Intellisense.

    L Offline
    L Offline
    leppie
    wrote on last edited by
    #12

    You cant derive from Array dummy ;P

    xacc.ide - now with TabsToSpaces support
    IronScheme - 1.0 alpha 4a out now (29 May 2008)

    1 Reply Last reply
    0
    • M Michael Sync

      J4amieC wrote:

      So your only option is MyArrayHelper.Find

      Yes. I used that way in my project[^] now.. that's big problem in porting WPF to SL. :( I need to change all Array.Find to ArrayHelper.Array.. The same goes for Enum.GetValue too.. I had to use EnumHelper.GetValue. or I have to use Linq for that..

      Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

      L Offline
      L Offline
      leppie
      wrote on last edited by
      #13

      Michael Sync wrote:

      I need to change all Array.Find to ArrayHelper.Array..

      Make a wrapper method, and use that all over, then only 1 place to call the helper.

      xacc.ide - now with TabsToSpaces support
      IronScheme - 1.0 alpha 4a out now (29 May 2008)

      M 1 Reply Last reply
      0
      • L leppie

        Michael Sync wrote:

        I need to change all Array.Find to ArrayHelper.Array..

        Make a wrapper method, and use that all over, then only 1 place to call the helper.

        xacc.ide - now with TabsToSpaces support
        IronScheme - 1.0 alpha 4a out now (29 May 2008)

        M Offline
        M Offline
        Michael Sync
        wrote on last edited by
        #14

        leppie wrote:

        Make a wrapper method, and use that all over, then only 1 place to call the helper.

        You mean like that.

        public static class Array{

        public static ... Find(..){
        ///.. my own implementation
        }
        public static ... Remove(...){
        ///.. call the original one.
        System.Array.Remove(....);
        }

        }

        Is this like that? but I think the name will be conflict. (My Helper.Array and System.Array) And I can't remove "using System;" since there are a lot of other references..

        Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

        D 1 Reply Last reply
        0
        • M Michael Sync

          leppie wrote:

          Make a wrapper method, and use that all over, then only 1 place to call the helper.

          You mean like that.

          public static class Array{

          public static ... Find(..){
          ///.. my own implementation
          }
          public static ... Remove(...){
          ///.. call the original one.
          System.Array.Remove(....);
          }

          }

          Is this like that? but I think the name will be conflict. (My Helper.Array and System.Array) And I can't remove "using System;" since there are a lot of other references..

          Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

          D Offline
          D Offline
          DaveyM69
          wrote on last edited by
          #15

          Put your array class in the root namespace of your project. That way, it will be used as the default instead by VS. If at anytime you need the built in class just specify System.Array

          Dave

          M S 2 Replies Last reply
          0
          • D DaveyM69

            Put your array class in the root namespace of your project. That way, it will be used as the default instead by VS. If at anytime you need the built in class just specify System.Array

            Dave

            M Offline
            M Offline
            Michael Sync
            wrote on last edited by
            #16

            Thanks. That means I dont need to change Array.Find to ArrayHelper.Find. But I will need to change Array.Remove to System.Array.Remove? Another thing: I think the name will be conflict.

            Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

            D 1 Reply Last reply
            0
            • M Michael Sync

              Thanks. That means I dont need to change Array.Find to ArrayHelper.Find. But I will need to change Array.Remove to System.Array.Remove? Another thing: I think the name will be conflict.

              Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

              D Offline
              D Offline
              DaveyM69
              wrote on last edited by
              #17

              Michael Sync wrote:

              But I will need to change Array.Remove to System.Array.Remove

              No. For any methods that you need to keep that exist in System.Array - simply create a method in your class with the same return type, name and signature. Then in your method return the System.Array's method result passing the parameters to it.

              Michael Sync wrote:

              Another thing: I think the name will be conflict.

              No, the IDE and compiler will assume yournamespace.class if there is also a System.class with the same class name.

              Dave

              M 1 Reply Last reply
              0
              • M Michael Sync

                Let's say there is no method called Find in Array class. So, I created my own Find method. then, if I type Array. then I want to show my own method "Find" in intellisense. AFAIK, C# extension method doesn't fit in this scenario so is there any way to make my own method to show in Intellisense? is there such a thing like attached method (similar to attached properties in WPF)?

                Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

                S Offline
                S Offline
                Scott Dorman
                wrote on last edited by
                #18

                Technically, extension methods require an instance of the data type being extended as the first parameter so you can't create a "true" static method on the actual type. You'll need to continue using a static helper class/method or create an extension method and call it from the instance of the array you want to search for the value.

                Scott Dorman

                Microsoft® MVP - Visual C# | MCPD President - Tampa Bay IASA [Blog][Articles][Forum Guidelines]


                Hey, hey, hey. Don't be mean. We don't have to be mean because, remember, no matter where you go, there you are. - Buckaroo Banzai

                1 Reply Last reply
                0
                • D DaveyM69

                  Put your array class in the root namespace of your project. That way, it will be used as the default instead by VS. If at anytime you need the built in class just specify System.Array

                  Dave

                  S Offline
                  S Offline
                  Scott Dorman
                  wrote on last edited by
                  #19

                  I'd highly reccommend against doing that. It can and most likely will lead to a lot of maintenance headaches later. It will also make it harder for new developers to get up to speed on the codebase since there is now a "new" Array class that isn't the standard one that everyone is familiar with.

                  Scott Dorman

                  Microsoft® MVP - Visual C# | MCPD President - Tampa Bay IASA [Blog][Articles][Forum Guidelines]


                  Hey, hey, hey. Don't be mean. We don't have to be mean because, remember, no matter where you go, there you are. - Buckaroo Banzai

                  D M 2 Replies Last reply
                  0
                  • S Scott Dorman

                    I'd highly reccommend against doing that. It can and most likely will lead to a lot of maintenance headaches later. It will also make it harder for new developers to get up to speed on the codebase since there is now a "new" Array class that isn't the standard one that everyone is familiar with.

                    Scott Dorman

                    Microsoft® MVP - Visual C# | MCPD President - Tampa Bay IASA [Blog][Articles][Forum Guidelines]


                    Hey, hey, hey. Don't be mean. We don't have to be mean because, remember, no matter where you go, there you are. - Buckaroo Banzai

                    D Offline
                    D Offline
                    DaveyM69
                    wrote on last edited by
                    #20

                    Even though I suggested it, I agree. Personally I would carefully rename all the 'Array' code to my helper class but the OP didn't want to do that. I've only done it the other way once and I made sure I implemented EVERY method/property/interface and all their overloads from the original class to avoid problems. It's been OK so far, but it was a headache creating the class in the first place!

                    Dave

                    1 Reply Last reply
                    0
                    • S Scott Dorman

                      I'd highly reccommend against doing that. It can and most likely will lead to a lot of maintenance headaches later. It will also make it harder for new developers to get up to speed on the codebase since there is now a "new" Array class that isn't the standard one that everyone is familiar with.

                      Scott Dorman

                      Microsoft® MVP - Visual C# | MCPD President - Tampa Bay IASA [Blog][Articles][Forum Guidelines]


                      Hey, hey, hey. Don't be mean. We don't have to be mean because, remember, no matter where you go, there you are. - Buckaroo Banzai

                      M Offline
                      M Offline
                      Michael Sync
                      wrote on last edited by
                      #21

                      Thanks, Scott. It's true that it will lead a lot of maintenance headaches but the problem is that we already have a lot of classes written for WPF project. I'm trying to port them to Silverlight-compatible project. What I was thinking is that if we can use the same way that we used to use for WPF then new developer won't need to remember that we have to use this (e.g ArrayHelper.Find) in Silverlight and we have to use that (ie. Array.Find) in WPF. All he need to do is that just use Array.Find no matter whether he is in Silverlight or WPF..

                      Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

                      S 1 Reply Last reply
                      0
                      • D DaveyM69

                        Michael Sync wrote:

                        But I will need to change Array.Remove to System.Array.Remove

                        No. For any methods that you need to keep that exist in System.Array - simply create a method in your class with the same return type, name and signature. Then in your method return the System.Array's method result passing the parameters to it.

                        Michael Sync wrote:

                        Another thing: I think the name will be conflict.

                        No, the IDE and compiler will assume yournamespace.class if there is also a System.class with the same class name.

                        Dave

                        M Offline
                        M Offline
                        Michael Sync
                        wrote on last edited by
                        #22

                        Thanks, Dave. I will try. But Scott's suggestion is also nice one. I will keep the suggestions from both of you and I will mentioned about that to my manager..

                        Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

                        1 Reply Last reply
                        0
                        • M Michael Sync

                          Thanks, Scott. It's true that it will lead a lot of maintenance headaches but the problem is that we already have a lot of classes written for WPF project. I'm trying to port them to Silverlight-compatible project. What I was thinking is that if we can use the same way that we used to use for WPF then new developer won't need to remember that we have to use this (e.g ArrayHelper.Find) in Silverlight and we have to use that (ie. Array.Find) in WPF. All he need to do is that just use Array.Find no matter whether he is in Silverlight or WPF..

                          Thanks and Regards, Michael Sync ( Blog: http://michaelsync.net)

                          S Offline
                          S Offline
                          Scott Dorman
                          wrote on last edited by
                          #23

                          I understand the problem you are looking at. It's a trade off as either way you are going to end up with possible maintenance issues later.

                          Scott Dorman

                          Microsoft® MVP - Visual C# | MCPD President - Tampa Bay IASA [Blog][Articles][Forum Guidelines]


                          Hey, hey, hey. Don't be mean. We don't have to be mean because, remember, no matter where you go, there you are. - Buckaroo Banzai

                          1 Reply Last reply
                          0
                          Reply
                          • Reply as topic
                          Log in to reply
                          • Oldest to Newest
                          • Newest to Oldest
                          • Most Votes


                          • Login

                          • Don't have an account? Register

                          • Login or register to search.
                          • First post
                            Last post
                          0
                          • Categories
                          • Recent
                          • Tags
                          • Popular
                          • World
                          • Users
                          • Groups