2007-03-15 17:30:04 +00:00
|
|
|
/*
|
2012-12-04 12:04:07 +00:00
|
|
|
* virbuffer.h: buffers for libvirt
|
2007-03-15 17:30:04 +00:00
|
|
|
*
|
2014-08-23 19:57:44 +00:00
|
|
|
* Copyright (C) 2005-2008, 2011-2014 Red Hat, Inc.
|
2007-03-15 17:30:04 +00:00
|
|
|
*
|
2012-07-27 09:39:53 +00:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-09-20 22:30:55 +00:00
|
|
|
* License along with this library. If not, see
|
2012-07-27 09:39:53 +00:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2007-03-15 17:30:04 +00:00
|
|
|
*/
|
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#pragma once
|
2007-03-15 17:30:04 +00:00
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#include <stdarg.h>
|
2018-07-24 15:52:04 +00:00
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#include "internal.h"
|
2007-03-15 17:30:04 +00:00
|
|
|
|
2011-04-30 16:44:42 +00:00
|
|
|
|
2007-03-15 17:30:04 +00:00
|
|
|
/**
|
2007-06-26 22:21:22 +00:00
|
|
|
* virBuffer:
|
2007-03-15 17:30:04 +00:00
|
|
|
*
|
|
|
|
* A buffer structure.
|
|
|
|
*/
|
2007-06-26 22:21:22 +00:00
|
|
|
typedef struct _virBuffer virBuffer;
|
|
|
|
typedef virBuffer *virBufferPtr;
|
2008-04-28 15:14:59 +00:00
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#define VIR_BUFFER_INITIALIZER { 0, 0, 0, 0, NULL }
|
2008-04-28 15:14:59 +00:00
|
|
|
|
2007-06-26 22:21:22 +00:00
|
|
|
struct _virBuffer {
|
2019-03-26 17:02:06 +00:00
|
|
|
size_t size;
|
|
|
|
size_t use;
|
2019-04-18 12:02:08 +00:00
|
|
|
int error; /* errno value, or -1 for usage error */
|
2019-03-25 15:54:28 +00:00
|
|
|
int indent;
|
|
|
|
char *content;
|
2007-03-15 17:30:04 +00:00
|
|
|
};
|
|
|
|
|
2012-06-08 19:50:23 +00:00
|
|
|
const char *virBufferCurrentContent(virBufferPtr buf);
|
2011-09-27 19:50:03 +00:00
|
|
|
char *virBufferContentAndReset(virBufferPtr buf);
|
|
|
|
void virBufferFreeAndReset(virBufferPtr buf);
|
maint: avoid 'const fooPtr' in several util files
'const fooPtr' is the same as 'foo * const' (the pointer won't
change, but it's contents can). But in general, if an interface
is trying to be const-correct, it should be using 'const foo *'
(the pointer is to data that can't be changed).
Fix up offenders in src/util outside of the virnet namespace.
Also, make a few virSocketAddr functions const-correct, for easier
conversions in future patches.
* src/util/virbuffer.h (virBufferError, virBufferUse)
(virBufferGetIndent): Use intended type.
* src/util/virmacaddr.h (virMacAddrCmp, virMacAddrCmpRaw)
(virMacAddrSet, virMcAddrFormat, virMacAddrIsUnicast)
(virMacAddrIsMulticast): Likewise.
* src/util/virebtables.h (ebtablesAddForwardAllowIn)
(ebtablesRemoveForwardAllowIn): Likewise.
* src/util/virsocketaddr.h (virSocketAddrSetIPv4Addr): Drop
incorrect const.
(virMacAddrGetRaw, virSocketAddrFormat, virSocketAddrFormatFull):
Make const-correct.
(virSocketAddrMask, virSocketAddrMaskByPrefix)
(virSocketAddrBroadcast, virSocketAddrBroadcastByPrefix)
(virSocketAddrGetNumNetmaskBits, virSocketAddrGetIpPrefix)
(virSocketAddrEqual, virSocketAddrIsPrivate)
(virSocketAddrIsWildcard): Use intended type.
* src/util/virbuffer.c (virBufferError, virBufferUse)
(virBufferGetIndent): Fix fallout.
* src/util/virmacaddr.c (virMacAddrCmp, virMacAddrCmpRaw)
(virMacAddrSet, virMcAddrFormat, virMacAddrIsUnicast)
(virMacAddrIsMulticast): Likewise.
* src/util/virebtables.c (ebtablesAddForwardAllowIn)
(ebtablesRemoveForwardAllowIn): Likewise.
* src/util/virsocketaddr.c (virSocketAddrMask, virMacAddrGetRaw)
(virSocketAddrMaskByPrefix, virSocketAddrBroadcast)
(virSocketAddrBroadcastByPrefix, virSocketAddrGetNumNetmaskBits)
(virSocketAddrGetIpPrefix, virSocketAddrEqual)
(virSocketAddrIsPrivate, virSocketAddrIsWildcard)
(virSocketAddrGetIPv4Addr, virSocketAddrGetIPv6Addr)
(virSocketAddrFormat, virSocketAddrFormatFull): Likewise.
Signed-off-by: Eric Blake <eblake@redhat.com>
2013-10-05 15:51:55 +00:00
|
|
|
int virBufferError(const virBuffer *buf);
|
2014-06-27 07:23:13 +00:00
|
|
|
int virBufferCheckErrorInternal(const virBuffer *buf,
|
|
|
|
int domcode,
|
|
|
|
const char *filename,
|
|
|
|
const char *funcname,
|
|
|
|
size_t linenr)
|
2017-08-16 09:09:47 +00:00
|
|
|
ATTRIBUTE_NONNULL(1);
|
2019-02-21 15:37:50 +00:00
|
|
|
|
2019-10-15 12:47:50 +00:00
|
|
|
G_DEFINE_AUTO_CLEANUP_CLEAR_FUNC(virBuffer, virBufferFreeAndReset);
|
2019-02-21 15:37:50 +00:00
|
|
|
|
2014-06-27 07:23:13 +00:00
|
|
|
/**
|
|
|
|
* virBufferCheckError
|
|
|
|
*
|
|
|
|
* Checks if the buffer is in error state and reports an error.
|
|
|
|
*
|
2014-08-23 19:57:44 +00:00
|
|
|
* Returns 0 if no error has occurred, otherwise an error is reported
|
2014-06-27 07:23:13 +00:00
|
|
|
* and -1 is returned.
|
|
|
|
*/
|
2019-06-18 16:13:08 +00:00
|
|
|
#define virBufferCheckError(buf) \
|
2014-06-27 07:23:13 +00:00
|
|
|
virBufferCheckErrorInternal(buf, VIR_FROM_THIS, __FILE__, __FUNCTION__, \
|
|
|
|
__LINE__)
|
2019-03-26 17:02:06 +00:00
|
|
|
size_t virBufferUse(const virBuffer *buf);
|
2011-09-27 19:50:03 +00:00
|
|
|
void virBufferAdd(virBufferPtr buf, const char *str, int len);
|
2015-02-19 09:56:58 +00:00
|
|
|
void virBufferAddBuffer(virBufferPtr buf, virBufferPtr toadd);
|
2011-09-27 19:50:03 +00:00
|
|
|
void virBufferAddChar(virBufferPtr buf, char c);
|
|
|
|
void virBufferAsprintf(virBufferPtr buf, const char *format, ...)
|
2019-10-15 11:35:07 +00:00
|
|
|
G_GNUC_PRINTF(2, 3);
|
2011-09-27 19:50:03 +00:00
|
|
|
void virBufferVasprintf(virBufferPtr buf, const char *format, va_list ap)
|
2019-10-15 11:35:07 +00:00
|
|
|
G_GNUC_PRINTF(2, 0);
|
2011-09-27 19:50:03 +00:00
|
|
|
void virBufferStrcat(virBufferPtr buf, ...)
|
2019-10-14 12:13:31 +00:00
|
|
|
G_GNUC_NULL_TERMINATED;
|
2017-07-24 16:54:15 +00:00
|
|
|
void virBufferStrcatVArgs(virBufferPtr buf, va_list ap);
|
|
|
|
|
2012-03-09 19:13:30 +00:00
|
|
|
void virBufferEscape(virBufferPtr buf, char escape, const char *toescape,
|
2011-09-27 19:50:03 +00:00
|
|
|
const char *format, const char *str);
|
|
|
|
void virBufferEscapeString(virBufferPtr buf, const char *format,
|
|
|
|
const char *str);
|
|
|
|
void virBufferEscapeSexpr(virBufferPtr buf, const char *format,
|
|
|
|
const char *str);
|
2017-05-12 12:26:09 +00:00
|
|
|
void virBufferEscapeRegex(virBufferPtr buf,
|
|
|
|
const char *format,
|
|
|
|
const char *str);
|
2017-10-06 06:47:34 +00:00
|
|
|
void virBufferEscapeSQL(virBufferPtr buf,
|
|
|
|
const char *format,
|
|
|
|
const char *str);
|
2011-07-28 13:25:00 +00:00
|
|
|
void virBufferEscapeShell(virBufferPtr buf, const char *str);
|
2011-09-27 19:50:03 +00:00
|
|
|
void virBufferURIEncodeString(virBufferPtr buf, const char *str);
|
2007-03-15 17:30:04 +00:00
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#define virBufferAddLit(buf_, literal_string_) \
|
2012-03-29 09:52:04 +00:00
|
|
|
virBufferAdd(buf_, "" literal_string_ "", sizeof(literal_string_) - 1)
|
2008-04-28 15:14:59 +00:00
|
|
|
|
2011-10-20 21:48:47 +00:00
|
|
|
void virBufferAdjustIndent(virBufferPtr buf, int indent);
|
2017-03-09 16:02:19 +00:00
|
|
|
void virBufferSetIndent(virBufferPtr, int indent);
|
|
|
|
|
2017-08-24 12:54:56 +00:00
|
|
|
/**
|
|
|
|
* virBufferSetChildIndent
|
|
|
|
*
|
|
|
|
* Gets the parent indentation, increments it by 2 and sets it to
|
|
|
|
* child buffer.
|
|
|
|
*/
|
2019-06-18 16:13:08 +00:00
|
|
|
#define virBufferSetChildIndent(childBuf_, parentBuf_) \
|
2018-05-11 12:05:53 +00:00
|
|
|
virBufferSetIndent(childBuf_, virBufferGetIndent(parentBuf_, false) + 2)
|
2017-08-24 12:54:56 +00:00
|
|
|
|
maint: avoid 'const fooPtr' in several util files
'const fooPtr' is the same as 'foo * const' (the pointer won't
change, but it's contents can). But in general, if an interface
is trying to be const-correct, it should be using 'const foo *'
(the pointer is to data that can't be changed).
Fix up offenders in src/util outside of the virnet namespace.
Also, make a few virSocketAddr functions const-correct, for easier
conversions in future patches.
* src/util/virbuffer.h (virBufferError, virBufferUse)
(virBufferGetIndent): Use intended type.
* src/util/virmacaddr.h (virMacAddrCmp, virMacAddrCmpRaw)
(virMacAddrSet, virMcAddrFormat, virMacAddrIsUnicast)
(virMacAddrIsMulticast): Likewise.
* src/util/virebtables.h (ebtablesAddForwardAllowIn)
(ebtablesRemoveForwardAllowIn): Likewise.
* src/util/virsocketaddr.h (virSocketAddrSetIPv4Addr): Drop
incorrect const.
(virMacAddrGetRaw, virSocketAddrFormat, virSocketAddrFormatFull):
Make const-correct.
(virSocketAddrMask, virSocketAddrMaskByPrefix)
(virSocketAddrBroadcast, virSocketAddrBroadcastByPrefix)
(virSocketAddrGetNumNetmaskBits, virSocketAddrGetIpPrefix)
(virSocketAddrEqual, virSocketAddrIsPrivate)
(virSocketAddrIsWildcard): Use intended type.
* src/util/virbuffer.c (virBufferError, virBufferUse)
(virBufferGetIndent): Fix fallout.
* src/util/virmacaddr.c (virMacAddrCmp, virMacAddrCmpRaw)
(virMacAddrSet, virMcAddrFormat, virMacAddrIsUnicast)
(virMacAddrIsMulticast): Likewise.
* src/util/virebtables.c (ebtablesAddForwardAllowIn)
(ebtablesRemoveForwardAllowIn): Likewise.
* src/util/virsocketaddr.c (virSocketAddrMask, virMacAddrGetRaw)
(virSocketAddrMaskByPrefix, virSocketAddrBroadcast)
(virSocketAddrBroadcastByPrefix, virSocketAddrGetNumNetmaskBits)
(virSocketAddrGetIpPrefix, virSocketAddrEqual)
(virSocketAddrIsPrivate, virSocketAddrIsWildcard)
(virSocketAddrGetIPv4Addr, virSocketAddrGetIPv6Addr)
(virSocketAddrFormat, virSocketAddrFormatFull): Likewise.
Signed-off-by: Eric Blake <eblake@redhat.com>
2013-10-05 15:51:55 +00:00
|
|
|
int virBufferGetIndent(const virBuffer *buf, bool dynamic);
|
2019-10-24 10:29:12 +00:00
|
|
|
size_t virBufferGetEffectiveIndent(const virBuffer *buf);
|
2011-10-20 21:48:47 +00:00
|
|
|
|
2013-06-18 15:52:00 +00:00
|
|
|
void virBufferTrim(virBufferPtr buf, const char *trim, int len);
|
2015-03-24 09:53:29 +00:00
|
|
|
void virBufferAddStr(virBufferPtr buf, const char *str);
|