fix GetEntitiesWuthComponent, pickup logic fixed accordingly
This commit is contained in:
parent
9f3eaafa3f
commit
76780d7936
@ -138,15 +138,20 @@ func (c *Controller) GetEntities() map[Entity]map[string]Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// GetEntitiesWithComponent returns a list of all entities with a given component attached
|
// GetEntitiesWithComponent returns a list of all entities with a given component attached
|
||||||
// TODO: Allow for passing a list of components
|
func (c *Controller) GetEntitiesWithComponent(componentTypes... string) []Entity {
|
||||||
func (c *Controller) GetEntitiesWithComponent(componentType string) []Entity {
|
|
||||||
entitiesWithComponent := make([]Entity, 0)
|
entitiesWithComponent := make([]Entity, 0)
|
||||||
for entity := range c.entities {
|
for entity := range c.entities {
|
||||||
if c.HasComponent(entity, componentType) {
|
mustAddThis := true
|
||||||
|
for _, componentType := range componentTypes {
|
||||||
|
if !c.HasComponent(entity, componentType) {
|
||||||
|
mustAddThis = false
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if mustAddThis {
|
||||||
entitiesWithComponent = append(entitiesWithComponent, entity)
|
entitiesWithComponent = append(entitiesWithComponent, entity)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return entitiesWithComponent
|
return entitiesWithComponent
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4,7 +4,6 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"lab.zaar.be/thefish/alchemyst-go/engine/ecs"
|
"lab.zaar.be/thefish/alchemyst-go/engine/ecs"
|
||||||
"lab.zaar.be/thefish/alchemyst-go/engine/types"
|
"lab.zaar.be/thefish/alchemyst-go/engine/types"
|
||||||
"lab.zaar.be/thefish/alchemyst-go/util/appctx"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type CarriedFace interface {
|
type CarriedFace interface {
|
||||||
@ -95,18 +94,11 @@ func (c *Carried) GetBulk(what ecs.Entity) int {
|
|||||||
|
|
||||||
func FindCarriedUnder(who ecs.Entity) []ecs.Entity {
|
func FindCarriedUnder(who ecs.Entity) []ecs.Entity {
|
||||||
pickerCoords := Controller.GetComponent(who, ecs.CoordsComponent).(types.Coords)
|
pickerCoords := Controller.GetComponent(who, ecs.CoordsComponent).(types.Coords)
|
||||||
carrieds := Controller.GetEntitiesWithComponent(ecs.CarriedComponent)
|
// _И_ носимые _И_ имеющие координаты, т.е. где-то лежащие
|
||||||
|
carrieds := Controller.GetEntitiesWithComponent(ecs.CarriedComponent, ecs.CoordsComponent)
|
||||||
result := make([]ecs.Entity, 0)
|
result := make([]ecs.Entity, 0)
|
||||||
for idx, carried := range carrieds {
|
for _, carried := range carrieds {
|
||||||
|
carriedCoords := Controller.GetComponent(carried, ecs.CoordsComponent).(types.Coords)
|
||||||
appctx.Logger().Info().Msgf("%d - %s", idx, carried)
|
|
||||||
|
|
||||||
maybeCoords := Controller.GetComponent(carried, ecs.CoordsComponent)
|
|
||||||
//if maybeCoords == nil {
|
|
||||||
// continue
|
|
||||||
//}
|
|
||||||
// убедились что что-то есть? тогда кастуем в тип
|
|
||||||
carriedCoords := maybeCoords.(types.Coords)
|
|
||||||
if pickerCoords.IsAdjacentTo(&carriedCoords) {
|
if pickerCoords.IsAdjacentTo(&carriedCoords) {
|
||||||
result = append(result, carried)
|
result = append(result, carried)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user