- vg_info( "Alloc: %d\n", ch->sk.collider_count );
- ch->ragdoll = malloc(sizeof(struct ragdoll_part) * ch->sk.collider_count);
- ch->ragdoll_count = 0;
-
- for( u32 i=0; i<ch->sk.bone_count; i ++ )
- {
- struct skeleton_bone *bone = &ch->sk.bones[i];
-
- if( bone->collider )
- {
- struct ragdoll_part *rp = &ch->ragdoll[ ch->ragdoll_count ++ ];
- rp->bone_id = i;
-
- v3f delta;
- v3_sub( bone->hitbox[1], bone->hitbox[0], delta );
- v3_muls( delta, 0.5f, delta );
-
- v3_add( bone->hitbox[0], delta, rp->offset );
-
- v3_copy( delta, rp->rb.bbx[1] );
- v3_muls( delta, -1.0f, rp->rb.bbx[0] );
-
- q_identity( rp->rb.q );
- v3_add( bone->co, rp->offset, rp->rb.co );
- rp->rb.type = k_rb_shape_box;
- rp->rb.is_world = 0;
- rp->parent = 0xffffffff;
-
- if( bone->parent )
- {
- for( u32 j=0; j<ch->ragdoll_count; j++ )
- {
- if( ch->ragdoll[ j ].bone_id == bone->parent )
- {
- rp->parent = j;
- break;
- }
- }
- }
-
- /* TODO: refactor to use this style elswhere */
- struct mdl_node *pnode = mdl_node_from_id( src, bone->orig_node );
- struct classtype_bone *bone_inf = mdl_get_entdata( src, pnode );
-
- rp->use_limits = bone_inf->use_limits;
- v3_copy( bone_inf->angle_limits[0], rp->limits[0] );
- v3_copy( bone_inf->angle_limits[1], rp->limits[1] );
-
- rb_init( &rp->rb );
- }
- }
+ mdl_unpack_glmesh( &player.mdl.meta, &player.mdl.player_meshes[0] );
+ mdl_unpack_glmesh( &ctx_outlaw, &player.mdl.player_meshes[1] );
+ mdl_unpack_glmesh( &ctx_jordan, &player.mdl.player_meshes[2] );