mirror of
https://github.com/open-goal/jak-project.git
synced 2024-10-20 21:27:52 -04:00
7ce58f709f
* some jp support to fix some errors in the original game * music fade toggle * recognize `process-new` macros!! * strip casts in this macro * rename macro * fix cast typecheck * update source 1 * detect kernel stack case * less boilerplate * `manipy-spawn` special case * pretty printer improvements * revert dumb thing from earlier * use shell detection on `send-event` * fix some events * remove unused argument * detect `static-attack-info` and add `CondNoElse` to shell detect * better `attack-info` detect * support `process-spawn` in multi-lets * detect `rand-float-gen` pt 1 * detect as return value * detect in `countdown` and `dotimes` * oops this wasnt working * fancier `send-event`s * clang * update source!! * fix tests * fine jeez * uh okay * fix some accidental regressions * fix more regressions * regression fixes * fix big bug... * extra safety!
402 lines
13 KiB
Common Lisp
402 lines
13 KiB
Common Lisp
;;-*-Lisp-*-
|
|
(in-package goal)
|
|
|
|
;; name: jungleb-obs.gc
|
|
;; name in dgo: jungleb-obs
|
|
;; dgos: JUB, L1
|
|
|
|
(define-extern *jng-iris-door-sg* skeleton-group)
|
|
(define-extern *eggtop-sg* skeleton-group)
|
|
|
|
(declare-type eggtop process-drawable)
|
|
|
|
|
|
;; DECOMP BEGINS
|
|
|
|
(import "goal_src/import/eggtop-ag.gc")
|
|
(import "goal_src/import/jng-iris-door-ag.gc")
|
|
|
|
(deftype eggtop (process-drawable)
|
|
((root-override collide-shape-moving :offset 112)
|
|
(cam-tracker handle :offset-assert 176)
|
|
(sound-id sound-id :offset-assert 184)
|
|
)
|
|
:heap-base #x50
|
|
:method-count-assert 20
|
|
:size-assert #xbc
|
|
:flag-assert #x14005000bc
|
|
(:states
|
|
(eggtop-close symbol)
|
|
eggtop-idle
|
|
)
|
|
)
|
|
|
|
|
|
(defskelgroup *eggtop-sg* eggtop eggtop-lod0-jg eggtop-idle-ja
|
|
((eggtop-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 -4.5 0 4.5)
|
|
)
|
|
|
|
(defpartgroup group-jungle-blue-eco-room-open
|
|
:id 189
|
|
:bounds (static-bspherem 0 -6 0 8)
|
|
:parts ((sp-item 899 :fade-after (meters 110))
|
|
(sp-item 900 :fade-after (meters 110))
|
|
(sp-item 901 :fade-after (meters 110))
|
|
(sp-item 902 :fade-after (meters 110))
|
|
(sp-item 903 :fade-after (meters 110))
|
|
)
|
|
)
|
|
|
|
(defpartgroup group-jungle-blue-eco-room-activate
|
|
:id 190
|
|
:duration 900
|
|
:bounds (static-bspherem 0 -6 0 8)
|
|
:parts ((sp-item 903) (sp-item 903) (sp-item 904 :flags (bit1) :period 1200 :length 15))
|
|
)
|
|
|
|
(defpart 904
|
|
:init-specs ((sp-tex spt-texture (new 'static 'texture-id :index #x2 :page #x2))
|
|
(sp-flt spt-num 30.0)
|
|
(sp-flt spt-y (meters -4))
|
|
(sp-rnd-flt spt-scale-x (meters 20) (meters 10) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 0.0) (degrees 360.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 5) (meters 2) 1.0)
|
|
(sp-rnd-flt spt-r 0.0 16.0 1.0)
|
|
(sp-rnd-flt spt-g 16.0 32.0 1.0)
|
|
(sp-flt spt-b 127.0)
|
|
(sp-flt spt-a 0.0)
|
|
(sp-rnd-flt spt-rotvel-z (degrees -0.05) (degrees 0.1) 1.0)
|
|
(sp-flt spt-fade-a 0.85333335)
|
|
(sp-int spt-timer 600)
|
|
(sp-cpuinfo-flags bit2 bit3 left-multiply-quat)
|
|
(sp-int spt-next-time 75)
|
|
(sp-launcher-by-id spt-next-launcher 905)
|
|
)
|
|
)
|
|
|
|
(defpart 905
|
|
:init-specs ((sp-flt spt-fade-a 0.0) (sp-int spt-next-time 225) (sp-launcher-by-id spt-next-launcher 906))
|
|
)
|
|
|
|
(defpart 906
|
|
:init-specs ((sp-flt spt-fade-a -0.14222223))
|
|
)
|
|
|
|
(defpart 899
|
|
:init-specs ((sp-tex spt-texture (new 'static 'texture-id :index #xf :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-flt spt-y (meters -4))
|
|
(sp-rnd-flt spt-scale-x (meters 10) (meters 2) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 8) (meters 2) 1.0)
|
|
(sp-rnd-flt spt-r 0.0 64.0 1.0)
|
|
(sp-rnd-flt spt-g 0.0 64.0 1.0)
|
|
(sp-flt spt-b 255.0)
|
|
(sp-rnd-flt spt-a 128.0 128.0 1.0)
|
|
(sp-int spt-timer 5)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
)
|
|
)
|
|
|
|
(defpart 900
|
|
:init-specs ((sp-tex spt-texture (new 'static 'texture-id :index #xf :page #x2))
|
|
(sp-flt spt-num 1.0)
|
|
(sp-flt spt-y (meters -4))
|
|
(sp-rnd-flt spt-scale-x (meters 3) (meters 2) 1.0)
|
|
(sp-copy-from-other spt-scale-y -4)
|
|
(sp-flt spt-r 128.0)
|
|
(sp-flt spt-g 128.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-rnd-flt spt-a 128.0 128.0 1.0)
|
|
(sp-int spt-timer 5)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
)
|
|
)
|
|
|
|
(defpart 901
|
|
:init-specs ((sp-tex spt-texture (new 'static 'texture-id :index #x1f :page #x2))
|
|
(sp-rnd-flt spt-num 0.5 1.0 1.0)
|
|
(sp-flt spt-y (meters -4))
|
|
(sp-rnd-flt spt-scale-x (meters 3) (meters 3) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees -30.0) (degrees 60.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.7) (meters 0.4) 1.0)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 907)
|
|
)
|
|
)
|
|
|
|
(defpart 907
|
|
:init-specs ((sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-fade-r -1.0)
|
|
(sp-flt spt-fade-g -1.0)
|
|
(sp-flt spt-fade-a -2.0)
|
|
)
|
|
)
|
|
|
|
(defpart 902
|
|
:init-specs ((sp-tex spt-texture (new 'static 'texture-id :index #x1f :page #x2))
|
|
(sp-rnd-flt spt-num 0.5 1.0 1.0)
|
|
(sp-flt spt-y (meters -4))
|
|
(sp-rnd-flt spt-scale-x (meters 3) (meters 3) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees 150.0) (degrees 60.0) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.7) (meters 0.4) 1.0)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 907)
|
|
)
|
|
)
|
|
|
|
(defpart 903
|
|
:init-specs ((sp-tex spt-texture (new 'static 'texture-id :index #x1f :page #x2))
|
|
(sp-rnd-flt spt-num 1.0 1.0 1.0)
|
|
(sp-rnd-flt spt-y (meters -6.5) (meters 1) 1.0)
|
|
(sp-rnd-flt spt-scale-x (meters 6) (meters 2) 1.0)
|
|
(sp-int spt-rot-x 4)
|
|
(sp-rnd-flt spt-rot-z (degrees -140.0) (degrees 100.00001) 1.0)
|
|
(sp-rnd-flt spt-scale-y (meters 0.7) (meters 0.4) 1.0)
|
|
(sp-flt spt-r 64.0)
|
|
(sp-flt spt-g 64.0)
|
|
(sp-flt spt-b 128.0)
|
|
(sp-flt spt-a 128.0)
|
|
(sp-flt spt-fade-a -1.6)
|
|
(sp-int spt-timer 90)
|
|
(sp-cpuinfo-flags bit2 bit3)
|
|
(sp-int spt-next-time 10)
|
|
(sp-launcher-by-id spt-next-launcher 907)
|
|
(sp-flt spt-conerot-x (degrees 90.0))
|
|
(sp-rnd-flt spt-conerot-y (degrees 80.0) (degrees 200.00002) 1.0)
|
|
(sp-flt spt-conerot-radius (meters 4))
|
|
)
|
|
)
|
|
|
|
(defstate eggtop-idle (eggtop)
|
|
:event (behavior ((arg0 process) (arg1 int) (arg2 symbol) (arg3 event-message-block))
|
|
(let ((v1-0 arg2))
|
|
(the-as object (when (= v1-0 'notify)
|
|
(case (-> arg3 param 0)
|
|
(('pickup)
|
|
(if (type-type? (-> arg0 type) fuel-cell)
|
|
(save-reminder (get-task-control (-> self entity extra perm task)) 1 0)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
)
|
|
:exit (behavior ()
|
|
(sound-stop (-> self sound-id))
|
|
(none)
|
|
)
|
|
:trans (behavior ()
|
|
(if (and (not (-> self child)) (task-complete? *game-info* (-> self entity extra perm task)))
|
|
(go eggtop-close #f)
|
|
)
|
|
(spawn (-> self part) (-> self root-override trans))
|
|
(sound-play-by-name (static-sound-name "electric-loop") (-> self sound-id) 1024 0 0 1 #t)
|
|
(none)
|
|
)
|
|
:code (behavior ()
|
|
(suspend)
|
|
(update-transforms! (-> self root-override))
|
|
(anim-loop)
|
|
(none)
|
|
)
|
|
:post (the-as (function none :behavior eggtop) ja-post)
|
|
)
|
|
|
|
(defstate eggtop-close (eggtop)
|
|
:trans (behavior ()
|
|
(rider-trans)
|
|
(hide-hud-quick)
|
|
(none)
|
|
)
|
|
:code (behavior ((arg0 symbol))
|
|
(when (not arg0)
|
|
(sound-play-by-name (static-sound-name "vent-switch") (new-sound-id) 2048 0 0 1 #t)
|
|
(process-spawn
|
|
part-tracker
|
|
:init part-tracker-init
|
|
(-> *part-group-id-table* 190)
|
|
-1
|
|
#f
|
|
#f
|
|
#f
|
|
(-> self root-override trans)
|
|
:to *entity-pool*
|
|
)
|
|
(set! (-> self cam-tracker)
|
|
(ppointer->handle (process-spawn
|
|
camera-tracker
|
|
:init camera-tracker-init
|
|
(lambda :behavior camera-tracker
|
|
()
|
|
(while (not (process-grab? *target*))
|
|
(suspend)
|
|
)
|
|
(let ((gp-0 (-> *display* base-frame-counter)))
|
|
(until (>= (- (-> *display* base-frame-counter) gp-0) (seconds 1))
|
|
(suspend)
|
|
)
|
|
)
|
|
(send-event *camera* 'blend-from-as-fixed)
|
|
(camera-look-at (the-as pair "ecovent-171") (the-as uint 0))
|
|
(camera-change-to "camera-223" 0 #f)
|
|
(let ((gp-1 (-> *display* base-frame-counter)))
|
|
(until (>= (- (-> *display* base-frame-counter) gp-1) (seconds 3))
|
|
(suspend)
|
|
)
|
|
)
|
|
(while (not (process-release? (handle->process (-> self grab-target))))
|
|
(suspend)
|
|
)
|
|
(send-event *camera* 'blend-from-as-fixed)
|
|
(level-hint-spawn
|
|
(game-text-id jungleb-eco-vents-opened)
|
|
"asstvb02"
|
|
(the-as entity #f)
|
|
*entity-pool*
|
|
(game-task none)
|
|
)
|
|
(camera-look-at (the-as pair *target*) (the-as uint 0))
|
|
(camera-change-to (the-as string 'base) 150 #f)
|
|
(send-event (ppointer->process (-> *hud-parts* fuel-cell)) 'show)
|
|
(none)
|
|
)
|
|
:to self
|
|
)
|
|
)
|
|
)
|
|
(save-reminder (get-task-control (-> self entity extra perm task)) 2 0)
|
|
(sound-play-by-name (static-sound-name "jngb-eggtop-seq") (new-sound-id) 1024 0 0 1 #t)
|
|
(ja-no-eval :group! (-> self draw art-group data 2) :num! (seek!) :frame-num 0.0)
|
|
(until (ja-done? 0)
|
|
(suspend)
|
|
(ja :num! (seek!))
|
|
)
|
|
)
|
|
(process-entity-status! self (entity-perm-status complete) #t)
|
|
(let ((a0-20 (-> self entity)))
|
|
(if (and a0-20 (= self (-> a0-20 extra process)))
|
|
(entity-task-complete-on a0-20)
|
|
)
|
|
)
|
|
(ja :group! (-> self draw art-group data 2) :num! max)
|
|
(suspend)
|
|
(logior! (-> self mask) (process-mask sleep))
|
|
(suspend)
|
|
0
|
|
(none)
|
|
)
|
|
:post (the-as (function none :behavior eggtop) rider-post)
|
|
)
|
|
|
|
(defmethod init-from-entity! eggtop ((obj eggtop) (arg0 entity-actor))
|
|
(let ((s4-0 (new 'process 'collide-shape-moving obj (collide-list-enum hit-by-player))))
|
|
(set! (-> s4-0 dynam) (copy *standard-dynamics* 'process))
|
|
(set! (-> s4-0 reaction) default-collision-reaction)
|
|
(set! (-> s4-0 no-reaction)
|
|
(the-as (function collide-shape-moving collide-shape-intersect vector vector none) nothing)
|
|
)
|
|
(alloc-riders s4-0 1)
|
|
(let ((s3-0 (new 'process 'collide-shape-prim-mesh s4-0 (the-as uint 0) (the-as uint 0))))
|
|
(set! (-> s3-0 prim-core collide-as) (collide-kind ground-object))
|
|
(set! (-> s3-0 collide-with) (collide-kind target))
|
|
(set! (-> s3-0 prim-core action) (collide-action solid ca-1))
|
|
(set! (-> s3-0 prim-core offense) (collide-offense indestructible))
|
|
(set! (-> s3-0 transform-index) 4)
|
|
(set-vector! (-> s3-0 local-sphere) 0.0 0.0 -7372.8 16384.0)
|
|
(set-root-prim! s4-0 s3-0)
|
|
)
|
|
(set! (-> s4-0 nav-radius) (* 0.75 (-> s4-0 root-prim local-sphere w)))
|
|
(backup-collide-with-as s4-0)
|
|
(set! (-> obj root-override) s4-0)
|
|
)
|
|
(process-drawable-from-entity! obj arg0)
|
|
(initialize-skeleton obj *eggtop-sg* '())
|
|
(logior! (-> obj skel status) (janim-status inited))
|
|
(update-transforms! (-> obj root-override))
|
|
(set! (-> obj part) (create-launch-control (-> *part-group-id-table* 189) obj))
|
|
(set! (-> obj sound-id) (new-sound-id))
|
|
(cond
|
|
((task-complete? *game-info* (-> obj entity extra perm task))
|
|
(go eggtop-close #t)
|
|
)
|
|
(else
|
|
(birth-pickup-at-point
|
|
(vector+! (new 'stack-no-clear 'vector) (-> obj root-override trans) (new 'static 'vector :y 6144.0 :w 1.0))
|
|
(pickup-type fuel-cell)
|
|
(the float (-> obj entity extra perm task))
|
|
#f
|
|
obj
|
|
(the-as fact-info #f)
|
|
)
|
|
(go eggtop-idle)
|
|
)
|
|
)
|
|
(none)
|
|
)
|
|
|
|
(deftype jng-iris-door (eco-door)
|
|
()
|
|
:heap-base #xa0
|
|
:method-count-assert 27
|
|
:size-assert #x104
|
|
:flag-assert #x1b00a00104
|
|
)
|
|
|
|
|
|
(defskelgroup *jng-iris-door-sg* jng-iris-door jng-iris-door-lod0-jg jng-iris-door-idle-ja
|
|
((jng-iris-door-lod0-mg (meters 999999)))
|
|
:bounds (static-spherem 0 0 0 8)
|
|
)
|
|
|
|
(defmethod TODO-RENAME-24 jng-iris-door ((obj jng-iris-door))
|
|
(let ((s5-0 (new 'process 'collide-shape obj (collide-list-enum hit-by-others))))
|
|
(let ((s4-0 (new 'process 'collide-shape-prim-mesh s5-0 (the-as uint 0) (the-as uint 0))))
|
|
(set! (-> s4-0 prim-core collide-as) (collide-kind wall-object))
|
|
(set! (-> s4-0 collide-with) (collide-kind target))
|
|
(set! (-> s4-0 prim-core action) (collide-action solid))
|
|
(set! (-> s4-0 prim-core offense) (collide-offense indestructible))
|
|
(set! (-> s4-0 transform-index) 0)
|
|
(set-vector! (-> s4-0 local-sphere) 0.0 0.0 0.0 16384.0)
|
|
(set-root-prim! s5-0 s4-0)
|
|
)
|
|
(set! (-> s5-0 nav-radius) (* 0.75 (-> s5-0 root-prim local-sphere w)))
|
|
(backup-collide-with-as s5-0)
|
|
(set! (-> obj root-override) s5-0)
|
|
)
|
|
0
|
|
(none)
|
|
)
|
|
|
|
(defmethod TODO-RENAME-25 jng-iris-door ((obj jng-iris-door))
|
|
(initialize-skeleton obj *jng-iris-door-sg* '())
|
|
(set! (-> obj open-distance) 32768.0)
|
|
(set! (-> obj close-distance) 49152.0)
|
|
(update-transforms! (-> obj root-override))
|
|
0
|
|
(none)
|
|
)
|
|
|
|
|
|
|
|
|