From 8052b98f596db048467c0c57cbaac1d3a27687ad Mon Sep 17 00:00:00 2001 From: Hans Bolinder Date: Tue, 22 Jun 2010 09:42:44 +0200 Subject: Make Erlang specifications and types available in EDoc It is now possible to use Erlang specifications and types in EDoc documentation. Erlang specifications and types will be used unless there is also a function specification (@spec) or a type alias (@type) with the same name. In the current implementation the placement of -spec matters: it should be placed where the @spec would otherwise have been placed. Not all Erlang types are included in the documentation, but only those exported by some export_type declaration or used by some documented Erlang specification (-spec). There is currently no support for overloaded Erlang specifications. The syntax definitions of EDoc have been augmented to cope with most of the Erlang types. (But we recommend that Erlang types should be used instead.) edoc:read_source() takes one new option, report_missing_types. edoc_layout:module() takes one new option, pretty_printer. --- lib/edoc/doc/overview.edoc | 103 ++++++++++++++++++++++++++++++++++++++++--- lib/edoc/doc/src/Makefile | 2 +- lib/edoc/doc/src/ref_man.xml | 2 +- 3 files changed, 99 insertions(+), 8 deletions(-) (limited to 'lib/edoc/doc') diff --git a/lib/edoc/doc/overview.edoc b/lib/edoc/doc/overview.edoc index 9b25c17b1f..bd603b7a13 100644 --- a/lib/edoc/doc/overview.edoc +++ b/lib/edoc/doc/overview.edoc @@ -205,8 +205,12 @@ The following tags can be used anywhere within a module: the text. See {@section Type specifications} for syntax and examples. All data type descriptions are placed in a separate section of - the documentation, regardless of where the tags occur. + the documentation, regardless of where the tags occur. + Instead of specifying the complete type alias in an EDoc + documentation comment, type definitions from the actual + Erlang code can be re-used for documentation. + See {@section Type specifications} for examples. @@ -405,7 +409,12 @@ The following tags can be used before a function definition: included in the specification, it must match the name in the actual code. When parameter names are not given in the specification, suitable names will be taken from the source - code if possible, and otherwise synthesized. + code if possible, and otherwise synthesized. + + Instead of specifying the complete function type in an EDoc + documentation comment, specifications from the actual + Erlang code can be re-used for documentation. + See {@section Type specifications} for examples.
`@throws'
Specifies which types of terms may be thrown by the @@ -763,6 +772,17 @@ following escape sequences may be used:
=== Function specifications === +Although the syntax described in the following can still be used +for specifying functions we recommend that Erlang specifications as +described in Types +and Function Specification should be added to the source +code instead. This way the analyses of Dialyzer's can be utilized in the +process of keeping the documentation consistent and up-to-date. +Erlang specifications will be used unless there is also a function +specification (a `@spec' tag followed by a type) with the same name. + + The following grammar describes the form of the specifications following a `@spec' tag. A '`?'' suffix implies that the element is optional. Function types have higher precedence than union types; e.g., "`(atom()) @@ -818,15 +838,50 @@ not as `(atom()) -> (atom() | integer())'.
| Atom
| Integer
| Float +
| Integer ".." Integer
| FunType +
| "fun(" FunType ")" +
| "fun(...)"
| "{" UnionTypes? "}" +
| "#" Atom "{" Fields? "}"
| "[" "]"
| "[" UnionType "]" +
| "[" UnionType "," "..." "]"
| "(" UnionType ")" +
| BinType
| TypeName "(" UnionTypes? ")"
| ModuleName ":" TypeName "(" UnionTypes? ")"
| "//" AppName "/" ModuleName ":" TypeName "(" UnionTypes? ")" + + Fields + ::= + Field +
| Fields "," Fields
+ + + Field + ::= + Atom "=" UnionList + + + BinType + ::= + "<<>>" +
| "<<" BaseType ">>" +
| "<<" UnitType ">>" +
| "<<" BaseType "," UnitType ">>"
+ + + BaseType + ::= + "_" ":" Integer + + + UnitType + ::= + "_" ":" "_" "*" Integer + TypeVariable ::= @@ -858,7 +913,7 @@ not as `(atom()) -> (atom() | integer())'. Def ::= - TypeVariable "=" UnionType + TypeVariable "=" UnionList
| TypeName "(" TypeVariables? ")" "=" UnionType
@@ -872,6 +927,9 @@ not as `(atom()) -> (atom() | integer())'. Examples: +``` + -spec my_function(X :: integer()) -> integer(). + %% @doc Creates ...''' ``` %% @spec my_function(X::integer()) -> integer()''' ``` @@ -895,6 +953,8 @@ Examples: ``` %% @spec close(graphics:window()) -> ok''' +The first example shows the recommended way of specifying functions. + In the above examples, `X', `A', `B', and `File' are parameter names, used for referring to the parameters from the documentation text. The type variables @@ -930,6 +990,13 @@ contain any annotations at all. === Type definitions === +Although the syntax described in the following can still be used +for specifying types we recommend that Erlang types as described in + Types and Function +Specification should be added to the source code instead. +Erlang types will be used unless there is a type alias with the same +name. + The following grammar (see above for auxiliary definitions) describes the form of the definitions that may follow a `@type' tag: @@ -939,13 +1006,18 @@ the form of the definitions that may follow a `@type' tag: Typedef ::= TypeName "(" TypeVariables? ")" DefList? -
| TypeName "(" TypeVariables? ")" "=" UnionType DefList?
+
| TypeName "(" TypeVariables? ")" "=" UnionList DefList?
(For a truly abstract data type, no equivalence is specified.) The main definition may be followed by additional local definitions. Examples: +``` + -type my_list(X) :: [X]. %% A special kind of lists ...''' +``` + -opaque another_list(X) :: [X]. + %% another_list() is a kind of list...''' ``` %% @type myList(X). A special kind of lists ...''' ``` @@ -955,6 +1027,7 @@ definition may be followed by additional local definitions. Examples: %% A = term(). %% A kind of wrapper type thingy.''' +The first two examples show the recommended way of specifying types. === Pre-defined data types === @@ -962,24 +1035,42 @@ The following data types are predefined by EDoc, and may not be redefined: ``` any() + arity() atom() binary() - bool() + bitstring() + bool() (allowed, but use boolean() instead) + boolean() + byte() char() cons() deep_string() float() function() integer() + iodata() + iolist() list() + maybe_improper_list() + mfa() + module() nil() + neg_integer() + node() + non_neg_integer() + nonempty_improper_list() + nonempty_list() + nonempty_maybe_improper_list() + nonempty_string() none() number() pid() port() + pos_integer() reference() string() term() + timeout() tuple() ''' Details: @@ -991,7 +1082,7 @@ Details: `integer()', `pid()', `port()' and `reference()' are primitive data types of the Erlang programming language. -
  • `bool()' is the subset of `atom()' consisting +
  • `boolean()' is the subset of `atom()' consisting of the atoms `true' and `false'.
  • `char()' is a subset of `integer()' representing character codes.
  • diff --git a/lib/edoc/doc/src/Makefile b/lib/edoc/doc/src/Makefile index 748691d173..5ee0096f0f 100644 --- a/lib/edoc/doc/src/Makefile +++ b/lib/edoc/doc/src/Makefile @@ -105,7 +105,7 @@ man: $(MAN3_FILES) $(XML_REF3_FILES): escript $(DOCGEN)/priv/bin/xml_from_edoc.escript -def vsn $(EDOC_VSN) -i $(ERL_TOP)/lib/edoc/include $(SRC_DIR)/$(@:%.xml=%.erl) -$(XML_CHAPTER_FILES): +$(XML_CHAPTER_FILES): ../overview.edoc escript $(DOCGEN)/priv/bin/xml_from_edoc.escript -def vsn $(EDOC_VSN) -chapter ../overview.edoc gifs: $(GIF_FILES:%=$(HTMLDIR)/%) diff --git a/lib/edoc/doc/src/ref_man.xml b/lib/edoc/doc/src/ref_man.xml index 619fbaa7ca..a9af8740b9 100644 --- a/lib/edoc/doc/src/ref_man.xml +++ b/lib/edoc/doc/src/ref_man.xml @@ -4,7 +4,7 @@
    - 20062009 + 20062011 Ericsson AB. All Rights Reserved. -- cgit v1.2.3 From 91b2e57ea0e3ab794d4b57a12ef10205383525a5 Mon Sep 17 00:00:00 2001 From: Erlang/OTP Date: Mon, 14 Mar 2011 18:18:42 +0100 Subject: Prepare release --- lib/edoc/doc/src/notes.xml | 55 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 55 insertions(+) (limited to 'lib/edoc/doc') diff --git a/lib/edoc/doc/src/notes.xml b/lib/edoc/doc/src/notes.xml index afcccf22b5..c18a126264 100644 --- a/lib/edoc/doc/src/notes.xml +++ b/lib/edoc/doc/src/notes.xml @@ -31,6 +31,61 @@

    This document describes the changes made to the EDoc application.

    +
    Edoc 0.7.7 + +
    Fixed Bugs and Malfunctions + + +

    Add encoding when parsing Wiki text. EDoc used to + fail on strings such as "δεφ". (Thanks to Richard + Carlsson.)

    +

    + Own Id: OTP-9109

    +
    +
    +
    + + +
    Improvements and New Features + + +

    It is now possible to use Erlang specifications and + types in EDoc documentation. Erlang specifications and + types will be used unless there is also a function + specification (@spec) or a type alias + (@type) with the same name. In the current + implementation the placement of -spec matters: it + should be placed where the @spec would otherwise + have been placed.

    +

    Not all Erlang types are included in the + documentation, but only those exported by some + export_type declaration or used by some documented + Erlang specification (-spec).

    +

    There is currently no support for overloaded Erlang + specifications.

    +

    The syntax definitions of EDoc have been augmented to + cope with most of the Erlang types. (But we recommend + that Erlang types should be used instead.)

    +

    edoc:read_source() takes one new option, + report_missing_types. edoc_layout:module() + takes one new option, pretty_printer.

    +

    + Own Id: OTP-8525

    +
    + +

    The edoc_lib module is meant to be private, + but since it is referred to from other man pages it has + been included in the OTP documentation. The modifications + introduced in this ticket make all functions private + except those referred to from other pages.

    +

    + Own Id: OTP-9110

    +
    +
    +
    + +
    +
    Edoc 0.7.6.8
    Improvements and New Features -- cgit v1.2.3