Skip to content

Improve @property documentation #39

@leandro-lucarella-frequenz

Description

What's needed?

Right now we are documenting properties as if they were functions (a description and a Return section are both required), but they are clearly not.

Google style says properties should be documented as attributes (in the class documentation) but darglint doesn't support this.

Proposed solution

  • Properties:
    • @properties are rendered as function (with a special mark for being a property), but this is planned to be improved in the future to be shown as attributes (see Use MkDocs to build the documentation frequenz-channels-python#25 (comment)).

    • Removing documentation from the function and using Attributes: instead somewhat works, but you only get a table in the Class documentation, attributes are not shown in the right ToC, which makes them hard to discover IMHO.

    • The best approach to @properties, that works well with pydocstyle and darglint seems to be the following:

      class AClass:
          """A class."""
      
          @property
          def a_prop(self) -> int:
              """Get the a prop.
      
              Returns:
                  The a prop of the class.
              """
              return 1
      
          @a_prop.setter
          def a_prop(self, a: int) -> None:
              pass

      image

      The only downside is properties are still listed as functions, not attributes (but this will change, so all good with this), and there is redundancy in the documentation (basically we need to document it twice, one for the description and one for the Returns:. mkdocstrings doesn't show the type if Returns: is not specified, and if the description is not included, pydocstyle complains.

So far the only option seems to be fixing the issue in the upstream darglint tool.

Use cases

No response

Alternatives and workarounds

We tried to use # noqa as suggested in the darglint issue but according to @jakub-toptal it doesn't work:

Before:

@property
def microgrid_api_client(self) -> MicrogridApiClient:
    """Get MicrogridApiClient.

    Returns:
        api client
    """
    return self._api

After:

    @property  # noqa
    def microgrid_api_client(self) -> MicrogridApiClient:  # noqa
        """Get MicrogridApiClient."""  # noqa
        return self._api  # noqa

Still fails with darglint code: DAR201

Additional context

There is a darglint issue for this, and at some point we might want to give it a shot to improve property handling in darglint:

Metadata

Metadata

Assignees

Labels

part:docsAffects the documentationtype:enhancementNew feature or enhancement visitble to users

Type

No type

Projects

Status

In progress

Relationships

None yet

Development

No branches or pull requests

Issue actions