summaryrefslogtreecommitdiffhomepage
path: root/docs/cstr_api.md
blob: 6624e779d507cd374fca8a0418c5a5942724cdcd (plain)
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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
# Container cstr_t: String

This describes the API of string type **cstr_t**.

## Types

| Type name         | Type definition                  | Used to represent...       |
|:------------------|:---------------------------------|:---------------------------|
| `cstr_t`          | `struct { const char *str; }`    | The string type            |
| `cstr_value_t`    | `char`                           | The string element type    |
| `cstr_iter_t`     | `struct { cstr_value_t *val; }`  | cstr_t iterator            |

## Constants and macros

| Name              | Value            |
|:------------------|:-----------------|
|  `cstr_inits`     | `{...}`          |
|  `cstr_npos`      | `-1ull`          |

## Header file

All cstr definitions and prototypes may be included in your C source file by including a single header file.

```c
#include "stc/cstr.h"
```
## Methods

```c
 1)     cstr_t       cstr_init(void);
 2)     cstr_t       cstr_with_capacity(size_t cap);
 3)     cstr_t       cstr_with_size(size_t len, char fill);
 4)     cstr_t       cstr_from(const char* str);
 5)     cstr_t       cstr_from_n(const char* str, size_t len);
 6)     cstr_t       cstr_from_fmt(const char* fmt, ...);
 7)     cstr_t       cstr_clone(cstr_t s);
 8)     void         cstr_del(cstr_t *self);
```
`1)` Create an empty string, `2)` with capacity. `3)` Create a string by repeating *fill* character *len* times.
`4)` Construct a string from *str*, and `5)` limit the length by *len* and *strlen(str)*.
`6)` Construct a string from the format specified by *fmt* and arguments, using *printf()* formatting.
`7)` Construct a new string by cloning another string. `8)` Free the allocated memory used by string.
```c
        size_t       cstr_size(cstr_t s);
        size_t       cstr_length(cstr_t s);
        size_t       cstr_capacity(cstr_t s);
        bool         cstr_empty(cstr_t s);
 5)     char*        cstr_front(cstr_t* self);
 6)     char*        cstr_back(cstr_t* self);
```
These returns properties of a string. `5-6)` returns reference, ie. pointer to the char.
```c
 1)     size_t       cstr_reserve(cstr_t* self, size_t capacity);
 2)     void         cstr_resize(cstr_t* self, size_t len, char fill);
 3)     void         cstr_clear(cstr_t* self);
 4)     cstr_t*      cstr_assign(cstr_t* self, const char* str);
 5)     cstr_t*      cstr_assign_n(cstr_t* self, const char* str, size_t len);
 6)     cstr_t*      cstr_take(cstr_t* self, cstr_t s);
 7)     cstr_t       cstr_move(cstr_t* self);
```
`1-3)` Reserve, resize, clear string. `4)` Assign *str* to string. `5)` assign substring *str* limited by
*len* and *strlen(str)*. `6)` Take the constructed or moved string *s*, i.e., no allocation takes place.
`7)` Explicitly move string to the caller of the method; string becomes empty after move.
```c
 1)     cstr_t*      cstr_append(cstr_t* self, const char* str);
 2)     cstr_t*      cstr_append_n(cstr_t* self, const char* str, size_t len);
 3)     cstr_t*      cstr_push_back(cstr_t* self, char ch);
 4)     void         cstr_pop_back(cstr_t* self);
 5)     void         cstr_insert(cstr_t* self, size_t pos, const char* str);
 6)     void         cstr_insert_n(cstr_t* self, size_t pos, const char* str, size_t n);
 7)     void         cstr_erase_n(cstr_t* self, size_t pos, size_t n);
 8)     void         cstr_replace(cstr_t* self, size_t pos, size_t len, const char* str);
 9)     void         cstr_replace_n(cstr_t* self, size_t pos, size_t len, const char* str, size_t n);
```
`1)` Append *str* to string. `2)` Append substring *str* limited by *len*. `3)` Append character *ch*.
`4)` Erase last character. `5)` Insert string at a position *pos*. `6)` string limited by n characters.
`7)` Erase *n* characters at position *pos*. `8)` Replace *len* characters at position *pos* with *str*.
`9)` Replace with *str* limited by *n* characters.
```c
        int          cstr_compare(const cstr_t *s1, const cstr_t *s2);
        bool         cstr_equals(cstr_t s, const char* str);
        bool         cstr_equals_s(cstr_t s, cstr_t s2);
        bool         cstr_iequals(cstr_t s, const char* str);
        size_t       cstr_find(cstr_t s, const char* substr);
        size_t       cstr_find_n(cstr_t s, const char* substr, size_t pos, size_t nlen);
        size_t       cstr_ifind_n(cstr_t s, const char* substr, size_t pos, size_t nlen);
        bool         cstr_contains(cstr_t s, const char* substr);
        bool         cstr_icontains(cstr_t s, const char* substr);
        bool         cstr_begins_with(cstr_t s, const char* substr);
        bool         cstr_ibegins_with(cstr_t s, const char* substr);
        bool         cstr_ends_with(cstr_t s, const char* substr);
        bool         cstr_iends_with(cstr_t s, const char* substr);
```
Compare and search methods. Methods prefixed by *i* does case-insensitive compare/search.
```c
        cstr_iter_t  cstr_begin(cstr_t* self);
        cstr_iter_t  cstr_end(cstr_t* self);
        void         cstr_next(cstr_iter_t* it);
        char*        cstr_itval(cstr_iter_t it);
```
Iterator methods, typically used via the general *c_foreach* macro.
```c
 1)     bool         cstr_getline(cstr_t *self, FILE *stream);
 2)     bool         cstr_getdelim(cstr_t *self, int delim, FILE *stream);
```
`1-2)` Read a line of text from *stream* and store it in string. Line is separated by *delim*, which is *'\n'* in `1)`.
```c
        const char*  cstr_to_raw(const cstr_t* x);
        int          cstr_compare_raw(const char** x, const char** y);
        bool         cstr_equals_raw(const char** x, const char** y);
        uint32_t     cstr_hash_raw(const char* const* spp, size_t ignored);
        int          c_strncasecmp(const char* s1, const char* s2, size_t n);
        char*        c_strnfind(const char* str, const char* needle, size_t nmax);
        char*        c_istrnfind(const char* str, const char* needle, size_t nmax);
        uint32_t     c_string_hash(const char* str);
```
Helper methods, used by other container types.

## Example
```c
#include "stc/cstr.h"

int main() {
    cstr_t s1 = cstr_from("one-nine-three-seven-five");
    printf("%s.\n", s1.str);

    cstr_insert(&s1, 3, "-two");
    printf("%s.\n", s1.str);

    cstr_erase(&s1, 7, 5); // -nine
    printf("%s.\n", s1.str);

    cstr_replace(&s1, cstr_find(&s1, "seven"), 5, "four");
    printf("%s.\n", s1.str);

    // reassign:
    cstr_assign(&s1, "one two three four five six seven");
    cstr_append(&s1, " eight");
    printf("append: %s\n", s1.str);

    cstr_t full_path = cstr_from_fmt("%s/%s.%s", "directory", "filename", "ext");
    printf("%s\n", full_path.str);

    c_del(cstr, &s1, &full_path);
}
```
Output:
```
one-nine-three-seven-five.
one-two-nine-three-seven-five.
one-two-three-seven-five.
one-two-three-four-five.
append: one two three four five six seven eight
directory/filename.ext
```