Ich pflege ein paar Bibliotheken für andere Leute. Nachdem ich für jeden von ihnen ein paar Releases durchgemacht hatte, gab es einige Dinge, die ich anders machen würde, wenn ich sie nochmal machen müsste.Wartung - Balancing die Frage, wann und wenn Sie Änderungen vornehmen
Die Frage ist: Soll ich sie tun? Ich denke, wir alle stehen vor diesem Dilemma - wie man die Hilfsbereitschaft der Wartungsaktivitäten gegen die störenden Auswirkungen der Veränderung ausbalanciert.
Offensichtlich für Bugs ist die Änderung zwingend erforderlich. Kein Dilemma da. Für neue Funktionen ist es eine Frage von Nutzen gegenüber zusätzlicher Komplexität. Ich fühle mich mit dieser Frage wohl.
Es ist der unscharfe Abstand zwischen Bugfix und neuer Funktion, nach dem ich frage. Ein Beispiel ist die Wartung, um die Rahmenrichtlinien für das Design oder die CLS-Konformität zu erfüllen. Für eine Bibliothek habe ich sie geschrieben, ohne an CLS-Compliance zu denken, und dann haben die Leute danach gefragt. Als Ergebnis musste ich die Schnittstelle ändern, um int für int zu tauschen. Das ist eine bahnbrechende Veränderung, für wenig Gewinn (für die meisten Leute).
Ein weiteres Problem: FxCop-Compliance. Ich musste für einige Methoden Änderungen in Parameternamen vornehmen, um FxCop glücklich zu machen. Aber diese Veränderungen betreffen nur Menschen, die sich der Reflexion bedienen - die Typen haben sich nicht geändert, nur die Namen der Params.
Das Problem, mit dem ich es gerade zu tun habe, ist: Framework Design Guidelines. Die Richtlinien zu Ereignissen sagen, dass Ereignisse eine Signatur mit zwei Argumenten haben sollten: (Objektquelle, EventArgs e). Aber ich war an diesem Tag in meinem Framework Design Kurs abwesend;). Die Ereignisse in meiner Bibliothek verwenden derzeit nur ein einziges EventArgs-Argument.
Ich füge jetzt neue Ereignisse zur Bibliothek hinzu. Sollten die neuen Veranstaltungen den Richtlinien für das Framework-Design entsprechen? oder das Muster bereits in der Bibliothek etabliert? Wenn ich die Designrichtlinien für die neuen Ereignisse verwende, sollte ich die vorhandenen Ereignisse so ändern, dass sie auch den Designrichtlinien entsprechen? Und wenn ja, wie wird die Migration durchgeführt? Soll ich das Attribut [Obsolet] verwenden? Wie viele Veröffentlichungen?
Allgemeiner bin ich interessiert an Gedanken zur Wartung in diesem unscharfen Bereich zwischen Bugfix und neuer Funktion.
Sie können das nicht tun, wenn Sie Bibliotheken schreiben, die andere Leute verwenden. –