OpenDiablo2/main.go

82 lines
2.4 KiB
Go
Raw Normal View History

2019-10-24 13:31:59 +00:00
package main
import (
"github.com/OpenDiablo2/OpenDiablo2/d2common"
"github.com/OpenDiablo2/OpenDiablo2/d2data/d2mpq"
"image"
2019-10-24 13:31:59 +00:00
"log"
2019-11-10 13:51:02 +00:00
"github.com/OpenDiablo2/OpenDiablo2/d2core/d2scene"
"github.com/OpenDiablo2/OpenDiablo2/d2input"
"github.com/OpenDiablo2/OpenDiablo2/d2render/d2surface"
"github.com/OpenDiablo2/OpenDiablo2/d2term"
2019-11-10 08:36:53 +00:00
"github.com/hajimehoshi/ebiten/ebitenutil"
"github.com/OpenDiablo2/OpenDiablo2/d2core"
2019-10-24 13:31:59 +00:00
"github.com/hajimehoshi/ebiten"
"gopkg.in/alecthomas/kingpin.v2"
2019-10-24 13:31:59 +00:00
)
2019-11-07 03:12:15 +00:00
// GitBranch is set by the CI build process to the name of the branch
var GitBranch string
2019-11-07 03:12:15 +00:00
// GitCommit is set by the CI build process to the commit hash
var GitCommit string
var d2Engine *d2core.Engine
2019-10-24 13:31:59 +00:00
var region = kingpin.Arg("region", "Region type id").Int()
var preset = kingpin.Arg("preset", "Level preset").Int()
2019-10-24 13:31:59 +00:00
func main() {
d2input.Initialize()
d2term.Initialize()
d2term.BindLogger()
//procs := runtime.GOMAXPROCS(16)
//log.Printf("Setting gomaxprocs to 16, it was previously set to %d", procs)
//runtime.LockOSThread()
//defer runtime.UnlockOSThread()
//defer profile.Start(profile.ProfilePath(".")).Stop()
if len(GitBranch) == 0 {
GitBranch = "Local Build"
GitCommit = ""
}
2019-11-10 08:36:53 +00:00
d2common.SetBuildInfo(GitBranch, GitCommit)
log.SetFlags(log.Lshortfile)
2019-10-24 13:31:59 +00:00
log.Println("OpenDiablo2 - Open source Diablo 2 engine")
_, iconImage, err := ebitenutil.NewImageFromFile("d2logo.png", ebiten.FilterLinear)
if err == nil {
ebiten.SetWindowIcon([]image.Image{iconImage})
}
2019-11-10 13:51:02 +00:00
d2mpq.InitializeCryptoBuffer()
2019-11-10 08:36:53 +00:00
d2Engine = d2core.CreateEngine()
kingpin.Parse()
if *region == 0 {
d2Engine.SetNextScene(d2scene.CreateMainMenu(d2Engine, d2Engine.UIManager, d2Engine.SoundManager))
} else {
d2Engine.SetNextScene(d2scene.CreateMapEngineTest(d2Engine, d2Engine.UIManager, d2Engine.SoundManager, *region, *preset))
}
2019-10-24 13:31:59 +00:00
ebiten.SetCursorVisible(false)
ebiten.SetFullscreen(d2Engine.Settings.FullScreen)
ebiten.SetRunnableInBackground(d2Engine.Settings.RunInBackground)
ebiten.SetVsyncEnabled(d2Engine.Settings.VsyncEnabled)
ebiten.SetMaxTPS(d2Engine.Settings.TicksPerSecond)
if err := ebiten.Run(update, 800, 600, d2Engine.Settings.Scale, "OpenDiablo 2 ("+GitBranch+")"); err != nil {
2019-10-24 13:31:59 +00:00
log.Fatal(err)
}
}
func update(screen *ebiten.Image) error {
d2Engine.Advance()
if !ebiten.IsDrawingSkipped() {
surface := d2surface.CreateSurface(screen)
d2Engine.Render(surface)
if surface.GetDepth() > 0 {
panic("detected surface stack leak")
}
2019-10-24 13:31:59 +00:00
}
2019-10-24 13:31:59 +00:00
return nil
}