Merge branch 'calli-3'
This commit is contained in:
		
						commit
						50f3ec8da2
					
				
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -13,183 +13,161 @@ int mf_setpos(void *handle, size_t pos); | |||||||
| 
 | 
 | ||||||
| sp_writefuncs_t cstd_funcs =  | sp_writefuncs_t cstd_funcs =  | ||||||
| { | { | ||||||
| 	mf_open, |   mf_open, | ||||||
| 	mf_close, |   mf_close, | ||||||
| 	mf_write, |   mf_write, | ||||||
| 	mf_read, |   mf_read, | ||||||
| 	mf_getpos, |   mf_getpos, | ||||||
| 	mf_setpos |   mf_setpos | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| sp_file_t *spfw_create(const char *name, sp_writefuncs_t *optfuncs) | sp_file_t *spfw_create(const char *name, sp_writefuncs_t *optfuncs) | ||||||
| { | { | ||||||
| 	sp_file_t file; |   sp_file_t file; | ||||||
| 	sp_file_t *pFile; |   sp_file_t *pFile; | ||||||
| 
 | 
 | ||||||
| 	if (!optfuncs) |   if (!optfuncs) | ||||||
| 	{ |     optfuncs = &cstd_funcs; | ||||||
| 		optfuncs = &cstd_funcs; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	file.handle = optfuncs->fnOpen(name); |   file.handle = optfuncs->fnOpen(name); | ||||||
| 	if (!file.handle) |   if (!file.handle) | ||||||
| 	{ |     return NULL; | ||||||
| 		return NULL; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	pFile = (sp_file_t *)malloc(sizeof(sp_file_t)); |   pFile = (sp_file_t *)malloc(sizeof(sp_file_t)); | ||||||
| 
 | 
 | ||||||
| 	pFile->handle = file.handle; |   pFile->handle = file.handle; | ||||||
| 	memcpy(&pFile->funcs, optfuncs, sizeof(sp_writefuncs_t)); |   memcpy(&pFile->funcs, optfuncs, sizeof(sp_writefuncs_t)); | ||||||
| 	pFile->curoffs = 0; |   pFile->curoffs = 0; | ||||||
| 	pFile->header.magic = SPFILE_MAGIC; |   pFile->header.magic = SPFILE_MAGIC; | ||||||
| 	pFile->header.sections = 0; |   pFile->header.sections = 0; | ||||||
| 	pFile->header.stringtab = 0; |   pFile->header.stringtab = 0; | ||||||
| 	pFile->header.version = SPFILE_VERSION; |   pFile->header.version = SPFILE_VERSION; | ||||||
| 	pFile->header.imagesize = 0; |   pFile->header.imagesize = 0; | ||||||
| 	pFile->header.disksize = 0; |   pFile->header.disksize = 0; | ||||||
| 	pFile->header.compression = SPFILE_COMPRESSION_NONE; |   pFile->header.compression = SPFILE_COMPRESSION_NONE; | ||||||
| 	pFile->header.dataoffs = 0; |   pFile->header.dataoffs = 0; | ||||||
| 	pFile->lastsection = 0; |   pFile->lastsection = 0; | ||||||
| 	pFile->offsets = NULL; |   pFile->offsets = NULL; | ||||||
| 	pFile->sections = NULL; |   pFile->sections = NULL; | ||||||
| 	pFile->state = -1; |   pFile->state = -1; | ||||||
| 	pFile->nametab = NULL; |   pFile->nametab = NULL; | ||||||
| 	pFile->nametab_idx = 0; |   pFile->nametab_idx = 0; | ||||||
| 
 | 
 | ||||||
| 	return pFile; |   return pFile; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void spfw_destroy(sp_file_t *spf) | void spfw_destroy(sp_file_t *spf) | ||||||
| { | { | ||||||
| 	free(spf->sections); |   free(spf->sections); | ||||||
| 	free(spf->nametab); |   free(spf->nametab); | ||||||
| 	free(spf->offsets); |   free(spf->offsets); | ||||||
| 	spf->funcs.fnClose(spf->handle); |   spf->funcs.fnClose(spf->handle); | ||||||
| 	free(spf); |   free(spf); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| uint8_t spfw_add_section(sp_file_t *spf, const char *name) | uint8_t spfw_add_section(sp_file_t *spf, const char *name) | ||||||
| { | { | ||||||
| 	size_t namelen; |   size_t namelen; | ||||||
| 	uint8_t s; |   uint8_t s; | ||||||
| 	if (spf->state != -1) |   if (spf->state != -1) | ||||||
| 	{ |     return 0; | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	namelen = strlen(name) + 1; |   namelen = strlen(name) + 1; | ||||||
| 
 | 
 | ||||||
| 	if (spf->header.sections == 0) |   if (spf->header.sections == 0) | ||||||
| 	{ |   { | ||||||
| 		/** allocate for first section */ |     /** allocate for first section */ | ||||||
| 		spf->sections = (sp_file_section_t *)malloc(sizeof(sp_file_section_t)); |     spf->sections = (sp_file_section_t *)malloc(sizeof(sp_file_section_t)); | ||||||
| 		spf->offsets = (size_t *)malloc(sizeof(size_t)); |     spf->offsets = (size_t *)malloc(sizeof(size_t)); | ||||||
| 		spf->nametab = (char *)malloc(namelen); |     spf->nametab = (char *)malloc(namelen); | ||||||
| 	} else { |   } else { | ||||||
| 		uint16_t num = spf->header.sections + 1; |     uint16_t num = spf->header.sections + 1; | ||||||
| 		spf->sections = (sp_file_section_t *)realloc(spf->sections, sizeof(sp_file_section_t) * num); |     spf->sections = (sp_file_section_t *)realloc(spf->sections, sizeof(sp_file_section_t) * num); | ||||||
| 		spf->offsets = (size_t *)realloc(spf->offsets, sizeof(size_t) * num); |     spf->offsets = (size_t *)realloc(spf->offsets, sizeof(size_t) * num); | ||||||
| 		spf->nametab = (char *)realloc(spf->nametab, spf->nametab_idx + namelen); |     spf->nametab = (char *)realloc(spf->nametab, spf->nametab_idx + namelen); | ||||||
| 	} |   } | ||||||
| 
 | 
 | ||||||
| 	s = spf->header.sections; |   s = spf->header.sections; | ||||||
| 
 | 
 | ||||||
| 	spf->sections[s].nameoffs = spf->nametab_idx; |   spf->sections[s].nameoffs = spf->nametab_idx; | ||||||
| 	/** 
 |   /** 
 | ||||||
| 	 * "fix" offset will be the second uint2 slot, which is after the previous sections after the header. |    * "fix" offset will be the second uint2 slot, which is after the previous sections after the header. | ||||||
| 	 */ |    */ | ||||||
| 	spf->offsets[s] = sizeof(spf->header) + (sizeof(sp_file_section_t) * spf->header.sections) + sizeof(uint32_t); |   spf->offsets[s] = sizeof(spf->header) + (sizeof(sp_file_section_t) * spf->header.sections) + sizeof(uint32_t); | ||||||
| 	strcpy(&spf->nametab[spf->nametab_idx], name); |   strcpy(&spf->nametab[spf->nametab_idx], name); | ||||||
| 	spf->nametab_idx += namelen; |   spf->nametab_idx += namelen; | ||||||
| 
 | 
 | ||||||
| 	return ++spf->header.sections; |   return ++spf->header.sections; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int spfw_finalize_header(sp_file_t *spf) | int spfw_finalize_header(sp_file_t *spf) | ||||||
| { | { | ||||||
| 	uint32_t size; |   uint32_t size; | ||||||
| 	if (spf->state != -1) |   if (spf->state != -1) | ||||||
| 	{ |     return -1; | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	size = sizeof(sp_file_section_t) * spf->header.sections; |   size = sizeof(sp_file_section_t) * spf->header.sections; | ||||||
| 
 | 
 | ||||||
| 	spf->header.stringtab = sizeof(spf->header) + size; |   spf->header.stringtab = sizeof(spf->header) + size; | ||||||
| 	spf->header.dataoffs = spf->header.stringtab + spf->nametab_idx; |   spf->header.dataoffs = spf->header.stringtab + spf->nametab_idx; | ||||||
| 	if (spf->funcs.fnWrite(&spf->header, sizeof(spf->header), 1, spf->handle) != 1) |   if (spf->funcs.fnWrite(&spf->header, sizeof(spf->header), 1, spf->handle) != 1) | ||||||
| 	{ |     return -1; | ||||||
| 		return -1; |   if (spf->funcs.fnWrite(spf->sections, sizeof(sp_file_section_t), spf->header.sections, spf->handle) !=  | ||||||
| 	} |     spf->header.sections) | ||||||
| 	if (spf->funcs.fnWrite(spf->sections, sizeof(sp_file_section_t), spf->header.sections, spf->handle) !=  |     return -1; | ||||||
| 		spf->header.sections) |   if (spf->funcs.fnWrite(spf->nametab, sizeof(char), spf->nametab_idx, spf->handle) != spf->nametab_idx) | ||||||
| 	{ |     return -1; | ||||||
| 		return -1; |   spf->curoffs = spf->funcs.fnGetPos(spf->handle); | ||||||
| 	} |   spf->lastsection = spf->curoffs; | ||||||
| 	if (spf->funcs.fnWrite(spf->nametab, sizeof(char), spf->nametab_idx, spf->handle) != spf->nametab_idx) |   spf->state++; | ||||||
| 	{ |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	spf->curoffs = spf->funcs.fnGetPos(spf->handle); |  | ||||||
| 	spf->lastsection = spf->curoffs; |  | ||||||
| 	spf->state++; |  | ||||||
| 
 | 
 | ||||||
| 	return 0; |   return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int spfw_next_section(sp_file_t *spf) | int spfw_next_section(sp_file_t *spf) | ||||||
| { | { | ||||||
| 	uint8_t s; |   uint8_t s; | ||||||
| 	uint32_t rest[2]; |   uint32_t rest[2]; | ||||||
| 
 | 
 | ||||||
| 	if (spf->state < 0 || spf->state > spf->header.sections) |   if (spf->state < 0 || spf->state > spf->header.sections) | ||||||
| 	{ |     return -1; | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	if (spf->state == (int)spf->header.sections) |   if (spf->state == (int)spf->header.sections) | ||||||
| 	{ |     return 0; | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	s = (uint8_t)spf->state; |   s = (uint8_t)spf->state; | ||||||
| 
 | 
 | ||||||
| 	spf->curoffs = spf->funcs.fnGetPos(spf->handle); |   spf->curoffs = spf->funcs.fnGetPos(spf->handle); | ||||||
| 	spf->funcs.fnSetPos(spf->handle, spf->offsets[s]); |   spf->funcs.fnSetPos(spf->handle, spf->offsets[s]); | ||||||
| 	 |    | ||||||
| 	rest[0] = spf->lastsection; |   rest[0] = spf->lastsection; | ||||||
| 	rest[1] = spf->curoffs - spf->lastsection; |   rest[1] = spf->curoffs - spf->lastsection; | ||||||
| 	if (spf->funcs.fnWrite(rest, sizeof(uint32_t), 2, spf->handle) != 2) |   if (spf->funcs.fnWrite(rest, sizeof(uint32_t), 2, spf->handle) != 2) | ||||||
| 	{ |     return -1; | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	spf->funcs.fnSetPos(spf->handle, spf->curoffs); |   spf->funcs.fnSetPos(spf->handle, spf->curoffs); | ||||||
| 	spf->lastsection = spf->curoffs; |   spf->lastsection = spf->curoffs; | ||||||
| 
 | 
 | ||||||
| 	spf->state++; |   spf->state++; | ||||||
| 
 | 
 | ||||||
| 	return 1; |   return 1; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int spfw_finalize_all(sp_file_t *spf) | int spfw_finalize_all(sp_file_t *spf) | ||||||
| { | { | ||||||
| 	uint8_t offs; |   uint8_t offs; | ||||||
| 
 | 
 | ||||||
| 	if (spf->state < spf->header.sections) |   if (spf->state < spf->header.sections) | ||||||
| 	{ |     return -1; | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	offs = offsetof(sp_file_hdr_t, imagesize); |   offs = offsetof(sp_file_hdr_t, imagesize); | ||||||
| 	spf->header.disksize = spf->funcs.fnGetPos(spf->handle); |   spf->header.disksize = spf->funcs.fnGetPos(spf->handle); | ||||||
| 	spf->header.imagesize = spf->funcs.fnGetPos(spf->handle); |   spf->header.imagesize = spf->funcs.fnGetPos(spf->handle); | ||||||
| 	spf->funcs.fnSetPos(spf->handle, offs); |   spf->funcs.fnSetPos(spf->handle, offs); | ||||||
| 	spf->funcs.fnWrite(&spf->header.imagesize, sizeof(uint32_t), 1, spf->handle); |   spf->funcs.fnWrite(&spf->header.imagesize, sizeof(uint32_t), 1, spf->handle); | ||||||
| 	spf->funcs.fnSetPos(spf->handle, spf->header.imagesize); |   spf->funcs.fnSetPos(spf->handle, spf->header.imagesize); | ||||||
| 
 | 
 | ||||||
| 	return 1; |   return 1; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
| @ -198,43 +176,39 @@ int spfw_finalize_all(sp_file_t *spf) | |||||||
| 
 | 
 | ||||||
| void *mf_open(const char *name) | void *mf_open(const char *name) | ||||||
| { | { | ||||||
| 	return memfile_creat(name, 1024); |   return memfile_creat(name, 1024); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void mf_close(void *handle) | void mf_close(void *handle) | ||||||
| { | { | ||||||
| 	memfile_destroy((memfile_t *)handle); |   memfile_destroy((memfile_t *)handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t mf_write(const void *buf, size_t size, size_t count, void *handle) | size_t mf_write(const void *buf, size_t size, size_t count, void *handle) | ||||||
| { | { | ||||||
| 	if (!count) |   if (!count) | ||||||
| 	{ |     return 0; | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	if (memfile_write((memfile_t *)handle, buf, size*count)) |   if (memfile_write((memfile_t *)handle, buf, size*count)) | ||||||
| 	{ |     return count; | ||||||
| 		return count; |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	return 0; |   return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t mf_read(void *buf, size_t size, size_t count, void *handle) | size_t mf_read(void *buf, size_t size, size_t count, void *handle) | ||||||
| { | { | ||||||
| 	return memfile_read((memfile_t *)handle, buf, size*count) / count; |   return memfile_read((memfile_t *)handle, buf, size*count) / count; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t mf_getpos(void *handle) | size_t mf_getpos(void *handle) | ||||||
| { | { | ||||||
| 	return (long)memfile_tell((memfile_t *)handle); |   return (long)memfile_tell((memfile_t *)handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int mf_setpos(void *handle, size_t pos) | int mf_setpos(void *handle, size_t pos) | ||||||
| { | { | ||||||
| 	memfile_seek((memfile_t *)handle, (long)pos); |   memfile_seek((memfile_t *)handle, (long)pos); | ||||||
| 	return 1; |   return 1; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -246,31 +220,31 @@ int mf_setpos(void *handle, size_t pos) | |||||||
| 
 | 
 | ||||||
| void *fp_open(const char *name) | void *fp_open(const char *name) | ||||||
| { | { | ||||||
| 	return fopen(name, "wb"); |   return fopen(name, "wb"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void fp_close(void *handle) | void fp_close(void *handle) | ||||||
| { | { | ||||||
| 	fclose((FILE *)handle); |   fclose((FILE *)handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t fp_write(const void *buf, size_t size, size_t count, void *handle) | size_t fp_write(const void *buf, size_t size, size_t count, void *handle) | ||||||
| { | { | ||||||
| 	return fwrite(buf, size, count, (FILE *)handle); |   return fwrite(buf, size, count, (FILE *)handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t fp_read(void *buf, size_t size, size_t count, void *handle) | size_t fp_read(void *buf, size_t size, size_t count, void *handle) | ||||||
| { | { | ||||||
| 	return fread(buf, size, count, (FILE *)handle); |   return fread(buf, size, count, (FILE *)handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t fp_getpos(void *handle) | size_t fp_getpos(void *handle) | ||||||
| { | { | ||||||
| 	return (size_t)ftell((FILE *)handle); |   return (size_t)ftell((FILE *)handle); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int fp_setpos(void *handle, size_t pos) | int fp_setpos(void *handle, size_t pos) | ||||||
| { | { | ||||||
| 	return fseek((FILE *)handle, (long)pos, SEEK_SET); |   return fseek((FILE *)handle, (long)pos, SEEK_SET); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -8,30 +8,30 @@ | |||||||
|  */ |  */ | ||||||
| typedef struct sp_writefuncs_s | typedef struct sp_writefuncs_s | ||||||
| { | { | ||||||
| 	void *(*fnOpen)(const char *);	/* filename, returns handle */ |   void *(*fnOpen)(const char *);  /* filename, returns handle */ | ||||||
| 	void (*fnClose)(void *);			/* handle */ |   void (*fnClose)(void *);      /* handle */ | ||||||
| 	/* buffer, size, count, handle, returns count written */ |   /* buffer, size, count, handle, returns count written */ | ||||||
| 	size_t (*fnWrite)(const void *, size_t, size_t, void *);	 |   size_t (*fnWrite)(const void *, size_t, size_t, void *);   | ||||||
| 	/* buffer, size, count, handle, returns count read */ |   /* buffer, size, count, handle, returns count read */ | ||||||
| 	size_t (*fnRead)(void *, size_t, size_t, void *); |   size_t (*fnRead)(void *, size_t, size_t, void *); | ||||||
| 	/* returns current position from start */ |   /* returns current position from start */ | ||||||
| 	size_t (*fnGetPos)(void *); |   size_t (*fnGetPos)(void *); | ||||||
| 	/* sets current position from start, return 0 for success, nonzero for error */ |   /* sets current position from start, return 0 for success, nonzero for error */ | ||||||
| 	int (*fnSetPos)(void *, size_t); |   int (*fnSetPos)(void *, size_t); | ||||||
| } sp_writefuncs_t; | } sp_writefuncs_t; | ||||||
| 
 | 
 | ||||||
| typedef struct sp_file_s | typedef struct sp_file_s | ||||||
| { | { | ||||||
| 	sp_file_hdr_t header; |   sp_file_hdr_t header; | ||||||
| 	sp_file_section_t *sections; |   sp_file_section_t *sections; | ||||||
| 	size_t *offsets; |   size_t *offsets; | ||||||
| 	sp_writefuncs_t funcs; |   sp_writefuncs_t funcs; | ||||||
| 	size_t lastsection; |   size_t lastsection; | ||||||
| 	size_t curoffs; |   size_t curoffs; | ||||||
| 	void *handle; |   void *handle; | ||||||
| 	int state; |   int state; | ||||||
| 	char *nametab; |   char *nametab; | ||||||
| 	size_t nametab_idx; |   size_t nametab_idx; | ||||||
| } sp_file_t; | } sp_file_t; | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user