2017-04-07 15:34:53 +00:00
|
|
|
/*
|
|
|
|
* virfilecache.h: file caching for data
|
|
|
|
*
|
|
|
|
* Copyright (C) 2017 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
|
|
|
|
* License along with this library. If not, see
|
|
|
|
* <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#pragma once
|
2017-04-07 15:34:53 +00:00
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#include "internal.h"
|
2017-04-07 15:34:53 +00:00
|
|
|
|
2019-06-18 16:13:08 +00:00
|
|
|
#include "virobject.h"
|
|
|
|
#include "virhash.h"
|
2017-04-07 15:34:53 +00:00
|
|
|
|
|
|
|
typedef struct _virFileCache virFileCache;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virFileCacheIsValidPtr:
|
|
|
|
* @data: data object to validate
|
|
|
|
* @priv: private data created together with cache
|
|
|
|
*
|
|
|
|
* Validates the cached data whether it needs to be refreshed
|
|
|
|
* or no.
|
|
|
|
*
|
|
|
|
* Returns *true* if it's valid or *false* if not valid.
|
|
|
|
*/
|
|
|
|
typedef bool
|
|
|
|
(*virFileCacheIsValidPtr)(void *data,
|
|
|
|
void *priv);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virFileCacheNewDataPtr:
|
|
|
|
* @name: name of the new data
|
|
|
|
* @priv: private data created together with cache
|
|
|
|
*
|
|
|
|
* Creates a new data based on the @name. The returned data must be
|
|
|
|
* an instance of virObject.
|
|
|
|
*
|
|
|
|
* Returns data object or NULL on error.
|
|
|
|
*/
|
|
|
|
typedef void *
|
|
|
|
(*virFileCacheNewDataPtr)(const char *name,
|
|
|
|
void *priv);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virFileCacheLoadFilePtr:
|
|
|
|
* @filename: name of a file with cached data
|
|
|
|
* @name: name of the cached data
|
|
|
|
* @priv: private data created together with cache
|
2020-06-18 13:44:16 +00:00
|
|
|
* @outdated: set to true if data was outdated
|
2017-04-07 15:34:53 +00:00
|
|
|
*
|
2020-06-18 13:44:16 +00:00
|
|
|
* Loads the cached data from a file @filename. If
|
|
|
|
* NULL is returned, then @oudated indicates whether
|
|
|
|
* this was due to the data being outdated, or an
|
|
|
|
* error loading the cache.
|
2017-04-07 15:34:53 +00:00
|
|
|
*
|
2020-06-18 13:44:16 +00:00
|
|
|
* Returns cached data object or NULL on outdated data or error.
|
2017-04-07 15:34:53 +00:00
|
|
|
*/
|
|
|
|
typedef void *
|
|
|
|
(*virFileCacheLoadFilePtr)(const char *filename,
|
|
|
|
const char *name,
|
2020-06-18 13:44:16 +00:00
|
|
|
void *priv,
|
|
|
|
bool *outdated);
|
2017-04-07 15:34:53 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* virFileCacheSaveFilePtr:
|
|
|
|
* @data: data object to save into a file
|
|
|
|
* @filename: name of the file where to store the cached data
|
|
|
|
* @priv: private data created together with cache
|
|
|
|
*
|
|
|
|
* Stores the cached to a file @filename.
|
|
|
|
*
|
|
|
|
* Returns 0 on success, -1 on error.
|
|
|
|
*/
|
|
|
|
typedef int
|
|
|
|
(*virFileCacheSaveFilePtr)(void *data,
|
|
|
|
const char *filename,
|
|
|
|
void *priv);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* virFileCachePrivFreePtr:
|
|
|
|
* @priv: private data created together with cache
|
|
|
|
*
|
|
|
|
* This is used to free the private data when the cache object
|
|
|
|
* is removed.
|
|
|
|
*/
|
|
|
|
typedef void
|
|
|
|
(*virFileCachePrivFreePtr)(void *priv);
|
|
|
|
|
|
|
|
typedef struct _virFileCacheHandlers virFileCacheHandlers;
|
|
|
|
struct _virFileCacheHandlers {
|
|
|
|
virFileCacheIsValidPtr isValid;
|
|
|
|
virFileCacheNewDataPtr newData;
|
|
|
|
virFileCacheLoadFilePtr loadFile;
|
|
|
|
virFileCacheSaveFilePtr saveFile;
|
|
|
|
virFileCachePrivFreePtr privFree;
|
|
|
|
};
|
|
|
|
|
2021-03-11 07:16:13 +00:00
|
|
|
virFileCache *
|
2017-04-07 15:34:53 +00:00
|
|
|
virFileCacheNew(const char *dir,
|
|
|
|
const char *suffix,
|
|
|
|
virFileCacheHandlers *handlers);
|
|
|
|
|
|
|
|
void *
|
2021-03-11 07:16:13 +00:00
|
|
|
virFileCacheLookup(virFileCache *cache,
|
2017-04-07 15:34:53 +00:00
|
|
|
const char *name);
|
|
|
|
|
|
|
|
void *
|
2021-03-11 07:16:13 +00:00
|
|
|
virFileCacheLookupByFunc(virFileCache *cache,
|
2017-04-07 15:34:53 +00:00
|
|
|
virHashSearcher iter,
|
|
|
|
const void *iterData);
|
|
|
|
|
|
|
|
void *
|
2021-03-11 07:16:13 +00:00
|
|
|
virFileCacheGetPriv(virFileCache *cache);
|
2017-04-07 15:34:53 +00:00
|
|
|
|
|
|
|
void
|
2021-03-11 07:16:13 +00:00
|
|
|
virFileCacheSetPriv(virFileCache *cache,
|
2017-04-07 15:34:53 +00:00
|
|
|
void *priv);
|
|
|
|
|
|
|
|
int
|
2021-03-11 07:16:13 +00:00
|
|
|
virFileCacheInsertData(virFileCache *cache,
|
2017-04-07 15:34:53 +00:00
|
|
|
const char *name,
|
|
|
|
void *data);
|