diff --git a/src/libvirt_private.syms b/src/libvirt_private.syms index 5914769acfc7a35b587c8fa357e291b9eba9bfc8..4a0acdf90b02e2aa1bc55984e06b2d8b59556a94 100644 --- a/src/libvirt_private.syms +++ b/src/libvirt_private.syms @@ -1870,6 +1870,7 @@ virLockSpaceReleaseResourcesForOwner; # util/virlog.h virLogDefineFilter; +virLogDefineFilters; virLogDefineOutput; virLogDefineOutputs; virLogFilterFree; diff --git a/src/util/virlog.c b/src/util/virlog.c index 5543a11350608e45606ba598021e682637615871..b087137c69528829c9f201ec4438fc7819fcf2d5 100644 --- a/src/util/virlog.c +++ b/src/util/virlog.c @@ -1706,3 +1706,30 @@ virLogDefineOutputs(virLogOutputPtr *outputs, size_t noutputs) return 0; } + + +/** + * virLogDefineFilters: + * @filters: new set of filters to be defined + * @nfilters: number of filters in @filters + * + * Resets any existing set of filters and defines a completely new one. The + * resulting set can also be empty in which case NULL should be passed to + * @filters. + * + * Returns 0 on success or -1 in case of error. + */ +int +virLogDefineFilters(virLogFilterPtr *filters, size_t nfilters) +{ + if (virLogInitialize() < 0) + return -1; + + virLogLock(); + virLogResetFilters(); + virLogFilters = filters; + virLogNbFilters = nfilters; + virLogUnlock(); + + return 0; +} diff --git a/src/util/virlog.h b/src/util/virlog.h index 3c4cd556e240e6c487de3806bb63a8443d72a766..d6d65bad875cd9fa655e71b7cd7520525372dc34 100644 --- a/src/util/virlog.h +++ b/src/util/virlog.h @@ -239,5 +239,6 @@ int virLogFindOutput(virLogOutputPtr *outputs, size_t noutputs, virLogDestination dest, const void *opaque); int virLogDefineOutputs(virLogOutputPtr *outputs, size_t noutputs) ATTRIBUTE_NONNULL(1); +int virLogDefineFilters(virLogFilterPtr *filters, size_t nfilters); #endif