/usr/include/elektra/kdbproposal.h is in libelektra-dev 0.8.14-5.1ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 | /***************************************************************************
* kdbproposal.h - Proposed declarations
*
* Do not use them if avoidable, they are likely not API/ABI stable.
*
* -------------------
* begin : Sun 08 Dec, 2013
* copyright : (C) 2013 by Markus Raab
* email : elektra@markus-raab.org
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the BSD License (revised). *
* *
***************************************************************************/
#ifndef KDBPROPOSAL_H
#define KDBPROPOSAL_H
#include <kdb.h>
#ifdef __cplusplus
namespace ckdb {
extern "C" {
#endif
// can be made simply without elektra's internals, so better keep it as
// extension.
ssize_t keySetStringF(Key *key, const char *format, ...);
// could also be in an array extension library.
int elektraArrayIncName(Key *key);
int elektraKsToMemArray(KeySet *ks, Key **buffer);
int elektraKsFilter (KeySet *result, KeySet *input, int (*filter) (const Key *k, void *argument), void *argument);
KeySet* elektraRenameKeys(KeySet *config, const char* name);
/**
* @brief Lock options
*
* @ingroup proposal
*/
enum elektraLockOptions
{
KEY_LOCK_NAME=1<<17,
KEY_LOCK_VALUE=1<<18,
KEY_LOCK_META=1<<19
};
/**
* @brief More lookup options
*
* @ingroup proposal
*/
enum elektraLookupOptions
{
KDB_O_SPEC=1<<15, ///< Use the passed key as specification, instead of looking up the specification first
KDB_O_CREATE=1<<16, ///< Create the key if it was not found
KDB_O_NOCASCADING=1<<17, ///< Disable cascading search for keys starting with /
KDB_O_NOSPEC=1<<18, ///< Do not use specification for cascading keys (internal)
KDB_O_NODEFAULT=1<<19, ///< Do not honor the default spec (internal)
KDB_O_CALLBACK=1<<20 ///< For spec/ lookups that traverse deeper into hierarchy (callback in ksLookup())
};
/**
* Elektra currently supported Key namespaces.
*
* @ingroup proposal
* @see kdbGet(), keyGetNamespace()
*/
typedef enum
{
KEY_NS_NONE=0, ///< no key given as parameter to keyGetNamespace()
KEY_NS_EMPTY=1, ///< key name was empty, e.g. invalid key name
KEY_NS_META=2, ///< meta key, i.e. any key name not under other categories
KEY_NS_CASCADING=3, ///< cascading key, starts with /, abstract name for any of the namespaces below
KEY_NS_FIRST=4, ///< For iteration over namespaces (first element, inclusive)
KEY_NS_SPEC=4, ///< spec contains the specification of the other namespaces
KEY_NS_PROC=5, ///< proc contains process-specific configuration
KEY_NS_DIR=6, ///< dir contains configuration from a specific directory
KEY_NS_USER=7, ///< user key in the home directory of the current user
KEY_NS_SYSTEM=8, ///< system key is shared for a computer system
KEY_NS_LAST=8 ///< For iteration over namespaces (last element, inclusive)
} elektraNamespace;
elektraNamespace keyGetNamespace(Key const* key);
// locks a key, is this needed externally?
int keyLock(Key *key,
/*option_t*/ enum elektraLockOptions lock);
// this might become the new keySetName
ssize_t elektraKeySetName(Key *key, const char *newName,
option_t options);
KeySet *elektraArrayGet(const Key *arrayParent, KeySet *keys);
Key *elektraArrayGetNextKey(KeySet *arrayKeys);
KeySet *elektraKeyGetMetaKeySet(const Key *key);
Key *ksPrev(KeySet *ks);
Key *ksPopAtCursor(KeySet *ks, cursor_t c);
#ifdef __cplusplus
}
}
#endif
#endif
|