Uploaded image for project: 'C# Driver'
  1. C# Driver
  2. CSHARP-3601

Remove [Serializable] attribute

    • Type: Icon: Improvement Improvement
    • Resolution: Fixed
    • Priority: Icon: Major - P3 Major - P3
    • 3.0.0
    • Affects Version/s: None
    • Component/s: None
    • None
    • Major Change
    • Not Needed
    • Hide

      1. What would you like to communicate to the user about this feature?
      2. Would you like the user to see examples of the syntax and/or executable code and its output?
      3. Which versions of the driver/connector does this apply to?

      Show
      1. What would you like to communicate to the user about this feature? 2. Would you like the user to see examples of the syntax and/or executable code and its output? 3. Which versions of the driver/connector does this apply to?
    • None
    • None
    • None
    • None
    • None
    • None

      The use of [Serializable] attribute should be revisited.
      According to investigation in scope of CSHARP-2936 it is currently used for making all MongoDB.Driver custom exceptions (e.g. MongoException and BsonException) serializable to binary, which in turn requires all of their fields to be serializable as well, resulting in the [Serializable] attribute being applied to a large amount of classes which do not need it otherwise.
      The reason for making custom exceptions [Serializable] is not entirely clear, but is likely connected to transferring these exceptions between different AppDomains (which should be confirmed).
      Dropping the [Serializable] attribute is a breaking change, thus it should be considered for major release (if the reason for applying it is not longer valid), but in return will eliminate the need to support it in the codebase.

            Assignee:
            ferdinando.papale@mongodb.com Ferdinando Papale
            Reporter:
            mikalai.mazurenka@mongodb.com Mikalai Mazurenka (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            3 Start watching this issue

              Created:
              Updated:
              Resolved:
              None
              None
              None
              None