X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=addon.h;h=59645daed4ef8ec603daf1e7c5654cbafaf3d2cd;hb=74b2136d5b41b18e2eec698f1fd11b503aa1100a;hp=691046da23299929ae749c1cd5123006f14f5cb9;hpb=844527ec68c063d78d4993bd8e4053f9ddc47b78;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/addon.h b/addon.h index 691046d..59645da 100644 --- a/addon.h +++ b/addon.h @@ -9,11 +9,6 @@ #include "world.h" #include "player.h" -#define ADDON_FOLDERNAME_MAX 64 - -/* total count that we have knowledge of */ -#define ADDON_MOUNTED_MAX 128 - typedef struct addon_reg addon_reg; typedef struct addon_cache_entry addon_cache_entry; typedef struct addon_alias addon_alias; @@ -24,12 +19,17 @@ struct addon_alias { char foldername[ ADDON_FOLDERNAME_MAX ]; }; +#define ADDON_REG_HIDDEN 0x1 +#define ADDON_REG_MTZERO 0x2 +#define ADDON_REG_CITY 0x4 + struct { struct addon_reg{ addon_alias alias; u32 foldername_hash; u8 metadata[512]; /* vg_msg buffer */ u32 metadata_len; + u32 flags; u16 cache_id; @@ -72,20 +72,24 @@ struct { static addon_system; static void addon_system_init( void ); -static u32 addon_count( enum addon_type type ); -static addon_reg *get_addon_from_index(enum addon_type type, u32 index); +static u32 addon_count( enum addon_type type, u32 ignoreflags ); +static addon_reg *get_addon_from_index( enum addon_type type, u32 index, + u32 ignoreflags ); static u32 get_index_from_addon( enum addon_type type, addon_reg *a ); -static int addon_get_content_folder( addon_reg *reg, vg_str *folder ); +static int addon_get_content_folder( addon_reg *reg, vg_str *folder, int async); /* scanning routines */ static u32 addon_match( addon_alias *alias ); -static void addon_alias_uid( addon_alias *alias, char buf[76] ); -VG_STATIC void addon_mount_content_folder( enum addon_type type, +static int addon_alias_eq( addon_alias *a, addon_alias *b ); +static void addon_alias_uid( addon_alias *alias, char buf[ADDON_UID_MAX] ); +static int addon_uid_to_alias( const char *uid, addon_alias *alias ); +static void invalidate_addon_alias( addon_alias *alias ); +static void addon_mount_content_folder( enum addon_type type, const char *base_folder, const char *content_ext ); -VG_STATIC void addon_mount_workshop_items(void); -VG_STATIC void async_addon_reg_update( void *data, u32 size ); -VG_STATIC addon_reg *addon_mount_local_addon( const char *folder, +static void addon_mount_workshop_items(void); +static void async_addon_reg_update( void *data, u32 size ); +static addon_reg *addon_mount_local_addon( const char *folder, enum addon_type type, const char *content_ext ); static u16 addon_cache_fetch( enum addon_type type, u32 reg_index ); @@ -98,5 +102,7 @@ static u16 addon_cache_create_viewer( enum addon_type type, u16 reg_id); static void addon_cache_watch( enum addon_type type, u16 cache_id ); static void addon_cache_unwatch( enum addon_type type, u16 cache_id ); +static u16 addon_cache_create_viewer_from_uid( enum addon_type type, + char uid[ADDON_UID_MAX] ); #endif /* ADDON_H */