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

[core] Utility classes in pmd 7 #2873

Closed
Tracked by #3898
oowekyala opened this issue Oct 26, 2020 · 0 comments
Closed
Tracked by #3898

[core] Utility classes in pmd 7 #2873

oowekyala opened this issue Oct 26, 2020 · 0 comments
Labels
an:enhancement An improvement on existing features / rules
Milestone

Comments

@oowekyala
Copy link
Member

Currently on master, all of the nspmd.util package was marked internal (#2060), and we have a few utility classes in nspmd.internal.util. Some of those are used in other pmd modules (IteratorUtil, StringUtil, CollectionUtil).

I think we should be strict about usage of internal API, ie, even modules in the main repo should not have access to pmd core's internal API.

I think we should have public utilities in nspmd.util, and a nspmd.util.internal for utils that are only relevant to pmd core (eg, IOUtil).

Public ones include at least:

  • IteratorUtil (should be moved from nspmd.internal.util)
  • CollectionUtil
  • StringUtil
  • AssertionUtil
  • GraphUtil (used in pmd-java)

Plus stuff like OptionalBool and DataMap. Publishing IteratorUtil also allows us to remove DesignerIteratorUtil from the designer codebase (it was intentionally copied to not depend on pmd-core's internals).

Other things should be internal (esp. FileUtil and IOUtil, which are only relevant to pmd-core).

We can also use the InternalApiUsage rule to verify that there is no internal api leak across our codebase.

Refs #995

@oowekyala oowekyala added the an:enhancement An improvement on existing features / rules label Oct 26, 2020
@oowekyala oowekyala added this to the 7.0.0 milestone Oct 26, 2020
@oowekyala oowekyala changed the title Utility classes in pmd 7 [core] Utility classes in pmd 7 Nov 2, 2020
@oowekyala oowekyala mentioned this issue Apr 7, 2022
55 tasks
@oowekyala oowekyala mentioned this issue Apr 30, 2022
5 tasks
@adangel adangel modified the milestones: 7.0.0, 7.x Jan 23, 2023
@oowekyala oowekyala modified the milestones: 7.x, 7.0.0 Jan 23, 2023
adangel added a commit that referenced this issue Jan 30, 2023
@adangel adangel closed this as completed Jan 30, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
an:enhancement An improvement on existing features / rules
Projects
None yet
Development

No branches or pull requests

2 participants