aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Voss <mail@thomasvoss.com> 2024-10-30 08:28:15 +0100
committerThomas Voss <mail@thomasvoss.com> 2024-10-30 08:28:15 +0100
commit045f4bb5b1767140c4f6cfe2d2002553925c4205 (patch)
treef51b2034e91a3f67d2bde506cf84d13cfc496c6e
parent5dbf53a1c512f9163744874e3d502e9f9e2808da (diff)
Make string view lengths signed
-rw-r--r--include/_uNview.h6
-rw-r--r--lib/cli/optparse.c2
-rw-r--r--lib/mbstring/u8chr.c2
-rw-r--r--lib/mbstring/u8rchr.c2
-rw-r--r--lib/unicode/string/u8gnext.c2
-rw-r--r--lib/unicode/string/u8wnext.c6
6 files changed, 10 insertions, 10 deletions
diff --git a/include/_uNview.h b/include/_uNview.h
index 1001807..1edbfde 100644
--- a/include/_uNview.h
+++ b/include/_uNview.h
@@ -7,17 +7,17 @@
typedef struct {
const char8_t *p;
- size_t len;
+ ptrdiff_t len;
} u8view_t;
typedef struct {
const char16_t *p;
- size_t len;
+ ptrdiff_t len;
} u16view_t;
typedef struct {
const char32_t *p;
- size_t len;
+ ptrdiff_t len;
} u32view_t;
#endif /* !MLIB__UNVIEW_H */
diff --git a/lib/cli/optparse.c b/lib/cli/optparse.c
index f4034a9..25719f0 100644
--- a/lib/cli/optparse.c
+++ b/lib/cli/optparse.c
@@ -52,7 +52,7 @@ optparse(optparser_t *st, const cli_opt_t *opts, size_t nopts)
const char8_t *eq_p = u8chr(opt, '=');
u8view_t opt_no_eq = {
.p = opt.p,
- .len = eq_p == nullptr ? opt.len : (size_t)(eq_p - opt.p),
+ .len = eq_p == nullptr ? opt.len : eq_p - opt.p,
};
for (size_t i = 0; i < nopts; i++) {
diff --git a/lib/mbstring/u8chr.c b/lib/mbstring/u8chr.c
index 5ddcdd8..4006ce5 100644
--- a/lib/mbstring/u8chr.c
+++ b/lib/mbstring/u8chr.c
@@ -79,7 +79,7 @@ u8chr(u8view_t sv, rune ch)
char8_t buf[U8_LEN_MAX];
int m = rtou8(buf, sizeof(buf), ch);
- if (sv.len < (size_t)m)
+ if (sv.len < m)
return nullptr;
switch (m) {
case 1:
diff --git a/lib/mbstring/u8rchr.c b/lib/mbstring/u8rchr.c
index 47eaa4c..0ed9f9e 100644
--- a/lib/mbstring/u8rchr.c
+++ b/lib/mbstring/u8rchr.c
@@ -69,7 +69,7 @@ u8rchr(u8view_t sv, rune ch)
char8_t buf[U8_LEN_MAX];
int n = rtou8(buf, ch, sizeof(buf));
- if (sv.len < (size_t)n)
+ if (sv.len < n)
return nullptr;
switch (n) {
case 1:
diff --git a/lib/unicode/string/u8gnext.c b/lib/unicode/string/u8gnext.c
index 7c551f7..6e91cf7 100644
--- a/lib/unicode/string/u8gnext.c
+++ b/lib/unicode/string/u8gnext.c
@@ -35,7 +35,7 @@ u8gnext(u8view_t *g, u8view_t *sv)
for (;;) {
rune ch2;
- if ((size_t)(p - sv->p) >= sv->len)
+ if (p - sv->p >= sv->len)
ch2 = 0;
else
m = u8tor(&ch2, p);
diff --git a/lib/unicode/string/u8wnext.c b/lib/unicode/string/u8wnext.c
index 493ec9f..da11f4a 100644
--- a/lib/unicode/string/u8wnext.c
+++ b/lib/unicode/string/u8wnext.c
@@ -22,7 +22,7 @@ struct wbrk_state {
};
static bool advance(struct wbrk_state *);
-static size_t findwbrk(u8view_t);
+static ptrdiff_t findwbrk(u8view_t);
static struct wbrk_state mkwbrkstate(u8view_t);
size_t
@@ -34,7 +34,7 @@ u8wnext(u8view_t *w, u8view_t *sv)
if (sv->len == 0)
return 0;
- size_t off = findwbrk(*sv);
+ ptrdiff_t off = findwbrk(*sv);
if (w != nullptr)
*w = (u8view_t){sv->p, off};
@@ -43,7 +43,7 @@ u8wnext(u8view_t *w, u8view_t *sv)
return off;
}
-size_t
+ptrdiff_t
findwbrk(u8view_t sv)
{
ASSUME(sv.p != nullptr);