;;-*-Lisp-*- (in-package goal) ;; definition of type process-focusable (deftype process-focusable (process-drawable) ((root collide-shape :override) (focus-status focus-status) ) (:methods (get-trans (_type_ int) vector) (get-quat (_type_ int) quaternion) (get-transv (_type_) vector) (time-to-apex-or-ground (_type_ int) int) (get-water-height (_type_) meters) (get-notice-time (_type_) time-frame) (get-inv-mass (_type_) float) ) ) ;; definition for method 3 of type process-focusable (defmethod inspect ((this process-focusable)) (when (not this) (set! this this) (goto cfg-4) ) (let ((t9-0 (method-of-type process-drawable inspect))) (t9-0 this) ) (format #t "~2Tfocus-status: ~D~%" (-> this focus-status)) (label cfg-4) this ) ;; definition for method 20 of type process-focusable ;; WARN: Return type mismatch structure vs vector. (defmethod get-trans ((this process-focusable) (arg0 int)) "@returns the `trans` [[vector]] from the process's `root` (typically either a [[trsqv]] or a [[collide-shape]])" (let ((gp-0 (-> this root))) (the-as vector (cond ((zero? arg0) (-> gp-0 trans) ) ((and (= arg0 1) (type? gp-0 collide-shape-moving)) (-> (the-as collide-shape-moving gp-0) gspot-pos) ) ((and (or (= arg0 2) (= arg0 3)) (type? gp-0 collide-shape)) (-> gp-0 root-prim prim-core) ) (else (-> gp-0 trans) ) ) ) ) ) ;; definition for method 22 of type process-focusable (defmethod get-transv ((this process-focusable)) (-> this root transv) ) ;; definition for method 21 of type process-focusable (defmethod get-quat ((this process-focusable) (arg0 int)) (-> this root quat) ) ;; definition for method 23 of type process-focusable (defmethod time-to-apex-or-ground ((this process-focusable) (arg0 int)) 0 ) ;; definition for method 24 of type process-focusable ;; WARN: Return type mismatch int vs meters. (defmethod get-water-height ((this process-focusable)) (the-as meters 0) ) ;; definition for method 26 of type process-focusable (defmethod get-inv-mass ((this process-focusable)) 0.0 ) ;; definition for method 25 of type process-focusable ;; WARN: Return type mismatch int vs time-frame. (defmethod get-notice-time ((this process-focusable)) (the-as time-frame 0) ) ;; failed to figure out what this is: 0