Documenteer je code
Documenteren van je code is uiteraard een best practice. De code op zich mag zo beschrijvend mogelijk zijn, zodat de documentatie impliciet is, maar bijvoorbeeld een uitleg over het waarom van een bepaalde functie of enkele code-voorbeelden zijn goede toepassingen van documentatie.
Documentatie zorgt er onder andere voor dat duidelijk is waarom iets is gemaakt, als dat vanuit de code niet direct duidelijk is, wat na jarenlang duizenden regels code schrijven voor iedereen geldt. Je zorgt er ook voor dat andere collegaâs en zeker ook nieuwe collegaâs snel begrijpen hoe de code werkt en toegepast wordt en waarom het is geschreven.
Er zijn de gebruikelijke inline comments, maar er zijn ook comments die een hele klasse of functie beschrijven. Dit kan je doen zoals je wilt, maar Microsoft gebruikt in .NET daarvoor XML Documentation Comments. Deze comments beginnen met drie slashes: /// en bevatten binnen die comment-blokken XML-elementen waarin je verschillende vormen van documentatie kan plaatsen, zoals een samenvatting, beschrijving van parameters en voorbeeldcode.
Een voorbeeld:
namespace WebApplication1.Utilities
{
/// <summary>
/// TextUtility provides easy methods to modify text.
/// </summary>
public class TextUtility
{
/// <summary>
/// Case me method changes text to upper case
/// </summary>
/// <example>
/// <code>
/// string t = "My text";
/// string TUPPER = TextUtility.CaseMe(t);
/// //TUPPER = "MY TEXT"
/// </code>
/// </example>
///
/// <param name="text">The string to change to upper case</param>
/// <returns>string in UPPER CASE</returns>
public static string CaseMe(string text)
{
return text.ToUpper();
}
}
}
In bovenstaande voorbeeld, wat een heel versimpeld voorbeeld is, wordt de class beschreven en de functie CaseMe. We zouden ook nog de namespace kunnen documenteren. Er staat een samenvatting, beschrijving van de argumenten en een voorbeeld.
Wanneer je deze XML-documentatie toevoegt, zie je deze hints ook in Visual Studio:
Dit is handig voor in Visual Studio, maar je kan alle documentatie ook exporteren als XML-bestanden door bij het builden een project dit aan te geven. Dit bestand kan je daarna converteren met een tool als Sandcastle Help File Builder naar een website met daarin al je documentatie, zodat collegaâs en andere ontwikkelaars snel de code als API kunnen naslaan:
Zie voor meer informatie over documentatie: https://visualstudiomagazine.com/articles/2017/02/21/vs-dotnet-code-documentation-tools-roundup.aspx.