forked from martanne/vis
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtext.h
102 lines (80 loc) · 3.5 KB
/
text.h
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#ifndef TEXT_H
#define TEXT_H
#include <stdbool.h>
#include <stddef.h>
#define EPOS ((size_t)-1) /* invalid position */
typedef size_t Filepos;
typedef struct {
size_t start, end; /* range in bytes from start of the file */
} Filerange;
bool text_range_valid(Filerange*);
Filerange text_range_empty(void);
Filerange text_range_union(Filerange*, 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, 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 EPOS if nothing could be undo/redo. */
size_t text_undo(Text*);
size_t text_redo(Text*);
size_t text_last_insertion(Text*, const char **content);
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*);
/* get byte at current iterator position, if this is at EOF a NUL
* byte (which is not actually part of the file) is read. */
bool text_iterator_byte_get(Iterator*, char *b);
/* advance iterator by one byte and get byte at new position. */
bool text_iterator_byte_prev(Iterator*, char *b);
/* if the new position is at EOF a NUL byte (which is not actually
* part of the file) is read. */
bool text_iterator_byte_next(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*);
/* test whether the underlying file uses UNIX style \n or Windows style \r\n newlines */
bool text_newlines_crnl(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