misc.h 3 KB
Newer Older
Damien's avatar
Damien committed
1
2
3
4
5
6
7
// a mini library of useful types and functions

#ifndef _INCLUDED_MINILIB_H
#define _INCLUDED_MINILIB_H

/** types *******************************************************/

ian-v's avatar
ian-v committed
8
typedef int MP_BOOL;
Damien's avatar
Damien committed
9
enum {
ian-v's avatar
ian-v committed
10
11
    MP_FALSE = 0,
    MP_TRUE = 1
Damien's avatar
Damien committed
12
13
14
15
16
17
18
};

typedef unsigned char byte;
typedef unsigned int uint;

/** memomry allocation ******************************************/

19
20
// TODO make a lazy m_renew that can increase by a smaller amount than requested (but by at least 1 more element)

Damien's avatar
Damien committed
21
22
#define m_new(type, num) ((type*)(m_malloc(sizeof(type) * (num))))
#define m_new0(type, num) ((type*)(m_malloc0(sizeof(type) * (num))))
23
24
#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)))
25
26
27
#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))
Damien's avatar
Damien committed
28
29
30

void *m_malloc(int num_bytes);
void *m_malloc0(int num_bytes);
31
32
void *m_realloc(void *ptr, int old_num_bytes, int new_num_bytes);
void m_free(void *ptr, int num_bytes);
Damien's avatar
Damien committed
33

34
int m_get_total_bytes_allocated(void);
35
int m_get_current_bytes_allocated(void);
36
int m_get_peak_bytes_allocated(void);
Damien's avatar
Damien committed
37
38
39
40
41

/** unichar / UTF-8 *********************************************/

typedef int unichar; // TODO

42
43
unichar utf8_get_char(const char *s);
char *utf8_next_char(const char *s);
Damien's avatar
Damien committed
44

ian-v's avatar
ian-v committed
45
46
47
48
MP_BOOL unichar_isspace(unichar c);
MP_BOOL unichar_isalpha(unichar c);
MP_BOOL unichar_isprint(unichar c);
MP_BOOL unichar_isdigit(unichar c);
Damien's avatar
Damien committed
49
50
51
52
53
54
55
56
57

/** string ******************************************************/

/*
#define streq(s1, s2) (strcmp((s1), (s2)) == 0)
*/

/** variable string *********************************************/

Damien's avatar
Damien committed
58
59
60
61
typedef struct _vstr_t {
    int alloc;
    int len;
    char *buf;
ian-v's avatar
ian-v committed
62
    MP_BOOL had_error;
Damien's avatar
Damien committed
63
64
65
66
} vstr_t;

void vstr_init(vstr_t *vstr);
void vstr_clear(vstr_t *vstr);
67
vstr_t *vstr_new(void);
Damien's avatar
Damien committed
68
69
void vstr_free(vstr_t *vstr);
void vstr_reset(vstr_t *vstr);
ian-v's avatar
ian-v committed
70
MP_BOOL vstr_had_error(vstr_t *vstr);
Damien's avatar
Damien committed
71
72
73
74
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);
Damien's avatar
Damien committed
75
76
void vstr_add_byte(vstr_t *vstr, byte v);
void vstr_add_char(vstr_t *vstr, unichar chr);
Damien's avatar
Damien committed
77
78
void vstr_add_str(vstr_t *vstr, const char *str);
void vstr_add_strn(vstr_t *vstr, const char *str, int len);
Damien's avatar
Damien committed
79
80
//void vstr_add_le16(vstr_t *vstr, unsigned short v);
//void vstr_add_le32(vstr_t *vstr, unsigned int v);
Damien's avatar
Damien committed
81
void vstr_cut_tail(vstr_t *vstr, int len);
82
void vstr_printf(vstr_t *vstr, const char *fmt, ...);
83
84

#ifdef va_start
85
void vstr_vprintf(vstr_t *vstr, const char *fmt, va_list ap);
86
#endif
Damien's avatar
Damien committed
87
88
89
90
91

/** unique string ***********************************************/

typedef unsigned int qstr;

92
void qstr_init(void);
Damien's avatar
Damien committed
93
qstr qstr_from_str_static(const char *str);
94
qstr qstr_from_str_take(char *str, int alloc_len);
Damien's avatar
Damien committed
95
96
97
98
qstr qstr_from_strn_copy(const char *str, int len);
const char* qstr_str(qstr qstr);

#endif // _INCLUDED_MINILIB_H