Skip to content

Commit

Permalink
ebiten: Make NewImage/NewImageFromImage panic when RunGame finishes
Browse files Browse the repository at this point in the history
  • Loading branch information
hajimehoshi committed Apr 3, 2021
1 parent d6ee55c commit 5c8d8ab
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 1 deletion.
12 changes: 11 additions & 1 deletion image.go
Original file line number Diff line number Diff line change
Expand Up @@ -748,7 +748,12 @@ func (i *Image) ReplacePixels(pixels []byte) {
// NewImage returns an empty image.
//
// If width or height is less than 1 or more than device-dependent maximum size, NewImage panics.
//
// NewImage panics if RunGame already finishes.
func NewImage(width, height int) *Image {
if isRunGameEnded() {
panic(fmt.Sprintf("ebiten: NewImage cannot be called after RunGame finishes"))
}
if width <= 0 {
panic(fmt.Sprintf("ebiten: width at NewImage must be positive but %d", width))
}
Expand All @@ -766,9 +771,14 @@ func NewImage(width, height int) *Image {
// NewImageFromImage creates a new image with the given image (source).
//
// If source's width or height is less than 1 or more than device-dependent maximum size, NewImageFromImage panics.
//
// NewImageFromImage panics if RunGame already finishes.
func NewImageFromImage(source image.Image) *Image {
size := source.Bounds().Size()
if isRunGameEnded() {
panic(fmt.Sprintf("ebiten: NewImage cannot be called after RunGame finishes"))
}

size := source.Bounds().Size()
width, height := size.X, size.Y
if width <= 0 {
panic(fmt.Sprintf("ebiten: source width at NewImageFromImage must be positive but %d", width))
Expand Down
7 changes: 7 additions & 0 deletions run.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ func CurrentFPS() float64 {

var (
isScreenClearedEveryFrame = int32(1)
isRunGameEnded_ = int32(0)
currentMaxTPS = int32(DefaultTPS)
)

Expand Down Expand Up @@ -162,6 +163,8 @@ func (i *imageDumperGame) Layout(outsideWidth, outsideHeight int) (screenWidth,
//
// Don't call RunGame twice or more in one process.
func RunGame(game Game) error {
defer atomic.StoreInt32(&isRunGameEnded_, 1)

fixWindowPosition(WindowSize())
theUIContext.set(&imageDumperGame{
game: game,
Expand All @@ -175,6 +178,10 @@ func RunGame(game Game) error {
return nil
}

func isRunGameEnded() bool {
return atomic.LoadInt32(&isRunGameEnded_) != 0
}

// RunGameWithoutMainLoop runs the game, but doesn't call the loop on the main (UI) thread.
// Different from Run, RunGameWithoutMainLoop returns immediately.
//
Expand Down

0 comments on commit 5c8d8ab

Please sign in to comment.