mirror of
https://github.com/open-goal/jak-project.git
synced 2024-10-20 21:27:52 -04:00
49e798f88c
This PR adds detection of the `launch-particles` and `seconds-per-frame` macros to the decompiler, removing a lot of bloat and hiding many process register uses. I also added `og:preserve-this` comments to as many manual patches and comments as I could, which will soon be used in conjunction with CI to hopefully catch any regressions in future big decomp update PRs. I have some concerns about the `launch-particles` macro (more details in `sparticle-launcher.gc`) , but thus far, I have not seen anything break yet. --------- Co-authored-by: water <awaterford111445@gmail.com>
1695 lines
61 KiB
Common Lisp
1695 lines
61 KiB
Common Lisp
;;-*-Lisp-*-
|
|
(in-package goal)
|
|
|
|
;; name: dig-digger.gc
|
|
;; name in dgo: dig-digger
|
|
;; dgos: DG1, D3A
|
|
|
|
;; DECOMP BEGINS
|
|
|
|
(defpartgroup group-dig-clasp-break
|
|
:id 1142
|
|
:duration (seconds 0.05)
|
|
:flags (use-local-clock)
|
|
:bounds (static-bspherem 0 0 0 8)
|
|
:parts ((sp-item 4937 :fade-after (meters 50) :falloff-to (meters 100) :period (seconds 2) :length (seconds 0.035))
|
|
(sp-item 4938 :fade-after (meters 50) :period (seconds 2) :length (seconds 0.017))
|
|
)
|
|
)
|
|
|
|
(defpart 4937
|
|
:init-specs ((:texture (new 'static 'texture-id :index #x92 :page #xc))
|
|
(:num 8.0 8.0)
|
|
(:scale-x (meters 2.5))
|
|
(:rot-x 4)
|
|
(:scale-y (meters 0.07) (meters 0.03))
|
|
(:r 255.0)
|
|
(:g 128.0 128.0)
|
|
(:b 0.0 128.0)
|
|
(:a 128.0)
|
|
(:omega (degrees 0.01125) (degrees 0.01125))
|
|
(:vel-y (meters 0.1) (meters 0.06666667))
|
|
(:fade-g -2.55 -2.55)
|
|
(:fade-b -8.0)
|
|
(:fade-a -0.64 -0.64)
|
|
(:friction 0.85 0.02)
|
|
(:timer (seconds 0.335))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-3))
|
|
(:func 'sparticle-motion-blur)
|
|
(:conerot-x (degrees 0) (degrees 80))
|
|
(:conerot-y (degrees 0) (degrees 3600))
|
|
)
|
|
)
|
|
|
|
(defpart 4938
|
|
:init-specs ((:texture (new 'static 'texture-id :index #xbb :page #xc))
|
|
(:num 1.0)
|
|
(:scale-x (meters 3))
|
|
(:rot-x (degrees 0.225))
|
|
(:rot-z (degrees 0) (degrees 3600))
|
|
(:scale-y :copy scale-x)
|
|
(:r 255.0)
|
|
(:g 128.0 128.0)
|
|
(:b 0.0)
|
|
(:a 96.0 16.0)
|
|
(:omega (degrees 1136.25))
|
|
(:scalevel-x (meters 0.08))
|
|
(:scalevel-y :copy scalevel-x)
|
|
(:fade-g -10.2)
|
|
(:fade-a -4.48)
|
|
(:timer (seconds 0.085))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-3 glow))
|
|
(:userdata 0.0)
|
|
)
|
|
)
|
|
|
|
(defpartgroup group-dig-digger-smoke
|
|
:id 1143
|
|
:duration (seconds 0.017)
|
|
:flags (use-local-clock)
|
|
:bounds (static-bspherem 0 0 0 16)
|
|
:parts ((sp-item 4939 :fade-after (meters 200) :falloff-to (meters 300))
|
|
(sp-item 4940 :fade-after (meters 200) :flags (bit6))
|
|
(sp-item 4941 :fade-after (meters 200) :flags (bit6))
|
|
)
|
|
)
|
|
|
|
(defpart 4940
|
|
:init-specs ((:texture (new 'static 'texture-id :index #xca :page #xc))
|
|
(:num 1.0)
|
|
(:y (meters 0) (meters 1))
|
|
(:scale-x (meters 24) (meters 0.1))
|
|
(:rot-x (degrees 6.7500005))
|
|
(:rot-z (degrees -4) (degrees 8))
|
|
(:scale-y :copy scale-x)
|
|
(:r 255.0)
|
|
(:g 128.0 128.0)
|
|
(:b 0.0 128.0)
|
|
(:a 12.0 4.0)
|
|
(:omega (degrees 4518))
|
|
(:fade-a -1.0666667)
|
|
(:timer (seconds 0.05))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-3 glow))
|
|
(:userdata 6144.0)
|
|
)
|
|
)
|
|
|
|
(defpart 4941
|
|
:init-specs ((:texture (new 'static 'texture-id :index #xbb :page #xc))
|
|
(:num 1.0)
|
|
(:y (meters 0))
|
|
(:scale-x (meters 6) (meters 2))
|
|
(:rot-x (degrees 6.7500005))
|
|
(:rot-z (degrees -4) (degrees 8))
|
|
(:scale-y :copy scale-x)
|
|
(:r 255.0)
|
|
(:g 128.0 128.0)
|
|
(:b 0.0 128.0)
|
|
(:a 20.0 4.0)
|
|
(:omega (degrees 4518))
|
|
(:timer (seconds 0.017))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-3 glow))
|
|
(:userdata 6144.0)
|
|
)
|
|
)
|
|
|
|
(defpart 4939
|
|
:init-specs ((:texture (new 'static 'texture-id :page #xc))
|
|
(:birth-func 'birth-func-texture-group)
|
|
(:num 0.0 1.0)
|
|
(:scale-x (meters 2) (meters 2))
|
|
(:rot-z (degrees 0) (degrees 360))
|
|
(:scale-y :copy scale-x)
|
|
(:r 255.0)
|
|
(:g 255.0)
|
|
(:b 255.0)
|
|
(:a 32.0 32.0)
|
|
(:vel-y (meters 0.06) (meters 0.01))
|
|
(:scalevel-x (meters 0.026666667) (meters 0.02))
|
|
(:rotvel-z (degrees -0.2) (degrees 0.4))
|
|
(:scalevel-y :copy scalevel-x)
|
|
(:fade-r 0.0)
|
|
(:fade-g -0.36)
|
|
(:fade-b -4.24)
|
|
(:fade-a -0.047407407 -0.047407407)
|
|
(:accel-x (meters -0.00066666666) (meters -0.00033333333))
|
|
(:accel-y (meters 0.0001) (meters 0.0001))
|
|
(:friction 0.96)
|
|
(:timer (seconds 8))
|
|
(:flags (sp-cpuinfo-flag-2))
|
|
(:userdata :data (new 'static 'boxed-array :type int32 40 1 0 #xc00000 #xc00000 #xc03300))
|
|
(:next-time (seconds 0.085))
|
|
(:next-launcher 4942)
|
|
)
|
|
)
|
|
|
|
(defpart 4942
|
|
:init-specs ((:fade-r 0.0) (:fade-g 0.0) (:fade-b 0.0) (:next-time (seconds 0.035) (seconds 0.13)) (:next-launcher 4943))
|
|
)
|
|
|
|
(defpart 4943
|
|
:init-specs ((:scalevel-x (meters 0.013333334) (meters 0.0033333334))
|
|
(:scalevel-y :copy scalevel-x)
|
|
(:fade-r -0.85333335)
|
|
(:fade-g -0.79333335)
|
|
(:fade-b -0.14)
|
|
(:next-time (seconds 0.5))
|
|
(:next-launcher 4944)
|
|
)
|
|
)
|
|
|
|
(defpart 4944
|
|
:init-specs ((:r 128.0)
|
|
(:g 128.0)
|
|
(:b 128.0)
|
|
(:fade-r 0.0 -0.256)
|
|
(:fade-g :copy fade-r)
|
|
(:fade-b :copy fade-g)
|
|
(:fade-a -0.072)
|
|
)
|
|
)
|
|
|
|
;; ERROR: Bad vector register dependency: vf4
|
|
;; ERROR: Bad vector register dependency: vf5
|
|
;; ERROR: Bad vector register dependency: vf6
|
|
;; ERROR: Bad vector register dependency: vf30
|
|
;; ERROR: Bad vector register dependency: vf31
|
|
(defun birth-func-dig-digger-collide ((arg0 sparticle-system)
|
|
(arg1 sparticle-cpuinfo)
|
|
(arg2 sprite-vec-data-3d)
|
|
(arg3 sparticle-launcher)
|
|
(arg4 sparticle-launch-state)
|
|
)
|
|
(local-vars (v1-11 float))
|
|
(rlet ((acc :class vf)
|
|
(vf0 :class vf)
|
|
(vf30 :class vf)
|
|
(vf31 :class vf)
|
|
(vf4 :class vf)
|
|
(vf5 :class vf)
|
|
(vf6 :class vf)
|
|
(vf7 :class vf)
|
|
)
|
|
(init-vf0-vector)
|
|
(let ((s5-0 (new 'stack-no-clear 'inline-array 'vector 5)))
|
|
(.svf (&-> s5-0 0 quad) vf4)
|
|
(.svf (&-> s5-0 1 quad) vf5)
|
|
(.svf (&-> s5-0 2 quad) vf6)
|
|
(.svf (&-> s5-0 3 quad) vf30)
|
|
(.svf (&-> s5-0 4 quad) vf31)
|
|
(let ((s3-0 (the-as object (-> (the-as process (-> arg4 control)) brother)))
|
|
(s4-0 (new 'stack-no-clear 'collide-query))
|
|
)
|
|
(let ((s2-0 (new 'stack-no-clear 'vector)))
|
|
(set! (-> s4-0 start-pos quad) (-> (the-as process-drawable s3-0) root trans quad))
|
|
(+! (-> s4-0 start-pos y) 61440.0)
|
|
(set! (-> s2-0 x) (-> arg1 vel-sxvel x))
|
|
(set! (-> s2-0 z) (-> arg1 vel-sxvel z))
|
|
(vector-normalize! s2-0 1.0)
|
|
(let ((a0-5 (-> s4-0 start-pos)))
|
|
(let ((v1-3 (-> s4-0 start-pos)))
|
|
(let ((a1-5 (* 245760.0 (- 0.2 (- 0.8 (-> arg1 friction))))))
|
|
(.mov vf7 a1-5)
|
|
)
|
|
(.lvf vf5 (&-> s2-0 quad))
|
|
(.lvf vf4 (&-> v1-3 quad))
|
|
)
|
|
(.add.x.vf vf6 vf0 vf0 :mask #b1000)
|
|
(.mul.x.vf acc vf5 vf7 :mask #b111)
|
|
(.add.mul.w.vf vf6 vf4 vf0 acc :mask #b111)
|
|
(.svf (&-> a0-5 quad) vf6)
|
|
)
|
|
)
|
|
(set-vector! (-> s4-0 move-dist) 0.0 -81920.0 0.0 1.0)
|
|
(let ((v1-5 s4-0))
|
|
(set! (-> v1-5 radius) 1228.8)
|
|
(set! (-> v1-5 collide-with) (collide-spec backgnd obstacle hit-by-player-list hit-by-others-list))
|
|
(set! (-> v1-5 ignore-process0) (the-as process-tree s3-0))
|
|
(set! (-> v1-5 ignore-process1) #f)
|
|
(set! (-> v1-5 ignore-pat) (new 'static 'pat-surface :noentity #x1 :nojak #x1 :probe #x1 :noendlessfall #x1))
|
|
(set! (-> v1-5 action-mask) (collide-action solid))
|
|
)
|
|
(if (>= (fill-and-probe-using-line-sphere *collide-cache* s4-0) 0.0)
|
|
(set! (-> arg1 user-float) (+ 1024.0 (-> s4-0 best-other-tri intersect y)))
|
|
)
|
|
)
|
|
(.lvf vf4 (&-> s5-0 0 quad))
|
|
(.lvf vf5 (&-> s5-0 1 quad))
|
|
(.lvf vf6 (&-> s5-0 2 quad))
|
|
(.lvf vf30 (&-> s5-0 3 quad))
|
|
(.lvf vf31 (&-> s5-0 4 quad))
|
|
)
|
|
(.mov v1-11 vf31)
|
|
0
|
|
(none)
|
|
)
|
|
)
|
|
|
|
(defpartgroup group-dig-digger-digging
|
|
:id 1144
|
|
:duration (seconds 0.017)
|
|
:flags (use-local-clock)
|
|
:bounds (static-bspherem 0 0 0 64)
|
|
:parts ((sp-item 4945 :falloff-to (meters 200))
|
|
(sp-item 4946 :falloff-to (meters 100))
|
|
(sp-item 4947 :falloff-to (meters 200))
|
|
(sp-item 4948 :falloff-to (meters 200))
|
|
(sp-item 4949 :falloff-to (meters 300))
|
|
)
|
|
)
|
|
|
|
(defpart 4945
|
|
:init-specs ((:texture (new 'static 'texture-id :page #x973))
|
|
(:birth-func 'birth-func-dig-digger-collide)
|
|
(:num 2.0)
|
|
(:x (meters 8))
|
|
(:scale-x (meters 0.2) (meters 0.3))
|
|
(:rot-z (degrees 0) (degrees 3600))
|
|
(:scale-y (meters 0.2) (meters 0.3))
|
|
(:r 180.0 32.0)
|
|
(:g 150.0 32.0)
|
|
(:b 130.0 32.0)
|
|
(:a 128.0)
|
|
(:vel-x (meters 0.083333336) (meters 0.01))
|
|
(:vel-y (meters 0.16666667) (meters 0.033333335))
|
|
(:scalevel-x (meters -0.00008333333))
|
|
(:rotvel-z (degrees -1.2) (degrees 2.4))
|
|
(:scalevel-y :copy scalevel-x)
|
|
(:accel-y (meters -0.003))
|
|
(:friction 0.95 0.04)
|
|
(:timer (seconds 4))
|
|
(:flags (sp-cpuinfo-flag-0 sp-cpuinfo-flag-2 sp-cpuinfo-flag-12 sp-cpuinfo-flag-14))
|
|
(:func 'check-drop-level-dig-digger-rubble-sparks)
|
|
(:rotate-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defun check-drop-level-dig-digger-rubble-sparks ((arg0 sparticle-system) (arg1 sparticle-cpuinfo) (arg2 vector))
|
|
(when (and (< (-> arg2 y) (-> arg1 user-float)) (< (-> arg1 vel-sxvel y) 0.0))
|
|
(let ((gp-0 (new 'stack-no-clear 'vector)))
|
|
(sp-kill-particle arg0 arg1)
|
|
(set-vector! gp-0 (-> arg2 x) (-> arg1 user-float) (-> arg2 z) 1.0)
|
|
(launch-particles (-> *part-id-table* 4950) gp-0)
|
|
(launch-particles (-> *part-id-table* 4951) gp-0)
|
|
(launch-particles (-> *part-id-table* 4952) gp-0)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
|
|
(defpart 4948
|
|
:init-specs ((:texture (new 'static 'texture-id :index #xbb :page #xc))
|
|
(:num 6.0)
|
|
(:x (meters 9))
|
|
(:y (meters 1) (meters 1))
|
|
(:scale-x (meters 4) (meters 6))
|
|
(:rot-x (degrees 11.25))
|
|
(:rot-z (degrees 0) (degrees 3600))
|
|
(:scale-y :copy scale-x)
|
|
(:r 255.0)
|
|
(:g 128.0 128.0)
|
|
(:b 0.0 128.0)
|
|
(:a 0.0)
|
|
(:fade-g -3.2)
|
|
(:fade-b -3.2)
|
|
(:fade-a 0.8)
|
|
(:timer (seconds 0.135))
|
|
(:flags (sp-cpuinfo-flag-0 sp-cpuinfo-flag-2 sp-cpuinfo-flag-14 glow))
|
|
(:userdata 4096.0)
|
|
(:next-time (seconds 0.067))
|
|
(:next-launcher 4953)
|
|
(:rotate-y (degrees -45) (degrees 135))
|
|
)
|
|
)
|
|
|
|
(defpart 4953
|
|
:init-specs ((:fade-a -0.8))
|
|
)
|
|
|
|
(defpart 4946
|
|
:init-specs ((:texture (new 'static 'texture-id :index #x92 :page #xc))
|
|
(:num 3.0)
|
|
(:x (meters 8))
|
|
(:scale-x (meters 0.075) (meters 0.02))
|
|
(:rot-x 4)
|
|
(:scale-y :copy scale-x)
|
|
(:r 255.0)
|
|
(:g 128.0 128.0)
|
|
(:b 0.0 128.0)
|
|
(:a 128.0)
|
|
(:omega (degrees 0.01125) (degrees 0.01125))
|
|
(:vel-x (meters 0.23333333) (meters 0.1))
|
|
(:vel-y (meters 0.4) (meters 0.033333335))
|
|
(:fade-g -0.85333335)
|
|
(:fade-b -1.7066667)
|
|
(:accel-y (meters -0.003))
|
|
(:friction 0.9 0.04)
|
|
(:timer (seconds 0.335) (seconds 0.165))
|
|
(:flags (sp-cpuinfo-flag-0 sp-cpuinfo-flag-2 sp-cpuinfo-flag-12 sp-cpuinfo-flag-14))
|
|
(:func 'sparticle-motion-blur)
|
|
(:rotate-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defpart 4947
|
|
:init-specs ((:texture (new 'static 'texture-id :page #x973))
|
|
(:birth-func 'birth-func-texture-group)
|
|
(:num 3.0)
|
|
(:x (meters 8))
|
|
(:scale-x (meters 0.2) (meters 0.3))
|
|
(:rot-x 4)
|
|
(:scale-y (meters 0.2) (meters 0.3))
|
|
(:r 180.0 32.0)
|
|
(:g 150.0 32.0)
|
|
(:b 130.0 32.0)
|
|
(:a 128.0)
|
|
(:omega (degrees 0.0225) (degrees 0.0225))
|
|
(:vel-x (meters 0.083333336) (meters 0.01))
|
|
(:vel-y (meters 0.16666667) (meters 0.033333335))
|
|
(:scalevel-x (meters -0.00008333333))
|
|
(:scalevel-y :copy scalevel-x)
|
|
(:fade-a -0.14222223 -0.21333334)
|
|
(:accel-y (meters -0.003))
|
|
(:friction 0.95 0.04)
|
|
(:timer (seconds 3))
|
|
(:flags (sp-cpuinfo-flag-0 sp-cpuinfo-flag-2 sp-cpuinfo-flag-12 sp-cpuinfo-flag-14))
|
|
(:userdata
|
|
:data (new 'static 'boxed-array :type int32 40 1 0 -1758461952 -1758461696 -1758461440 -1758461184 -1758460928)
|
|
)
|
|
(:func 'sparticle-motion-blur)
|
|
(:rotate-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defpart 4949
|
|
:init-specs ((:texture (new 'static 'texture-id :page #xc))
|
|
(:num 1.0 1.0)
|
|
(:x (meters 9))
|
|
(:scale-x (meters 3) (meters 3))
|
|
(:rot-z (degrees 0) (degrees 3600))
|
|
(:scale-y (meters 3) (meters 3))
|
|
(:r 80.0 16.0)
|
|
(:g 70.0 16.0)
|
|
(:b 70.0 16.0)
|
|
(:a 96.0 32.0)
|
|
(:vel-x (meters 0.11333334))
|
|
(:vel-y (meters 0.16666667) (meters 0.033333335))
|
|
(:scalevel-x (meters 0.01) (meters 0.011666667))
|
|
(:rotvel-z (degrees -0.2) (degrees 0.4))
|
|
(:scalevel-y :copy scalevel-x)
|
|
(:fade-a -0.21333334 -0.21333334)
|
|
(:accel-y (meters -0.00033333333) (meters -0.00066666666))
|
|
(:friction 0.9 0.04)
|
|
(:timer (seconds 8))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-12))
|
|
(:rotate-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defpart 4950
|
|
:init-specs ((:texture (new 'static 'texture-id :page #x973))
|
|
(:birth-func 'birth-func-texture-group)
|
|
(:num 1.0 3.0)
|
|
(:scale-x (meters 0.1) (meters 0.2))
|
|
(:rot-z (degrees 0) (degrees 360))
|
|
(:scale-y (meters 0.1) (meters 0.2))
|
|
(:r 180.0 32.0)
|
|
(:g 150.0 32.0)
|
|
(:b 130.0 32.0)
|
|
(:a 96.0 32.0)
|
|
(:vel-y (meters 0.006666667) (meters 0.026666667))
|
|
(:rotvel-z (degrees -1.2) (degrees 2.4))
|
|
(:fade-a -0.42666668 -0.85333335)
|
|
(:accel-y (meters -0.00066666666))
|
|
(:timer (seconds 2))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-12))
|
|
(:userdata
|
|
:data (new 'static 'boxed-array :type int32 40 1 0 -1758461952 -1758461696 -1758461440 -1758461184 -1758460928)
|
|
)
|
|
(:conerot-x (degrees 10) (degrees 60))
|
|
(:conerot-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defpart 4951
|
|
:init-specs ((:texture (new 'static 'texture-id :page #x973))
|
|
(:birth-func 'birth-func-texture-group)
|
|
(:num 1.0 1.0)
|
|
(:scale-x (meters 0.1) (meters 0.2))
|
|
(:rot-z (degrees 0) (degrees 360))
|
|
(:scale-y (meters 0.1) (meters 0.2))
|
|
(:r 180.0 32.0)
|
|
(:g 150.0 32.0)
|
|
(:b 130.0 32.0)
|
|
(:a 96.0 32.0)
|
|
(:vel-y (meters 0) (meters 0.04))
|
|
(:rotvel-z (degrees -1.2) (degrees 2.4))
|
|
(:friction 0.94 0.02)
|
|
(:timer (seconds 8))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-12))
|
|
(:userdata
|
|
:data (new 'static 'boxed-array :type int32 40 1 0 -1758461952 -1758461696 -1758461440 -1758461184 -1758460928)
|
|
)
|
|
(:next-time (seconds 0.5) (seconds 0.997))
|
|
(:next-launcher 4954)
|
|
(:conerot-x (degrees 90))
|
|
(:conerot-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defpart 4954
|
|
:init-specs ((:rotvel-z (degrees 0)) (:fade-a -0.28444445 -0.28444445))
|
|
)
|
|
|
|
(defpart 4952
|
|
:init-specs ((:texture (new 'static 'texture-id :page #xc))
|
|
(:num 0.5 1.0)
|
|
(:scale-x (meters 1) (meters 1))
|
|
(:scale-y (meters 1) (meters 1))
|
|
(:r 80.0 16.0)
|
|
(:g 70.0 16.0)
|
|
(:b 70.0 16.0)
|
|
(:a 32.0 16.0)
|
|
(:vel-y (meters 0.013333334) (meters 0.026666667))
|
|
(:scalevel-x (meters 0.0033333334) (meters 0.0016666667))
|
|
(:scalevel-y (meters 0.0033333334) (meters 0.0016666667))
|
|
(:fade-a -0.053333335 -0.053333335)
|
|
(:accel-y (meters 0) (meters 0.00033333333))
|
|
(:friction 0.9 0.05)
|
|
(:timer (seconds 8))
|
|
(:flags (sp-cpuinfo-flag-2 sp-cpuinfo-flag-12))
|
|
(:conerot-x (degrees 70) (degrees 20))
|
|
(:conerot-y (degrees 0) (degrees 360))
|
|
)
|
|
)
|
|
|
|
(defmethod draw hud-dig-clasp ((obj hud-dig-clasp))
|
|
(set-hud-piece-position!
|
|
(the-as hud-sprite (-> obj sprites))
|
|
(the int (+ 457.0 (* 130.0 (-> obj offset))))
|
|
210
|
|
)
|
|
(format (clear (-> obj strings 0 text)) "~D" (-> obj values 0 current))
|
|
(set-as-offset-from! (the-as hud-sprite (-> obj strings 0 pos)) (the-as vector4w (-> obj sprites)) -18 29)
|
|
((method-of-type hud draw) obj)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
(defmethod update-values hud-dig-clasp ((obj hud-dig-clasp))
|
|
(set! (-> obj values 0 target) (the int (-> *game-info* counter)))
|
|
((method-of-type hud update-values) obj)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
(defmethod init-callback hud-dig-clasp ((obj hud-dig-clasp))
|
|
(set! (-> obj level) (level-get *level* 'dig1))
|
|
(set! (-> obj gui-id)
|
|
(add-process *gui-control* obj (gui-channel hud-middle-right) (gui-action hidden) (-> obj name) 81920.0 0)
|
|
)
|
|
(logior! (-> obj flags) (hud-flags show))
|
|
(set! (-> obj sprites 0 tex) (lookup-texture-by-id (new 'static 'texture-id :page #xb1c)))
|
|
(set! (-> obj sprites 0 flags) (the-as uint 4))
|
|
(set! (-> obj sprites 0 scale-x) 1.2)
|
|
(set! (-> obj sprites 0 scale-y) 1.2)
|
|
(alloc-string-if-needed obj 0)
|
|
(set! (-> obj strings 0 scale) 0.6)
|
|
(set! (-> obj strings 0 flags) (font-flags kerning middle large))
|
|
0
|
|
(none)
|
|
)
|
|
|
|
(deftype dig-clasp (process-drawable)
|
|
((b basic :offset-assert 200)
|
|
(conn connection-minimap :offset-assert 204)
|
|
)
|
|
:heap-base #x50
|
|
:method-count-assert 24
|
|
:size-assert #xd0
|
|
:flag-assert #x18005000d0
|
|
(:methods
|
|
(broken () _type_ :state 20)
|
|
(break-it () _type_ :state 21)
|
|
(idle () _type_ :state 22)
|
|
(dig-clasp-method-23 (_type_ vector) vector 23)
|
|
)
|
|
)
|
|
|
|
|
|
(defskelgroup skel-dig-clasp dig-clasp dig-clasp-lod0-jg dig-clasp-idle-ja
|
|
((dig-clasp-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 0 0 4)
|
|
)
|
|
|
|
(defskelgroup skel-dig-clasp-explode dig-clasp dig-clasp-explode-lod0-jg dig-clasp-explode-idle-ja
|
|
((dig-clasp-explode-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 0 0 8)
|
|
)
|
|
|
|
(defskelgroup skel-dig-clasp-b dig-clasp-b dig-clasp-b-lod0-jg dig-clasp-b-idle-ja
|
|
((dig-clasp-b-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 0 0 4)
|
|
)
|
|
|
|
(define *dig-clasp-exploder-params*
|
|
(new 'static 'joint-exploder-static-params
|
|
:joints (new 'static 'boxed-array :type joint-exploder-static-joint-params
|
|
(new 'static 'joint-exploder-static-joint-params :joint-index 3 :parent-joint-index -1)
|
|
(new 'static 'joint-exploder-static-joint-params :joint-index 4 :parent-joint-index -1)
|
|
(new 'static 'joint-exploder-static-joint-params :joint-index 5 :parent-joint-index -1)
|
|
(new 'static 'joint-exploder-static-joint-params :joint-index 7 :parent-joint-index -1)
|
|
(new 'static 'joint-exploder-static-joint-params :joint-index 8 :parent-joint-index -1)
|
|
)
|
|
:collide-spec #x1
|
|
)
|
|
)
|
|
|
|
(defmethod dig-clasp-method-23 dig-clasp ((obj dig-clasp) (arg0 vector))
|
|
(if (-> obj b)
|
|
(vector<-cspace! arg0 (-> obj node-list data 3))
|
|
(vector<-cspace! arg0 (-> obj node-list data 6))
|
|
)
|
|
)
|
|
|
|
(defstate broken (dig-clasp)
|
|
:virtual #t
|
|
:event (behavior ((proc process) (arg1 int) (event-type symbol) (event event-message-block))
|
|
(the-as object (case event-type
|
|
(('broken?)
|
|
#t
|
|
)
|
|
)
|
|
)
|
|
)
|
|
:enter (behavior ()
|
|
(when (-> self conn)
|
|
(kill-callback (-> *minimap* engine) (-> self conn))
|
|
(set! (-> self conn) #f)
|
|
)
|
|
(cond
|
|
((-> self b)
|
|
(ja :group! dig-digger-idle-ja
|
|
:num! (identity (the float (+ (-> (the-as art-joint-anim dig-digger-idle-ja) frames num-frames) -1)))
|
|
)
|
|
(setup-masks (-> self draw) 0 2)
|
|
)
|
|
(else
|
|
(ja :group! dig-digger-idle-ja
|
|
:num! (identity (the float (+ (-> (the-as art-joint-anim dig-digger-idle-ja) frames num-frames) -1)))
|
|
)
|
|
(setup-masks (-> self draw) 0 2)
|
|
)
|
|
)
|
|
(ja-post)
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-clasp) sleep-code)
|
|
)
|
|
|
|
(defstate break-it (dig-clasp)
|
|
:virtual #t
|
|
:event (behavior ((proc process) (arg1 int) (event-type symbol) (event event-message-block))
|
|
(the-as object (case event-type
|
|
(('broken?)
|
|
#t
|
|
)
|
|
)
|
|
)
|
|
)
|
|
:enter (behavior ()
|
|
(process-entity-status! self (entity-perm-status subtask-complete) #t)
|
|
(sound-play "dig-tether-snap")
|
|
(play-communicator-speech! (-> *talker-speech* 191))
|
|
(play-communicator-speech! (-> *talker-speech* 192))
|
|
(cond
|
|
((-> self b)
|
|
(ja :group! dig-digger-idle-ja :num! min)
|
|
(setup-masks (-> self draw) 0 2)
|
|
)
|
|
(else
|
|
(ja :group! dig-digger-idle-ja :num! min)
|
|
(setup-masks (-> self draw) 0 2)
|
|
)
|
|
)
|
|
(let ((gp-3 (new 'stack 'joint-exploder-tuning (the-as uint 0))))
|
|
(process-spawn
|
|
joint-exploder
|
|
(art-group-get-by-name *level* "skel-dig-clasp-explode" (the-as (pointer uint32) #f))
|
|
5
|
|
gp-3
|
|
*dig-clasp-exploder-params*
|
|
:to self
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
:trans (behavior ()
|
|
(ja :num! (seek!))
|
|
(if (nonzero? (-> self part))
|
|
(spawn (-> self part) (dig-clasp-method-23 self (new 'stack-no-clear 'vector)))
|
|
)
|
|
(if (ja-done? 0)
|
|
(go-virtual broken)
|
|
)
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-clasp) sleep-code)
|
|
:post (the-as (function none :behavior dig-clasp) ja-post)
|
|
)
|
|
|
|
(defstate idle (dig-clasp)
|
|
:virtual #t
|
|
:event (behavior ((proc process) (arg1 int) (event-type symbol) (event event-message-block))
|
|
(case event-type
|
|
(('tether-position)
|
|
(dig-clasp-method-23 self (the-as vector (-> event param 0)))
|
|
)
|
|
(('attack)
|
|
(let ((v1-2 (the-as attack-info (-> event param 1))))
|
|
(when (and (logtest? (-> v1-2 mask) (attack-info-mask mode)) (= (-> v1-2 mode) 'board))
|
|
(cpad-set-buzz! (-> *cpad-list* cpads 0) 0 85 (seconds 0.1))
|
|
(go-virtual break-it)
|
|
)
|
|
)
|
|
)
|
|
(('break)
|
|
(go-virtual break-it)
|
|
)
|
|
)
|
|
)
|
|
:enter (behavior ()
|
|
(ja-post)
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-clasp) sleep-code)
|
|
)
|
|
|
|
;; WARN: Return type mismatch object vs none.
|
|
(defmethod init-from-entity! dig-clasp ((obj dig-clasp) (arg0 entity-actor))
|
|
"Typically the method that does the initial setup on the process, potentially using the [[entity-actor]] provided as part of that.
|
|
This commonly includes things such as:
|
|
- stack size
|
|
- collision information
|
|
- loading the skeleton group / bones
|
|
- sounds"
|
|
(let ((s4-0 (new 'process 'collide-shape obj (collide-list-enum usually-hit-by-player))))
|
|
(let ((v1-2 (new 'process 'collide-shape-prim-sphere s4-0 (the-as uint 0))))
|
|
(set! (-> v1-2 prim-core collide-as) (collide-spec enemy))
|
|
(set! (-> v1-2 prim-core collide-with) (collide-spec jak bot player-list))
|
|
(set! (-> v1-2 transform-index) 6)
|
|
(set-vector! (-> v1-2 local-sphere) 0.0 -3072.0 0.0 4096.0)
|
|
(set! (-> s4-0 total-prims) (the-as uint 1))
|
|
(set! (-> s4-0 root-prim) v1-2)
|
|
)
|
|
(set! (-> s4-0 nav-radius) (* 0.75 (-> s4-0 root-prim local-sphere w)))
|
|
(let ((v1-5 (-> s4-0 root-prim)))
|
|
(set! (-> s4-0 backup-collide-as) (-> v1-5 prim-core collide-as))
|
|
(set! (-> s4-0 backup-collide-with) (-> v1-5 prim-core collide-with))
|
|
)
|
|
(set! (-> obj root) s4-0)
|
|
)
|
|
(process-drawable-from-entity! obj arg0)
|
|
(initialize-skeleton
|
|
obj
|
|
(the-as skeleton-group (art-group-get-by-name *level* "skel-dig-clasp" (the-as (pointer uint32) #f)))
|
|
(the-as pair 0)
|
|
)
|
|
(set! (-> obj draw light-index) (the-as uint 1))
|
|
(set! (-> obj part) (create-launch-control (-> *part-group-id-table* 1142) obj))
|
|
(set! (-> obj b) #f)
|
|
(set! (-> obj conn) (add-icon! *minimap* obj (the-as uint 16) (the-as int #f) (the-as vector #t) 0))
|
|
(if (and (-> obj entity) (logtest? (-> obj entity extra perm status) (entity-perm-status subtask-complete)))
|
|
(go (method-of-object obj broken))
|
|
(go (method-of-object obj idle))
|
|
)
|
|
(none)
|
|
)
|
|
|
|
(deftype dig-clasp-b (dig-clasp)
|
|
()
|
|
:heap-base #x50
|
|
:method-count-assert 24
|
|
:size-assert #xd0
|
|
:flag-assert #x18005000d0
|
|
)
|
|
|
|
|
|
;; WARN: Return type mismatch object vs none.
|
|
(defmethod init-from-entity! dig-clasp-b ((obj dig-clasp-b) (arg0 entity-actor))
|
|
"Typically the method that does the initial setup on the process, potentially using the [[entity-actor]] provided as part of that.
|
|
This commonly includes things such as:
|
|
- stack size
|
|
- collision information
|
|
- loading the skeleton group / bones
|
|
- sounds"
|
|
(when (not (task-node-closed? (game-task-node dig-knock-down-resolution)))
|
|
(let ((s4-0 (new 'process 'collide-shape obj (collide-list-enum usually-hit-by-player))))
|
|
(let ((v1-2 (new 'process 'collide-shape-prim-sphere s4-0 (the-as uint 0))))
|
|
(set! (-> v1-2 prim-core collide-as) (collide-spec enemy))
|
|
(set! (-> v1-2 prim-core collide-with) (collide-spec jak bot player-list))
|
|
(set! (-> v1-2 transform-index) 3)
|
|
(set-vector! (-> v1-2 local-sphere) 0.0 -3072.0 0.0 4096.0)
|
|
(set! (-> s4-0 total-prims) (the-as uint 1))
|
|
(set! (-> s4-0 root-prim) v1-2)
|
|
)
|
|
(set! (-> s4-0 nav-radius) (* 0.75 (-> s4-0 root-prim local-sphere w)))
|
|
(let ((v1-5 (-> s4-0 root-prim)))
|
|
(set! (-> s4-0 backup-collide-as) (-> v1-5 prim-core collide-as))
|
|
(set! (-> s4-0 backup-collide-with) (-> v1-5 prim-core collide-with))
|
|
)
|
|
(set! (-> obj root) s4-0)
|
|
)
|
|
(process-drawable-from-entity! obj arg0)
|
|
(initialize-skeleton
|
|
obj
|
|
(the-as skeleton-group (art-group-get-by-name *level* "skel-dig-clasp-b" (the-as (pointer uint32) #f)))
|
|
(the-as pair 0)
|
|
)
|
|
(set! (-> obj draw light-index) (the-as uint 1))
|
|
(set! (-> obj part) (create-launch-control (-> *part-group-id-table* 1142) obj))
|
|
(set! (-> obj b) (the-as basic #t))
|
|
(set! (-> obj conn) (add-icon! *minimap* obj (the-as uint 16) (the-as int #f) (the-as vector #t) 0))
|
|
(if (and (-> obj entity) (logtest? (-> obj entity extra perm status) (entity-perm-status subtask-complete)))
|
|
(go (method-of-object obj broken))
|
|
(go (method-of-object obj idle))
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
|
|
(deftype dig-tether-chain (structure)
|
|
((position vector :inline :offset-assert 0)
|
|
(velocity vector :inline :offset-assert 16)
|
|
(joint-mod joint-mod :offset-assert 32)
|
|
)
|
|
:method-count-assert 9
|
|
:size-assert #x24
|
|
:flag-assert #x900000024
|
|
)
|
|
|
|
|
|
(deftype dig-tether (process-drawable)
|
|
((clasp entity-actor :offset-assert 200)
|
|
(clasp-info-ok symbol :offset-assert 204)
|
|
(clasp-pos vector :inline :offset-assert 208)
|
|
(digger-pos vector :inline :offset-assert 224)
|
|
(digger-vertical vector :inline :offset-assert 240)
|
|
(frame oscillating-float :inline :offset-assert 256)
|
|
(frame-kicker delayed-rand-float :inline :offset-assert 280)
|
|
(old-dist float :offset-assert 308)
|
|
(chain-joints dig-tether-chain 8 :inline :offset-assert 320)
|
|
(chain-offset-rand delayed-rand-vector :inline :offset-assert 704)
|
|
(chain-offset oscillating-vector :inline :offset-assert 752)
|
|
(joint-one joint-mod :offset-assert 812)
|
|
(snapped-look lod-set :inline :offset-assert 816)
|
|
)
|
|
:heap-base #x2f0
|
|
:method-count-assert 25
|
|
:size-assert #x361
|
|
:flag-assert #x1902f00361
|
|
(:methods
|
|
(broken () _type_ :state 20)
|
|
(idle () _type_ :state 21)
|
|
(dig-tether-method-22 (_type_) none 22)
|
|
(dig-tether-method-23 (_type_) none 23)
|
|
(dig-tether-method-24 (_type_) none 24)
|
|
)
|
|
)
|
|
|
|
|
|
(defskelgroup skel-dig-tether-unsnapped dig-tether dig-tether-unsnapped-lod0-jg dig-tether-idle-ja
|
|
((dig-tether-unsnapped-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 0 0 80)
|
|
)
|
|
|
|
(defskelgroup skel-dig-tether-snapped dig-tether dig-tether-snapped-lod0-jg dig-tether-idle-ja
|
|
((dig-tether-snapped-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 0 0 80)
|
|
)
|
|
|
|
(defmethod dig-tether-method-22 dig-tether ((obj dig-tether))
|
|
(with-pp
|
|
(when (-> obj clasp)
|
|
(let* ((s4-0 (-> obj clasp extra process))
|
|
(s5-0 (if (type? s4-0 dig-clasp)
|
|
s4-0
|
|
)
|
|
)
|
|
(a1-1 (new 'stack-no-clear 'event-message-block))
|
|
)
|
|
(set! (-> a1-1 from) (process->ppointer pp))
|
|
(set! (-> a1-1 num-params) 0)
|
|
(set! (-> a1-1 message) 'broken?)
|
|
(cond
|
|
((or (send-event-function s5-0 a1-1)
|
|
(logtest? (-> obj clasp extra perm status) (entity-perm-status subtask-complete))
|
|
)
|
|
(go (method-of-object obj broken))
|
|
)
|
|
(s5-0
|
|
(send-event s5-0 'tether-position (-> obj clasp-pos))
|
|
(set! (-> obj clasp-info-ok) #t)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
)
|
|
|
|
(defmethod dig-tether-method-23 dig-tether ((obj dig-tether))
|
|
(set-params! (-> obj chain-offset-rand) 75 150 2048.0 204.8)
|
|
(set-params! (-> obj chain-offset) (the-as vector #f) 4.096 20.48 0.9)
|
|
(mode-set! (-> obj joint-one) (joint-mod-mode joint-set-world))
|
|
(dotimes (s5-0 7)
|
|
(cond
|
|
((-> obj clasp-info-ok)
|
|
(vector<-cspace! (the-as vector (-> obj chain-joints s5-0)) (-> obj chain-joints s5-0 joint-mod joint))
|
|
)
|
|
(else
|
|
(set! (-> obj chain-joints s5-0 position quad) (-> obj root trans quad))
|
|
(set! (-> obj chain-joints s5-0 position y)
|
|
(- (-> obj chain-joints s5-0 position y) (* 4096.0 (the float s5-0)))
|
|
)
|
|
)
|
|
)
|
|
;; og:preserve-this hack
|
|
;; original
|
|
;; (vector-reset! (+ (the-as uint (-> obj chain-joints 0 velocity)) (* 48 s5-0)))
|
|
(vector-reset! (-> obj chain-joints s5-0 velocity)) ;; hack
|
|
(mode-set! (-> obj chain-joints s5-0 joint-mod) (joint-mod-mode joint-set-world))
|
|
)
|
|
(set! (-> obj chain-joints 7 position quad) (-> obj chain-joints 6 position quad))
|
|
(vector-reset! (-> obj chain-joints 7 velocity))
|
|
(lods-assign! (-> obj draw) (-> obj snapped-look))
|
|
(none)
|
|
)
|
|
|
|
(defmethod dig-tether-method-24 dig-tether ((obj dig-tether))
|
|
(local-vars (sv-144 dig-tether-chain) (sv-160 vector))
|
|
(update-with-delay! (-> obj chain-offset-rand))
|
|
(update! (-> obj chain-offset) (-> obj chain-offset-rand value))
|
|
(let ((s5-0 (new 'stack-no-clear 'matrix))
|
|
(s4-0 (new 'stack-no-clear 'vector))
|
|
)
|
|
(set! (-> s4-0 quad) (-> obj root trans quad))
|
|
(let ((s3-0 (new 'stack-no-clear 'vector))
|
|
(f30-0 0.2)
|
|
(s2-0 (-> obj chain-offset))
|
|
(f28-0 0.1)
|
|
(s1-0 (new 'stack-no-clear 'vector))
|
|
)
|
|
(vector-! (-> s5-0 vector 2) (the-as vector (-> obj chain-joints)) (-> obj root trans))
|
|
(vector-normalize! (-> s5-0 vector 2) 1.0)
|
|
(vector-cross! (the-as vector (-> s5-0 vector)) (-> obj digger-vertical) (-> s5-0 vector 2))
|
|
(vector-normalize! (the-as vector (-> s5-0 vector)) 1.0)
|
|
(vector-cross! (-> s5-0 vector 1) (-> s5-0 vector 2) (the-as vector (-> s5-0 vector)))
|
|
(matrix->quaternion (-> obj root quat) s5-0)
|
|
(set! (-> obj joint-one trans quad) (-> obj root trans quad))
|
|
(quaternion-copy! (-> obj joint-one quat) (-> obj root quat))
|
|
(set! (-> s3-0 quad) (-> s5-0 vector 1 quad))
|
|
(dotimes (s0-0 8)
|
|
(set! sv-144 (-> obj chain-joints s0-0))
|
|
(set! sv-160 (new 'stack-no-clear 'vector))
|
|
(let ((v1-23 (-> sv-144 position quad)))
|
|
(set! (-> sv-160 quad) v1-23)
|
|
)
|
|
(+! (-> sv-160 y) -2048.0)
|
|
(vector+float*! sv-160 sv-160 (the-as vector s2-0) f28-0)
|
|
(set! f28-0 (fmin 1.0 (+ 0.2 f28-0)))
|
|
(when (< s0-0 7)
|
|
(vector+float*!
|
|
sv-160
|
|
sv-160
|
|
(the-as vector (+ (the-as uint (-> obj chain-joints 0 velocity)) (* 48 (+ s0-0 1))))
|
|
f30-0
|
|
)
|
|
(set! f30-0 (fmin 0.9 (+ 0.2 f30-0)))
|
|
)
|
|
(vector-! s1-0 sv-160 s4-0)
|
|
(vector-normalize! s1-0 12288.0)
|
|
(vector+! sv-160 s1-0 s4-0)
|
|
(vector-! s1-0 sv-160 (-> obj digger-pos))
|
|
(vector-flatten! s1-0 s1-0 (-> obj digger-vertical))
|
|
(let ((f0-6 (vector-normalize-ret-len! s1-0 1.0)))
|
|
(if (< f0-6 73728.0)
|
|
(vector+float*! sv-160 sv-160 s1-0 (- 73728.0 f0-6))
|
|
)
|
|
)
|
|
(vector-! (-> sv-144 velocity) sv-160 (-> sv-144 position))
|
|
(vector-float*! (-> sv-144 velocity) (-> sv-144 velocity) 0.75)
|
|
(let ((f0-9 (vector-length (-> sv-144 velocity))))
|
|
(if (< 6144.0 f0-9)
|
|
(vector-float*! (-> sv-144 velocity) (-> sv-144 velocity) (/ 2048.0 f0-9))
|
|
)
|
|
)
|
|
(vector+! sv-160 (-> sv-144 position) (-> sv-144 velocity))
|
|
(set! (-> sv-144 position quad) (-> sv-160 quad))
|
|
(if (-> sv-144 joint-mod)
|
|
(set! (-> sv-144 joint-mod trans quad) (-> sv-160 quad))
|
|
)
|
|
(when (< s0-0 7)
|
|
(vector-! (-> s5-0 vector 2) (the-as vector (-> obj chain-joints (+ s0-0 1))) sv-160)
|
|
(vector-normalize! (-> s5-0 vector 2) 1.0)
|
|
(vector-cross! (the-as vector (-> s5-0 vector)) s3-0 (-> s5-0 vector 2))
|
|
(vector-normalize! (the-as vector (-> s5-0 vector)) 1.0)
|
|
(vector-cross! (-> s5-0 vector 1) (-> s5-0 vector 2) (the-as vector (-> s5-0 vector)))
|
|
(matrix->quaternion (-> sv-144 joint-mod quat) s5-0)
|
|
(set! (-> s3-0 quad) (-> s5-0 vector 1 quad))
|
|
)
|
|
(set! (-> s4-0 quad) (-> sv-160 quad))
|
|
)
|
|
)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
;; WARN: Return type mismatch vector vs object.
|
|
(defbehavior dig-tether-handler dig-tether ((arg0 process) (arg1 int) (arg2 symbol) (arg3 event-message-block))
|
|
(the-as object (case arg2
|
|
(('set-pos)
|
|
(set! (-> self root trans quad) (-> (the-as vector (-> arg3 param 0)) quad))
|
|
(set! (-> self digger-pos quad) (-> (the-as vector (-> arg3 param 1)) quad))
|
|
(let ((v0-0 (-> self digger-vertical)))
|
|
(set! (-> v0-0 quad) (-> (the-as vector (-> arg3 param 2)) quad))
|
|
v0-0
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
|
|
(defstate broken (dig-tether)
|
|
:virtual #t
|
|
:event (behavior ((proc process) (arg1 int) (event-type symbol) (event event-message-block))
|
|
(case event-type
|
|
(('broken?)
|
|
#t
|
|
)
|
|
(else
|
|
(dig-tether-handler proc arg1 event-type event)
|
|
)
|
|
)
|
|
)
|
|
:enter (behavior ()
|
|
(dig-tether-method-23 self)
|
|
(none)
|
|
)
|
|
:trans (behavior ()
|
|
(dig-tether-method-24 self)
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-tether) sleep-code)
|
|
:post (the-as (function none :behavior dig-tether) ja-post)
|
|
)
|
|
|
|
(defstate idle (dig-tether)
|
|
:virtual #t
|
|
:event dig-tether-handler
|
|
:enter (behavior ()
|
|
(set! (-> self clasp-info-ok) #f)
|
|
(set-params! (-> self frame) 0.5 0.01 0.02 0.97)
|
|
(set-params! (-> self frame-kicker) 9 30 0.4)
|
|
(set! (-> self old-dist) 0.0)
|
|
(none)
|
|
)
|
|
:trans (behavior ()
|
|
(dig-tether-method-22 self)
|
|
(when (-> self clasp-info-ok)
|
|
(let* ((v1-4 (vector-! (new 'stack-no-clear 'vector) (-> self clasp-pos) (-> self root trans)))
|
|
(f30-0 (vector-length v1-4))
|
|
)
|
|
(let ((gp-0 (new 'stack-no-clear 'matrix)))
|
|
(vector-float*! (-> gp-0 vector 2) v1-4 (/ 1.0 f30-0))
|
|
(set-vector! (-> gp-0 vector 0) (-> gp-0 vector 2 z) 0.0 (- (-> gp-0 vector 2 x)) 1.0)
|
|
(vector-normalize! (the-as vector (-> gp-0 vector)) 1.0)
|
|
(vector-cross! (-> gp-0 vector 1) (-> gp-0 vector 2) (the-as vector (-> gp-0 vector)))
|
|
(vector-reset! (-> gp-0 trans))
|
|
(set! (-> gp-0 vector 0 w) 0.0)
|
|
(set! (-> gp-0 vector 1 w) 0.0)
|
|
(set! (-> gp-0 vector 2 w) 0.0)
|
|
(matrix->quaternion (-> self root quat) gp-0)
|
|
)
|
|
(set! (-> self root scale z) (* 0.000003937752 f30-0))
|
|
(when (!= (-> self old-dist) 0.0)
|
|
(let ((f2-0 (fabs (- f30-0 (-> self old-dist)))))
|
|
(set! (-> self frame target) (fmin 1.0 (fmax 0.0 (* 0.0008719308 (- 573.44 f2-0)))))
|
|
)
|
|
)
|
|
(set! (-> self old-dist) f30-0)
|
|
)
|
|
(update! (-> self frame-kicker))
|
|
(update! (-> self frame) (-> self frame-kicker value))
|
|
(ja :num-func num-func-identity :frame-num (* 10.0 (-> self frame value)))
|
|
)
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-tether) sleep-code)
|
|
:post (the-as (function none :behavior dig-tether) ja-post)
|
|
)
|
|
|
|
;; WARN: Return type mismatch process-drawable vs dig-tether.
|
|
(defmethod relocate dig-tether ((obj dig-tether) (arg0 int))
|
|
(if (nonzero? (-> obj joint-one))
|
|
(&+! (-> obj joint-one) arg0)
|
|
)
|
|
(dotimes (v1-4 7)
|
|
(if (nonzero? (-> obj chain-joints v1-4 joint-mod))
|
|
(&+! (-> obj chain-joints v1-4 joint-mod) arg0)
|
|
)
|
|
)
|
|
(the-as dig-tether ((method-of-type process-drawable relocate) obj arg0))
|
|
)
|
|
|
|
;; WARN: Return type mismatch object vs none.
|
|
(defbehavior dig-tether-init-by-other dig-tether ((arg0 vector) (arg1 entity))
|
|
(set! (-> self root) (new 'process 'trsqv))
|
|
(set! (-> self root trans quad) (-> arg0 quad))
|
|
(initialize-skeleton
|
|
self
|
|
(the-as skeleton-group (art-group-get-by-name *level* "skel-dig-tether-snapped" (the-as (pointer uint32) #f)))
|
|
(the-as pair 0)
|
|
)
|
|
(set! (-> self draw light-index) (the-as uint 1))
|
|
(set! (-> self clasp) (the-as entity-actor arg1))
|
|
(set! (-> self root pause-adjust-distance) 819200.0)
|
|
(set! (-> self joint-one) (new 'process 'joint-mod (joint-mod-mode flex-blend) self 3))
|
|
(set! (-> self joint-one track-mode) (track-mode no-scale))
|
|
(dotimes (gp-1 7)
|
|
(set! (-> self chain-joints gp-1 joint-mod)
|
|
(new 'process 'joint-mod (joint-mod-mode flex-blend) self (+ gp-1 4))
|
|
)
|
|
(set! (-> self chain-joints gp-1 joint-mod track-mode) (track-mode no-scale))
|
|
)
|
|
(set! (-> self chain-joints 7 joint-mod) #f)
|
|
(setup-lods!
|
|
(-> self snapped-look)
|
|
(the-as skeleton-group (art-group-get-by-name *level* "skel-dig-tether-snapped" (the-as (pointer uint32) #f)))
|
|
(-> self draw art-group)
|
|
(-> self entity)
|
|
)
|
|
(go-virtual idle)
|
|
(none)
|
|
)
|
|
|
|
(deftype dig-digger-tether-info (structure)
|
|
((rp int32 :offset-assert 0)
|
|
(handle handle :offset-assert 8)
|
|
(broken-x float :offset-assert 16)
|
|
(broken-z float :offset-assert 20)
|
|
)
|
|
:method-count-assert 9
|
|
:size-assert #x18
|
|
:flag-assert #x900000018
|
|
)
|
|
|
|
|
|
(deftype dig-digger (process-drawable)
|
|
((actor-group (pointer actor-group) :offset-assert 200)
|
|
(actor-group-count int32 :offset-assert 204)
|
|
(tethers dig-digger-tether-info 24 :inline :offset-assert 208)
|
|
(vertical oscillating-vector :inline :offset-assert 976)
|
|
(vertical-rand delayed-rand-vector :inline :offset-assert 1040)
|
|
(start-y float :offset-assert 1088)
|
|
(y-offset bouncing-float :inline :offset-assert 1092)
|
|
(y-offset-kicker delayed-rand-float :inline :offset-assert 1136)
|
|
(twist oscillating-float :inline :offset-assert 1164)
|
|
(twist-kicker delayed-rand-float :inline :offset-assert 1192)
|
|
(smoke-part sparticle-launch-control :offset-assert 1220)
|
|
(motor-sound sound-id :offset-assert 1224)
|
|
(bit-sound sound-id :offset-assert 1228)
|
|
(movie-handle handle :offset-assert 1232)
|
|
(hud-counter handle :offset-assert 1240)
|
|
(speech-time time-frame :offset-assert 1248)
|
|
(speech-count int32 :offset-assert 1256)
|
|
)
|
|
:heap-base #x470
|
|
:method-count-assert 25
|
|
:size-assert #x4ec
|
|
:flag-assert #x19047004ec
|
|
(:methods
|
|
(idle () _type_ :state 20)
|
|
(hidden () _type_ :state 21)
|
|
(dig-digger-method-22 (_type_ int) entity 22)
|
|
(dig-digger-method-23 (_type_) none 23)
|
|
(dig-digger-method-24 (_type_) none 24)
|
|
)
|
|
)
|
|
|
|
|
|
(defskelgroup skel-dig-digger dig-digger dig-digger-lod0-jg dig-digger-idle-ja
|
|
((dig-digger-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 36 0 40)
|
|
:origin-joint-index 3
|
|
)
|
|
|
|
(defmethod dig-digger-method-22 dig-digger ((obj dig-digger) (arg0 int))
|
|
(if (and (> (-> obj actor-group-count) 0) (< arg0 (-> obj actor-group 0 length)))
|
|
(-> obj actor-group 0 data arg0 actor)
|
|
(the-as entity #f)
|
|
)
|
|
)
|
|
|
|
(defmethod dig-digger-method-23 dig-digger ((obj dig-digger))
|
|
(dotimes (s5-0 24)
|
|
(let ((s4-0 (vector<-cspace! (new 'stack-no-clear 'vector) (-> obj node-list data (-> obj tethers s5-0 rp))))
|
|
(s3-0 (dig-digger-method-22 obj s5-0))
|
|
)
|
|
(if (and s3-0 (not (handle->process (-> obj tethers s5-0 handle))))
|
|
(set! (-> obj tethers s5-0 handle) (ppointer->handle (process-spawn dig-tether s4-0 s3-0 :to obj)))
|
|
)
|
|
)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
(defmethod dig-digger-method-24 dig-digger ((obj dig-digger))
|
|
(set! (-> obj vertical target x) 0.0)
|
|
(set! (-> obj vertical target z) 0.0)
|
|
(let ((s4-0 (vector-normalize-copy! (new 'stack-no-clear 'vector) (the-as vector (-> obj vertical)) 1.0))
|
|
(s5-0 0)
|
|
)
|
|
(dotimes (s3-0 24)
|
|
(let* ((s2-0 (-> obj tethers s3-0))
|
|
(s1-0 (handle->process (-> s2-0 handle)))
|
|
)
|
|
(cond
|
|
(s1-0
|
|
(let ((v1-10 (vector<-cspace! (new 'stack-no-clear 'vector) (-> obj node-list data (-> obj tethers s3-0 rp)))))
|
|
(send-event s1-0 'set-pos v1-10 (-> obj root trans) s4-0)
|
|
)
|
|
(cond
|
|
((send-event s1-0 'broken?)
|
|
(+! (-> obj vertical target x) (-> s2-0 broken-x))
|
|
(+! (-> obj vertical target z) (-> s2-0 broken-z))
|
|
)
|
|
(else
|
|
(+! s5-0 1)
|
|
)
|
|
)
|
|
)
|
|
(else
|
|
(+! (-> obj vertical target x) (-> s2-0 broken-x))
|
|
(+! (-> obj vertical target z) (-> s2-0 broken-z))
|
|
)
|
|
)
|
|
)
|
|
)
|
|
(set! (-> *game-info* counter) (the float s5-0))
|
|
(when (and (= s5-0 24)
|
|
(>= (- (current-time) (-> obj speech-time)) (seconds 20))
|
|
*target*
|
|
(and (>= 409600.0 (vector-vector-distance (-> obj root trans) (-> *target* control trans)))
|
|
(not (logtest? (focus-status teleporting) (-> *target* focus-status)))
|
|
)
|
|
)
|
|
(let ((v1-37 (logand (-> obj speech-count) 1)))
|
|
(cond
|
|
((zero? v1-37)
|
|
(talker-spawn-func (-> *talker-speech* 191) *entity-pool* (target-pos 0) (the-as region #f))
|
|
(if (and *target* (not (logtest? (focus-status board) (-> *target* focus-status))))
|
|
(talker-spawn-func (-> *talker-speech* 115) *entity-pool* (target-pos 0) (the-as region #f))
|
|
)
|
|
)
|
|
((= v1-37 1)
|
|
(talker-spawn-func (-> *talker-speech* 192) *entity-pool* (target-pos 0) (the-as region #f))
|
|
)
|
|
)
|
|
)
|
|
(set! (-> obj speech-time) (current-time))
|
|
(+! (-> obj speech-count) 1)
|
|
)
|
|
(cond
|
|
((zero? s5-0)
|
|
(send-event (handle->process (-> obj hud-counter)) 'hide-and-die)
|
|
(set! (-> obj hud-counter) (the-as handle #f))
|
|
(when (= (-> obj movie-handle) #f)
|
|
(set! (-> obj movie-handle)
|
|
(ppointer->handle (process-spawn scene-player :init scene-player-init "dig-digger-explode" #t #f))
|
|
)
|
|
(if (handle->process (-> obj movie-handle))
|
|
(cleanup-for-death obj)
|
|
)
|
|
)
|
|
)
|
|
((>= 4 s5-0)
|
|
(script-eval '(want-anim "dig-digger-explode"))
|
|
)
|
|
)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
(defstate idle (dig-digger)
|
|
:virtual #t
|
|
:event (behavior ((proc process) (arg1 int) (event-type symbol) (event event-message-block))
|
|
(case event-type
|
|
(('touch 'attack)
|
|
(when ((method-of-type touching-shapes-entry prims-touching?)
|
|
(the-as touching-shapes-entry (-> event param 0))
|
|
(the-as collide-shape (-> self root))
|
|
(the-as uint 1)
|
|
)
|
|
(let ((a0-7 (if (type? proc process-focusable)
|
|
proc
|
|
)
|
|
)
|
|
)
|
|
(when a0-7
|
|
(let ((a1-4 (new 'stack-no-clear 'event-message-block)))
|
|
(set! (-> a1-4 from) (process->ppointer self))
|
|
(set! (-> a1-4 num-params) 2)
|
|
(set! (-> a1-4 message) 'attack)
|
|
(set! (-> a1-4 param 0) (-> event param 0))
|
|
(let ((a2-3 (new 'static 'attack-info :mask (attack-info-mask id))))
|
|
(let* ((v1-7 *game-info*)
|
|
(a3-2 (+ (-> v1-7 attack-id) 1))
|
|
)
|
|
(set! (-> v1-7 attack-id) a3-2)
|
|
(set! (-> a2-3 id) a3-2)
|
|
)
|
|
(set! (-> a1-4 param 1) (the-as uint a2-3))
|
|
)
|
|
(if (send-event-function a0-7 a1-4)
|
|
#f
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
(('hide)
|
|
(go-virtual hidden)
|
|
)
|
|
)
|
|
)
|
|
:enter (behavior ()
|
|
(set-params! (-> self vertical) (new 'static 'vector :y 16.0) 0.01 0.1 0.9)
|
|
(set-params! (-> self vertical-rand) 15 75 1.0 0.0)
|
|
(set-params! (-> self y-offset) 0.0 1.0 0.0 0.7 0.08 0.3 0.97)
|
|
(set-params! (-> self y-offset-kicker) 18 30 1.0)
|
|
(set-params! (-> self twist) 0.0 0.01 0.1 0.9)
|
|
(set-params! (-> self twist-kicker) 24 75 1.0)
|
|
(ja-post)
|
|
(dig-digger-method-23 self)
|
|
(set! (-> self motor-sound) (new-sound-id))
|
|
(set! (-> self bit-sound) (new-sound-id))
|
|
(none)
|
|
)
|
|
:exit (behavior ()
|
|
(sound-stop (-> self motor-sound))
|
|
(sound-stop (-> self bit-sound))
|
|
(send-event (handle->process (-> self hud-counter)) 'hide-and-die)
|
|
(set! (-> self hud-counter) (the-as handle #f))
|
|
(none)
|
|
)
|
|
:trans (behavior ()
|
|
(let ((f0-0 (vector-vector-distance-squared (ear-trans 0) (-> self root trans)))
|
|
(f1-0 1228800.0)
|
|
)
|
|
(when (< f0-0 (* f1-0 f1-0))
|
|
(let ((gp-1 (new 'stack-no-clear 'vector)))
|
|
(vector<-cspace! gp-1 (-> self node-list data 29))
|
|
(sound-play "digger-motor" :id (-> self motor-sound) :position gp-1)
|
|
)
|
|
(sound-play "digger-bit" :id (-> self bit-sound) :position (-> self root trans))
|
|
)
|
|
)
|
|
(ja :num! (loop!))
|
|
(update-with-delay! (-> self vertical-rand))
|
|
(update! (-> self vertical) (-> self vertical-rand value))
|
|
(update-and-clear! (-> self twist-kicker))
|
|
(if (!= (-> self twist-kicker value) 0.0)
|
|
(set! (-> self twist-kicker value) 1.0)
|
|
)
|
|
(update! (-> self twist) (fabs (-> self twist-kicker value)))
|
|
(let ((gp-2 (new 'stack-no-clear 'matrix)))
|
|
(vector-normalize-copy! (-> gp-2 vector 1) (the-as vector (-> self vertical)) 1.0)
|
|
(set-vector!
|
|
(-> gp-2 vector 0)
|
|
(cos (* 32768.0 (-> self twist value)))
|
|
0.0
|
|
(sin (* 32768.0 (-> self twist value)))
|
|
1.0
|
|
)
|
|
(vector-cross! (-> gp-2 vector 2) (the-as vector (-> gp-2 vector)) (-> gp-2 vector 1))
|
|
(vector-normalize! (-> gp-2 vector 2) 1.0)
|
|
(vector-cross! (the-as vector (-> gp-2 vector)) (-> gp-2 vector 1) (-> gp-2 vector 2))
|
|
(vector-reset! (-> gp-2 trans))
|
|
(set! (-> gp-2 vector 0 w) 0.0)
|
|
(set! (-> gp-2 vector 1 w) 0.0)
|
|
(set! (-> gp-2 vector 2 w) 0.0)
|
|
(matrix->quaternion (-> self root quat) gp-2)
|
|
)
|
|
(update! (-> self y-offset-kicker))
|
|
(update! (-> self y-offset) (-> self y-offset-kicker value))
|
|
(set! (-> self root trans y) (+ (-> self start-y) (* 4096.0 (-> self y-offset osc value))))
|
|
(when (nonzero? (-> self smoke-part))
|
|
(spawn-with-cspace (-> self smoke-part) (-> self node-list data 28))
|
|
(spawn-with-cspace (-> self smoke-part) (-> self node-list data 29))
|
|
(spawn-with-cspace (-> self smoke-part) (-> self node-list data 30))
|
|
(spawn-with-cspace (-> self smoke-part) (-> self node-list data 31))
|
|
)
|
|
(if (nonzero? (-> self part))
|
|
(spawn (-> self part) (-> self root trans))
|
|
)
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-digger) sleep-code)
|
|
:post (behavior ()
|
|
(transform-post)
|
|
(dig-digger-method-24 self)
|
|
(none)
|
|
)
|
|
)
|
|
|
|
(defstate hidden (dig-digger)
|
|
:virtual #t
|
|
:event (behavior ((proc process) (arg1 int) (event-type symbol) (event event-message-block))
|
|
(let ((v1-0 event-type)
|
|
(a0-1 'explode)
|
|
)
|
|
(the-as object (if (= v1-0 a0-1)
|
|
(set-dig1-explosion! (the-as float a0-1))
|
|
)
|
|
)
|
|
)
|
|
)
|
|
:enter (behavior ()
|
|
(while (-> self child)
|
|
(deactivate (-> self child 0))
|
|
)
|
|
(logior! (-> self draw status) (draw-control-status no-draw))
|
|
(none)
|
|
)
|
|
:code (the-as (function none :behavior dig-digger) sleep-code)
|
|
)
|
|
|
|
(defmethod deactivate dig-digger ((obj dig-digger))
|
|
(if (nonzero? (-> obj smoke-part))
|
|
(kill-and-free-particles (-> obj smoke-part))
|
|
)
|
|
((method-of-type process-drawable deactivate) obj)
|
|
(none)
|
|
)
|
|
|
|
;; WARN: Return type mismatch process-drawable vs dig-digger.
|
|
(defmethod relocate dig-digger ((obj dig-digger) (arg0 int))
|
|
(when (nonzero? (-> obj smoke-part))
|
|
(if (nonzero? (-> obj smoke-part))
|
|
(&+! (-> obj smoke-part) arg0)
|
|
)
|
|
)
|
|
(the-as dig-digger ((method-of-type process-drawable relocate) obj arg0))
|
|
)
|
|
|
|
;; WARN: Return type mismatch object vs none.
|
|
(defmethod init-from-entity! dig-digger ((obj dig-digger) (arg0 entity-actor))
|
|
"Typically the method that does the initial setup on the process, potentially using the [[entity-actor]] provided as part of that.
|
|
This commonly includes things such as:
|
|
- stack size
|
|
- collision information
|
|
- loading the skeleton group / bones
|
|
- sounds"
|
|
(local-vars (sv-16 res-tag))
|
|
(let ((s4-0 (new 'process 'collide-shape-moving obj (collide-list-enum usually-hit-by-player))))
|
|
(set! (-> s4-0 dynam) (copy *standard-dynamics* 'process))
|
|
(set! (-> s4-0 reaction) cshape-reaction-default)
|
|
(set! (-> s4-0 no-reaction)
|
|
(the-as (function collide-shape-moving collide-query vector vector object) nothing)
|
|
)
|
|
(set! (-> s4-0 penetrated-by) (penetrate))
|
|
(let ((s3-0 (new 'process 'collide-shape-prim-group s4-0 (the-as uint 10) 0)))
|
|
(set! (-> s4-0 total-prims) (the-as uint 11))
|
|
(set! (-> s3-0 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> s3-0 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> s3-0 prim-core action) (collide-action solid deadly))
|
|
(set! (-> s3-0 transform-index) 3)
|
|
(set-vector! (-> s3-0 local-sphere) 0.0 143360.0 0.0 159744.0)
|
|
(set! (-> s4-0 root-prim) s3-0)
|
|
)
|
|
(let ((v1-13 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 9) (the-as uint 1))))
|
|
(set! (-> v1-13 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-13 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-13 prim-core action) (collide-action solid deadly))
|
|
(set! (-> v1-13 transform-index) 3)
|
|
(set-vector! (-> v1-13 local-sphere) 0.0 36864.0 0.0 65536.0)
|
|
)
|
|
(let ((v1-15 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 0) (the-as uint 0))))
|
|
(set! (-> v1-15 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-15 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-15 prim-core action) (collide-action solid))
|
|
(set! (-> v1-15 transform-index) 3)
|
|
(set-vector! (-> v1-15 local-sphere) 0.0 172032.0 0.0 86016.0)
|
|
)
|
|
(let ((v1-17 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 1) (the-as uint 0))))
|
|
(set! (-> v1-17 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-17 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-17 prim-core action) (collide-action solid))
|
|
(set! (-> v1-17 transform-index) 3)
|
|
(set-vector! (-> v1-17 local-sphere) 0.0 151552.0 0.0 86016.0)
|
|
)
|
|
(let ((v1-19 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 2) (the-as uint 0))))
|
|
(set! (-> v1-19 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-19 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-19 prim-core action) (collide-action solid))
|
|
(set! (-> v1-19 transform-index) 3)
|
|
(set-vector! (-> v1-19 local-sphere) 0.0 110592.0 0.0 69632.0)
|
|
)
|
|
(let ((v1-21 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 3) (the-as uint 0))))
|
|
(set! (-> v1-21 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-21 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-21 prim-core action) (collide-action solid))
|
|
(set! (-> v1-21 transform-index) 3)
|
|
(set-vector! (-> v1-21 local-sphere) 0.0 73728.0 0.0 65536.0)
|
|
)
|
|
(let ((v1-23 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 4) (the-as uint 0))))
|
|
(set! (-> v1-23 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-23 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-23 prim-core action) (collide-action solid))
|
|
(set! (-> v1-23 transform-index) 3)
|
|
(set-vector! (-> v1-23 local-sphere) 0.0 266240.0 0.0 40960.0)
|
|
)
|
|
(let ((v1-25 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 5) (the-as uint 0))))
|
|
(set! (-> v1-25 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-25 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-25 prim-core action) (collide-action solid))
|
|
(set! (-> v1-25 transform-index) 3)
|
|
(set-vector! (-> v1-25 local-sphere) 16384.0 249856.0 -16384.0 20480.0)
|
|
)
|
|
(let ((v1-27 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 6) (the-as uint 0))))
|
|
(set! (-> v1-27 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-27 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-27 prim-core action) (collide-action solid))
|
|
(set! (-> v1-27 transform-index) 3)
|
|
(set-vector! (-> v1-27 local-sphere) 8192.0 245760.0 24576.0 16384.0)
|
|
)
|
|
(let ((v1-29 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 7) (the-as uint 0))))
|
|
(set! (-> v1-29 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-29 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-29 prim-core action) (collide-action solid))
|
|
(set! (-> v1-29 transform-index) 3)
|
|
(set-vector! (-> v1-29 local-sphere) -61440.0 102400.0 0.0 20480.0)
|
|
)
|
|
(let ((v1-31 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 8) (the-as uint 0))))
|
|
(set! (-> v1-31 prim-core collide-as) (collide-spec obstacle))
|
|
(set! (-> v1-31 prim-core collide-with) (collide-spec jak bot hit-by-others-list player-list))
|
|
(set! (-> v1-31 prim-core action) (collide-action solid))
|
|
(set! (-> v1-31 transform-index) 3)
|
|
(set-vector! (-> v1-31 local-sphere) -57344.0 81920.0 0.0 16384.0)
|
|
)
|
|
(set! (-> s4-0 nav-radius) (* 0.75 (-> s4-0 root-prim local-sphere w)))
|
|
(let ((v1-34 (-> s4-0 root-prim)))
|
|
(set! (-> s4-0 backup-collide-as) (-> v1-34 prim-core collide-as))
|
|
(set! (-> s4-0 backup-collide-with) (-> v1-34 prim-core collide-with))
|
|
)
|
|
(set! (-> obj root) s4-0)
|
|
)
|
|
(set! (-> obj root pause-adjust-distance) 819200.0)
|
|
(process-drawable-from-entity! obj arg0)
|
|
(initialize-skeleton
|
|
obj
|
|
(the-as skeleton-group (art-group-get-by-name *level* "skel-dig-digger" (the-as (pointer uint32) #f)))
|
|
(the-as pair 0)
|
|
)
|
|
(set! (-> obj draw light-index) (the-as uint 1))
|
|
(logior! (-> obj skel status) (joint-control-status sync-math))
|
|
(set! sv-16 (new 'static 'res-tag))
|
|
(let ((v1-46 (res-lump-data (-> obj entity) 'actor-groups pointer :tag-ptr (& sv-16))))
|
|
(cond
|
|
((and v1-46 (nonzero? (-> sv-16 elt-count)))
|
|
(set! (-> obj actor-group) (the-as (pointer actor-group) v1-46))
|
|
(set! (-> obj actor-group-count) (the-as int (-> sv-16 elt-count)))
|
|
)
|
|
(else
|
|
(set! (-> obj actor-group) (the-as (pointer actor-group) #f))
|
|
(set! (-> obj actor-group-count) 0)
|
|
0
|
|
)
|
|
)
|
|
)
|
|
(dotimes (v1-52 24)
|
|
(set! (-> obj tethers v1-52 handle) (the-as handle #f))
|
|
(let ((a0-77 v1-52))
|
|
(cond
|
|
((zero? a0-77)
|
|
(set! (-> obj tethers v1-52 rp) 18)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) -1.0)
|
|
)
|
|
((= a0-77 1)
|
|
(set! (-> obj tethers v1-52 rp) 16)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) -1.0)
|
|
)
|
|
((= a0-77 2)
|
|
(set! (-> obj tethers v1-52 rp) 17)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) -1.0)
|
|
)
|
|
((= a0-77 3)
|
|
(set! (-> obj tethers v1-52 rp) 24)
|
|
(set! (-> obj tethers v1-52 broken-x) -1.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
((= a0-77 4)
|
|
(set! (-> obj tethers v1-52 rp) 22)
|
|
(set! (-> obj tethers v1-52 broken-x) -1.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
((= a0-77 5)
|
|
(set! (-> obj tethers v1-52 rp) 23)
|
|
(set! (-> obj tethers v1-52 broken-x) -1.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
((= a0-77 6)
|
|
(set! (-> obj tethers v1-52 rp) 6)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 1.0)
|
|
)
|
|
((= a0-77 7)
|
|
(set! (-> obj tethers v1-52 rp) 4)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 1.0)
|
|
)
|
|
((= a0-77 8)
|
|
(set! (-> obj tethers v1-52 rp) 5)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 1.0)
|
|
)
|
|
((= a0-77 9)
|
|
(set! (-> obj tethers v1-52 rp) 12)
|
|
(set! (-> obj tethers v1-52 broken-x) 1.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
((= a0-77 10)
|
|
(set! (-> obj tethers v1-52 rp) 10)
|
|
(set! (-> obj tethers v1-52 broken-x) 1.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
((= a0-77 11)
|
|
(set! (-> obj tethers v1-52 rp) 11)
|
|
(set! (-> obj tethers v1-52 broken-x) 1.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
((= a0-77 12)
|
|
(set! (-> obj tethers v1-52 rp) 25)
|
|
(set! (-> obj tethers v1-52 broken-x) -0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.707)
|
|
)
|
|
((= a0-77 13)
|
|
(set! (-> obj tethers v1-52 rp) 26)
|
|
(set! (-> obj tethers v1-52 broken-x) -0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.707)
|
|
)
|
|
((= a0-77 14)
|
|
(set! (-> obj tethers v1-52 rp) 27)
|
|
(set! (-> obj tethers v1-52 broken-x) -0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.707)
|
|
)
|
|
((= a0-77 15)
|
|
(set! (-> obj tethers v1-52 rp) 19)
|
|
(set! (-> obj tethers v1-52 broken-x) -0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) -0.707)
|
|
)
|
|
((= a0-77 16)
|
|
(set! (-> obj tethers v1-52 rp) 21)
|
|
(set! (-> obj tethers v1-52 broken-x) -0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) -0.707)
|
|
)
|
|
((= a0-77 17)
|
|
(set! (-> obj tethers v1-52 rp) 20)
|
|
(set! (-> obj tethers v1-52 broken-x) -0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) -0.707)
|
|
)
|
|
((= a0-77 18)
|
|
(set! (-> obj tethers v1-52 rp) 14)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) -0.707)
|
|
)
|
|
((= a0-77 19)
|
|
(set! (-> obj tethers v1-52 rp) 13)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) -0.707)
|
|
)
|
|
((= a0-77 20)
|
|
(set! (-> obj tethers v1-52 rp) 15)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) -0.707)
|
|
)
|
|
((= a0-77 21)
|
|
(set! (-> obj tethers v1-52 rp) 8)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.707)
|
|
)
|
|
((= a0-77 22)
|
|
(set! (-> obj tethers v1-52 rp) 7)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.707)
|
|
)
|
|
((= a0-77 23)
|
|
(set! (-> obj tethers v1-52 rp) 9)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.707)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.707)
|
|
)
|
|
(else
|
|
(set! (-> obj tethers v1-52 rp) 3)
|
|
(set! (-> obj tethers v1-52 broken-x) 0.0)
|
|
(set! (-> obj tethers v1-52 broken-z) 0.0)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
(set! (-> obj start-y) (-> obj root trans y))
|
|
(set! (-> obj smoke-part) (create-launch-control (-> *part-group-id-table* 1143) obj))
|
|
(set! (-> obj part) (create-launch-control (-> *part-group-id-table* 1144) obj))
|
|
(set! (-> obj motor-sound) (new 'static 'sound-id))
|
|
(set! (-> obj bit-sound) (new 'static 'sound-id))
|
|
(set! (-> obj movie-handle) (the-as handle #f))
|
|
(set! (-> obj hud-counter) (ppointer->handle (process-spawn hud-dig-clasp :init hud-init-by-other :to obj)))
|
|
(go (method-of-object obj idle))
|
|
(none)
|
|
)
|
|
|
|
;; WARN: Return type mismatch object vs none.
|
|
(defun-debug bustclasp ((arg0 int))
|
|
(format (clear *temp-string*) "dig-clasp-~S" arg0)
|
|
(let ((v1-0 (entity-by-name *temp-string*)))
|
|
(when v1-0
|
|
(send-event
|
|
(if v1-0
|
|
(-> v1-0 extra process)
|
|
)
|
|
'break
|
|
)
|
|
(format #t "found clasp ~D~%" arg0)
|
|
)
|
|
)
|
|
(none)
|
|
)
|