You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

74 lines
1.3 KiB
Go

package sim
import (
"time"
"github.com/jordanorelli/astro-domu/internal/math"
"github.com/jordanorelli/astro-domu/internal/wire"
"github.com/jordanorelli/blammo"
)
4 years ago
type room struct {
*blammo.Log
name string
origin point
bounds math.Bounds
tiles []tile
players map[string]*player
}
func (r *room) update(dt time.Duration) {
for _, p := range r.players {
for _, req := range p.pending {
4 years ago
res := req.Wants.exec(r, p, req.Seq)
p.outbox <- wire.Response{Re: req.Seq, Body: res.reply}
if res.announce != nil {
for _, p2 := range r.players {
if p2 == p {
continue
}
p2.outbox <- wire.Response{Body: res.announce}
}
}
}
p.pending = p.pending[0:0]
}
for _, t := range r.tiles {
4 years ago
if t.here != nil {
t.here.update(dt)
}
}
}
func (r *room) allEntities() map[int]*entity {
all := make(map[int]*entity, 4)
4 years ago
for _, t := range r.tiles {
if t.here != nil {
e := t.here
all[e.ID] = e
}
}
4 years ago
return all
}
func (r *room) addPlayer(p *player) {
r.players[p.name] = p
}
func (r *room) removePlayer(name string) bool {
if _, ok := r.players[name]; ok {
delete(r.players, name)
return true
}
return false
}
func (r *room) getTile(pos math.Vec) *tile {
if !r.bounds.Contains(pos) {
return nil
}
n := pos.X*r.bounds.Width() + pos.Y
return &r.tiles[n]
}