CA1041: Zapewnianie wiadomości ObsoleteAttribute
Właściwości | Wartość |
---|---|
Identyfikator reguły | CA1041 |
Tytuł | Udostępnij komunikat ObsoleteAttribute |
Kategoria | Projekt |
Poprawka powodująca niezgodność lub niezgodność | Niezgodność |
Domyślnie włączone na platformie .NET 9 | Jako sugestia |
Przyczyna
Typ lub element członkowski jest oznaczony za pomocą atrybutu System.ObsoleteAttribute , który nie ma określonej właściwości System.ObsoleteAttribute.Message .
Domyślnie ta reguła analizuje tylko widoczne zewnętrznie typy i elementy członkowskie, ale można to skonfigurować.
Opis reguły
ObsoleteAttribute służy do oznaczania przestarzałych typów bibliotek i elementów członkowskich. Użytkownicy biblioteki powinni unikać używania dowolnego typu lub elementu członkowskiego oznaczonego jako przestarzałe. Jest to spowodowane tym, że może nie być obsługiwane i ostatecznie zostanie usunięte z nowszych wersji biblioteki. Gdy typ lub element członkowski oznaczony za pomocą ObsoleteAttribute jest kompilowany, Message zostanie wyświetlona właściwość atrybutu. Dostarcza to informacje użytkownika o przestarzałym typie lub elemencie członkowskim. Te informacje zazwyczaj obejmują, jak długo przestarzały typ lub element członkowski będą obsługiwane przez projektantów biblioteki i preferowaną zamianę do użycia.
Jak naprawić naruszenia
Aby naprawić naruszenie tej reguły, dodaj message
parametr do konstruktora ObsoleteAttribute .
Kiedy pomijać ostrzeżenia
Nie pomijaj ostrzeżenia z tej reguły, ponieważ Message właściwość udostępnia krytyczne informacje o przestarzałym typie lub elemencie członkowskim.
Konfigurowanie kodu do analizowania
Użyj następującej opcji, aby skonfigurować, które części bazy kodu mają być uruchamiane w tej regule.
Tę opcję można skonfigurować tylko dla tej reguły, dla wszystkich reguł, do których ma ona zastosowanie, lub dla wszystkich reguł w tej kategorii (Projekt), których dotyczy. Aby uzyskać więcej informacji, zobacz Opcje konfiguracji reguły jakości kodu.
Uwzględnij określone powierzchnie interfejsu API
Możesz skonfigurować, na których częściach bazy kodu ma być uruchamiana ta reguła, na podstawie ich ułatwień dostępu. Aby na przykład określić, że reguła powinna być uruchamiana tylko na powierzchni niepublicznego interfejsu API, dodaj następującą parę klucz-wartość do pliku editorconfig w projekcie:
dotnet_code_quality.CAXXXX.api_surface = private, internal
Nuta
Zastąp część XXXX
CAXXXX
identyfikatorem odpowiedniej reguły.
Przykład
W poniższym przykładzie pokazano przestarzały element członkowski z poprawnie zadeklarowanym elementem ObsoleteAttribute.
[ObsoleteAttribute("This property is obsolete and will be removed in a " +
"future version. Use the FullName property instead.", false)]
public string Name
{
get => "Name";
}
Imports System
Namespace ca1041
Public Class ObsoleteAttributeOnMember
<ObsoleteAttribute("This property is obsolete and will " &
"be removed in a future version. Use the FirstName " &
"and LastName properties instead.", False)>
ReadOnly Property Name As String
Get
Return "Name"
End Get
End Property
ReadOnly Property FirstName As String
Get
Return "FirstName"
End Get
End Property
ReadOnly Property LastName As String
Get
Return "LastName"
End Get
End Property
End Class
End Namespace