cab4487cb963

Simple mutation
[view raw] [browse files]
author Steve Losh <steve@stevelosh.com>
date Sun, 07 Aug 2016 19:48:52 +0000 (2016-08-07)
parents 53bd3da97926
children 41418d32bbba
branches/tags (none)
files silt.lisp

Changes

--- a/silt.lisp	Sun Aug 07 19:29:36 2016 +0000
+++ b/silt.lisp	Sun Aug 07 19:48:52 2016 +0000
@@ -546,7 +546,8 @@
 
 ;;; Food
 (define-component edible
-  energy)
+  energy
+  original-energy)
 
 (define-component decomposing
   rate
@@ -556,13 +557,20 @@
   chance)
 
 
+(defmethod initialize-instance :after ((e edible) &key)
+  (setf (edible/original-energy e)
+        (edible/energy e)))
+
+
 (define-system rot ((entity decomposing))
   (when (minusp (decf (decomposing/remaining entity)
                       (decomposing/rate entity)))
     (destroy-entity entity)))
 
 (define-system rot-food ((entity decomposing edible))
-  (mulf (edible/energy entity) 0.999))
+  (setf (edible/energy entity)
+        (lerp 0.0 (edible/original-energy entity)
+              (decomposing/remaining entity))))
 
 
 (defun decomposing-description (entity)
@@ -631,7 +639,7 @@
                  :visible/glyph "รณ"
                  :visible/color +color-pink+
                  :edible/energy (random-around 300 10)
-                 :decomposing/rate 0.001
+                 :decomposing/rate 0.0005
                  :inspectable/slots '(edible/energy)
                  :flavor/text '("A ripe piece of fruit has fallen to the ground.")))
 
@@ -709,15 +717,26 @@
                                             (+ y dy))))))))
 
 
+(defun creature-mutate (c)
+  (let ((v (random 1.0)))
+    (cond
+      (t (setf (visible/glyph c)
+               (random-elt #("@" "$" "?" "!" "&" "+")))))))
+
 (defun creature-should-reproduce-p (c)
   (and (> (metabolizing/energy c) 1000)
        (< (random 1.0) 0.01)))
 
+(defun creature-should-mutate-p ()
+  (< (random 1.0) 0.01))
+
 (defun creature-reproduce (parent)
   (let ((energy (floor (metabolizing/energy parent) 2))
         (child (make-creature (coords/x parent) (coords/y parent))))
     (setf (metabolizing/energy parent) energy
           (metabolizing/energy child) energy)
+    (when (creature-should-mutate-p)
+      (creature-mutate child))
     (log-message "~A begets ~A." (creature-name parent) (creature-name child))))
 
 (defun creature-move (c)
@@ -1097,7 +1116,7 @@
            (tick-world)
            (tick-log))
          (render-map)
-         (sleep 0.02)
+         (sleep 0.01)
          (state-map-loop)))))