X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=entity.h;h=1de6f7026b62379c7f80092ecc6550849e5723c7;hb=badfa88dd109bbae5628f58504402f4707569f73;hp=6e30ef219ec96a5b0080eec52fe2e9d7f18dec9f;hpb=9d0ff08fef8507613586856de7ce25d43704db92;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/entity.h b/entity.h index 6e30ef2..1de6f70 100644 --- a/entity.h +++ b/entity.h @@ -24,6 +24,7 @@ typedef struct ent_glyph ent_glyph; typedef struct ent_skateshop ent_skateshop; typedef struct ent_camera ent_camera; typedef struct ent_swspreview ent_swspreview; +typedef struct ent_worldinfo ent_worldinfo; enum entity_alias{ k_ent_none = 0, @@ -41,7 +42,8 @@ enum entity_alias{ k_ent_skateshop = 12, k_ent_camera = 13, k_ent_swspreview = 14, - k_ent_menuitem = 15 + k_ent_menuitem = 15, + k_ent_worldinfo = 16 }; static u32 mdl_entity_id_type( u32 entity_id ) @@ -96,7 +98,8 @@ enum gate_type{ struct ent_gate{ u32 type, - target; + target, + key; v3f dimensions, co[2]; @@ -215,12 +218,36 @@ struct ent_marker{ u32 pstr_alias; }; +enum skateshop_type{ + k_skateshop_type_boardshop, + k_skateshop_type_charshop, + k_skateshop_type_worldshop +}; + struct ent_skateshop{ mdl_transform transform; - u32 id_display, - id_info, - id_rack, - id_camera; + u32 type, id_camera; + + union{ + struct{ + u32 id_display, + id_info, + id_rack; + } + boards; + + struct{ + u32 id_display, + id_info; + } + character; + + struct{ + u32 id_display, + id_info; + } + worlds; + }; }; struct ent_swspreview{ @@ -256,10 +283,17 @@ typedef struct ent_menuitem ent_menuitem; struct ent_menuitem{ u32 type, groups, id_links[4]; /* ent_menuitem */ + f32 factive, fvisible; mdl_transform transform; u32 submesh_start, submesh_count; + union{ u64 _u64; /* force storage for 64bit pointers */ + i32 *pi32; + f32 *pf32; + void *pvoid; + }; + union{ struct{ u32 id_min, /* ent_marker */ @@ -277,6 +311,7 @@ struct ent_menuitem{ struct{ u32 id_check, /* ent_menuitem */ pstr_data; + v3f offset; /* relative to parent */ } checkmark; @@ -289,6 +324,11 @@ struct ent_menuitem{ }; }; +struct ent_worldinfo{ + u32 pstr_name, pstr_author, pstr_desc; + f32 timezone; +}; + VG_STATIC ent_marker *ent_find_marker( mdl_context *mdl, mdl_array_ptr *arr, const char *alias ) { @@ -343,5 +383,6 @@ struct ent_call{ }; #include "world.h" +VG_STATIC void entity_call( world_instance *world, ent_call *call ); #endif /* ENTITY_H */