misc.h 2.89 KB
Newer Older
Damien's avatar
Damien committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// 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 ******************************************/

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);
Damien's avatar
Damien committed
35
36
37
38
39

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

typedef int unichar; // TODO

40
41
unichar utf8_get_char(const char *s);
char *utf8_next_char(const char *s);
Damien's avatar
Damien committed
42

43
44
45
46
bool unichar_isspace(unichar c);
bool unichar_isalpha(unichar c);
bool unichar_isprint(unichar c);
bool unichar_isdigit(unichar c);
Damien's avatar
Damien committed
47
48
49
50
51
52
53
54
55

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

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

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

Damien's avatar
Damien committed
56
57
58
59
60
61
62
63
64
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);
65
vstr_t *vstr_new(void);
Damien's avatar
Damien committed
66
67
68
69
70
71
72
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);
Damien's avatar
Damien committed
73
74
void vstr_add_byte(vstr_t *vstr, byte v);
void vstr_add_char(vstr_t *vstr, unichar chr);
Damien's avatar
Damien committed
75
76
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
77
78
//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
79
void vstr_cut_tail(vstr_t *vstr, int len);
80
void vstr_printf(vstr_t *vstr, const char *fmt, ...);
81
82

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

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

typedef unsigned int qstr;

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

#endif // _INCLUDED_MINILIB_H