forked from len0rd/rockbox
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@7039 a1c6a512-1295-4272-9138-f99709370657
84 lines
2.3 KiB
C
84 lines
2.3 KiB
C
#ifndef __FILE_H__
|
|
#define __FILE_H__
|
|
|
|
#include "config.h"
|
|
#include <stdio.h>
|
|
#include <stdint.h>
|
|
|
|
struct file_entry {
|
|
char* name; // song name
|
|
|
|
uint32_t hash;
|
|
uint32_t song; // pointer to song
|
|
uint32_t rundb; // pointer to rundb
|
|
|
|
struct file_size {
|
|
uint32_t name_len; // must be mulitple of 4
|
|
} size;
|
|
unsigned char flag; // flags
|
|
};
|
|
|
|
struct file_entry* new_file_entry(const uint32_t name_len);
|
|
/* Creates a new file_entry with the specified sizes
|
|
* Returns a pointer to the structure on success,
|
|
* NULL on failure
|
|
*/
|
|
|
|
int file_entry_destruct(struct file_entry *e);
|
|
/* Destructs the given file_entry and free()'s it's memory
|
|
* returns 0 on success, 1 on failure
|
|
*/
|
|
|
|
inline int file_entry_resize(struct file_entry *e, const uint32_t name_len);
|
|
/* Change the size of the entry
|
|
* returns 0 on succes, 1 on failure
|
|
*/
|
|
|
|
int file_entry_serialize(FILE *fd, const struct file_entry *e);
|
|
/* Serializes the entry in the file at the current position
|
|
* returns 0 on success, 1 on failure
|
|
*/
|
|
|
|
int file_entry_unserialize(struct file_entry* *e, FILE *fd);
|
|
/* Unserializes an entry from file into a new structure
|
|
* The address of the structure is saved into *e
|
|
* returns 0 on success
|
|
* 1 on malloc() failure
|
|
* 2 on fread() failure
|
|
*/
|
|
|
|
int file_entry_write(FILE *fd, struct file_entry *e, struct file_size *s);
|
|
/* Writes the entry to file in the final form
|
|
* returns 0 (0) on success, 1 (1) on failure
|
|
*/
|
|
|
|
inline int file_entry_compare(const struct file_entry *a, const struct file_entry *b);
|
|
/* Compares 2 entries
|
|
* When a < b it returns <0
|
|
* a = b 0
|
|
* a > b >0
|
|
*/
|
|
|
|
struct file_size* new_file_size();
|
|
/* Creates a new size structure
|
|
* returns a pointer to the structure on success,
|
|
* NULL on failure
|
|
*/
|
|
|
|
inline uint32_t file_size_get_length(const struct file_size *size);
|
|
/* Calculates the length of the entry when written by file_entry_write()
|
|
* returns the length on success, 0xffffffff on failure
|
|
*/
|
|
|
|
inline int file_size_max(struct file_size *s, const struct file_entry *e);
|
|
/* Updates the file_size structure to contain the maximal lengths of either
|
|
* the original entry in s, or the entry e
|
|
* returns 0 on success, 1 on failure
|
|
*/
|
|
|
|
int file_size_destruct(struct file_size *s);
|
|
/* destructs the file_size structure
|
|
* returns 0 on success, 1 on failure
|
|
*/
|
|
|
|
#endif
|