|  | /* | 
|  | * QString Module | 
|  | * | 
|  | * Copyright (C) 2009 Red Hat Inc. | 
|  | * | 
|  | * Authors: | 
|  | *  Luiz Capitulino <lcapitulino@redhat.com> | 
|  | * | 
|  | * This work is licensed under the terms of the GNU LGPL, version 2.1 or later. | 
|  | * See the COPYING.LIB file in the top-level directory. | 
|  | */ | 
|  |  | 
|  | #include "qemu/osdep.h" | 
|  | #include "qapi/qmp/qstring.h" | 
|  | #include "qobject-internal.h" | 
|  |  | 
|  | /** | 
|  | * qstring_new(): Create a new empty QString | 
|  | * | 
|  | * Return strong reference. | 
|  | */ | 
|  | QString *qstring_new(void) | 
|  | { | 
|  | return qstring_from_str(""); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * qstring_from_substr(): Create a new QString from a C string substring | 
|  | * | 
|  | * Return string reference | 
|  | */ | 
|  | QString *qstring_from_substr(const char *str, size_t start, size_t end) | 
|  | { | 
|  | QString *qstring; | 
|  |  | 
|  | assert(start <= end); | 
|  | qstring = g_malloc(sizeof(*qstring)); | 
|  | qobject_init(QOBJECT(qstring), QTYPE_QSTRING); | 
|  | qstring->string = g_strndup(str + start, end - start); | 
|  | return qstring; | 
|  | } | 
|  |  | 
|  | /** | 
|  | * qstring_from_str(): Create a new QString from a regular C string | 
|  | * | 
|  | * Return strong reference. | 
|  | */ | 
|  | QString *qstring_from_str(const char *str) | 
|  | { | 
|  | return qstring_from_substr(str, 0, strlen(str)); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * qstring_from_gstring(): Convert a GString to a QString | 
|  | * | 
|  | * Return strong reference. | 
|  | */ | 
|  |  | 
|  | QString *qstring_from_gstring(GString *gstr) | 
|  | { | 
|  | QString *qstring; | 
|  |  | 
|  | qstring = g_malloc(sizeof(*qstring)); | 
|  | qobject_init(QOBJECT(qstring), QTYPE_QSTRING); | 
|  | qstring->string = g_string_free(gstr, false); | 
|  | return qstring; | 
|  | } | 
|  |  | 
|  |  | 
|  | /** | 
|  | * qstring_get_str(): Return a pointer to the stored string | 
|  | * | 
|  | * NOTE: Should be used with caution, if the object is deallocated | 
|  | * this pointer becomes invalid. | 
|  | */ | 
|  | const char *qstring_get_str(const QString *qstring) | 
|  | { | 
|  | return qstring->string; | 
|  | } | 
|  |  | 
|  | /** | 
|  | * qstring_is_equal(): Test whether the two QStrings are equal | 
|  | */ | 
|  | bool qstring_is_equal(const QObject *x, const QObject *y) | 
|  | { | 
|  | return !strcmp(qobject_to(QString, x)->string, | 
|  | qobject_to(QString, y)->string); | 
|  | } | 
|  |  | 
|  | /** | 
|  | * qstring_destroy_obj(): Free all memory allocated by a QString | 
|  | * object | 
|  | */ | 
|  | void qstring_destroy_obj(QObject *obj) | 
|  | { | 
|  | QString *qs; | 
|  |  | 
|  | assert(obj != NULL); | 
|  | qs = qobject_to(QString, obj); | 
|  | g_free((char *)qs->string); | 
|  | g_free(qs); | 
|  | } | 
|  |  | 
|  | void qstring_unref(QString *q) | 
|  | { | 
|  | qobject_unref(q); | 
|  | } |