2019-10-24 09:31:59 -04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
2020-11-01 15:12:45 -05:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2networking"
|
2020-06-30 12:36:48 -04:00
|
|
|
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2app"
|
2020-11-01 15:12:45 -05:00
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2core/d2asset"
|
|
|
|
ebiten2 "github.com/OpenDiablo2/OpenDiablo2/d2core/d2audio/ebiten"
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2core/d2config"
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2core/d2input"
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2core/d2render/ebiten"
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2core/d2term"
|
|
|
|
"github.com/OpenDiablo2/OpenDiablo2/d2script"
|
2019-10-24 09:31:59 -04:00
|
|
|
)
|
|
|
|
|
2019-11-06 22:12:15 -05:00
|
|
|
// GitBranch is set by the CI build process to the name of the branch
|
2020-10-26 05:04:50 -04:00
|
|
|
//nolint:gochecknoglobals // This is filled in by the build system
|
2019-11-02 16:15:16 -04:00
|
|
|
var GitBranch string
|
2019-11-06 22:12:15 -05:00
|
|
|
|
|
|
|
// GitCommit is set by the CI build process to the commit hash
|
2020-10-26 05:04:50 -04:00
|
|
|
//nolint:gochecknoglobals // This is filled in by the build system
|
2019-11-02 16:15:16 -04:00
|
|
|
var GitCommit string
|
2019-10-24 09:31:59 -04:00
|
|
|
|
|
|
|
func main() {
|
2020-01-31 23:18:11 -05:00
|
|
|
log.SetFlags(log.Lshortfile)
|
|
|
|
log.Println("OpenDiablo2 - Open source Diablo 2 engine")
|
|
|
|
|
2020-11-01 15:12:45 -05:00
|
|
|
// Attempt to load the configuration file
|
|
|
|
configError := d2config.Load()
|
|
|
|
|
|
|
|
// Create our renderer
|
|
|
|
renderer, err := ebiten.CreateRenderer()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we failed to load our config, lets show the boot panic screen
|
|
|
|
if configError != nil {
|
|
|
|
renderer.ShowPanicScreen(configError.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create the asset manager
|
|
|
|
asset, err := d2asset.NewAssetManager(d2config.Config)
|
|
|
|
if err != nil {
|
|
|
|
renderer.ShowPanicScreen(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
srvChanIn := make(chan byte)
|
|
|
|
srvChanLog := make(chan string)
|
|
|
|
started, srvErr := d2networking.StartDedicatedServer(asset, srvChanIn, srvChanLog)
|
|
|
|
|
|
|
|
if srvErr != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
c := make(chan os.Signal)
|
|
|
|
signal.Notify(c, os.Interrupt, syscall.SIGTERM) // This traps Control-c to safely shut down the server
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
<-c
|
|
|
|
srvChanIn <- 0b1
|
|
|
|
}()
|
|
|
|
|
|
|
|
if started {
|
|
|
|
for data := range srvChanLog {
|
|
|
|
log.Println(data)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
audio := ebiten2.CreateAudio(asset)
|
|
|
|
|
|
|
|
inputManager := d2input.NewInputManager()
|
|
|
|
|
|
|
|
term, err := d2term.New(inputManager)
|
|
|
|
if err != nil {
|
|
|
|
renderer.ShowPanicScreen(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
err = asset.BindTerminalCommands(term)
|
|
|
|
if err != nil {
|
|
|
|
renderer.ShowPanicScreen(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
scriptEngine := d2script.CreateScriptEngine()
|
2020-07-11 11:24:04 -04:00
|
|
|
|
2020-11-01 15:12:45 -05:00
|
|
|
app := d2app.Create(GitBranch, GitCommit, inputManager, term, scriptEngine, audio, renderer, asset)
|
|
|
|
if err := app.Run(); err != nil {
|
|
|
|
renderer.ShowPanicScreen(err.Error())
|
2020-10-28 21:02:12 -04:00
|
|
|
return
|
2020-07-08 09:16:16 -04:00
|
|
|
}
|
2020-06-22 22:17:54 -04:00
|
|
|
}
|