;;-*-Lisp-*- (in-package goal) ;; definition of type touching-prim (deftype touching-prim (structure) "A collide primitive that's touching another. Potentially also stores the triangle that is involved." ((cprim collide-shape-prim) (has-tri? symbol) (tri collide-tri-result :inline) ) ) ;; definition for method 3 of type touching-prim (defmethod inspect ((this touching-prim)) (when (not this) (set! this this) (goto cfg-4) ) (format #t "[~8x] ~A~%" this 'touching-prim) (format #t "~1Tcprim: ~A~%" (-> this cprim)) (format #t "~1Thas-tri?: ~A~%" (-> this has-tri?)) (format #t "~1Ttri: #~%" (-> this tri)) (label cfg-4) this ) ;; definition of type touching-prims-entry (deftype touching-prims-entry (structure) "A record of two primitives touching." ((next touching-prims-entry) (prev touching-prims-entry) (allocated? symbol) (u float) (prim1 touching-prim :inline) (prim2 touching-prim :inline) ) (:methods (get-middle-of-bsphere-overlap (_type_ vector) vector) (get-touched-prim (_type_ collide-shape touching-shapes-entry) collide-shape-prim) (get-touched-tri (_type_ collide-shape touching-shapes-entry) collide-tri-result) ) ) ;; definition for method 3 of type touching-prims-entry (defmethod inspect ((this touching-prims-entry)) (when (not this) (set! this this) (goto cfg-4) ) (format #t "[~8x] ~A~%" this 'touching-prims-entry) (format #t "~1Tnext: #~%" (-> this next)) (format #t "~1Tprev: #~%" (-> this prev)) (format #t "~1Tallocated?: ~A~%" (-> this allocated?)) (format #t "~1Tu: ~f~%" (-> this u)) (format #t "~1Tprim1: #~%" (-> this prim1)) (format #t "~1Tprim2: #~%" (-> this prim2)) (label cfg-4) this ) ;; definition of type touching-prims-entry-pool (deftype touching-prims-entry-pool (structure) "A pool of up to 64 touching prim records." ((head touching-prims-entry) (nodes touching-prims-entry 64 :inline) ) (:methods (new (symbol type) _type_) (alloc-node (_type_) touching-prims-entry) (get-free-node-count (_type_) int) (init-list! (_type_) none) (free-node (_type_ touching-prims-entry) touching-prims-entry) ) ) ;; definition for method 3 of type touching-prims-entry-pool (defmethod inspect ((this touching-prims-entry-pool)) (when (not this) (set! this this) (goto cfg-4) ) (format #t "[~8x] ~A~%" this 'touching-prims-entry-pool) (format #t "~1Thead: #~%" (-> this head)) (format #t "~1Tnodes[64] @ #x~X~%" (-> this nodes)) (label cfg-4) this ) ;; definition for method 11 of type touching-prims-entry-pool ;; WARN: Return type mismatch int vs none. (defmethod init-list! ((this touching-prims-entry-pool)) (let ((prev (the-as touching-prims-entry #f))) (let ((current (the-as touching-prims-entry (-> this nodes)))) (set! (-> this head) current) (countdown (a0-1 64) (set! (-> current prev) prev) (let ((next (&+ current 240))) (set! (-> current next) (the-as touching-prims-entry next)) (set! (-> current allocated?) #f) (set! prev current) (set! current (the-as touching-prims-entry next)) ) ) ) (set! (-> prev next) #f) ) 0 (none) ) ;; definition for method 0 of type touching-prims-entry-pool ;; WARN: Return type mismatch structure vs touching-prims-entry-pool. (defmethod new touching-prims-entry-pool ((allocation symbol) (type-to-make type)) (let ((t9-0 (method-of-type structure new)) (v1-1 type-to-make) ) (-> type-to-make size) (let ((gp-0 (t9-0 allocation v1-1))) ((method-of-type touching-prims-entry-pool init-list!) (the-as touching-prims-entry-pool gp-0)) (the-as touching-prims-entry-pool gp-0) ) ) ) ;; definition of type touching-shapes-entry (deftype touching-shapes-entry (structure) "A record of two collide shapes touching, storing a record of the primitives involved." ((cshape1 collide-shape) (cshape2 collide-shape) (resolve-u int8) (head touching-prims-entry) (handle1 handle) (handle2 handle) ) :pack-me (:methods (get-head (_type_) touching-prims-entry) (get-next (_type_ touching-shapes-entry) touching-prims-entry) (get-touched-shape (_type_ collide-shape) collide-shape) (prims-touching? (_type_ collide-shape uint) touching-prims-entry) (prims-touching-action? (_type_ collide-shape collide-action collide-action) basic) (free-touching-prims-list (_type_) none) ) ) ;; definition for method 3 of type touching-shapes-entry (defmethod inspect ((this touching-shapes-entry)) (when (not this) (set! this this) (goto cfg-4) ) (format #t "[~8x] ~A~%" this 'touching-shapes-entry) (format #t "~1Tcshape1: ~A~%" (-> this cshape1)) (format #t "~1Tcshape2: ~A~%" (-> this cshape2)) (format #t "~1Tresolve-u: ~D~%" (-> this resolve-u)) (format #t "~1Thead: #~%" (-> this head)) (format #t "~1Thandle1: ~D~%" (-> this handle1)) (format #t "~1Thandle2: ~D~%" (-> this handle2)) (label cfg-4) this ) ;; definition of type touching-list (deftype touching-list (structure) "Contains a record of touching collide shape pairs." ((num-touching-shapes int32) (resolve-u int8) (touching-shapes touching-shapes-entry 32 :inline) ) (:methods (new (symbol type) _type_) (add-touching-prims (_type_ collide-shape-prim collide-shape-prim float collide-tri-result collide-tri-result) none) (free-nodes (_type_) none) (update-from-step-size (_type_ float) none) (send-events-for-touching-shapes (_type_) none) (get-shapes-entry (_type_ collide-shape collide-shape) touching-shapes-entry) ) ) ;; definition for method 3 of type touching-list (defmethod inspect ((this touching-list)) (when (not this) (set! this this) (goto cfg-4) ) (format #t "[~8x] ~A~%" this 'touching-list) (format #t "~1Tnum-touching-shapes: ~D~%" (-> this num-touching-shapes)) (format #t "~1Tresolve-u: ~D~%" (-> this resolve-u)) (format #t "~1Ttouching-shapes[32] @ #x~X~%" (-> this touching-shapes)) (label cfg-4) this ) ;; definition for method 0 of type touching-list ;; WARN: Return type mismatch structure vs touching-list. (defmethod new touching-list ((allocation symbol) (type-to-make type)) (let ((t9-0 (method-of-type structure new)) (v1-1 type-to-make) ) (-> type-to-make size) (let ((v0-0 (the-as touching-list (t9-0 allocation v1-1)))) (set! (-> v0-0 num-touching-shapes) 0) (set! (-> v0-0 resolve-u) 0) v0-0 ) ) ) ;; definition for method 9 of type touching-shapes-entry (defmethod get-head ((this touching-shapes-entry)) (-> this head) ) ;; definition for method 10 of type touching-shapes-entry ;; WARN: Return type mismatch collide-shape vs touching-prims-entry. (defmethod get-next ((this touching-shapes-entry) (arg0 touching-shapes-entry)) (the-as touching-prims-entry (-> arg0 cshape1)) ) ;; failed to figure out what this is: (kmemopen global "collide-touching-lists") ;; definition (perm) for symbol *touching-prims-entry-pool*, type touching-prims-entry-pool (define-perm *touching-prims-entry-pool* touching-prims-entry-pool (new 'global 'touching-prims-entry-pool)) ;; definition (perm) for symbol *touching-list*, type touching-list (define-perm *touching-list* touching-list (new 'global 'touching-list)) ;; failed to figure out what this is: (kmemclose)