From 7763427a8d55963c056bba94f6b519dc3e78e739 Mon Sep 17 00:00:00 2001 From: Patrick Lehmann Date: Fri, 23 Dec 2022 08:56:19 +0100 Subject: Testing complex documentation examples (#2275) * Testing complex examples. * Added comment annotations. * Removed duplicated file. --- testsuite/pyunit/libghdl/Comments.py | 14 ++- testsuite/pyunit/libghdl/examples/Complex.vhdl | 130 ------------------- .../pyunit/libghdl/examples/Complex_MultiLine.vhdl | 138 +++++++++++++++++++++ .../libghdl/examples/Complex_Multilines.vhdl | 138 --------------------- .../libghdl/examples/Complex_SingleLine.vhdl | 125 +++++++++++++++++++ 5 files changed, 271 insertions(+), 274 deletions(-) delete mode 100644 testsuite/pyunit/libghdl/examples/Complex.vhdl create mode 100644 testsuite/pyunit/libghdl/examples/Complex_MultiLine.vhdl delete mode 100644 testsuite/pyunit/libghdl/examples/Complex_Multilines.vhdl create mode 100644 testsuite/pyunit/libghdl/examples/Complex_SingleLine.vhdl (limited to 'testsuite') diff --git a/testsuite/pyunit/libghdl/Comments.py b/testsuite/pyunit/libghdl/Comments.py index b46eef82d..a9d593568 100644 --- a/testsuite/pyunit/libghdl/Comments.py +++ b/testsuite/pyunit/libghdl/Comments.py @@ -300,13 +300,15 @@ class CommentAssociation(Base): self.checkFile(self._root / "comments/line1.vhdl") -class Complex(Base): - @expectedFailure # "not yet handled" - def test_Comment2(self) -> None: +class SingleLine(Base): + def test_Complex(self) -> None: """More exhaustive""" - self.checkFile(self._root / "Complex.vhdl") + self.checkFile(self._root / "Complex_SingleLine.vhdl") - def test_complex(self) -> None: - self.checkFile(self._root / "Complex_Multilines.vhdl") + +class MultiLine(Base): + def test_Complex(self) -> None: + """More exhaustive""" + self.checkFile(self._root / "Complex_MultiLine.vhdl") # Empty line before to easy cut & put diff --git a/testsuite/pyunit/libghdl/examples/Complex.vhdl b/testsuite/pyunit/libghdl/examples/Complex.vhdl deleted file mode 100644 index 40eaa80ff..000000000 --- a/testsuite/pyunit/libghdl/examples/Complex.vhdl +++ /dev/null @@ -1,130 +0,0 @@ --- :e1: comments before desIgn units (javadoc / .net documentation style) --- :e1: mIGht be multiline -entity e1 is -end entitY; - --- :a1: comments before design units --- :a1: might be multiline -architecture a1 of e1 is -begin -end architecture; - --- :p1: comments before design units --- :p1: might be multiline -package p1 is -end package; - --- :ctx1: comments before design units --- :ctx1: might be multiline -context ctx1 is -end context; - --- :cfg1: comments before design units --- :cfg1: might be multiline -configuration cfg1 of e1 is - for a1 - end for; -end configuration; - - -library ieee; -use ieee.std_logic_1164.all; - -entity e2 is - -- :e2: comments in design units (python doc-string style) - -- :e2: might be multi line - generic ( - -- :FREQUENCY: comment before a generic - -- :FREQUENCY: might be multiline - constant FREQUENCY : positive; - constant BITS : positive; -- :BITS: comment after a generic are mostly single line, - -- :BITS: but could be multi line too - -- :BITS: in case comment is before and after - constant DEBUG : boolean -- :DEBUG: the after has presidency - ); - port ( - signal Clock : in std_logic -- :Clock: same as for generics - ); -end entity; - -architecture a2 of e2 is - -- :a2: comments in design units (python doc-string style) - -- :a2: might be multi line -begin - -end architecture; - --- :p2: As packages define public elements like constants, types and sub-programs, we are interested in such documentation too. -package p2 is - -- :p2: comments in design units (python doc-string style) - -- :p2: might be multi line - - -- :DEBUG: comment before - constant DEBUG : boolean := TRUE; - constant SYNC_STAGES : positive := 3; -- :SYNC_STAGES: comment after - - -- :AType1: comment before - type AType1 is array(natural range <>) of bit; - type AType2 is array(natural range <>) of bit; -- :AType2: comment after - - -- same applies to subtype, alias, attributes, ... - - -- :RType: comment before - type RType is record - -- :RType: xor comment inside - - -- :elem1: per element comment before (note the comment "block" is separated by newlines) - elem1 : integer; - elem2 : integer; -- :elem2: per element comment behind - end record; - - -- :log2: as functions are longer in definitions, it might be written before - function log2(param : positive) return natural; - - function log2( - -- :log2: otoh, we also want to document parameters too (similar to a record with comments) - - -- :param1: comment before - param1 : integer; - param2 : boolean -- :param2: comment after - ) return natural; - - -- this applies to procedures as well. - - - -end package; - -context ctx2 is - -- :ctx2: comments in design units (python doc-string style) - -- :ctx2: might be multi line -end context; - -configuration cfg2 of e2 is - -- :cfg2: comments in design units (python doc-string style) - -- :cfg2: might be multi line - for a2 - end for; -end configuration; - - - - - - - --- This should allow for any kind of documentation style and embedded documentation language. --- A real implementation might use similar rules are Python+docutils+Sphinx. Here we would e.g. --- document a function either before (or inside) a function declaration and use the --- :arg name: description --- syntax. - - --- :math: Package `math` provides math extensions not provided by the IEEE packages. -package math is - -- :log2: Computes the logarithm to base 2. - -- :log2: - -- :log2: :arg param: Input value - -- :log2: :returns: Logarithm - function log2(param : positive) return natural; -end package; diff --git a/testsuite/pyunit/libghdl/examples/Complex_MultiLine.vhdl b/testsuite/pyunit/libghdl/examples/Complex_MultiLine.vhdl new file mode 100644 index 000000000..01d7fe129 --- /dev/null +++ b/testsuite/pyunit/libghdl/examples/Complex_MultiLine.vhdl @@ -0,0 +1,138 @@ +/* :e1: comments before desIgn units (javadoc / .net documentation style) + * :e1: mIGht be multiline + */ +entity e1 is +end entitY; + +/* :a1: comments before design units + * :a1: might be multiline + */ +architecture a1 of e1 is +begin +end architecture; + +/* :p1: comments before design units + * :p1: might be multiline + */ +package p1 is +end package; + +/* package body should be supported too to keep parity, but I have currently no usecase for it. */ + +/* :ctx1: comments before design units + * :ctx1: might be multiline + */ +context ctx1 is +end context; + +/* :cfg1: comments before design units + * :cfg1: might be multiline + */ +configuration cfg1 of e1 is + for a1 + end for; +end configuration; + + +library ieee; +use ieee.std_logic_1164.all; + +entity e2 is + /* :e2: comments in design units (python doc-string style) + * :e2: might be multi line + */ + generic ( + /* :FREQUENCY: comment before a generic + * :FREQUENCY: might be multiline + */ + constant FREQUENCY : positive; + constant BITS : positive; /* :BITS: comment after a generic are mostly single line, + * :BITS: but could be multi line too + */ + /* in case comment is before and after */ + constant DEBUG : boolean /* :DEBUG: the after has presidency */ + ); + port ( + signal Clock : in std_logic /* :Clock: same as for generics */ + ); +end entity; + +architecture a2 of e2 is + /* :a2: comments in design units (python doc-string style) + * :a2: might be multi line + */ +begin + +end architecture; + +/* As packages define public elements like constants, types and sub-programs, we are interested in such documentation too. */ +package p2 is + /* :p2: comments in design units (python doc-string style) + * :p2: might be multi line + */ + + /* :DEBUG: comment before */ + constant DEBUG : boolean := TRUE; + constant SYNC_STAGES : positive := 3; /* :SYNC_STAGES: comment after */ + + /* :AType1: comment before */ + type AType1 is array(natural range <>) of bit; + type AType2 is array(natural range <>) of bit; /* :AType2: comment after */ + + /* same applies to subtype, alias, attributes, ... */ + + /* :RType: comment before */ + type RType is record + /* :RType: xor comment inside */ + + /* :elem1: per element comment before (note the comment "block" is separated by newlines) */ + elem1 : integer; + elem2 : integer; /* :elem2: per element comment behind */ + end record; + + /* :log2: as functions are longer in definitions, it might be written before */ + function log2(param : positive) return natural; + + function log2( + /* :log2: otoh, we also want to document parameters too (similar to a record with comments) */ + + /* :param1: comment before */ + param1 : integer; + param2 : boolean /* :param2: comment after */ + ) return natural; + + /* this applies to procedures as well. */ +end package; + +context ctx2 is + /* :ctx2: comments in design units (python doc-string style) + * :ctx2: might be multi line + */ +end context; + +configuration cfg2 of e2 is + /* :cfg2: comments in design units (python doc-string style) + * :cfg2: might be multi line + */ + for a2 + end for; +end configuration; + + +/* This should allow for any kind of documentation style and embedded documentation language. + * A real implementation might use similar rules are Python+docutils+Sphinx. Here we would e.g. + * document a function either before (or inside) a function declaration and use the + * :arg name: description + * syntax. + */ + + +/* :math: Package `math` provides math extensions not provided by the IEEE packages. */ +package math is + /* :log2: Computes the logarithm to base 2. + * :log2: + * :log2: :arg param: Input value + * :log2: :returns: Logarithm + */ + function log2(param : positive) return natural; +end package; diff --git a/testsuite/pyunit/libghdl/examples/Complex_Multilines.vhdl b/testsuite/pyunit/libghdl/examples/Complex_Multilines.vhdl deleted file mode 100644 index 01d7fe129..000000000 --- a/testsuite/pyunit/libghdl/examples/Complex_Multilines.vhdl +++ /dev/null @@ -1,138 +0,0 @@ -/* :e1: comments before desIgn units (javadoc / .net documentation style) - * :e1: mIGht be multiline - */ -entity e1 is -end entitY; - -/* :a1: comments before design units - * :a1: might be multiline - */ -architecture a1 of e1 is -begin -end architecture; - -/* :p1: comments before design units - * :p1: might be multiline - */ -package p1 is -end package; - -/* package body should be supported too to keep parity, but I have currently no usecase for it. */ - -/* :ctx1: comments before design units - * :ctx1: might be multiline - */ -context ctx1 is -end context; - -/* :cfg1: comments before design units - * :cfg1: might be multiline - */ -configuration cfg1 of e1 is - for a1 - end for; -end configuration; - - -library ieee; -use ieee.std_logic_1164.all; - -entity e2 is - /* :e2: comments in design units (python doc-string style) - * :e2: might be multi line - */ - generic ( - /* :FREQUENCY: comment before a generic - * :FREQUENCY: might be multiline - */ - constant FREQUENCY : positive; - constant BITS : positive; /* :BITS: comment after a generic are mostly single line, - * :BITS: but could be multi line too - */ - /* in case comment is before and after */ - constant DEBUG : boolean /* :DEBUG: the after has presidency */ - ); - port ( - signal Clock : in std_logic /* :Clock: same as for generics */ - ); -end entity; - -architecture a2 of e2 is - /* :a2: comments in design units (python doc-string style) - * :a2: might be multi line - */ -begin - -end architecture; - -/* As packages define public elements like constants, types and sub-programs, we are interested in such documentation too. */ -package p2 is - /* :p2: comments in design units (python doc-string style) - * :p2: might be multi line - */ - - /* :DEBUG: comment before */ - constant DEBUG : boolean := TRUE; - constant SYNC_STAGES : positive := 3; /* :SYNC_STAGES: comment after */ - - /* :AType1: comment before */ - type AType1 is array(natural range <>) of bit; - type AType2 is array(natural range <>) of bit; /* :AType2: comment after */ - - /* same applies to subtype, alias, attributes, ... */ - - /* :RType: comment before */ - type RType is record - /* :RType: xor comment inside */ - - /* :elem1: per element comment before (note the comment "block" is separated by newlines) */ - elem1 : integer; - elem2 : integer; /* :elem2: per element comment behind */ - end record; - - /* :log2: as functions are longer in definitions, it might be written before */ - function log2(param : positive) return natural; - - function log2( - /* :log2: otoh, we also want to document parameters too (similar to a record with comments) */ - - /* :param1: comment before */ - param1 : integer; - param2 : boolean /* :param2: comment after */ - ) return natural; - - /* this applies to procedures as well. */ -end package; - -context ctx2 is - /* :ctx2: comments in design units (python doc-string style) - * :ctx2: might be multi line - */ -end context; - -configuration cfg2 of e2 is - /* :cfg2: comments in design units (python doc-string style) - * :cfg2: might be multi line - */ - for a2 - end for; -end configuration; - - -/* This should allow for any kind of documentation style and embedded documentation language. - * A real implementation might use similar rules are Python+docutils+Sphinx. Here we would e.g. - * document a function either before (or inside) a function declaration and use the - * :arg name: description - * syntax. - */ - - -/* :math: Package `math` provides math extensions not provided by the IEEE packages. */ -package math is - /* :log2: Computes the logarithm to base 2. - * :log2: - * :log2: :arg param: Input value - * :log2: :returns: Logarithm - */ - function log2(param : positive) return natural; -end package; diff --git a/testsuite/pyunit/libghdl/examples/Complex_SingleLine.vhdl b/testsuite/pyunit/libghdl/examples/Complex_SingleLine.vhdl new file mode 100644 index 000000000..3f7fdc44c --- /dev/null +++ b/testsuite/pyunit/libghdl/examples/Complex_SingleLine.vhdl @@ -0,0 +1,125 @@ +-- :e1: comments before desIgn units (javadoc / .net documentation style) +-- :e1: mIGht be multiline +entity e1 is +end entitY; + +-- :a1: comments before design units +-- :a1: might be multiline +architecture a1 of e1 is +begin +end architecture; + +-- :p1: comments before design units +-- :p1: might be multiline +package p1 is +end package; + +--! :ctx1: package body should be supported too to keep parity, but I have currently no usecase for it. + +-- :ctx1: comments before design units +-- :ctx1: might be multiline +context ctx1 is +end context; + +-- :cfg1: comments before design units +-- :cfg1: might be multiline +configuration cfg1 of e1 is + for a1 + end for; +end configuration; + + +library ieee; +use ieee.std_logic_1164.all; + +entity e2 is + -- :e2: comments in design units (python doc-string style) + -- :e2: might be multi line + generic ( + -- :FREQUENCY: comment before a generic + -- :FREQUENCY: might be multiline + constant FREQUENCY : positive; + constant BITS : positive; -- :BITS: comment after a generic are mostly single line, + -- :BITS: but could be multi line too + + -- :DEBUG: in case comment is before and after + constant DEBUG : boolean -- :DEBUG: the after has presidency + ); + port ( + signal Clock : in std_logic -- :Clock: same as for generics + ); +end entity; + +architecture a2 of e2 is + -- :a2: comments in design units (python doc-string style) + -- :a2: might be multi line +begin + +end architecture; + +-- :p2: As packages define public elements like constants, types and sub-programs, we are interested in such documentation too. +package p2 is + -- :p2: comments in design units (python doc-string style) + -- :p2: might be multi line + + -- :DEBUG: comment before + constant DEBUG : boolean := TRUE; + constant SYNC_STAGES : positive := 3; -- :SYNC_STAGES: comment after + + -- :AType1: comment before + type AType1 is array(natural range <>) of bit; + type AType2 is array(natural range <>) of bit; -- :AType2: comment after + + --! :AType2: same applies to subtype, alias, attributes, ... + + -- :RType: comment before + type RType is record + -- :RType: xor comment inside + + -- :elem1: per element comment before (note the comment "block" is separated by newlines) + elem1 : integer; + elem2 : integer; -- :elem2: per element comment behind + end record; + + --! :elem2: as functions are longer in definitions, it might be written before + function log2(param : positive) return natural; + + function log2( + --! :param1: otoh, we also want to document parameters too (similar to a record with comments) + + -- :param1: comment before + param1 : integer; + param2 : boolean -- :param2: comment after + ) return natural; + + --! :param2: this applies to procedures as well. +end package; + +context ctx2 is + -- :ctx2: comments in design units (python doc-string style) + -- :ctx2: might be multi line +end context; + +configuration cfg2 of e2 is + -- :cfg2: comments in design units (python doc-string style) + -- :cfg2: might be multi line + for a2 + end for; +end configuration; + + +--! :cfg2: This should allow for any kind of documentation style and embedded documentation language. +--! :cfg2: A real implementation might use similar rules are Python+docutils+Sphinx. Here we would e.g. +--! :cfg2: document a function either before (or inside) a function declaration and use the +--! :cfg2: :arg name: description +--! :cfg2: syntax. + + +-- :math: Package `math` provides math extensions not provided by the IEEE packages. +package math is + -- :log2: Computes the logarithm to base 2. + -- :log2: + -- :log2: :arg param: Input value + -- :log2: :returns: Logarithm + function log2(param : positive) return natural; +end package; -- cgit v1.2.3