-
Notifications
You must be signed in to change notification settings - Fork 143
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
Update Peniko #769
Update Peniko #769
Conversation
This builds on linebender/peniko#85 |
vello_encoding/src/ramp_cache.rs
Outdated
entry.1 = self.epoch; | ||
entry.0 | ||
} else if self.map.len() < RETAINED_COUNT { | ||
let id = (self.data.len() / N_SAMPLES) as u32; | ||
self.data.extend(make_ramp(stops)); | ||
self.map.insert(stops.into(), (id, self.epoch)); | ||
self.map | ||
.insert(CacheKey(ColorStops(stops.into())), (id, self.epoch)); |
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.
I'm not thrilled about this change to ColorStops(stops.into())
rather than perhaps going and doing some better impls for From
or something in Peniko.
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.
linebender/peniko#86 allows for CacheKey(ColorStops::from(stops))
/ CacheKey(stops.into())
.
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.
But really this copying of the color stops just to serve as key seems suboptimal since what we could probably do this with the Range<usize>
that we have available in the resolver code. But that's not for this PR.
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 can't currently do that ... I just tried, but we can't rely on data in the Resources::color_stops
being uniqued, so we can't use the range of it as a key.
@DJMcNab This is to help make sure that all is well before we go and publish the new version of Peniko so this doesn't have to land by itself yet ... |
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.
I think this is fine. IWBN to avoid the need to allocate for get
to allocate. But given that we probably should be using the entry API here anyway (which would allocate), it's probably fine.
vello_encoding/src/ramp_cache.rs
Outdated
@@ -35,13 +36,14 @@ impl RampCache { | |||
} | |||
|
|||
pub(crate) fn add(&mut self, stops: &[ColorStop]) -> u32 { | |||
if let Some(entry) = self.map.get_mut(stops) { | |||
if let Some(entry) = self.map.get_mut(&CacheKey(ColorStops(stops.into()))) { |
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.
This is not ideal, as it allocates "unnecessarily". It really complicates the traits in the Color crate to make this work nicely, I think.
31e7634
to
4a3f672
Compare
4a3f672
to
e53d2d9
Compare
No description provided.