Add tick tracking, aging, and actual eating
author |
Steve Losh <steve@stevelosh.com> |
date |
Sun, 07 Aug 2016 00:13:39 +0000 (2016-08-07) |
parents |
bedfd140c6ef
|
children |
7399fa9ab331
|
branches/tags |
(none) |
files |
silt.lisp |
Changes
--- a/silt.lisp Sat Aug 06 23:55:01 2016 +0000
+++ b/silt.lisp Sun Aug 07 00:13:39 2016 +0000
@@ -25,6 +25,7 @@
(defparameter *game-log* nil)
(defparameter *population* 0)
+(defparameter *tick* 0)
(deftype world-coordinate ()
@@ -563,6 +564,16 @@
(funcall (sentient/function entity) entity))
+;;; Age
+(define-component aging
+ (birthtick :initform *tick*)
+ (age :initform 0))
+
+
+(define-system age ((entity aging))
+ (incf (aging/age entity)))
+
+
;;;; Entities ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;; Flora
(define-entity tree (coords visible fruiting flavor))
@@ -576,7 +587,7 @@
:coords/y y
:visible/glyph "T"
:visible/color +color-green+
- :fruiting/chance 0.0001
+ :fruiting/chance 0.0005
:flavor/text '("A tree sways gently in the wind.")))
(defun make-fruit (x y)
@@ -634,8 +645,8 @@
;;; Fauna
-(define-entity creature (coords visible sentient flavor metabolizing)
- (name :initform (random-name) :accessor creature-name))
+(define-entity creature (coords visible sentient flavor metabolizing aging)
+ (name :accessor creature-name :initarg :name))
(defparameter *directions*
@@ -666,6 +677,7 @@
(coords-move-entity c (+ x dx) (+ y dy)))))
(defun creature-eat (c food)
+ (incf (metabolizing/energy c) (edible/energy food))
(destroy-entity food))
(defun creature-act (c)
@@ -677,20 +689,25 @@
(defun make-creature (x y)
- (create-entity 'creature
- :coords/x x
- :coords/y y
- :visible/color +color-white+
- :visible/glyph "@"
- :metabolizing/energy 1000
- :metabolizing/insulation 1
- :sentient/function 'creature-act
- :flavor/text '("A creature is here."
- "It likes food.")))
+ (let ((name (random-name)))
+ (create-entity 'creature
+ :name name
+ :coords/x x
+ :coords/y y
+ :visible/color +color-white+
+ :visible/glyph "@"
+ :metabolizing/energy 1000
+ :metabolizing/insulation 1
+ :sentient/function 'creature-act
+ :flavor/text
+ (list (format nil "A creature named ~:(~A~) is here." name)
+ "It likes food."))))
(defmethod starve :after ((c creature))
- (log-message "~A has starved!" (creature-name c)))
+ (log-message "~A has starved. It was ~D tick~:P old."
+ (creature-name c)
+ (aging/age c)))
(defmethod entity-created :after ((e creature))
@@ -847,7 +864,8 @@
(format nil "[~D, ~D]" *view-x* *view-y*)
(format nil "[~D, ~D]" *cursor-x* *cursor-y*)
(format nil "~D creature~:P" *population*)
- (format nil "~D entit~:@P" (hash-table-count *entity-index*)))
+ (format nil "~D entit~:@P" (hash-table-count *entity-index*))
+ (format nil "tick ~D" *tick*))
(1- *screen-width*)
0)
(write-left
@@ -928,6 +946,8 @@
(defun tick-world ()
+ (incf *tick*)
+ (run-system 'age)
(run-system 'consume-energy)
(run-system 'grow-fruit)
(run-system 'rot)
@@ -964,7 +984,8 @@
*view-y* (wrap (- *screen-center-y*))
*cursor-x* 0
*cursor-y* 0
- *population* 0)
+ *population* 0
+ *tick* 0)
(generate-trees)
(generate-algae)
(generate-mysteries)