qstring.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. /*
  2. * QString Module
  3. *
  4. * Copyright (C) 2009 Red Hat Inc.
  5. *
  6. * Authors:
  7. * Luiz Capitulino <lcapitulino@redhat.com>
  8. *
  9. * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
  10. * See the COPYING.LIB file in the top-level directory.
  11. */
  12. #include "qobject.h"
  13. #include "qstring.h"
  14. #include "qemu-common.h"
  15. static void qstring_destroy_obj(QObject *obj);
  16. static const QType qstring_type = {
  17. .code = QTYPE_QSTRING,
  18. .destroy = qstring_destroy_obj,
  19. };
  20. /**
  21. * qstring_new(): Create a new empty QString
  22. *
  23. * Return strong reference.
  24. */
  25. QString *qstring_new(void)
  26. {
  27. return qstring_from_str("");
  28. }
  29. /**
  30. * qstring_from_substr(): Create a new QString from a C string substring
  31. *
  32. * Return string reference
  33. */
  34. QString *qstring_from_substr(const char *str, int start, int end)
  35. {
  36. QString *qstring;
  37. qstring = g_malloc(sizeof(*qstring));
  38. qstring->length = end - start + 1;
  39. qstring->capacity = qstring->length;
  40. qstring->string = g_malloc(qstring->capacity + 1);
  41. memcpy(qstring->string, str + start, qstring->length);
  42. qstring->string[qstring->length] = 0;
  43. QOBJECT_INIT(qstring, &qstring_type);
  44. return qstring;
  45. }
  46. /**
  47. * qstring_from_str(): Create a new QString from a regular C string
  48. *
  49. * Return strong reference.
  50. */
  51. QString *qstring_from_str(const char *str)
  52. {
  53. return qstring_from_substr(str, 0, strlen(str) - 1);
  54. }
  55. static void capacity_increase(QString *qstring, size_t len)
  56. {
  57. if (qstring->capacity < (qstring->length + len)) {
  58. qstring->capacity += len;
  59. qstring->capacity *= 2; /* use exponential growth */
  60. qstring->string = g_realloc(qstring->string, qstring->capacity + 1);
  61. }
  62. }
  63. /* qstring_append(): Append a C string to a QString
  64. */
  65. void qstring_append(QString *qstring, const char *str)
  66. {
  67. size_t len = strlen(str);
  68. capacity_increase(qstring, len);
  69. memcpy(qstring->string + qstring->length, str, len);
  70. qstring->length += len;
  71. qstring->string[qstring->length] = 0;
  72. }
  73. void qstring_append_int(QString *qstring, int64_t value)
  74. {
  75. char num[32];
  76. snprintf(num, sizeof(num), "%" PRId64, value);
  77. qstring_append(qstring, num);
  78. }
  79. /**
  80. * qstring_append_chr(): Append a C char to a QString
  81. */
  82. void qstring_append_chr(QString *qstring, int c)
  83. {
  84. capacity_increase(qstring, 1);
  85. qstring->string[qstring->length++] = c;
  86. qstring->string[qstring->length] = 0;
  87. }
  88. /**
  89. * qobject_to_qstring(): Convert a QObject to a QString
  90. */
  91. QString *qobject_to_qstring(const QObject *obj)
  92. {
  93. if (qobject_type(obj) != QTYPE_QSTRING)
  94. return NULL;
  95. return container_of(obj, QString, base);
  96. }
  97. /**
  98. * qstring_get_str(): Return a pointer to the stored string
  99. *
  100. * NOTE: Should be used with caution, if the object is deallocated
  101. * this pointer becomes invalid.
  102. */
  103. const char *qstring_get_str(const QString *qstring)
  104. {
  105. return qstring->string;
  106. }
  107. /**
  108. * qstring_destroy_obj(): Free all memory allocated by a QString
  109. * object
  110. */
  111. static void qstring_destroy_obj(QObject *obj)
  112. {
  113. QString *qs;
  114. assert(obj != NULL);
  115. qs = qobject_to_qstring(obj);
  116. g_free(qs->string);
  117. g_free(qs);
  118. }