Documenteer je code

Geschreven door: op zaterdag 27 oktober 2018

Leestijd:

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:

api-documentatie.png.png

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:

voorbeeld-wiki-api.png

 

Zie voor meer informatie over documentatie: https://visualstudiomagazine.com/articles/2017/02/21/vs-dotnet-code-documentation-tools-roundup.aspx.


Andere blogartikelen

  • SQL: Geclusterde en niet-geclusterde index

    Geschreven door: op zondag 30 juni 2019

    Het kan soms voorkomen dat het veel tijd kost voordat een bepaalde query resultaten teruggeeft. Dit kan liggen aan een scala aan problemen, zoals het gebruik van veel joins. Wat de query kan helpen ve ...

    Bekijk het artikel »
  • Hoe werkt OAuth 2.0

    Geschreven door: op zondag 30 juni 2019

    In de huidige samenleving is iedereen bijna altijd online, zo ook de applicaties waarvan de mensen gebruik maken. Als je jouw applicatie niet goed afschermt, kan dit allemaal veiligheidsrisico’s met z ...

    Bekijk het artikel »
  • OAuth 2.0: JWT token en claims

    Geschreven door: op zondag 30 juni 2019

    In mijn vorige blog heb ik uitgelegd hoe OAuth 2.0 ervoor kan zorgen dat derde partijen op een veilige manier gebruik kunnen maken van jouw applicatie met behulp van tokens. In deze blog gaan we wat m ...

    Bekijk het artikel »
Bel 072 5345 888
Onze Middelen en Technologieën
microsoft silver partner
Adobe partner
fd-gazellen-2018.jpg
Google analytics
partners-logo.jpg
Op de hoogte blijven?

Meld u aan voor de gratis nieuwsbrief om op de hoogte te blijven van onze activiteiten