-
Notifications
You must be signed in to change notification settings - Fork 749
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
Safe epoxy char sequence #4837
Safe epoxy char sequence #4837
Conversation
…utation of the CharSequence, which can happen during rendering
Or use String if possible
9c602a7
to
4642299
Compare
private val hash = charSequence.toString().hashCode() | ||
|
||
override fun hashCode() = hash | ||
override fun equals(other: Any?) = other is EpoxyCharSequence && other.hash == hash |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We do not compare the String content, since the risk of collision is low enough, and Epoxy is mainly using hashCode() to compare items
@@ -1,5 +1,5 @@ | |||
/* | |||
* Copyright (c) 2021 New Vector Ltd | |||
* Copyright (c) 2022 New Vector Ltd |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Happy new year!
@@ -33,7 +33,7 @@ import im.vector.app.core.extensions.setAttributeTintedImageResource | |||
abstract class RadioButtonItem : VectorEpoxyModel<RadioButtonItem.Holder>() { | |||
|
|||
@EpoxyAttribute | |||
var title: CharSequence? = null | |||
var title: String? = null |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Whenever a CharSequence is not required, it simpler to use an immutable String
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just one comment, otherwise LGTM
/** | ||
* Wrapper for a CharSequence, which support mutation of the CharSequence, which can happen during rendering | ||
*/ | ||
class EpoxyCharSequence(val charSequence: CharSequence) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe let the EpoxyCharSequence inherits CharSequence like this, to avoid accessing charSequence value everywhere
class EpoxyCharSequence(val charSequence: CharSequence) : CharSequence by charSequence
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good idea, let me try it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
According to @ganfra investigation, it can work using
class EpoxyCharSequence(val charSequence: CharSequence) : Spannable by SpannableString(charSequence) {...}
but I prefer not to create a new SpannableString for each charSequence.
Using .charSequence
whenever it is necesssary is probably better, because it forces the developer to do it (no "hidden magic")
Using CharSequence in Epoxy item is not safe, since CharSequence are no immutable.
This PR introduce a wrapper for CharSequences used in Epoxy. If CharSequence is not mandatory, use immutable String.