Blame shared/nm-glib-aux/nm-ref-string.h

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__ */