Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

Expose controls on which block, method, relation can be included in uml diagram #108

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

vignesh14052002
Copy link

@vignesh14052002 vignesh14052002 commented Jul 27, 2024

For my usecase, I need to ignore some portions in the uml diagram whenever i was generating, thought it would be useful for others as well, so raising this PR

Usage

from py2puml.domain.umlrelation import UmlRelation
from py2puml.domain.umlclass import UmlMethod
from py2puml.domain.umlitem import UmlItem
from py2puml.export.puml import Filters
from py2puml.py2puml import py2puml

def skip_block(item: UmlItem) -> bool:
    return item.fqn.endswith('<block-to-ignore>')

def skip_relation(relation: UmlRelation) -> bool:
    return relation.source_fqn.endswith('<relation-source>') and relation.target_fqn.endswith('<relation-target>')

filters = Filters(skip_block, skip_relation)

puml_content = "".join(
        py2puml(
            'py2puml/domain',
            'py2puml.domain',
            filters
        )
    )

@lucsorel
Copy link
Owner

lucsorel commented Jul 28, 2024

hi @vignesh14052002, thank you for your pull-request 🙏

I am lacking free time to handle the PRs on this project for the moment and there are several that should be merged first, I am sorry to keep you waiting.

However, I had a quick look at the changes that you proposed and I feel like the naming of the filtering functions that you proposed is not clear enough 🤔 since it is not a matter of "validity". I think that such functions should be called skip_block rather than "not is_block_valid". Maybe all the "skip" functions should be passed in a filtering object rather than in the kwargs.

The whole idea of filtering out unwanted contents is good though, I am just not fond of the implementation as it is now. Let's give that some time and thoughts before being merged. And the PR lacks unit tests, which is a requirement to have it merged (see https://github.com/lucsorel/py2puml/blob/main/CONTRIBUTING.md#unit-tests). It also lacks documentation in the readme.md file, but let's do that after redesigning the feature request.

@lucsorel lucsorel added enhancement New feature or request help wanted Extra attention is needed in progress Somebody is working on it labels Jul 28, 2024
@vignesh14052002
Copy link
Author

hi @lucsorel , Thank you for your feedback , made the suggested changes, added tests and docs. There’s no rush to review the PR as we have implemented the necessary changes locally and are using the builded .whl file. We will switch to the official package once this PR is merged.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed in progress Somebody is working on it
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants