2013-10-04 22:53:11 +04:00
|
|
|
// a mini library of useful types and functions
|
|
|
|
|
|
|
|
#ifndef _INCLUDED_MINILIB_H
|
|
|
|
#define _INCLUDED_MINILIB_H
|
|
|
|
|
|
|
|
/** types *******************************************************/
|
|
|
|
|
|
|
|
typedef int bool;
|
|
|
|
enum {
|
|
|
|
false = 0,
|
|
|
|
true = 1
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef unsigned char byte;
|
|
|
|
typedef unsigned int uint;
|
|
|
|
|
|
|
|
/** memomry allocation ******************************************/
|
|
|
|
|
2013-12-29 23:33:23 +04:00
|
|
|
// TODO make a lazy m_renew that can increase by a smaller amount than requested (but by at least 1 more element)
|
|
|
|
|
2013-10-04 22:53:11 +04:00
|
|
|
#define m_new(type, num) ((type*)(m_malloc(sizeof(type) * (num))))
|
|
|
|
#define m_new0(type, num) ((type*)(m_malloc0(sizeof(type) * (num))))
|
2013-12-21 22:17:45 +04:00
|
|
|
#define m_new_obj(type) (m_new(type, 1))
|
|
|
|
#define m_new_obj_var(obj_type, var_type, var_num) ((obj_type*)m_malloc(sizeof(obj_type) + sizeof(var_type) * (var_num)))
|
2013-12-29 23:33:23 +04:00
|
|
|
#define m_renew(type, ptr, old_num, new_num) ((type*)(m_realloc((ptr), sizeof(type) * (old_num), sizeof(type) * (new_num))))
|
|
|
|
#define m_del(type, ptr, num) m_free(ptr, sizeof(type) * (num))
|
|
|
|
#define m_del_obj(type, ptr) (m_del(type, ptr, 1))
|
2013-10-04 22:53:11 +04:00
|
|
|
|
|
|
|
void *m_malloc(int num_bytes);
|
|
|
|
void *m_malloc0(int num_bytes);
|
2013-12-29 23:33:23 +04:00
|
|
|
void *m_realloc(void *ptr, int old_num_bytes, int new_num_bytes);
|
|
|
|
void m_free(void *ptr, int num_bytes);
|
2013-10-04 22:53:11 +04:00
|
|
|
|
2013-10-23 23:20:17 +04:00
|
|
|
int m_get_total_bytes_allocated(void);
|
2013-10-04 22:53:11 +04:00
|
|
|
|
|
|
|
/** unichar / UTF-8 *********************************************/
|
|
|
|
|
|
|
|
typedef int unichar; // TODO
|
|
|
|
|
2013-12-30 22:23:50 +04:00
|
|
|
unichar utf8_get_char(const char *s);
|
|
|
|
char *utf8_next_char(const char *s);
|
2013-10-04 22:53:11 +04:00
|
|
|
|
2013-12-30 22:23:50 +04:00
|
|
|
bool unichar_isspace(unichar c);
|
|
|
|
bool unichar_isalpha(unichar c);
|
|
|
|
bool unichar_isprint(unichar c);
|
|
|
|
bool unichar_isdigit(unichar c);
|
2013-10-04 22:53:11 +04:00
|
|
|
|
|
|
|
/** string ******************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
#define streq(s1, s2) (strcmp((s1), (s2)) == 0)
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** variable string *********************************************/
|
|
|
|
|
2013-10-20 17:39:58 +04:00
|
|
|
typedef struct _vstr_t {
|
|
|
|
int alloc;
|
|
|
|
int len;
|
|
|
|
char *buf;
|
|
|
|
bool had_error;
|
|
|
|
} vstr_t;
|
|
|
|
|
|
|
|
void vstr_init(vstr_t *vstr);
|
|
|
|
void vstr_clear(vstr_t *vstr);
|
2013-10-23 23:20:17 +04:00
|
|
|
vstr_t *vstr_new(void);
|
2013-10-04 22:53:11 +04:00
|
|
|
void vstr_free(vstr_t *vstr);
|
|
|
|
void vstr_reset(vstr_t *vstr);
|
|
|
|
bool vstr_had_error(vstr_t *vstr);
|
|
|
|
char *vstr_str(vstr_t *vstr);
|
|
|
|
int vstr_len(vstr_t *vstr);
|
|
|
|
void vstr_hint_size(vstr_t *vstr, int size);
|
|
|
|
char *vstr_add_len(vstr_t *vstr, int len);
|
2013-10-20 17:39:58 +04:00
|
|
|
void vstr_add_byte(vstr_t *vstr, byte v);
|
|
|
|
void vstr_add_char(vstr_t *vstr, unichar chr);
|
2013-10-04 22:53:11 +04:00
|
|
|
void vstr_add_str(vstr_t *vstr, const char *str);
|
|
|
|
void vstr_add_strn(vstr_t *vstr, const char *str, int len);
|
2013-10-20 17:39:58 +04:00
|
|
|
//void vstr_add_le16(vstr_t *vstr, unsigned short v);
|
|
|
|
//void vstr_add_le32(vstr_t *vstr, unsigned int v);
|
2013-10-04 22:53:11 +04:00
|
|
|
void vstr_cut_tail(vstr_t *vstr, int len);
|
2013-11-03 22:20:56 +04:00
|
|
|
void vstr_printf(vstr_t *vstr, const char *fmt, ...);
|
2013-11-03 22:30:10 +04:00
|
|
|
|
|
|
|
#ifdef va_start
|
2013-11-03 22:20:56 +04:00
|
|
|
void vstr_vprintf(vstr_t *vstr, const char *fmt, va_list ap);
|
2013-11-03 22:30:10 +04:00
|
|
|
#endif
|
2013-10-04 22:53:11 +04:00
|
|
|
|
|
|
|
/** unique string ***********************************************/
|
|
|
|
|
|
|
|
typedef unsigned int qstr;
|
|
|
|
|
2013-10-23 23:20:17 +04:00
|
|
|
void qstr_init(void);
|
2013-10-04 22:53:11 +04:00
|
|
|
qstr qstr_from_str_static(const char *str);
|
2013-12-29 23:33:23 +04:00
|
|
|
qstr qstr_from_str_take(char *str, int alloc_len);
|
2013-10-04 22:53:11 +04:00
|
|
|
qstr qstr_from_strn_copy(const char *str, int len);
|
|
|
|
const char* qstr_str(qstr qstr);
|
|
|
|
|
|
|
|
#endif // _INCLUDED_MINILIB_H
|