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

Make data classes in db package immutable #1210

Closed
2 tasks
rfc2822 opened this issue Jan 1, 2025 · 5 comments · Fixed by #1218
Closed
2 tasks

Make data classes in db package immutable #1210

rfc2822 opened this issue Jan 1, 2025 · 5 comments · Fixed by #1218
Assignees
Labels
refactoring Internal improvement of existing functions

Comments

@rfc2822
Copy link
Member

rfc2822 commented Jan 1, 2025

Currently we have var properties in the database entity data classes.

I think there should be only immutable data classes, at least they're immutable in the documentation.

  • Check whether we really need mutable data classes.
  • Either document why or make them immutable.
@rfc2822 rfc2822 added the refactoring Internal improvement of existing functions label Jan 1, 2025
@sunkup
Copy link
Member

sunkup commented Jan 2, 2025

While it's not shown in the examples, they don't say that it's outright "bad" to use mutable properties for the room data class entities and I think it's quite convenient to be honest. We can make all of them immutable, but we would have to create copies of the original entity objects every time we want to change values. So

  localHomeset.displayName = ...
  localHomeset.privBind =  ...
  homeSetRepository.insertOrUpdateByUrl(localHomeset)

becomes

  val newLocalHomeset = localHomeset.copy(
      displayName =  ...,
      privBind =  ...
  )
  homeSetRepository.insertOrUpdateByUrl(newLocalHomeset)

and I don't really see the benefit in that. In the PR I have made the properties immutable which are not updated.

@sunkup sunkup linked a pull request Jan 2, 2025 that will close this issue
4 tasks
@rfc2822
Copy link
Member Author

rfc2822 commented Jan 3, 2025

I think it's quite convenient to be honest. We can make all of them immutable, but we would have to create copies of the original entity objects every time we want to change values.

While I agree that it's convenient (which is probably the reason why they are not immutable at the moment), I wonder whether it's a sign of bad design when data transfer objects are used as a place where modifications etc happen.

When we pass for instance a Collection around, immutable objects would prevent methods from changing fields without saving the object. When we have to make a copy, it makes it explicit that this is only a copy, so it must be saved to the database with an extra call.

I found a lot of article about this topic out there, with different conclusions. So it seems like a matter of taste.

Another question, if we'd choose mutability, is: which properties should be mutable and which not? Or probably just var for anything by default?

So I'd go either the one or the other way, but mixing (like in the current codebase, where we have many vars and then for instance some vals in SyncStats) seems strange to me.

So what do you think? Also @ArnyminerZ

@sunkup
Copy link
Member

sunkup commented Jan 6, 2025

I do not have a strong opinion on this. I like the ease of use with mutable properties, but also see the security/stability immutability brings. I am fine with either.

@rfc2822
Copy link
Member Author

rfc2822 commented Jan 7, 2025

I do not have a strong opinion on this. I like the ease of use with mutable properties, but also see the security/stability immutability brings. I am fine with either.

Ok, so let's make them immutable :)

@ArnyminerZ
Copy link
Member

So what do you think? Also @ArnyminerZ

I'd stick with immutable for all data classes. Even though that it's a bit more code, I think it can lead to better practices. Mainly for lists, which I think is what has most issues with Compose.

Another question, if we'd choose mutability, is: which properties should be mutable and which not? Or probably just var for anything by default?

In that regard, since I don't think is ever good to mix var with val, and we really should make some variables val, I'd just stick with everything like that, and use copy whenever is needed.

@github-project-automation github-project-automation bot moved this from Todo to Done in DAVx⁵ Releases Jan 10, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
refactoring Internal improvement of existing functions
Projects
Status: Done
Development

Successfully merging a pull request may close this issue.

3 participants