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 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