Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Wrapping doesn't work at all when there is an argument list? #174

Open
benjamin-kirkbride opened this issue Apr 9, 2023 · 2 comments
Open
Labels
C: stakeholder Relates to docformatter stakeholder requested behavior question Questions related to docformatter
Milestone

Comments

@benjamin-kirkbride
Copy link

I may be ignorant or missing something. Here are some examples:

    """Split audio at silences to keep under the size limit.

    It's important to split near the middle of a silent section to prevent splitting on a spoken word and causing
    issues with transcription and diarization.

    Args:
        silent_sections: list of silent sections in ms.
        duration: total length of audio in ms
        audio_size: total size of audio file in bytes
        max_file_size: maximum file size that may exist after splits

    Returns:
        List of points in ms to use to split the audio file into chunks.
    """

Running docformatter on the above does nothing, unless I specify --force-wrap which does what I want for the long line, but botches the argument list:

    """Split audio at silences to keep under the size limit.

    It's important to split near the middle of a silent section to
    prevent splitting on a spoken word and causing issues with
    transcription and diarization.

    Args:     silent_sections: list of silent sections in ms.
    duration: total length of audio in ms     audio_size: total size of
    audio file in bytes     max_file_size: maximum file size that may
    exist after splits

    Returns:     List of points in ms to use to split the audio file
    into chunks.
    """

Compare to what happens if I remove the lists, and also remove --force-wrap:

    """Split audio at silences to keep under the size limit.

    It's important to split near the middle of a silent section to
    prevent splitting on a spoken word and causing issues with
    transcription and diarization.
    """

Is wrapping all or nothing; if there are lists no lines get wrapped? Or are my arg/returns lists malformed? Any insight is appreciated!

@github-actions github-actions bot added the fresh This is a new issue label Apr 9, 2023
@weibullguy
Copy link
Member

docformatter doesn't know how to handle various directives at the moment. It's the next "big thing" I plan to work on. See #58, #60, #68, and #78.

@weibullguy weibullguy added question Questions related to docformatter and removed fresh This is a new issue labels Apr 10, 2023
@weibullguy weibullguy added the C: stakeholder Relates to docformatter stakeholder requested behavior label Apr 25, 2023
@weibullguy weibullguy added this to the v1.8.0 milestone May 15, 2023
@glenn-jocher
Copy link

glenn-jocher commented Jul 21, 2024

+1, docformatter is wrapping summaries nicely for me but not descriptions (i.e. the paragraph under the summary):

docformatter \
--wrap-summaries 120 \
--wrap-descriptions 120 \
--in-place \
--pre-summary-newline \
--close-quotes-on-newline \
--recursive \
.

This second line should be reformatted into a small paragraph but is not:

"""
Initializes a new model and infers the task type from the model definitions.

This method creates a new model instance based on the provided configuration file. It loads the model configuration, infers the task type if not specified, and initializes the model using the appropriate class from the task map.

Parameters:
    cfg (str): Path to the model configuration file in YAML format.
    task (str | None): The specific task for the model. If None, it will be inferred from the config.
    model (torch.nn.Module | None): A custom model instance. If provided, it will be used instead of creating a new one.
    verbose (bool): If True, displays model information during loading.

Raises:
    ValueError: If the configuration file is invalid or the task cannot be inferred.
    ImportError: If the required dependencies for the specified task are not installed.

Examples:
    >>> model = Model()
    >>> model._new('yolov8n.yaml', task='detect', verbose=True)
"""

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
C: stakeholder Relates to docformatter stakeholder requested behavior question Questions related to docformatter
Projects
None yet
Development

No branches or pull requests

3 participants