summaryrefslogtreecommitdiffstats
path: root/src/libnetdata/string/string.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/libnetdata/string/string.c')
-rw-r--r--src/libnetdata/string/string.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/src/libnetdata/string/string.c b/src/libnetdata/string/string.c
index 257a3cc4b..107c7eea5 100644
--- a/src/libnetdata/string/string.c
+++ b/src/libnetdata/string/string.c
@@ -347,16 +347,34 @@ void string_freez(STRING *string) {
string_stats_atomic_increment(partition, releases);
}
-inline size_t string_strlen(STRING *string) {
+inline size_t string_strlen(const STRING *string) {
if(unlikely(!string)) return 0;
return string->length - 1;
}
-inline const char *string2str(STRING *string) {
+inline const char *string2str(const STRING *string) {
if(unlikely(!string)) return "";
return string->str;
}
+bool string_ends_with_string(const STRING *whole, const STRING *end) {
+ if(whole == end) return true;
+ if(!whole || !end) return false;
+ if(end->length > whole->length) return false;
+ if(end->length == whole->length) return strcmp(string2str(whole), string2str(end)) == 0;
+ const char *we = string2str(whole);
+ we = &we[string_strlen(whole) - string_strlen(end)];
+ return strncmp(we, end->str, string_strlen(end)) == 0;
+}
+
+bool string_starts_with_string(const STRING *whole, const STRING *end) {
+ if(whole == end) return true;
+ if(!whole || !end) return false;
+ if(end->length > whole->length) return false;
+ if(end->length == whole->length) return strcmp(string2str(whole), string2str(end)) == 0;
+ return strncmp(string2str(whole), string2str(end), string_strlen(end)) == 0;
+}
+
STRING *string_2way_merge(STRING *a, STRING *b) {
static STRING *X = NULL;