;;-*-Lisp-*- (in-package goal) ;; definition of type ticky (deftype ticky (structure) ((delay-til-ramp time-frame) (delay-til-timeout time-frame) (starting-time time-frame) (last-tick-time time-frame) ) (:methods (sleep (_type_ time-frame) none) (reached-delay? (_type_ time-frame) symbol) (completed? (_type_) symbol) ) ) ;; definition for method 3 of type ticky (defmethod inspect ((this ticky)) (format #t "[~8x] ~A~%" this 'ticky) (format #t "~Tdelay-til-ramp: ~D~%" (-> this delay-til-ramp)) (format #t "~Tdelay-til-timeout: ~D~%" (-> this delay-til-timeout)) (format #t "~Tstarting-time: ~D~%" (-> this starting-time)) (format #t "~Tlast-tick-time: ~D~%" (-> this last-tick-time)) this ) ;; definition for method 9 of type ticky ;; INFO: Return type mismatch int vs none. (defmethod sleep ((this ticky) (arg0 time-frame)) (set-time! (-> this starting-time)) (set! (-> this delay-til-timeout) arg0) (set! (-> this delay-til-ramp) (max 0 (+ arg0 (seconds -4)))) (set! (-> this last-tick-time) 0) 0 (none) ) ;; definition for method 11 of type ticky (defmethod completed? ((this ticky)) (let ((gp-0 #f)) (let ((v1-2 (- (current-time) (-> this starting-time)))) (cond ((>= v1-2 (-> this delay-til-timeout)) (set! gp-0 #t) ) (else (let* ((f0-1 (fmin 1.0 (/ (the float (max 0 (- v1-2 (-> this delay-til-ramp)))) (the float (- (-> this delay-til-timeout) (-> this delay-til-ramp))) ) ) ) (v1-7 (the int (lerp 105.0 41.0 f0-1))) ) (when (time-elapsed? (-> this last-tick-time) v1-7) (set-time! (-> this last-tick-time)) (sound-play "stopwatch") ) ) ) ) ) gp-0 ) ) ;; definition for method 10 of type ticky (defmethod reached-delay? ((this ticky) (arg0 time-frame)) (time-elapsed? (-> this starting-time) arg0) )