X-Git-Url: https://www.kengrimes.com/gitweb/?p=henge%2Fapc.git;a=blobdiff_plain;f=src%2Fir.h;h=cce1e7970da5da31386b978e264ce826932a867c;hp=6d045dd828f5ef769b05245726beca29c6154505;hb=52b3767316142be128199f8f3a5eccd51d464d08;hpb=9fb546438cedd3fb67bd1b11665e7a0b6744f45b diff --git a/src/ir.h b/src/ir.h index 6d045dd..cce1e79 100644 --- a/src/ir.h +++ b/src/ir.h @@ -22,12 +22,14 @@ #include #include "apc.h" -typedef union ir_setdata_t* ir_setdata; -typedef struct ir_set_t* ir_set; -typedef struct ir_class_t* ir_class; -typedef struct ir_setld_t* ir_setld; -typedef struct ir_classld_t* ir_classld; - +struct ir_frameinfo_t +{ int facing, w, h; }; +typedef union ir_setdata_t* ir_setdata; +typedef struct ir_frameinfo_t* ir_frameinfo; +typedef struct ir_set_t* ir_set; +typedef struct ir_class_t* ir_class; +typedef struct ir_setld_t* ir_setld; +typedef struct ir_classld_t* ir_classld; /* Classes and Sets Classes are rooted at a special root class, representing the current working directory at scan-time, named ".". The root class can always be identified @@ -46,9 +48,22 @@ typedef struct ir_classld_t* ir_classld; specified set. */ ir_class ir_class_root(void); -ir_class ir_class_addchild(ir_class, uint8_t*); -ir_set ir_class_addset(ir_class,uint8_t*); -ir_set ir_set_addchild(ir_set,uint8_t*); +ir_class ir_class_addchild(ir_class,const uint8_t*); +uint8_t* ir_class_name(ir_class); +ir_set ir_class_addset(ir_class,const uint8_t*); +ir_set ir_class_rootset(ir_class); +ir_set ir_set_addchild(ir_set,const uint8_t*); +uint8_t* ir_set_name(ir_set); +/* Output */ +ir_class ir_class_nextsib(ir_class); +ir_class ir_class_nextchild(ir_class); +long ir_class_fpos(ir_class); +void ir_class_assign_fpos(ir_class,long); +ir_set ir_set_from_ref(uint32_t); +ir_set ir_set_nextsib(ir_set); +ir_set ir_set_nextchild(ir_set); +long ir_set_fpos(ir_set); +void ir_set_assign_fpos(ir_set,long); /* Set Data Each set can contain up to FACING_MAX each of framesheets and mapsheets, one sheet for each facing, per label. Each set can contain any number of audio @@ -63,14 +78,34 @@ ir_set ir_set_addchild(ir_set,uint8_t*); data of an associated file at that path and no path is provided, the data will be entered null. */ +typedef ir_setdata framebox; +typedef ir_setdata audiodata; +typedef ir_setdata linkdata; +typedef ir_setdata framedata; enum ltype { OLINK, MLINK, VLINK, ALINK }; void ir_set_assign_data(ir_set,ir_setdata); -void ir_set_assign_ref(ir_set,long long); -void ir_data_assign_path(ir_setdata,uint8_t*); -ir_setdata ir_framesheet(uint8_t*, apc_facing, int,int); -ir_setdata ir_mapsheet(uint8_t*, apc_facing, int,int); -ir_setdata ir_audio(uint8_t*); -ir_setdata ir_link(enum ltype, ir_setld, uint8_t*); +void ir_set_assign_ref(ir_set,uint32_t); +void ir_data_assign_path(ir_setdata,const uint8_t*); +ir_setdata ir_framesheet(const uint8_t*, apc_facing, int,int); +ir_setdata ir_mapsheet(const uint8_t*, apc_facing, int,int); +ir_setdata ir_audio(const uint8_t*); +ir_setdata ir_link(enum ltype,ir_setld,const uint8_t*); +/* Output */ +framebox ir_set_framebox(ir_set); +audiodata ir_set_audio(ir_set); +linkdata ir_set_link(ir_set); +enum ltype ir_linkdata_type(linkdata); +uint32_t ir_linkdata_ref(linkdata); +ir_set ir_linkdata_set(linkdata); +void ir_linkdata_assign_set(ir_set); +ir_setdata ir_setdata_nextsib(ir_setdata); +uint8_t* ir_setdata_name(ir_setdata); +uint8_t* ir_setdata_filename(ir_setdata); +long ir_setdata_fpos(ir_setdata); +void ir_setdata_assign_fpos(ir_setdata,long); +framedata ir_framebox_framesheet(framebox,apc_facing); +framedata ir_framebox_mapsheet(framebox,apc_facing); +ir_frameinfo ir_framedata_frameinfo(framedata); /* Reference Linking Data Create linking data to sets or classes that will be resolved at a later stage. Class references can be created from an ir_class object, if @@ -81,8 +116,11 @@ ir_setdata ir_link(enum ltype, ir_setld, uint8_t*); */ ir_classld ir_classld_from_class(ir_class); ir_classld ir_classld_from_root(void); -ir_classld ir_classld_addchild(ir_classld,uint8_t*); -ir_setld ir_setld_from_ref(long long); -ir_setld ir_setld_from_classld(ir_classld,uint8_t*); -ir_setld ir_setld_addchild(ir_setld,uint8_t*); +ir_classld ir_classld_addchild(ir_classld,const uint8_t*); +ir_setld ir_setld_from_ref(uint32_t); +ir_setld ir_setld_from_classld(ir_classld,const uint8_t*); +ir_setld ir_setld_addchild(ir_setld,const uint8_t*); +/* Output */ +enum ltype ir_setld_type(ir_setld); +uint32_t ir_setld_ref(ir_setld); #endif //_IR_H_