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

refactor: ListItem construction #3370

Conversation

ilandikov
Copy link
Collaborator

@ilandikov ilandikov commented Mar 5, 2025

Types of changes

Done by pairing with @claremacrae

Internal changes:

  • Refactor (prefix: refactor - non-breaking change which only improves the design or structure of existing code, and making no changes to its external behaviour)
  • Tests (prefix: test - additions and improvements to unit tests and the smoke tests)

Description

  • Add ListItem.fromListItemLine() method, similar to Task.fromLine()
  • Use ListItem.fromListItemLine() instead of the constructor
  • Use destructured parameter in ListItem constructor similar to Task

Motivation and Context

  • Make ListItem shape and patters similar to Task

This is in preparation for allowing ListItem.fromListItemLine() to return null if given a non-list-item line.

How has this been tested?

  • Unit tests

Checklist

  • My code follows the code style of this project and passes yarn run lint.
  • My change has adequate Unit Test coverage.

Terms

Copy link

sonarqubecloud bot commented Mar 5, 2025

@claremacrae claremacrae added the type: internal Only regards development or contributing label Mar 5, 2025
@claremacrae
Copy link
Collaborator

Make ListItem constructor private and use ListItem.fromListItemLine() instead

I'm not seeing that change in the diffs... It looks public still to me.

Having said that, the Tasks constructor is also public, and that works fine.
So I guess making it protected was a useful temporary step to confirm we had caught all cases - and it's fine now that it's public...

@ilandikov
Copy link
Collaborator Author

Make ListItem constructor private and use ListItem.fromListItemLine() instead

I'm not seeing that change in the diffs... It looks public still to me.

Having said that, the Tasks constructor is also public, and that works fine. So I guess making it protected was a useful temporary step to confirm we had caught all cases - and it's fine now that it's public...

Ah, right. Fixed in the description

@claremacrae claremacrae merged commit a1be7ea into obsidian-tasks-group:main Mar 5, 2025
3 checks passed
@claremacrae
Copy link
Collaborator

Thank you!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: internal Only regards development or contributing
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants