]> git.proxmox.com Git - libgit2.git/blame - src/config.h
New upstream version 1.4.3+dfsg.1
[libgit2.git] / src / config.h
CommitLineData
bb742ede 1/*
359fc2d2 2 * Copyright (C) the libgit2 contributors. All rights reserved.
bb742ede
VM
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 */
6d7bb4e0
CMN
7#ifndef INCLUDE_config_h__
8#define INCLUDE_config_h__
9
eae0bfdc
PP
10#include "common.h"
11
c0335005 12#include "git2.h"
6d7bb4e0 13#include "git2/config.h"
c0335005 14#include "vector.h"
44daec42 15#include "repository.h"
6b45cb8a 16
8c7c5fa5 17#define GIT_CONFIG_FILENAME_PROGRAMDATA "config"
73b51450 18#define GIT_CONFIG_FILENAME_SYSTEM "gitconfig"
5540d947
RB
19#define GIT_CONFIG_FILENAME_GLOBAL ".gitconfig"
20#define GIT_CONFIG_FILENAME_XDG "config"
21
22#define GIT_CONFIG_FILENAME_INREPO "config"
01ad7b3a 23#define GIT_CONFIG_FILE_MODE 0666
8adbf2ed 24
5d4cd003 25struct git_config {
9462c471 26 git_refcount rc;
ac3d33df 27 git_vector backends;
5d4cd003
CMN
28};
29
e579e0f7
MB
30extern int git_config__global_location(git_str *buf);
31
32extern int git_config__find_global(git_str *path);
33extern int git_config__find_xdg(git_str *path);
34extern int git_config__find_system(git_str *path);
35extern int git_config__find_programdata(git_str *path);
a4b75dcf 36
aba70781 37extern int git_config_rename_section(
38 git_repository *repo,
39 const char *old_section_name, /* eg "branch.dummy" */
40 const char *new_section_name); /* NULL to drop the old section */
41
f4be8209
CMN
42extern int git_config__normalize_name(const char *in, char **out);
43
9f77b3f6
RB
44/* internal only: does not normalize key and sets out to NULL if not found */
45extern int git_config__lookup_entry(
9a97f49e 46 git_config_entry **out,
9f77b3f6
RB
47 const git_config *cfg,
48 const char *key,
49 bool no_errors);
50
8286300a
RB
51/* internal only: update and/or delete entry string with constraints */
52extern int git_config__update_entry(
53 git_config *cfg,
54 const char *key,
55 const char *value,
56 bool overwrite_existing,
57 bool only_if_existing);
58
e579e0f7
MB
59int git_config__get_path(
60 git_str *out,
61 const git_config *cfg,
62 const char *name);
63
64int git_config__get_string_buf(
65 git_str *out, const git_config *cfg, const char *name);
66
9f77b3f6
RB
67/*
68 * Lookup functions that cannot fail. These functions look up a config
69 * value and return a fallback value if the value is missing or if any
70 * failures occur while trying to access the value.
71 */
72
9a97f49e 73extern char *git_config__get_string_force(
9f77b3f6
RB
74 const git_config *cfg, const char *key, const char *fallback_value);
75
76extern int git_config__get_bool_force(
77 const git_config *cfg, const char *key, int fallback_value);
78
79extern int git_config__get_int_force(
80 const git_config *cfg, const char *key, int fallback_value);
f4be8209 81
22a2d3d5
UG
82/* API for repository configmap-style lookups from config - not cached, but
83 * uses configmap value maps and fallbacks
2b52a0bf 84 */
22a2d3d5
UG
85extern int git_config__configmap_lookup(
86 int *out, git_config *config, git_configmap_item item);
2b52a0bf 87
15c38103
CMN
88/**
89 * The opposite of git_config_lookup_map_value, we take an enum value
90 * and map it to the string or bool value on the config.
91 */
22a2d3d5
UG
92int git_config_lookup_map_enum(git_configmap_t *type_out,
93 const char **str_out, const git_configmap *maps,
94 size_t map_n, int enum_val);
5340d63d
CMN
95
96/**
97 * Unlock the backend with the highest priority
98 *
e579e0f7 99 * Unlocking will allow other writers to update the configuration
5340d63d
CMN
100 * file. Optionally, any changes performed since the lock will be
101 * applied to the configuration.
102 *
103 * @param cfg the configuration
104 * @param commit boolean which indicates whether to commit any changes
105 * done since locking
106 * @return 0 or an error code
107 */
108GIT_EXTERN(int) git_config_unlock(git_config *cfg, int commit);
109
5d4cd003 110#endif