Docstring - Docstring
v programování, a docstring je řetězec doslovný uvedeno v zdrojový kód který se používá, jako a komentář, k dokumentaci konkrétního segmentu kódu. Na rozdíl od konvenčních komentářů ke zdrojovým kódům nebo dokonce ke konkrétně formátovaným komentářům jako Javadoc dokumentace, dokumentační řetězce nejsou odstraněny ze zdrojového stromu, když je analyzován, a jsou zachovány po celou dobu běhu programu. To umožňuje programátorovi zkontrolovat tyto komentáře za běhu, například jako interaktivní systém nápovědy nebo jako metadata.
Zdá se, že byl poprvé představen v originále TECO implementace Emacs.[1]
Mezi jazyky, které podporují dokumenty, patří Krajta, Lisp, Elixír, Clojure,[2] kyselá okurka,[3] Julie[4] a Haskell.[5]
Příklady implementace
Elixír
Dokumentace je podporována na jazykové úrovni ve formě dokumentů. Markdown je de facto značkovací jazyk Elixir pro použití v docstrings:
def modul MyModule dělat @modulesoc """ Dokumentace pro můj modul. S ** formátováním **. """ @doc "Ahoj" def svět dělat "Svět" koneckonec
Lisp
V Lispu jsou docstrings známé jako dokumentační řetězce. The Společný Lisp Standard uvádí, že konkrétní implementace se může rozhodnout zahodit dokumenty, kdykoli chtějí, z jakéhokoli důvodu. Když jsou uchovány, lze dokumenty a řetězce zobrazit a změnit pomocí funkce DOKUMENTACE.[6] Například:
(defun foo () "Ahoj" nula) (dokumentace #'foo 'funkce) => "Ahoj"
Krajta
Běžnou praxi dokumentování objektu kódu v záhlaví jeho definice zachycuje přidání syntaxe docstring v jazyce Python.
Docstring pro objekt kódu Python (modul, třída nebo funkce) je první příkaz tohoto objektu kódu, bezprostředně následující po definici (příkaz 'def' nebo 'class'). Příkaz musí být holý řetězcový literál, nikoli jakýkoli jiný druh výrazu. Docstring pro objekt kódu je k dispozici na tomto objektu kódu __doc__
atribut a prostřednictvím Pomoc
funkce.
Následující soubor Pythonu ukazuje deklaraci docstrings ve zdrojovém souboru Pythonu:
"" "Dokumentační řetězec modulu" ""třída Moje třída: "" "Dokumentační řetězec třídy" "" def moje_metoda(já): "" "Dokumentační řetězec metody" ""def moje_funkce(): "" "Dokumentační řetězec funkce" ""
Za předpokladu, že výše uvedený kód byl uložen jako mymodule.py, následující je interaktivní relace ukazující, jak lze přistupovat k dokumentovým řetězcům:
>>> import mymodule>>> Pomoc(mymodule)Dokumentační řetězec modulu>>> Pomoc(mymodule.Moje třída)Docstring třídy>>> Pomoc(mymodule.Moje třída.moje_metoda)Metodický dokument>>> Pomoc(mymodule.moje_funkce)Funkční dokumentační řetězec>>>
Nástroje využívající docstrings
- kobra -doc (Kobra)
- doctest (Krajta)
- Epydoc (Krajta)
- Pydoc (Krajta)
- Sfinga (Krajta)
Viz také
- Literární programování - alternativní paradigma komentování kódu -
- Prostá stará dokumentace - Perl dokumentace
Reference
- ^ „EMACS: Rozšiřitelný, přizpůsobitelný editor zobrazení“.
- ^ Definice funkce s dokumentovým řetězcem v Clojure
- ^ „Krokové argumenty - Doc Strings“. Archivovány od originál dne 31.01.2016. Citováno 2016-06-22.
- ^ http://docs.julialang.org/en/stable/manual/documentation/
- ^ https://hackage.haskell.org/package/docstrings
- ^ CLHS: Standardní obecná funkce DOKUMENTACE ...
externí odkazy
- Python Docstrings u Epydoc Sourceforge strana
- Dokumentace v GNU Emacs Lisp
- Sekce z doxygen dokumentace o Python docstrings