File Coverage

deps/libgit2/src/config_backend.h
Criterion Covered Total %
statement 0 10 0.0
branch 0 2 0.0
condition n/a
subroutine n/a
pod n/a
total 0 12 0.0


line stmt bran cond sub pod time code
1             /*
2             * Copyright (C) the libgit2 contributors. All rights reserved.
3             *
4             * This file is part of libgit2, distributed under the GNU GPL v2 with
5             * a Linking Exception. For full terms see the included COPYING file.
6             */
7             #ifndef INCLUDE_config_file_h__
8             #define INCLUDE_config_file_h__
9              
10             #include "common.h"
11              
12             #include "git2/sys/config.h"
13             #include "git2/config.h"
14              
15             /**
16             * Create a configuration file backend for ondisk files
17             *
18             * These are the normal `.gitconfig` files that Core Git
19             * processes. Note that you first have to add this file to a
20             * configuration object before you can query it for configuration
21             * variables.
22             *
23             * @param out the new backend
24             * @param path where the config file is located
25             */
26             extern int git_config_backend_from_file(git_config_backend **out, const char *path);
27              
28             /**
29             * Create a readonly configuration file backend from another backend
30             *
31             * This copies the complete contents of the source backend to the
32             * new backend. The new backend will be completely read-only and
33             * cannot be modified.
34             *
35             * @param out the new snapshotted backend
36             * @param source the backend to copy
37             */
38             extern int git_config_backend_snapshot(git_config_backend **out, git_config_backend *source);
39              
40             /**
41             * Create an in-memory configuration file backend
42             *
43             * @param out the new backend
44             * @param cfg the configuration that is to be parsed
45             * @param len the length of the string pointed to by `cfg`
46             */
47             extern int git_config_backend_from_string(git_config_backend **out, const char *cfg, size_t len);
48              
49 0           GIT_INLINE(int) git_config_backend_open(git_config_backend *cfg, unsigned int level, const git_repository *repo)
50             {
51 0           return cfg->open(cfg, level, repo);
52             }
53              
54 0           GIT_INLINE(void) git_config_backend_free(git_config_backend *cfg)
55             {
56 0 0         if (cfg)
57 0           cfg->free(cfg);
58 0           }
59              
60             GIT_INLINE(int) git_config_backend_get_string(
61             git_config_entry **out, git_config_backend *cfg, const char *name)
62             {
63             return cfg->get(cfg, name, out);
64             }
65              
66 0           GIT_INLINE(int) git_config_backend_set_string(
67             git_config_backend *cfg, const char *name, const char *value)
68             {
69 0           return cfg->set(cfg, name, value);
70             }
71              
72 0           GIT_INLINE(int) git_config_backend_delete(
73             git_config_backend *cfg, const char *name)
74             {
75 0           return cfg->del(cfg, name);
76             }
77              
78             GIT_INLINE(int) git_config_backend_foreach(
79             git_config_backend *cfg,
80             int (*fn)(const git_config_entry *entry, void *data),
81             void *data)
82             {
83             return git_config_backend_foreach_match(cfg, NULL, fn, data);
84             }
85              
86             GIT_INLINE(int) git_config_backend_lock(git_config_backend *cfg)
87             {
88             return cfg->lock(cfg);
89             }
90              
91             GIT_INLINE(int) git_config_backend_unlock(git_config_backend *cfg, int success)
92             {
93             return cfg->unlock(cfg, success);
94             }
95              
96             #endif