Генератор документации: различия между версиями
[непроверенная версия] | [непроверенная версия] |
Нет описания правки |
РобоСтася (обсуждение | вклад) |
||
(не показаны 33 промежуточные версии 25 участников) | |||
Строка 1: | Строка 1: | ||
'''Генератор документации''' — [[Компьютерная программа|программа]] или [[ |
'''Генератор документации''' — [[Компьютерная программа|программа]] или [[Программный пакет|пакет программ]], позволяющая получать [[техническая документация|документацию]], предназначенную для [[программист]]ов (документация на [[API]]) и/или для конечных пользователей системы, по особым образом комментированному [[исходный код|исходному коду]] и, в некоторых случаях, по [[Исполнимый модуль|исполняемым модулям]] (полученным на выходе [[компилятор]]а). |
||
Обычно генератор анализирует исходный код программы, выделяя синтаксические конструкции, соответствующие значимым объектам программы (типам, классам и их членам/свойствам/методам, процедурам/функциям |
Обычно генератор анализирует исходный код программы, выделяя синтаксические конструкции, соответствующие значимым объектам программы (типам, классам и их членам/свойствам/методам, процедурам/функциям и т. п.). В ходе анализа также используется мета-информация об объектах программы, представленная в виде документирующих комментариев. На основе всей собранной информации формируется готовая документация, как правило, в одном из общепринятых форматов — [[HTML]], [[HTMLHelp]], [[PDF]], [[RTF]] и других. |
||
== Документирующие комментарии == |
== Документирующие комментарии == |
||
{{main|Документирующие комментарии}} |
|||
Документирующий комментарий — это особым образом оформленный [[комментарии (программирование)|комментарий]] к объекту программы, предназначенный для использования каким-либо конкретным генератором документации. От того, какой генератор документации применяется, зависит [[синтаксис]] конструкций, используемых в документирующих комментариях. |
Документирующий комментарий — это особым образом оформленный [[комментарии (программирование)|комментарий]] к объекту программы, предназначенный для использования каким-либо конкретным генератором документации. От того, какой генератор документации применяется, зависит [[синтаксис]] конструкций, используемых в документирующих комментариях. |
||
Строка 10: | Строка 9: | ||
В документирующих комментариях может содержаться информация об авторе кода, описываться назначение объекта программы, смысл входных и выходных параметров — для функции/процедуры, примеры использования, возможные исключительные ситуации, особенности реализации. |
В документирующих комментариях может содержаться информация об авторе кода, описываться назначение объекта программы, смысл входных и выходных параметров — для функции/процедуры, примеры использования, возможные исключительные ситуации, особенности реализации. |
||
Документирующие комментарии, как правило, оформляются как многострочные комментарии в стиле языка [[Си (язык программирования)|Си]]. В каждом случае комментарий должен находиться перед документируемым элементом. Первым символом в комментарии (и |
Документирующие комментарии, как правило, оформляются как многострочные комментарии в стиле языка [[Си (язык программирования)|Си]]. В каждом случае комментарий должен находиться перед документируемым элементом. Первым символом в комментарии (и в начале строк комментария) должен быть <code>*</code>. Блоки разделяются пустыми строками. |
||
Пример документирующего комментария на языке [[PHP]]: |
Пример документирующего комментария на языке [[PHP]]: |
||
Строка 23: | Строка 22: | ||
*/</source> |
*/</source> |
||
{{ |
{{PhpDocumentor}} |
||
Пример документирующего комментария к функции в программе на [[Java]], предназначенного для использования [[Javadoc]]: |
Пример документирующего комментария к функции в программе на [[Java]], предназначенного для использования [[Javadoc]]: |
||
Строка 45: | Строка 44: | ||
== Популярные генераторы документации == |
== Популярные генераторы документации == |
||
Примеры для разных языков и сред программирования: |
Примеры для разных языков и сред программирования: |
||
* |
* {{нп1|Doc-O-Matic||en|Doc-O-Matic}}; |
||
* [[Document! X]] |
* [[Document! X]] предназначен для программ на языке [[VB6]], языках: VB.NET/C#/Visual C++ .NET ([[.NET Framework]] 1.0, 1.1 и 2.0), [[Component Object Model|COM]]-компонентов, баз данных [[Microsoft Access|Access]], [[Microsoft SQL Server]] и [[Oracle (СУБД)|Oracle]], [[XML Schema]] и других языках описания [[XML]]; |
||
* [[Doxygen]] |
* [[Doxygen]] — языках: [[C++]], [[Си (язык программирования)|Си]], [[Objective-C]], [[Java]], [[Язык описания интерфейсов|IDL]], [[PHP]], [[C Sharp|C#]], [[Фортран]], [[VHDL]], [[Python]] и, частично, [[D (язык программирования)|D]]; |
||
* [[Epydoc]] |
* [[Epydoc]] — языке [[Python]]; |
||
* [[Javadoc]] |
* [[Javadoc]] — языке [[Java]]; |
||
* [[JSDoc]] — языке [[JavaScript]]; |
|||
* [[HappyDoc]]<ref>http://happydoc.sourceforge.net/</ref>; |
|||
* [[HappyDoc]]<ref>{{Cite web |url=http://happydoc.sourceforge.net/ |title=HappyDoc Source Documentation<!-- Заголовок добавлен ботом --> |access-date=2006-01-27 |archive-date=2020-11-27 |archive-url=https://web.archive.org/web/20201127012332/http://happydoc.sourceforge.net/ |deadlink=no }}</ref> — языке [[Python]]; |
|||
* [[PasDoc]]<ref>http://pasdoc.sipsolutions.net/</ref> — языке [[Delphi]]/[[Pascal (язык программирования)|Pascal]]; |
|||
* [[PasDoc]]<ref>{{Cite web |url=http://pasdoc.sipsolutions.net/ |title=PasDoc — pasdoc<!-- Заголовок добавлен ботом --> |access-date=2009-09-07 |archive-date=2016-12-20 |archive-url=https://web.archive.org/web/20161220073637/http://pasdoc.sipsolutions.net/ |deadlink=no }}</ref> — языке [[Delphi (язык программирования)|Delphi]]/[[Pascal (язык программирования)|Pascal]]; |
|||
* [[perldoc]]<ref>http://perldoc.perl.org/</ref> — языке [[Perl]] (включен в стандартный дистрибутив); |
|||
* [[perldoc]]<ref>{{Cite web |url=http://perldoc.perl.org/ |title=Perl programming documentation — perldoc.perl.org<!-- Заголовок добавлен ботом --> |access-date=2009-06-17 |archive-date=2009-01-30 |archive-url=https://web.archive.org/web/20090130002833/http://perldoc.perl.org/ |deadlink=no }}</ref> — языке [[Perl]] (включен в стандартный дистрибутив); |
|||
* [[PhpDocumentor]] и [[PHPDoc]] (адаптация [[Javadoc]] для использования с [[PHP]]) |
* [[PhpDocumentor]] и [[PHPDoc]] (адаптация [[Javadoc]] для использования с [[PHP]]) — языке [[PHP]]; |
||
* [[:en:POD|POD]]{{ref-en}}; |
* [[:en:POD|POD]]{{ref-en}}; |
||
* [[RDoc]]<ref>http://rdoc.sourceforge.net</ref> |
* [[RDoc]]<ref>{{Cite web |url=http://rdoc.sourceforge.net/ |title=RDoc — Document Generator for Ruby Source<!-- Заголовок добавлен ботом --> |access-date=2022-06-19 |archive-date=2022-06-06 |archive-url=https://web.archive.org/web/20220606211041/http://rdoc.sourceforge.net/ |deadlink=no }}</ref> — языке [[Ruby]]; |
||
* [[ROBODoc]]<ref>{{Cite web |url=http://www.xs4all.nl/~rfsber/Robo/robodoc.html |title=ROBODoc — automating the software documentation process<!-- Заголовок добавлен ботом --> |access-date=2006-01-27 |archive-date=2011-05-13 |archive-url=https://web.archive.org/web/20110513234924/http://www.xs4all.nl/~rfsber/Robo/robodoc.html |deadlink=no }}</ref>; |
|||
* [[ROBODoc]]<ref>http://www.xs4all.nl/~rfsber/Robo/robodoc.html</ref>; |
|||
* [[:en:TwinText|TwinText]]{{ref-en}}; |
* [[:en:TwinText|TwinText]]{{ref-en}}; |
||
* [[NDoc]]<ref>http://ndoc.sourceforge.net/</ref> |
* [[NDoc]]<ref>{{Cite web |url=http://ndoc.sourceforge.net/ |title=NDoc Online<!-- Заголовок добавлен ботом --> |access-date=2006-01-27 |archive-date=2006-07-03 |archive-url=https://web.archive.org/web/20060703024816/http://ndoc.sourceforge.net/ |deadlink=no }}</ref> — языках [[C Sharp|C#]], [[VB.NET]] и других языках платформы [[.NET Framework|.NET]]; |
||
* [[Sandcastle]] |
* [[Sandcastle]] — для [[C Sharp|C#]], [[VB.NET]] и других языков платформы [[.NET Framework|.NET]]; |
||
* [[Sphinx (генератор документации)|Sphinx]] — языке [[Python]]<ref>[http://blog.doughellmann.com/2009/02/writing-technical-documentation-with.html Doug Hellmann, Writing Technical Documentation with Sphinx, Paver, and Cog] {{Wayback|url=http://blog.doughellmann.com/2009/02/writing-technical-documentation-with.html |date=20130116234041 }}</ref>; |
|||
* [[VBdocman]]<ref>http://www.helixoft.com/vbdocman/</ref> |
* [[VBdocman]]<ref>http://www.helixoft.com/vbdocman/{{Недоступная ссылка|date=2018-06|bot=InternetArchiveBot }}</ref> — языке [[VB6]]; |
||
* [[VSdocman]] (ранее VBdocman .NET) |
* [[VSdocman]] (ранее VBdocman .NET) — языков [[VB.NET]] и [[C Sharp|C#]]; |
||
* [[Грамотное программирование | WEB]] / [[CWEB]]<ref>http://sunburn.stanford.edu/~knuth/cweb.html</ref>; |
|||
* [[Грамотное программирование|WEB]] / [[CWEB]]<ref>[http://sunburn.stanford.edu/~knuth/cweb.html Knuth and Levy:CWEB<!-- Заголовок добавлен ботом -->] {{webarchive|url=https://web.archive.org/web/20121120183829/http://sunburn.stanford.edu/~knuth/cweb.html |date=2012-11-20 }}</ref>; |
|||
* [[XHelpGen]] |
* [[XHelpGen]] — языке [[Delphi (язык программирования)|Delphi]] (входит в состав библиотеки KOL/MCK). |
||
* [http://phpdox.de/ PHPDox] — проекты PHP. |
|||
== См. также == |
|||
* [[Стандарт оформления кода]] |
|||
== Ссылки == |
|||
<references /> |
|||
== Примечания == |
|||
{{примечания}} |
|||
[[Категория:Генераторы документации|*]] |
[[Категория:Генераторы документации|*]] |
||
[[Категория:Стандарт оформления кода]] |
[[Категория:Стандарт оформления кода]] |
||
[[cs:Generátor dokumentace]] |
|||
[[de:Software-Dokumentationswerkzeug]] |
|||
[[en:Documentation generator]] |
|||
[[es:Generador de documentación]] |
|||
[[fr:Générateur de documentation]] |
|||
[[ja:ドキュメンテーションジェネレータ]] |
|||
[[nl:Documentatiegenerator]] |
Текущая версия от 20:08, 21 июля 2024
Генератор документации — программа или пакет программ, позволяющая получать документацию, предназначенную для программистов (документация на API) и/или для конечных пользователей системы, по особым образом комментированному исходному коду и, в некоторых случаях, по исполняемым модулям (полученным на выходе компилятора).
Обычно генератор анализирует исходный код программы, выделяя синтаксические конструкции, соответствующие значимым объектам программы (типам, классам и их членам/свойствам/методам, процедурам/функциям и т. п.). В ходе анализа также используется мета-информация об объектах программы, представленная в виде документирующих комментариев. На основе всей собранной информации формируется готовая документация, как правило, в одном из общепринятых форматов — HTML, HTMLHelp, PDF, RTF и других.
Документирующие комментарии
[править | править код]Документирующий комментарий — это особым образом оформленный комментарий к объекту программы, предназначенный для использования каким-либо конкретным генератором документации. От того, какой генератор документации применяется, зависит синтаксис конструкций, используемых в документирующих комментариях.
В документирующих комментариях может содержаться информация об авторе кода, описываться назначение объекта программы, смысл входных и выходных параметров — для функции/процедуры, примеры использования, возможные исключительные ситуации, особенности реализации.
Документирующие комментарии, как правило, оформляются как многострочные комментарии в стиле языка Си. В каждом случае комментарий должен находиться перед документируемым элементом. Первым символом в комментарии (и в начале строк комментария) должен быть *
. Блоки разделяются пустыми строками.
Пример документирующего комментария на языке PHP:
/**
* Имя или краткое описание объекта
*
* Развернутое описание
*
* @имя_дескриптора значение
* @return тип_данных
*/
Список дескрипторов phpDocumentor | ||
---|---|---|
Дескриптор | Описание | Пример |
@author |
Автор | /**
* Sample File 2, phpDocumentor Quickstart
*
* Файл из документации к phpDocumentor
* демонстрирующий способы комментирования.
* @author Greg Beaver <cellog@php.net>
* @version 1.0
* @package sample
* @subpackage classes
*/
|
@version |
Версия кода | |
@package |
Указывает пакет к которому относится код | |
@subpackage |
Указывает подпакет | |
@global |
Описание глобальных переменных | /**
* DocBlock для глобальной переменной
* @global integer $GLOBALS['myvar'] далее идет функция с с глобальной переменной
* или глобальная переменная, в этом случае необходимо указать ее имя
* @name $myvar
*/
$GLOBALS['myvar'] = 6;
|
@name |
Имя, метка | |
@staticvar |
Описание статических переменных | /**
* @staticvar integer $staticvar
* @return возвращает целое значение
*/
|
@return |
Описание возвращаемого значения | |
@todo |
Заметки для последующей реализации. | /**
* DocBlock с вложенными списками
* @todo Простой TODO список
* - item 1
* - item 2
* - item 3
* @todo Вложенный TODO список
* <ol>
* <li>item 1.0</li>
* <li>item 2.0</li>
* <ol>
* <li>item 2.1</li>
* <li>item 2.2</li>
* </ol>
* <li>item 3.0</li>
* </ol>
*/
|
@link |
Ссылка | /**
* Это пример {@link http://www.example.com встроенной гиперссылки}
*/
|
@deprecated (@deprec) |
Описание устаревшего блока | /**
* @deprecated описание
* @deprec синоним для deprecated
*/
|
@example |
Пример | /**
* @abstract
* @access public или private
* @copyright Имя дата
* @example /path/to/example
* @ignore
* @internal закрытая информация для специалистов
* @param тип [$varname] описание входного параметра
* @return тип описание возвращаемого значения
* @see имя другого элемента (ссылка)
* @since версия или дата
* @static
*/
|
@see |
Ссылка на другое место в документации | |
Другие дескрипторы | ||
@copyright · @license · @filesource · @category · @since · @abstract · @access · @example · @ignore · @internal · @static · @throws · @uses · @tutorial
|
Пример документирующего комментария к функции в программе на Java, предназначенного для использования Javadoc:
/**
* Проверяет, допустимый ли ход.
* Например, чтобы задать ход e2-e4, напишите isValidMove(5,2,5,4);
* @author John Doe
* @param theFromFile Вертикаль, на которой находится фигура (1=a, 8=h)
* @param theFromRank Горизонталь, на которой находится фигура (1...8)
* @param theToFile Вертикаль клетки, на которую выполняется ход (1=a, 8=h)
* @param theToRank Горизонталь клетки, на которую выполняется ход (1...8)
* @return true, если ход допустим, и false, если недопустим
*/
boolean isValidMove(int theFromFile, int theFromRank, int theToFile, int theToRank)
{
. . .
}
Популярные генераторы документации
[править | править код]Примеры для разных языков и сред программирования:
- Doc-O-Matic[англ.];
- Document! X предназначен для программ на языке VB6, языках: VB.NET/C#/Visual C++ .NET (.NET Framework 1.0, 1.1 и 2.0), COM-компонентов, баз данных Access, Microsoft SQL Server и Oracle, XML Schema и других языках описания XML;
- Doxygen — языках: C++, Си, Objective-C, Java, IDL, PHP, C#, Фортран, VHDL, Python и, частично, D;
- Epydoc — языке Python;
- Javadoc — языке Java;
- JSDoc — языке JavaScript;
- HappyDoc[1] — языке Python;
- PasDoc[2] — языке Delphi/Pascal;
- perldoc[3] — языке Perl (включен в стандартный дистрибутив);
- PhpDocumentor и PHPDoc (адаптация Javadoc для использования с PHP) — языке PHP;
- POD (англ.);
- RDoc[4] — языке Ruby;
- ROBODoc[5];
- TwinText (англ.);
- NDoc[6] — языках C#, VB.NET и других языках платформы .NET;
- Sandcastle — для C#, VB.NET и других языков платформы .NET;
- Sphinx — языке Python[7];
- VBdocman[8] — языке VB6;
- VSdocman (ранее VBdocman .NET) — языков VB.NET и C#;
- WEB / CWEB[9];
- XHelpGen — языке Delphi (входит в состав библиотеки KOL/MCK).
- PHPDox — проекты PHP.
Примечания
[править | править код]- ↑ HappyDoc Source Documentation . Дата обращения: 27 января 2006. Архивировано 27 ноября 2020 года.
- ↑ PasDoc — pasdoc . Дата обращения: 7 сентября 2009. Архивировано 20 декабря 2016 года.
- ↑ Perl programming documentation — perldoc.perl.org . Дата обращения: 17 июня 2009. Архивировано 30 января 2009 года.
- ↑ RDoc — Document Generator for Ruby Source . Дата обращения: 19 июня 2022. Архивировано 6 июня 2022 года.
- ↑ ROBODoc — automating the software documentation process . Дата обращения: 27 января 2006. Архивировано 13 мая 2011 года.
- ↑ NDoc Online . Дата обращения: 27 января 2006. Архивировано 3 июля 2006 года.
- ↑ Doug Hellmann, Writing Technical Documentation with Sphinx, Paver, and Cog Архивная копия от 16 января 2013 на Wayback Machine
- ↑ http://www.helixoft.com/vbdocman/ (недоступная ссылка)
- ↑ Knuth and Levy:CWEB Архивировано 20 ноября 2012 года.