Files
jak-project/test/decompiler/reference/engine/camera/cam-master_REF.gc
T
ManDude 24578b64b9 proper support for hardcoded "time" types (#1141)
* hardcode `time-frame`things

* Update cam-states_REF.gc

* Update level-info_REF.gc

* update refs 1

* update refs 2

* update refs 3

* update refs 4

* update refs 5

* update detection and casting

* Update FormExpressionAnalysis.cpp

* update refs 6

* update mood decomp

* update refs 7

* update refs 8

* remove temp entity birth code

* update time-frame casts

* fix compiler

* hardcode stuff and fix some types

* fix some bitfield detection being wrong

* bug fixes

* detect seconds on adds with immediate

* update refs 9

* fix casts and rand-vu-int-range bugs (update refs 10)

* update refs 11

* update 12

* update 13

* update 14

* Update game-info_REF.gc

* improve cpad macros detection

* remove unused code

* update refs

* clang

* update source code

* Update cam-states.gc

* `lavatube-energy` finish

* update refs

* fix actor bank stuff

* Update navigate.gc

* reduce entity default stack size

* Update transformq-h.gc

* oops forgot these

* fix code and tests

* fix mood sound stuff

* Update load-dgo.gc

* Update README.md
2022-02-12 12:26:19 -05:00

1065 lines
42 KiB
Common Lisp
Vendored
Generated

;;-*-Lisp-*-
(in-package goal)
;; definition of type camera-master-bank
(deftype camera-master-bank (basic)
((onscreen-head-height meters :offset-assert 4)
(onscreen-foot-height meters :offset-assert 8)
(target-height meters :offset-assert 12)
(up-move-to-pitch-ratio-in-air float :offset-assert 16)
(down-move-to-pitch-ratio-in-air float :offset-assert 20)
(up-move-to-pitch-on-ground float :offset-assert 24)
(down-move-to-pitch-on-ground float :offset-assert 28)
(pitch-off-blend float :offset-assert 32)
)
:method-count-assert 9
:size-assert #x24
:flag-assert #x900000024
)
;; definition for method 3 of type camera-master-bank
(defmethod inspect camera-master-bank ((obj camera-master-bank))
(format #t "[~8x] ~A~%" obj (-> obj type))
(format #t "~Tonscreen-head-height: (meters ~m)~%" (-> obj onscreen-head-height))
(format #t "~Tonscreen-foot-height: (meters ~m)~%" (-> obj onscreen-foot-height))
(format #t "~Ttarget-height: (meters ~m)~%" (-> obj target-height))
(format #t "~Tup-move-to-pitch-ratio-in-air: ~f~%" (-> obj up-move-to-pitch-ratio-in-air))
(format #t "~Tdown-move-to-pitch-ratio-in-air: ~f~%" (-> obj down-move-to-pitch-ratio-in-air))
(format #t "~Tup-move-to-pitch-on-ground: ~f~%" (-> obj up-move-to-pitch-on-ground))
(format #t "~Tdown-move-to-pitch-on-ground: ~f~%" (-> obj down-move-to-pitch-on-ground))
(format #t "~Tpitch-off-blend: ~f~%" (-> obj pitch-off-blend))
obj
)
;; definition for symbol *CAMERA_MASTER-bank*, type camera-master-bank
(define *CAMERA_MASTER-bank* (new 'static 'camera-master-bank
:onscreen-head-height (meters 2.65)
:onscreen-foot-height (meters -0.5)
:target-height (meters 2.15)
:up-move-to-pitch-ratio-in-air 1.0
:down-move-to-pitch-ratio-in-air 0.5
:up-move-to-pitch-on-ground 0.9
:down-move-to-pitch-on-ground 0.9
:pitch-off-blend 0.5
)
)
;; definition for function reset-follow
;; Used lq/sq
(defbehavior reset-follow camera-master ()
(set! (-> self tpos-old quad) (-> (target-cam-pos) quad))
(set! (-> self tpos-curr quad) (-> self tpos-old quad))
(set! (-> self tpos-old-adj quad) (-> self tpos-old quad))
(set! (-> self tpos-curr-adj quad) (-> self tpos-old quad))
(set! (-> self tpos-tgt quad) (-> self tpos-old quad))
(let ((f0-0 0.0))
(set! (-> self upspeed) f0-0)
f0-0
)
)
;; definition for function reset-target-tracking
;; INFO: Return type mismatch none vs symbol.
;; Used lq/sq
(defbehavior reset-target-tracking camera-master ()
(set! (-> self tpos-old quad) (-> (target-cam-pos) quad))
(set! (-> self tpos-curr quad) (-> self tpos-old quad))
(set! (-> self tpos-old-adj quad) (-> self tpos-old quad))
(set! (-> self tpos-curr-adj quad) (-> self tpos-old quad))
(set! (-> self tpos-tgt quad) (-> self tpos-old quad))
(quaternion->matrix (-> self tgt-rot-mat) (-> *target* control dir-targ))
(quaternion->matrix (-> self tgt-face-mat) (-> *target* control unknown-quaternion00))
(vector-reset! (-> self pitch-off))
(set! (-> self upspeed) 0.0)
(set! (-> self foot-offset) (-> *CAMERA_MASTER-bank* onscreen-foot-height))
(set! (-> self head-offset) (-> *CAMERA_MASTER-bank* onscreen-head-height))
(set! (-> self target-height) (-> *CAMERA_MASTER-bank* target-height))
(set! (-> self on-ground) (not (and (logtest? (-> *target* control unknown-surface00 flags) 2048)
(zero? (logand (-> *target* control status) 1))
)
)
)
(set! (-> self on-pole) #f)
(set! (-> self ease-t) 1.0)
(set! (-> self string-max target y) (-> self stringMaxHeight))
(set! (-> self string-max target z) (-> self stringMaxLength))
(set! (-> self string-push-z) (fmax (-> self string-min value z) (-> *CAMERA-bank* default-string-push-z)))
(cond
((>= (- (-> *display* base-frame-counter) (the-as time-frame (if *target*
(the-as int (-> *target* neck notice-time))
0
)
)
)
(-> *CAMERA-bank* attack-timeout)
)
(set! (-> self being-attacked) #f)
)
(else
(set! (-> self attack-start) (-> *display* base-frame-counter))
(set! (-> self being-attacked) #t)
(when (and (zero? (logand (-> self master-options) 64))
(or (!= (-> last-try-to-look-at-data horz) 0.0) (!= (-> last-try-to-look-at-data vert) 0.0))
)
(set! (-> self string-max target y) (fmax (-> self string-max target y) (-> last-try-to-look-at-data vert)))
(set! (-> self string-max target z) (fmax (-> self string-max target z) (-> last-try-to-look-at-data horz)))
(set! (-> self string-push-z) (fmax (-> self string-push-z) (-> self string-max target z)))
)
)
)
(cond
((and (logtest? (-> *target* water flags) 4096) (zero? (logand (-> *target* water flags) 16)))
(set! (-> self under-water) 2)
)
(else
(set! (-> self under-water) 0)
0
)
)
(let ((gp-1 (new 'stack-no-clear 'vector)))
(vector--float*! gp-1 (-> self tpos-curr-adj) (-> self local-down) (-> self target-height))
(the-as symbol (TODO-RENAME-10 (-> self target-spline) gp-1))
)
)
;; definition for function reset-drawable-follow
;; Used lq/sq
(defbehavior reset-drawable-follow camera-master ()
(let ((v1-2 (the-as target (-> self drawable-target process 0))))
(if (nonzero? (-> v1-2 node-list))
(vector<-cspace! (-> self tpos-old) (-> v1-2 node-list data (-> self which-bone)))
(set! (-> self tpos-old quad) (-> v1-2 control trans quad))
)
)
(set! (-> self tpos-curr quad) (-> self tpos-old quad))
(set! (-> self tpos-old-adj quad) (-> self tpos-old quad))
(set! (-> self tpos-curr-adj quad) (-> self tpos-old quad))
(let ((f0-0 0.0))
(set! (-> self upspeed) f0-0)
f0-0
)
)
;; definition for function reset-drawable-tracking
;; INFO: Return type mismatch none vs symbol.
;; Used lq/sq
(defbehavior reset-drawable-tracking camera-master ()
(let ((gp-0 (the-as target (-> self drawable-target process 0))))
(cond
((nonzero? (-> gp-0 node-list))
(vector<-cspace! (-> self tpos-old) (-> gp-0 node-list data (-> self which-bone)))
(let* ((v1-6 (-> self tgt-rot-mat))
(a3-0 (-> gp-0 node-list data (-> self which-bone) bone transform))
(a0-4 (-> a3-0 vector 0 quad))
(a1-4 (-> a3-0 vector 1 quad))
(a2-0 (-> a3-0 vector 2 quad))
(a3-1 (-> a3-0 vector 3 quad))
)
(set! (-> v1-6 vector 0 quad) a0-4)
(set! (-> v1-6 vector 1 quad) a1-4)
(set! (-> v1-6 vector 2 quad) a2-0)
(set! (-> v1-6 vector 3 quad) a3-1)
)
(set! (-> self tgt-rot-mat vector 3 quad) (the-as uint128 0))
(let* ((v1-8 (-> self tgt-face-mat))
(a3-2 (-> self tgt-rot-mat))
(a0-5 (-> a3-2 vector 0 quad))
(a1-5 (-> a3-2 vector 1 quad))
(a2-1 (-> a3-2 vector 2 quad))
(a3-3 (-> a3-2 vector 3 quad))
)
(set! (-> v1-8 vector 0 quad) a0-5)
(set! (-> v1-8 vector 1 quad) a1-5)
(set! (-> v1-8 vector 2 quad) a2-1)
(set! (-> v1-8 vector 3 quad) a3-3)
)
)
(else
(set! (-> self tpos-old quad) (-> gp-0 control trans quad))
(quaternion->matrix (-> self tgt-rot-mat) (-> gp-0 control quat))
(let* ((v1-11 (-> self tgt-face-mat))
(a3-4 (-> self tgt-rot-mat))
(a0-10 (-> a3-4 vector 0 quad))
(a1-7 (-> a3-4 vector 1 quad))
(a2-2 (-> a3-4 vector 2 quad))
(a3-5 (-> a3-4 vector 3 quad))
)
(set! (-> v1-11 vector 0 quad) a0-10)
(set! (-> v1-11 vector 1 quad) a1-7)
(set! (-> v1-11 vector 2 quad) a2-2)
(set! (-> v1-11 vector 3 quad) a3-5)
)
)
)
)
(set! (-> self tpos-curr quad) (-> self tpos-old quad))
(set! (-> self tpos-old-adj quad) (-> self tpos-old quad))
(set! (-> self tpos-curr-adj quad) (-> self tpos-old quad))
(vector-reset! (-> self pitch-off))
(set! (-> self upspeed) 0.0)
(set! (-> self foot-offset) (-> *CAMERA_MASTER-bank* onscreen-foot-height))
(set! (-> self head-offset) (-> *CAMERA_MASTER-bank* onscreen-head-height))
(set! (-> self target-height) (-> *CAMERA_MASTER-bank* target-height))
(set! (-> self on-ground) #t)
(set! (-> self on-pole) #f)
(set! (-> self ease-t) 1.0)
(set! (-> self being-attacked) #f)
(set! (-> self string-max target y) (-> self stringMaxHeight))
(set! (-> self string-max target z) (-> self stringMaxLength))
(set! (-> self string-push-z) (fmax (-> self string-min value z) (-> *CAMERA-bank* default-string-push-z)))
(set! (-> self under-water) 0)
(let ((gp-1 (new 'stack-no-clear 'vector)))
(vector--float*! gp-1 (-> self tpos-curr-adj) (-> self local-down) (-> self target-height))
(the-as symbol (TODO-RENAME-10 (-> self target-spline) gp-1))
)
)
;; definition for function master-track-target
;; INFO: Return type mismatch none vs symbol.
;; Used lq/sq
(defbehavior master-track-target camera-master ()
(cond
((and (logtest? (-> self master-options) 2)
(!= (-> self drawable-target) #f)
(not (handle->process (-> self drawable-target)))
)
(set! (-> self master-options) (logand -3 (-> self master-options)))
(set! (-> self drawable-target) (the-as handle #f))
)
((and (logtest? (-> self master-options) 2) (handle->process (-> self drawable-target)))
(let ((gp-0 (-> self drawable-target process 0)))
(if (paused?)
(return (the-as symbol #f))
)
(set! (-> self tpos-old quad) (-> self tpos-curr quad))
(set! (-> self tpos-old-adj quad) (-> self tpos-curr-adj quad))
(cond
((nonzero? (-> (the-as target gp-0) node-list))
(let* ((v1-24 (-> self tgt-rot-mat))
(a3-0 (-> (the-as target gp-0) node-list data (-> self which-bone) bone transform))
(a0-17 (-> a3-0 vector 0 quad))
(a1-4 (-> a3-0 vector 1 quad))
(a2-0 (-> a3-0 vector 2 quad))
(a3-1 (-> a3-0 vector 3 quad))
)
(set! (-> v1-24 vector 0 quad) a0-17)
(set! (-> v1-24 vector 1 quad) a1-4)
(set! (-> v1-24 vector 2 quad) a2-0)
(set! (-> v1-24 vector 3 quad) a3-1)
)
(set! (-> self tgt-rot-mat vector 3 quad) (the-as uint128 0))
(let* ((a2-1 (-> self tgt-face-mat))
(a3-2 (-> self tgt-rot-mat))
(v1-26 (-> a3-2 vector 0 quad))
(a0-18 (-> a3-2 vector 1 quad))
(a1-5 (-> a3-2 vector 2 quad))
(a3-3 (-> a3-2 vector 3 quad))
)
(set! (-> a2-1 vector 0 quad) v1-26)
(set! (-> a2-1 vector 1 quad) a0-18)
(set! (-> a2-1 vector 2 quad) a1-5)
(set! (-> a2-1 vector 3 quad) a3-3)
)
(vector<-cspace! (-> self tpos-curr) (-> (the-as target gp-0) node-list data (-> self which-bone)))
)
(else
(quaternion->matrix (-> self tgt-rot-mat) (-> (the-as target gp-0) control quat))
(let* ((a2-3 (-> self tgt-face-mat))
(a3-4 (-> self tgt-rot-mat))
(v1-31 (-> a3-4 vector 0 quad))
(a0-21 (-> a3-4 vector 1 quad))
(a1-9 (-> a3-4 vector 2 quad))
(a3-5 (-> a3-4 vector 3 quad))
)
(set! (-> a2-3 vector 0 quad) v1-31)
(set! (-> a2-3 vector 1 quad) a0-21)
(set! (-> a2-3 vector 2 quad) a1-9)
(set! (-> a2-3 vector 3 quad) a3-5)
)
)
)
)
(let ((v1-32 (new-stack-vector0)))
0.0
(vector-! v1-32 (-> self tpos-curr-adj) (-> self tpos-curr))
(let* ((f0-2 (vector-dot v1-32 (-> self local-down)))
(f0-3 (if (< 0.0 f0-2)
(* f0-2 (-> *CAMERA_MASTER-bank* up-move-to-pitch-on-ground))
(* f0-2 (-> *CAMERA_MASTER-bank* down-move-to-pitch-on-ground))
)
)
)
(vector+float*! (-> self tpos-curr-adj) (-> self tpos-curr) (-> self local-down) f0-3)
)
)
(let ((gp-1 (new 'stack-no-clear 'vector)))
(vector--float*! gp-1 (-> self tpos-curr-adj) (-> self local-down) (-> self target-height))
(TODO-RENAME-17 (-> self target-spline) gp-1 2048.0 0.0 #f)
)
(TODO-RENAME-22 (-> self target-spline) 40960.0)
)
((handle->process (-> self drawable-target))
(logior! (-> self master-options) 2)
(reset-drawable-tracking)
)
)
(the-as
symbol
(cond
((handle->process (-> self drawable-target))
#f
)
((and *target* (logtest? (-> self master-options) 2))
(if (paused?)
(return (the-as symbol #f))
)
(cond
((>= (- (-> *display* base-frame-counter) (the-as time-frame (if *target*
(the-as int (-> *target* neck notice-time))
0
)
)
)
(-> *CAMERA-bank* attack-timeout)
)
(set! (-> self being-attacked) #f)
)
(else
(if (not (-> self being-attacked))
(set! (-> self attack-start) (-> *display* base-frame-counter))
)
(set! (-> self being-attacked) #t)
(when (and (zero? (logand (-> self master-options) 64))
(or (!= (-> last-try-to-look-at-data horz) 0.0) (!= (-> last-try-to-look-at-data vert) 0.0))
)
(set! (-> self string-max target y) (fmax (-> self string-max target y) (-> last-try-to-look-at-data vert)))
(set! (-> self string-max target z) (fmax (-> self string-max target z) (-> last-try-to-look-at-data horz)))
(set! (-> self string-push-z) (fmax (-> self string-push-z) (-> self string-max target z)))
)
)
)
(cond
((and (logtest? (-> *target* water flags) 4096) (zero? (logand (-> *target* water flags) 16)))
(set! (-> self under-water) 2)
)
((> (-> self under-water) 0)
(+! (-> self under-water) -1)
)
)
(set! (-> self tpos-old quad) (-> self tpos-curr quad))
(set! (-> self tpos-old-adj quad) (-> self tpos-curr-adj quad))
(quaternion->matrix (-> self tgt-rot-mat) (-> *target* control dir-targ))
(quaternion->matrix (-> self tgt-face-mat) (-> *target* control unknown-quaternion00))
(cond
((< (-> self ease-t) 1.0)
(new 'stack-no-clear 'vector)
(cond
((logtest? (-> self master-options) 32)
(vector-lerp!
(-> self tpos-curr)
(-> self ease-from)
(-> self ease-to)
(parameter-ease-sin-clamp (-> self ease-t))
)
(set! (-> self master-options) (logand -33 (-> self master-options)))
)
(else
(vector-lerp!
(-> self tpos-curr)
(-> self ease-from)
(target-cam-pos)
(parameter-ease-sin-clamp (-> self ease-t))
)
)
)
(+! (-> self ease-t) (-> self ease-step))
)
(else
(set! (-> self tpos-curr quad) (-> (target-cam-pos) quad))
)
)
(when (logtest? (-> *target* control root-prim prim-core action) (collide-action ca-7))
(if *display-cam-los-debug*
(format *stdcon* "ride edge~%")
)
(let ((s4-2 (new 'stack-no-clear 'collide-tri-result))
(gp-5 (new 'stack-no-clear 'vector))
(s5-2 (new 'stack-no-clear 'vector))
)
(vector--float*! s5-2 (-> self tpos-curr) (-> self local-down) (-> self target-height))
(vector-float*! gp-5 (-> self tgt-rot-mat vector 2) 4915.2)
(vector-! s5-2 s5-2 gp-5)
(let ((f0-20 (fill-and-probe-using-line-sphere
*collide-cache*
s5-2
gp-5
4300.8
(collide-kind background)
(the-as process #f)
s4-2
4098
)
)
)
(if (and (< 0.0 f0-20) (< f0-20 1.0))
(vector+float*! (-> self tpos-curr) (-> self tpos-curr) gp-5 (+ -1.0 f0-20))
)
)
)
)
(set! (-> self on-ground) (not (and (logtest? (-> *target* control unknown-surface00 flags) 2048)
(zero? (logand (-> *target* control status) 1))
)
)
)
(let ((gp-6 (new-stack-vector0)))
0.0
(cond
((and (and (logtest? (-> *target* control unknown-surface00 flags) 2048)
(zero? (logand (-> *target* control status) 1))
)
(!= (-> *target* control unknown-surface00 name) 'launch-jump)
)
(if *display-cam-los-debug*
(format *stdcon* "air tracking~%")
)
(vector+float*! (-> self tpos-curr-adj) (-> self tpos-curr-adj) (-> self local-down) (-> self upspeed))
(vector+float*! (-> self tpos-tgt) (-> self tpos-tgt) (-> self local-down) (-> self upspeed))
(vector-! gp-6 (-> self tpos-curr) (-> self tpos-tgt))
(let ((f30-0 (vector-dot gp-6 (-> self local-down))))
(vector--float*! gp-6 gp-6 (-> self local-down) f30-0)
(if (< 0.0 f30-0)
(set! (-> self upspeed) (* 0.5 (-> self upspeed)))
)
(vector+! (-> self tpos-tgt) (-> self tpos-tgt) gp-6)
(let ((f0-30 (* 0.05 f30-0)))
(vector+float*! (-> self tpos-tgt) (-> self tpos-tgt) (-> self local-down) f0-30)
)
)
(vector-! gp-6 (-> self tpos-curr-adj) (-> self tpos-tgt))
(let* ((f0-32 (vector-dot gp-6 (-> self local-down)))
(f0-33 (if (< 0.0 f0-32)
(* f0-32 (-> *CAMERA_MASTER-bank* up-move-to-pitch-ratio-in-air))
(* f0-32 (-> *CAMERA_MASTER-bank* down-move-to-pitch-ratio-in-air))
)
)
)
(vector+float*! (-> self tpos-curr-adj) (-> self tpos-tgt) (-> self local-down) f0-33)
)
(vector-! gp-6 (-> *target* control shadow-pos) (-> self tpos-curr-adj))
(let* ((f0-35 (vector-dot gp-6 (-> self local-down)))
(f0-36 (* 0.03 f0-35))
)
(if (and (< f0-36 0.0) (< f0-36 (-> self upspeed)))
(set! (-> self upspeed) f0-36)
)
)
)
(else
(if *display-cam-los-debug*
(format *stdcon* "ground tracking~%")
)
(vector-! gp-6 (-> self tpos-curr) (-> self tpos-old))
(let ((f0-38 (vector-dot gp-6 (-> self local-down))))
(cond
((logtest? (-> *target* water flags) 512)
(set! (-> self upspeed) 0.0)
)
((< 0.0 f0-38)
(set! (-> self upspeed) 0.0)
)
(else
(set! (-> self upspeed) f0-38)
)
)
)
(set! (-> self tpos-tgt quad) (-> self tpos-curr quad))
(vector-! gp-6 (-> self tpos-curr-adj) (-> self tpos-curr))
(let* ((f0-42 (vector-dot gp-6 (-> self local-down)))
(f0-43 (if (< 0.0 f0-42)
(* f0-42 (-> *CAMERA_MASTER-bank* up-move-to-pitch-on-ground))
(* f0-42 (-> *CAMERA_MASTER-bank* down-move-to-pitch-on-ground))
)
)
)
(vector+float*! (-> self tpos-curr-adj) (-> self tpos-curr) (-> self local-down) f0-43)
)
)
)
)
(if (zero? (logand (-> self slave-options) 16))
(reset-follow)
)
(let ((v1-196 (-> *target* water flags)))
(when (and (logtest? v1-196 512) (logtest? v1-196 6144))
(let ((f0-45 (- (-> *target* water base-height) (-> self target-height))))
(if (< (-> self tpos-curr-adj y) f0-45)
(set! (-> self tpos-curr-adj y) f0-45)
)
)
)
)
(vector+! (-> self pitch-off) (-> self pitch-off) (-> self tpos-curr))
(vector-! (-> self pitch-off) (-> self pitch-off) (-> self tpos-old))
(vector-float*! (-> self pitch-off) (-> self pitch-off) (-> *CAMERA_MASTER-bank* pitch-off-blend))
(let ((gp-7 (new 'stack-no-clear 'vector)))
(vector--float*! gp-7 (-> self tpos-curr-adj) (-> self local-down) (-> self target-height))
(let ((v1-207 (new 'stack-no-clear 'vector)))
0.0
(vector-! v1-207 (-> *target* control shadow-pos) gp-7)
(let* ((f0-50 (vector-dot v1-207 (-> self local-down)))
(f0-51 (+ -4096.0 f0-50))
)
(if (< f0-51 0.0)
(vector+float*! gp-7 gp-7 (-> self local-down) f0-51)
)
)
)
(TODO-RENAME-17 (-> self target-spline) gp-7 2048.0 0.0 #f)
)
(the-as symbol (TODO-RENAME-22 (-> self target-spline) 40960.0))
)
(*target*
(logior! (-> self master-options) 2)
(reset-target-tracking)
)
((logtest? (-> self master-options) 2)
(let ((v0-1 (the-as symbol (logand -3 (-> self master-options)))))
(set! (-> self master-options) (the-as uint v0-1))
v0-1
)
)
)
)
)
;; definition for function in-cam-entity-volume?
;; Used lq/sq
(defun in-cam-entity-volume? ((arg0 vector) (arg1 entity) (arg2 float) (arg3 symbol))
(local-vars (sv-16 res-tag))
(let ((s2-0 0))
(while #t
(set! sv-16 (new 'static 'res-tag))
(let ((v1-1 (the-as object ((method-of-type res-lump get-property-data)
arg1
arg3
'exact
(the float s2-0)
(the-as pointer #f)
(& sv-16)
*res-static-buf*
)
)
)
)
(cond
((not (the-as pointer v1-1))
(return #f)
)
(else
(dotimes (a0-2 (the-as int (-> sv-16 elt-count)))
(if (< arg2 (- (vector-dot arg0 (-> (the-as (inline-array vector) v1-1) a0-2))
(-> (the-as (inline-array vector) v1-1) a0-2 w)
)
)
(goto cfg-12)
)
)
(return #t)
)
)
)
(label cfg-12)
(+! s2-0 1)
)
)
(the-as symbol #f)
)
;; definition for function master-unset-region
(defbehavior master-unset-region camera-master ()
(when (-> self cam-entity)
(set! (-> self cam-entity) #f)
(set! (-> self master-options) (logand -65 (-> self master-options)))
(set! (-> self stringMinHeight) (-> *CAMERA-bank* default-string-min-y))
(set! (-> self stringMaxHeight) (-> *CAMERA-bank* default-string-max-y))
(set! (-> self stringMinLength) (-> *CAMERA-bank* default-string-min-z))
(set! (-> self stringMaxLength) (-> *CAMERA-bank* default-string-max-z))
(set! (-> self stringCliffHeight) 163840.0)
(send-event *camera* 'point-of-interest #f)
(set! (-> *camera-combiner* tracking point-of-interest-blend target) 0.0)
(let ((a1-1 (new 'stack-no-clear 'event-message-block)))
(set! (-> a1-1 from) self)
(set! (-> a1-1 num-params) 1)
(set! (-> a1-1 message) 'query-state)
(set! (-> a1-1 param 0) (the-as uint *camera-base-mode*))
(if (not (send-event-function *camera* a1-1))
(send-event *camera* 'change-state *camera-base-mode* 450)
)
)
(set! (-> *camera-combiner* tracking tilt-adjust target) (-> *CAMERA-bank* default-tilt-adjust))
(send-event *camera* 'clear-slave-option #x10000)
)
)
;; definition for function master-base-region
(defbehavior master-base-region camera-master ((arg0 entity))
(logior! (-> self master-options) 64)
(set! (-> self stringMinHeight)
(cam-slave-get-float arg0 'stringMinHeight (-> *CAMERA-bank* default-string-min-y))
)
(set! (-> self stringMaxHeight)
(cam-slave-get-float arg0 'stringMaxHeight (-> *CAMERA-bank* default-string-max-y))
)
(set! (-> self stringMinLength)
(cam-slave-get-float arg0 'stringMinLength (-> *CAMERA-bank* default-string-min-z))
)
(set! (-> self stringMaxLength)
(cam-slave-get-float arg0 'stringMaxLength (-> *CAMERA-bank* default-string-max-z))
)
(let ((s5-0 (new 'stack-no-clear 'vector)))
(if (cam-slave-get-vector-with-offset (the-as entity-actor arg0) s5-0 'interesting)
(send-event *camera* 'point-of-interest s5-0)
)
)
(if (< 405504.0 (-> self stringMaxLength))
(set! (-> self stringMaxLength) (-> *CAMERA-bank* default-string-max-z))
)
(set! (-> self stringCliffHeight) (cam-slave-get-float arg0 'stringCliffHeight 163840.0))
(let ((a1-7 (new 'stack-no-clear 'event-message-block)))
(set! (-> a1-7 from) self)
(set! (-> a1-7 num-params) 1)
(set! (-> a1-7 message) 'query-state)
(set! (-> a1-7 param 0) (the-as uint *camera-base-mode*))
(if (not (send-event-function *camera* a1-7))
(send-event *camera* 'change-state *camera-base-mode* 450)
)
)
(if (logtest? #x10000 (cam-slave-get-flags (-> self cam-entity) 'flags))
(send-event *camera* 'set-slave-option #x10000)
)
(let ((f0-12 (cam-slave-get-float arg0 'tiltAdjust (-> *CAMERA-bank* default-tilt-adjust))))
(set! (-> *camera-combiner* tracking tilt-adjust target) f0-12)
f0-12
)
)
;; definition for function setup-slave-for-hopefull
(defun setup-slave-for-hopefull ((arg0 camera-slave))
(when (= (-> arg0 blend-to-type) 2)
(cam-calc-follow! (-> arg0 tracking) (-> arg0 trans) #f)
(slave-set-rotation! (-> arg0 tracking) (-> arg0 trans) (the-as float (-> arg0 options)) (-> arg0 fov) #f)
)
(none)
)
;; definition for function master-is-hopeful-better?
(defbehavior master-is-hopeful-better? camera-master ((arg0 camera-slave) (arg1 camera-slave))
(if (not *camera-combiner*)
#f
(< (vector-dot (-> arg0 tracking inv-mat vector 2) (-> *camera-combiner* inv-camera-rot vector 2))
(vector-dot (-> arg1 tracking inv-mat vector 2) (-> *camera-combiner* inv-camera-rot vector 2))
)
)
)
;; definition for function master-switch-to-entity
;; WARN: rewrite_to_get_var got a none typed variable. Is there unreachable code? [OP: 166]
;; WARN: rewrite_to_get_var got a none typed variable. Is there unreachable code? [OP: 176]
;; WARN: rewrite_to_get_var got a none typed variable. Is there unreachable code? [OP: 196]
;; WARN: rewrite_to_get_var got a none typed variable. Is there unreachable code? [OP: 220]
;; Used lq/sq
(defbehavior master-switch-to-entity camera-master ((arg0 entity))
(local-vars
(v0-21 none)
(gp-0 (pointer process))
(sv-16 res-tag)
(sv-112 process)
(sv-128 string)
(sv-144 string)
)
(set! (-> self cam-entity) arg0)
10
(let ((s4-0 (cam-state-from-entity arg0)))
(cond
((= s4-0 *camera-base-mode*)
(master-base-region arg0)
(return #t)
)
(s4-0
(let ((s3-0 (get-process *camera-dead-pool* camera-slave #x4000)))
(set! gp-0 (when s3-0
(let ((t9-3 (method-of-type camera-slave activate)))
(t9-3 (the-as camera-slave s3-0) self 'camera-slave (the-as pointer #x70004000))
)
(run-now-in-process s3-0 cam-slave-init s4-0 arg0)
(-> s3-0 ppointer)
)
)
)
(when (not gp-0)
(format 0 "ERROR <GMJ>: primary region activate failed~%")
(return #f)
)
(setup-slave-for-hopefull (the-as camera-slave (ppointer->process gp-0)))
)
(else
(format 0 "ERROR <GMJ>: camera region '~S' didn't produce a state~%" (res-lump-struct arg0 'name structure))
(return #f)
)
)
)
(set! sv-16 (new 'static 'res-tag))
(let ((s4-2 (res-lump-data arg0 'alternates (pointer string) :tag-ptr (& sv-16))))
(when s4-2
(dotimes (s3-2 (the-as int (-> sv-16 elt-count)))
(let ((s2-0 (entity-by-name (-> s4-2 s3-2))))
(set! v0-21
(cond
(s2-0
(let ((s0-0 (cam-state-from-entity s2-0)))
(cond
((= s0-0 *camera-base-mode*)
(deactivate (-> gp-0 0))
(master-base-region s2-0)
(return #t)
v0-21
)
(s0-0
(set! sv-112 (get-process *camera-dead-pool* camera-slave #x4000))
(let ((s1-0 (when sv-112
(let ((t9-15 (method-of-type camera-slave activate)))
(t9-15 (the-as camera-slave sv-112) self 'camera-slave (the-as pointer #x70004000))
)
(run-now-in-process sv-112 cam-slave-init s0-0 s2-0)
(-> sv-112 ppointer)
)
)
)
(cond
(s1-0
(setup-slave-for-hopefull (the-as camera-slave (ppointer->process s1-0)))
(cond
((master-is-hopeful-better?
(the-as camera-slave (ppointer->process gp-0))
(the-as camera-slave (ppointer->process s1-0))
)
(deactivate (-> gp-0 0))
(set! gp-0 s1-0)
gp-0
)
(else
(deactivate (-> s1-0 0))
)
)
)
(else
(format 0 "ERROR <GMJ>: alternate region activate failed~%")
)
)
)
)
(else
(let ((s1-1 format)
(s0-1 0)
)
(set! sv-128 "ERROR <GMJ>: alternate camera region '~S' didn't produce a state~%")
(let ((a2-10 (res-lump-struct s2-0 'name structure)))
(s1-1 s0-1 sv-128 a2-10)
)
)
)
)
)
)
(else
(let ((s2-1 format)
(s1-2 0)
(s0-2 "ERROR <GMJ>: alternate '~S' not found for '~S'~%")
)
(set! sv-144 (-> s4-2 s3-2))
(let ((a3-8 (res-lump-struct arg0 'name structure)))
(s2-1 s1-2 s0-2 sv-144 a3-8)
)
)
)
)
)
)
)
)
)
(let ((v1-48 (the int (* 300.0 (cam-slave-get-interp-time (-> (the-as camera-slave (-> gp-0 0)) cam-entity))))))
(if (nonzero? (-> self force-blend))
(set! v1-48 (min v1-48 (the-as int (-> self force-blend-time))))
)
(send-event *camera* 'change-state (ppointer->process gp-0) v1-48)
)
#t
)
;; definition for function master-check-regions
(defbehavior master-check-regions camera-master ()
(let ((a1-0 (new 'stack-no-clear 'event-message-block)))
(set! (-> a1-0 from) self)
(set! (-> a1-0 num-params) 1)
(set! (-> a1-0 message) 'query-state)
(set! (-> a1-0 param 0) (the-as uint cam-eye))
(cond
((send-event-function *camera* a1-0)
#f
)
((or (not *target*) (logtest? (-> self master-options) 1))
(master-unset-region)
)
((and (logtest? (-> self master-options) 4)
(not (-> self on-ground))
(or (not (-> self cam-entity)) (zero? (logand #x20000 (cam-slave-get-flags (-> self cam-entity) 'flags))))
)
#f
)
((and (-> self cam-entity)
(not (in-cam-entity-volume? (target-pos 0) (-> self cam-entity) 0.0 'cutoutvol))
(or (in-cam-entity-volume? (target-pos 0) (-> self cam-entity) 1024.0 'pvol)
(in-cam-entity-volume? (target-pos 0) (-> self cam-entity) 1024.0 'vol)
(and (not ((method-of-type res-lump get-property-data)
(-> self cam-entity)
'pvol
'exact
0.0
(the-as pointer #f)
(the-as (pointer res-tag) #f)
*res-static-buf*
)
)
(not ((method-of-type res-lump get-property-data)
(-> self cam-entity)
'vol
'exact
0.0
(the-as pointer #f)
(the-as (pointer res-tag) #f)
*res-static-buf*
)
)
)
)
)
#f
)
(else
(let ((v1-17 (-> *camera-engine* alive-list next0)))
*camera-engine*
(let ((gp-5 (-> v1-17 next0)))
(while (!= v1-17 (-> *camera-engine* alive-list-end))
(let ((s5-1 (-> (the-as connection v1-17) param1)))
(when (and (not (in-cam-entity-volume? (target-pos 0) (the-as entity s5-1) 1024.0 'cutoutvol))
(in-cam-entity-volume? (target-pos 0) (the-as entity s5-1) 0.0 'vol)
)
(if (master-switch-to-entity (the-as entity s5-1))
(return #t)
)
)
)
(set! v1-17 gp-5)
*camera-engine*
(set! gp-5 (-> gp-5 next0))
)
)
)
(master-unset-region)
)
)
)
)
;; failed to figure out what this is:
(defstate cam-master-active (camera-master)
:enter
(behavior ()
(if (and (nonzero? camera-master-debug) *debug-segment*)
(add-connection *debug-engine* self camera-master-debug self #f #f)
)
(none)
)
:trans
(behavior ()
(when (not (paused?))
(vector-negate!
(-> self local-down)
(vector-normalize-copy! (-> self local-down) (-> *standard-dynamics* gravity) 1.0)
)
(cam-master-effect)
)
(none)
)
:code
(behavior ()
(while #t
(if (and *dproc* *debug-segment*)
(add-frame
(-> *display* frames (-> *display* on-screen) frame profile-bar 0)
'camera
(new 'static 'rgba :r #x40 :b #x40 :a #x80)
)
)
(set! (-> self string-min target y) (-> self stringMinHeight))
(set! (-> self string-max target y) (-> self stringMaxHeight))
(set! (-> self string-min target z) (-> self stringMinLength))
(set! (-> self string-max target z) (-> self stringMaxLength))
(set! (-> self string-push-z) (fmax (-> self string-min value z) (-> *CAMERA-bank* default-string-push-z)))
(master-track-target)
(set! (-> last-try-to-look-at-data horz) 0.0)
(set! (-> last-try-to-look-at-data vert) 0.0)
(let ((a1-1 (new 'stack-no-clear 'event-message-block)))
(set! (-> a1-1 from) self)
(set! (-> a1-1 num-params) 1)
(set! (-> a1-1 message) 'slave-option?)
(set! (-> a1-1 param 0) (the-as uint #x4000))
(when (send-event-function *camera* a1-1)
(set! (-> self string-min target y) 18432.0)
(set! (-> self string-max target y) 18432.041)
)
)
(when (not (paused?))
(update! (-> self string-min) (the-as vector #f))
(update! (-> self string-max) (the-as vector #f))
(master-check-regions)
)
(set! (-> self string-min value x)
(fmin (-> self string-min value x) (+ -4.096 (-> self string-max value x)))
)
(set! (-> self string-min value y)
(fmin (-> self string-min value y) (+ -4.096 (-> self string-max value y)))
)
(set! (-> self string-min value z)
(fmin (-> self string-min value z) (+ -4.096 (-> self string-max value z)))
)
(if (nonzero? (-> self no-intro))
(+! (-> self no-intro) -1)
)
(if (nonzero? (-> self force-blend))
(+! (-> self force-blend) -1)
)
(suspend)
)
(none)
)
)
;; definition of type list-keeper
(deftype list-keeper (process)
((dummy float :offset-assert 112)
)
:heap-base #x10
:method-count-assert 14
:size-assert #x74
:flag-assert #xe00100074
)
;; definition for method 3 of type list-keeper
(defmethod inspect list-keeper ((obj list-keeper))
(let ((t9-0 (method-of-type process inspect)))
(t9-0 obj)
)
(format #t "~T~Tdummy: ~f~%" (-> obj dummy))
obj
)
;; failed to figure out what this is:
(defstate list-keeper-active (camera-master)
:code
(behavior ()
(while #t
(change-to-last-brother self)
(suspend)
)
(none)
)
)
;; definition for function list-keeper-init
;; INFO: Return type mismatch int vs none.
(defbehavior list-keeper-init camera-master ()
(go list-keeper-active)
0
(none)
)
;; definition for function cam-master-init
;; INFO: Return type mismatch int vs none.
;; Used lq/sq
(defbehavior cam-master-init camera-master ()
(set! *camera* self)
(stack-size-set! (-> self main-thread) 512)
(logclear! (-> self mask) (process-mask menu))
(set! (-> self master-options) (the-as uint 4))
(set! (-> self num-slaves) 0)
(dotimes (v1-5 2)
(set! (-> self slave v1-5) (the-as (pointer camera-slave) #f))
)
(set! (-> self slave-options) (the-as uint 560))
(set! (-> self view-off-param-save) 1.0)
(set! (-> self changer) (the-as uint (process->ppointer self)))
(set! (-> self cam-entity) #f)
(set! (-> self stringMinHeight) (-> *CAMERA-bank* default-string-min-y))
(set! (-> self stringMaxHeight) (-> *CAMERA-bank* default-string-max-y))
(set! (-> self stringMinLength) (-> *CAMERA-bank* default-string-min-z))
(set! (-> self stringMaxLength) (-> *CAMERA-bank* default-string-max-z))
(set! (-> self stringCliffHeight) 163840.0)
(set! (-> self no-intro) (the-as uint 0))
(set! (-> self force-blend) (the-as uint 0))
(set! (-> self string-push-z) (-> *CAMERA-bank* default-string-push-z))
(let ((gp-0 (new-stack-vector0)))
(set! (-> gp-0 y) (-> *CAMERA-bank* default-string-min-y))
(set! (-> gp-0 z) (-> *CAMERA-bank* default-string-min-z))
(init! (-> self string-min) gp-0 40.96 409.6 0.9)
(set! (-> gp-0 y) (-> *CAMERA-bank* default-string-max-y))
(set! (-> gp-0 z) (-> *CAMERA-bank* default-string-max-z))
(init! (-> self string-max) gp-0 40.96 409.6 0.9)
)
(set! (-> self outro-t-step) 0.0)
(set! (-> self drawable-target) (the-as handle #f))
(set! (-> self which-bone) 0)
(let ((a1-3 (new-stack-vector0)))
(TODO-RENAME-10 (-> self target-spline) a1-3)
)
(set! (-> self pov-handle) (the-as handle #f))
(set! (-> self pov-bone) 0)
(let ((gp-1 (get-process *camera-dead-pool* list-keeper #x4000)))
(cond
((when gp-1
(let ((t9-5 (method-of-type list-keeper activate)))
(t9-5 (the-as list-keeper gp-1) self 'list-keeper (the-as pointer #x70004000))
)
(run-next-time-in-process gp-1 list-keeper-init)
(-> gp-1 ppointer)
)
)
(else
(format 0 "ERROR <GMJ>: master camera list keeper failed to activate~%")
)
)
)
(let ((gp-2 (get-process *camera-dead-pool* camera-slave #x4000)))
(cond
((when gp-2
(let ((t9-9 (method-of-type camera-slave activate)))
(t9-9 (the-as camera-slave gp-2) self 'camera-slave (the-as pointer #x70004000))
)
(run-next-time-in-process gp-2 cam-slave-init cam-free-floating #f)
(-> gp-2 ppointer)
)
)
(else
(format 0 "ERROR <GMJ>: first slave failed to activate~%")
)
)
)
(set! (-> self water-drip) (create-launch-control group-rain-screend-drop self))
(set! (-> self water-drip-time) (seconds -60))
(go cam-master-active)
0
(none)
)