|
Packit Service |
b23acc |
// SPDX-License-Identifier: LGPL-2.1+
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
#ifndef __NM_REF_STRING_H__
|
|
Packit Service |
b23acc |
#define __NM_REF_STRING_H__
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
typedef struct _NMRefString {
|
|
Packit Service |
b23acc |
const char *const str;
|
|
Packit Service |
b23acc |
const gsize len;
|
|
Packit Service |
b23acc |
} NMRefString;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
NMRefString *nm_ref_string_new_len (const char *cstr, gsize len);
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static inline NMRefString *
|
|
Packit Service |
b23acc |
nm_ref_string_new (const char *cstr)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return cstr
|
|
Packit Service |
b23acc |
? nm_ref_string_new_len (cstr, strlen (cstr))
|
|
Packit Service |
b23acc |
: NULL;
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
NMRefString *nm_ref_string_ref (NMRefString *rstr);
|
|
Packit Service |
b23acc |
void _nm_ref_string_unref_non_null (NMRefString *rstr);
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static inline void
|
|
Packit Service |
b23acc |
nm_ref_string_unref (NMRefString *rstr)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
if (rstr)
|
|
Packit Service |
b23acc |
_nm_ref_string_unref_non_null (rstr);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
NM_AUTO_DEFINE_FCN_VOID0 (NMRefString *, _nm_auto_ref_string, _nm_ref_string_unref_non_null)
|
|
Packit Service |
b23acc |
#define nm_auto_ref_string nm_auto(_nm_auto_ref_string)
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/*****************************************************************************/
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static inline const char *
|
|
Packit Service |
b23acc |
nm_ref_string_get_str (NMRefString *rstr)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return rstr ? rstr->str : NULL;
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static inline gsize
|
|
Packit Service |
b23acc |
nm_ref_string_get_len (NMRefString *rstr)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
return rstr ? rstr->len : 0u;
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static inline gboolean
|
|
Packit Service |
b23acc |
nm_ref_string_equals_str (NMRefString *rstr, const char *s)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
/* Note that rstr->len might be greater than strlen(rstr->str). This function does
|
|
Packit Service |
b23acc |
* not cover that and would ignore everything after the first NUL byte. If you need
|
|
Packit Service |
b23acc |
* that distinction, this function is not for you. */
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
return rstr
|
|
Packit Service |
b23acc |
? (s && nm_streq (rstr->str, s))
|
|
Packit Service |
b23acc |
: (s == NULL);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
static inline gboolean
|
|
Packit Service |
b23acc |
NM_IS_REF_STRING (const NMRefString *rstr)
|
|
Packit Service |
b23acc |
{
|
|
Packit Service |
b23acc |
#if NM_MORE_ASSERTS > 10
|
|
Packit Service |
b23acc |
if (rstr) {
|
|
Packit Service |
b23acc |
nm_auto_ref_string NMRefString *r2 = NULL;
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
r2 = nm_ref_string_new_len (rstr->str, rstr->len);
|
|
Packit Service |
b23acc |
nm_assert (rstr == r2);
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
#endif
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
/* Technically, %NULL is also a valid NMRefString (according to nm_ref_string_new(),
|
|
Packit Service |
b23acc |
* nm_ref_string_get_str() and nm_ref_string_unref()). However, NM_IS_REF_STRING()
|
|
Packit Service |
b23acc |
* does not think so. If callers want to allow %NULL, they need to check
|
|
Packit Service |
b23acc |
* separately. */
|
|
Packit Service |
b23acc |
return !!rstr;
|
|
Packit Service |
b23acc |
}
|
|
Packit Service |
b23acc |
|
|
Packit Service |
b23acc |
#endif /* __NM_REF_STRING_H__ */
|