aboutsummaryrefslogtreecommitdiff
path: root/text.h
blob: 0dadbb68b4d0e278f8ea27e71b605918c1c7ea0b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#ifndef TEXT_H
#define TEXT_H

#include <stdbool.h>
#include <stddef.h>

typedef size_t Filepos;

typedef struct {
	size_t start, end;        /* range in bytes from start of the file */
} Filerange;

typedef struct Text Text;
typedef struct Piece Piece;

typedef struct {
	const char const *start;  /* begin of piece's data */
	const char const *end;    /* pointer to the first byte after valid data i.e. [start, end) */
	const char const *text;   /* current position within piece: start <= text < end */
	const Piece const *piece; /* internal state do not touch! */
	size_t pos;               /* global position in bytes from start of file */
} Iterator;

#define text_iterate(txt, it, pos) \
	for (Iterator it = text_iterator_get((txt), (pos)); \
	     text_iterator_valid(&it); \
	     text_iterator_next(&it))

Text *text_load(const char *file);
/* the filename from which this text was loaded or first saved to */
const char *text_filename_get(Text*);
/* associate a filename with the yet unnamed buffer */
void text_filename_set(Text*, const char *filename);
bool text_insert(Text*, size_t pos, const char *data);
bool text_insert_raw(Text*, size_t pos, const char *data, size_t len);
bool text_delete(Text*, size_t pos, size_t len);
void text_snapshot(Text*);
/* undo/redos to the last snapshoted state. returns the position where
 * the change occured or (size_t)-1 if nothing could be undo/redo. */
size_t text_undo(Text*);
size_t text_redo(Text*);

size_t text_pos_by_lineno(Text*, size_t lineno);
size_t text_lineno_by_pos(Text*, size_t pos);

bool text_byte_get(Text*, size_t pos, char *buf);
size_t text_bytes_get(Text*, size_t pos, size_t len, char *buf);

Iterator text_iterator_get(Text*, size_t pos);
bool text_iterator_valid(const Iterator*);
bool text_iterator_next(Iterator*);
bool text_iterator_prev(Iterator*);

bool text_iterator_byte_get(Iterator*, char *b);
bool text_iterator_byte_next(Iterator*, char *b);
bool text_iterator_byte_prev(Iterator*, char *b);

bool text_iterator_char_next(Iterator*, char *c);
bool text_iterator_char_prev(Iterator*, char *c);

typedef int Mark;
void text_mark_set(Text*, Mark, size_t pos);
size_t text_mark_get(Text*, Mark);
void text_mark_clear(Text*, Mark);
void text_mark_clear_all(Text*);

size_t text_size(Text*);
bool text_modified(Text*);
int text_save(Text*, const char *file);
void text_free(Text*);

typedef struct Regex Regex;

typedef struct {
	size_t start; /* start of match in bytes from start of file or -1 if unused */
	size_t end;   /* end of match in bytes from start of file or -1 if unused */
} RegexMatch;

Regex *text_regex_new(void);
int text_regex_compile(Regex *r, const char *regex, int cflags);
void text_regex_free(Regex *r);
int text_search_range_forward(Text*, size_t pos, size_t len, Regex *r, size_t nmatch, RegexMatch pmatch[], int eflags);
int text_search_range_backward(Text*, size_t pos, size_t len, Regex *r, size_t nmatch, RegexMatch pmatch[], int eflags);

// TMP
void text_debug(Text*);

#endif