mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-12 20:18:59 +01:00
restorable: Refactoring: Make functions more atomic
This commit is contained in:
parent
99f72a1b64
commit
c47b549fd1
@ -335,13 +335,12 @@ func (i *Image) restore() error {
|
||||
//
|
||||
// After disposing, calling the function of the image causes unexpected results.
|
||||
func (i *Image) Dispose() {
|
||||
theImages.makeStaleIfDependingOn(i)
|
||||
theImages.remove(i)
|
||||
i.image.Dispose()
|
||||
i.image = nil
|
||||
i.basePixels = nil
|
||||
i.drawImageHistory = nil
|
||||
i.stale = false
|
||||
theImages.remove(i)
|
||||
runtime.SetFinalizer(i, nil)
|
||||
}
|
||||
|
||||
|
@ -76,15 +76,16 @@ func Restore() error {
|
||||
// add adds img to the images.
|
||||
func (i *images) add(img *Image) {
|
||||
i.m.Lock()
|
||||
defer i.m.Unlock()
|
||||
i.images[img] = struct{}{}
|
||||
i.m.Unlock()
|
||||
}
|
||||
|
||||
// remove removes img from the images.
|
||||
func (i *images) remove(img *Image) {
|
||||
i.m.Lock()
|
||||
defer i.m.Unlock()
|
||||
i.makeStaleIfDependingOnImpl(img)
|
||||
delete(i.images, img)
|
||||
i.m.Unlock()
|
||||
}
|
||||
|
||||
// resolveStaleImages resolves stale images.
|
||||
@ -105,13 +106,17 @@ func (i *images) resolveStaleImages() error {
|
||||
// When target is changed, all images depending on target can't be restored with target.
|
||||
// makeStaleIfDependingOn is called in such situation.
|
||||
func (i *images) makeStaleIfDependingOn(target *Image) {
|
||||
// Avoid defer for performance
|
||||
i.m.Lock()
|
||||
i.makeStaleIfDependingOnImpl(target)
|
||||
i.m.Unlock()
|
||||
}
|
||||
|
||||
func (i *images) makeStaleIfDependingOnImpl(target *Image) {
|
||||
if target == nil {
|
||||
panic("not reached")
|
||||
}
|
||||
// Avoid defer for performance
|
||||
i.m.Lock()
|
||||
if i.lastTarget == target {
|
||||
i.m.Unlock()
|
||||
return
|
||||
}
|
||||
i.lastTarget = target
|
||||
@ -120,7 +125,6 @@ func (i *images) makeStaleIfDependingOn(target *Image) {
|
||||
// other images depend on img? (#357)
|
||||
img.makeStaleIfDependingOn(target)
|
||||
}
|
||||
i.m.Unlock()
|
||||
}
|
||||
|
||||
// restore restores the images.
|
||||
|
Loading…
Reference in New Issue
Block a user