2012-01-02 15:03:19 -07:00
|
|
|
/*
|
|
|
|
* virtypedparam.h: managing typed parameters
|
|
|
|
*
|
|
|
|
* Copyright (C) 2011-2012 Red Hat, Inc.
|
|
|
|
*
|
|
|
|
* 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 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 18:06:23 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2012-01-02 15:03:19 -07:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-06-18 11:13:08 -05:00
|
|
|
#pragma once
|
2012-01-02 15:03:19 -07:00
|
|
|
|
2019-06-18 11:13:08 -05:00
|
|
|
#include "internal.h"
|
|
|
|
#include "virenum.h"
|
2012-01-02 15:03:19 -07:00
|
|
|
|
2015-06-16 01:42:06 +03:00
|
|
|
/**
|
|
|
|
* VIR_TYPED_PARAM_MULTIPLE:
|
|
|
|
*
|
|
|
|
* Flag indicating that the params has multiple occurrences of the parameter.
|
|
|
|
* Only used as a flag for @type argument of the virTypedParamsValidate.
|
|
|
|
*/
|
2019-06-18 11:13:08 -05:00
|
|
|
#define VIR_TYPED_PARAM_MULTIPLE (1U << 31)
|
2015-06-16 01:42:06 +03:00
|
|
|
|
2020-01-09 10:39:55 +00:00
|
|
|
G_STATIC_ASSERT(!(VIR_TYPED_PARAM_LAST & VIR_TYPED_PARAM_MULTIPLE));
|
2015-06-16 01:42:06 +03:00
|
|
|
|
2016-02-02 15:33:30 +01:00
|
|
|
typedef struct _virTypedParameterRemoteValue virTypedParameterRemoteValue;
|
|
|
|
struct _virTypedParameterRemoteValue {
|
|
|
|
int type;
|
|
|
|
union {
|
|
|
|
int i; /* exempt from syntax-check */
|
|
|
|
unsigned int ui;
|
|
|
|
long long int l;
|
|
|
|
unsigned long long int ul;
|
|
|
|
double d;
|
|
|
|
char b;
|
|
|
|
char *s;
|
|
|
|
} remote_typed_param_value;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct _virTypedParameterRemote {
|
|
|
|
char *field;
|
|
|
|
virTypedParameterRemoteValue value;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-05-03 15:34:10 +02:00
|
|
|
int virTypedParamsValidate(virTypedParameterPtr params, int nparams,
|
|
|
|
/* const char *name, int type ... */ ...)
|
2019-10-14 14:25:14 +02:00
|
|
|
G_GNUC_NULL_TERMINATED G_GNUC_WARN_UNUSED_RESULT;
|
2012-01-02 15:03:19 -07:00
|
|
|
|
2013-05-06 12:04:06 +02:00
|
|
|
bool virTypedParamsCheck(virTypedParameterPtr params,
|
|
|
|
int nparams,
|
|
|
|
const char **names,
|
|
|
|
int nnames);
|
|
|
|
|
2015-06-16 01:42:08 +03:00
|
|
|
int
|
|
|
|
virTypedParamsGetStringList(virTypedParameterPtr params,
|
|
|
|
int nparams,
|
|
|
|
const char *name,
|
|
|
|
const char ***values);
|
|
|
|
int
|
|
|
|
virTypedParamsFilter(virTypedParameterPtr params,
|
|
|
|
int nparams,
|
|
|
|
const char *name,
|
|
|
|
virTypedParameterPtr **ret)
|
2019-10-14 14:25:14 +02:00
|
|
|
G_GNUC_WARN_UNUSED_RESULT;
|
2015-06-16 01:42:08 +03:00
|
|
|
|
|
|
|
|
2012-01-02 15:03:19 -07:00
|
|
|
int virTypedParameterAssign(virTypedParameterPtr param, const char *name,
|
2012-03-09 08:20:20 -07:00
|
|
|
int type, /* TYPE arg */ ...)
|
2019-10-14 14:25:14 +02:00
|
|
|
G_GNUC_WARN_UNUSED_RESULT;
|
2012-01-02 15:03:19 -07:00
|
|
|
|
2013-05-21 15:11:56 +02:00
|
|
|
int virTypedParamsReplaceString(virTypedParameterPtr *params,
|
|
|
|
int *nparams,
|
|
|
|
const char *name,
|
|
|
|
const char *value);
|
|
|
|
|
2013-06-07 16:34:13 +02:00
|
|
|
int virTypedParamsCopy(virTypedParameterPtr *dst,
|
|
|
|
virTypedParameterPtr src,
|
|
|
|
int nparams);
|
|
|
|
|
2013-06-06 18:54:48 +02:00
|
|
|
char *virTypedParameterToString(virTypedParameterPtr param);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virTypedParamsRemoteFree(struct _virTypedParameterRemote *remote_params_val,
|
2016-02-02 13:19:35 +01:00
|
|
|
unsigned int remote_params_len);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamsDeserialize(struct _virTypedParameterRemote *remote_params,
|
2016-01-28 17:27:42 +01:00
|
|
|
unsigned int remote_params_len,
|
|
|
|
int limit,
|
|
|
|
virTypedParameterPtr *params,
|
|
|
|
int *nparams);
|
|
|
|
|
2016-02-02 14:13:15 +01:00
|
|
|
int virTypedParamsSerialize(virTypedParameterPtr params,
|
|
|
|
int nparams,
|
2019-08-27 10:57:49 +02:00
|
|
|
int limit,
|
2021-03-11 08:16:13 +01:00
|
|
|
struct _virTypedParameterRemote **remote_params_val,
|
2016-02-02 14:13:15 +01:00
|
|
|
unsigned int *remote_params_len,
|
|
|
|
unsigned int flags);
|
|
|
|
|
2019-01-20 11:04:56 -05:00
|
|
|
VIR_ENUM_DECL(virTypedParameter);
|
2013-06-06 18:54:48 +02:00
|
|
|
|
2019-06-18 11:13:08 -05:00
|
|
|
#define VIR_TYPED_PARAMS_DEBUG(params, nparams) \
|
2017-11-03 13:09:47 +01:00
|
|
|
do { \
|
|
|
|
int _i; \
|
|
|
|
if (!params) \
|
|
|
|
break; \
|
|
|
|
for (_i = 0; _i < (nparams); _i++) { \
|
|
|
|
char *_value = virTypedParameterToString((params) + _i); \
|
|
|
|
VIR_DEBUG("params[\"%s\"]=(%s)%s", \
|
|
|
|
(params)[_i].field, \
|
|
|
|
virTypedParameterTypeToString((params)[_i].type), \
|
|
|
|
NULLSTR(_value)); \
|
|
|
|
VIR_FREE(_value); \
|
|
|
|
} \
|
2013-06-06 18:54:48 +02:00
|
|
|
} while (0)
|
2019-09-19 09:20:49 +02:00
|
|
|
|
|
|
|
typedef struct _virTypedParamList virTypedParamList;
|
|
|
|
struct _virTypedParamList {
|
|
|
|
virTypedParameterPtr par;
|
|
|
|
size_t npar;
|
|
|
|
size_t par_alloc;
|
|
|
|
};
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virTypedParamListFree(virTypedParamList *list);
|
2019-10-15 14:47:50 +02:00
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virTypedParamList, virTypedParamListFree);
|
2019-09-19 09:20:49 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
size_t virTypedParamListStealParams(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
virTypedParameterPtr *params);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddInt(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
int value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddUInt(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
unsigned int value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddLLong(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
long long value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddULLong(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
unsigned long long value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddString(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
const char *value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddBoolean(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
bool value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|
2021-03-11 08:16:13 +01:00
|
|
|
int virTypedParamListAddDouble(virTypedParamList *list,
|
2019-09-19 09:20:49 +02:00
|
|
|
double value,
|
|
|
|
const char *namefmt,
|
|
|
|
...)
|
2019-10-15 13:35:07 +02:00
|
|
|
G_GNUC_PRINTF(3, 4) G_GNUC_WARN_UNUSED_RESULT;
|