Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
git2
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
git2
Commits
2bcc1afd
Commit
2bcc1afd
authored
May 14, 2014
by
Vicent Marti
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2349 from libgit2/rb/coverity-fixes
Increase config snapshot usage
parents
a8af3e02
2b52a0bf
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
93 additions
and
73 deletions
+93
-73
src/attrcache.c
+7
-4
src/config.c
+6
-6
src/config.h
+6
-0
src/config_cache.c
+24
-18
src/config_file.c
+5
-3
src/diff.c
+10
-9
src/diff_driver.c
+5
-5
src/refdb_fs.c
+6
-10
src/repository.c
+12
-12
src/repository.h
+4
-0
src/tag.c
+8
-6
No files found.
src/attrcache.c
View file @
2bcc1afd
...
...
@@ -349,14 +349,11 @@ int git_attr_cache__do_init(git_repository *repo)
{
int
ret
=
0
;
git_attr_cache
*
cache
=
git_repository_attr_cache
(
repo
);
git_config
*
cfg
;
git_config
*
cfg
=
NULL
;
if
(
cache
)
return
0
;
if
((
ret
=
git_repository_config__weakptr
(
&
cfg
,
repo
))
<
0
)
return
ret
;
cache
=
git__calloc
(
1
,
sizeof
(
git_attr_cache
));
GITERR_CHECK_ALLOC
(
cache
);
...
...
@@ -367,6 +364,9 @@ int git_attr_cache__do_init(git_repository *repo)
return
-
1
;
}
if
((
ret
=
git_repository_config_snapshot
(
&
cfg
,
repo
))
<
0
)
goto
cancel
;
/* cache config settings for attributes and ignores */
ret
=
attr_cache__lookup_path
(
&
cache
->
cfg_attr_file
,
cfg
,
GIT_ATTR_CONFIG
,
GIT_ATTR_FILE_XDG
);
...
...
@@ -390,11 +390,14 @@ int git_attr_cache__do_init(git_repository *repo)
if
(
cache
)
goto
cancel
;
/* raced with another thread, free this but no error */
git_config_free
(
cfg
);
/* insert default macros */
return
git_attr_add_macro
(
repo
,
"binary"
,
"-diff -crlf -text"
);
cancel
:
attr_cache__free
(
cache
);
git_config_free
(
cfg
);
return
ret
;
}
...
...
src/config.c
View file @
2bcc1afd
...
...
@@ -153,19 +153,19 @@ int git_config_snapshot(git_config **out, git_config *in)
git_config_backend
*
b
;
if
((
error
=
internal
->
file
->
snapshot
(
&
b
,
internal
->
file
))
<
0
)
goto
on_error
;
break
;
if
((
error
=
git_config_add_backend
(
config
,
b
,
internal
->
level
,
0
))
<
0
)
{
b
->
free
(
b
);
goto
on_error
;
break
;
}
}
*
out
=
config
;
return
error
;
if
(
error
<
0
)
git_config_free
(
config
);
else
*
out
=
config
;
on_error:
git_config_free
(
config
);
return
error
;
}
...
...
src/config.h
View file @
2bcc1afd
...
...
@@ -76,4 +76,10 @@ extern int git_config__get_bool_force(
extern
int
git_config__get_int_force
(
const
git_config
*
cfg
,
const
char
*
key
,
int
fallback_value
);
/* API for repository cvar-style lookups from config - not cached, but
* uses cvar value maps and fallbacks
*/
extern
int
git_config__cvar
(
int
*
out
,
git_config
*
config
,
git_cvar_cached
cvar
);
#endif
src/config_cache.c
View file @
2bcc1afd
...
...
@@ -7,11 +7,11 @@
#include "common.h"
#include "fileops.h"
#include "repository.h"
#include "config.h"
#include "git2/config.h"
#include "vector.h"
#include "filter.h"
#include "repository.h"
struct
map_data
{
const
char
*
cvar_name
;
...
...
@@ -69,32 +69,38 @@ static struct map_data _cvar_maps[] = {
{
"core.abbrev"
,
_cvar_map_int
,
1
,
GIT_ABBREV_DEFAULT
},
{
"core.precomposeunicode"
,
NULL
,
0
,
GIT_PRECOMPOSE_DEFAULT
},
{
"core.safecrlf"
,
NULL
,
0
,
GIT_SAFE_CRLF_DEFAULT
},
{
"core.logallrefupdates"
,
NULL
,
0
,
GIT_LOGALLREFUPDATES_DEFAULT
},
};
int
git_config__cvar
(
int
*
out
,
git_config
*
config
,
git_cvar_cached
cvar
)
{
int
error
=
0
;
struct
map_data
*
data
=
&
_cvar_maps
[(
int
)
cvar
];
const
git_config_entry
*
entry
;
git_config__lookup_entry
(
&
entry
,
config
,
data
->
cvar_name
,
false
);
if
(
!
entry
)
*
out
=
data
->
default_value
;
else
if
(
data
->
maps
)
error
=
git_config_lookup_map_value
(
out
,
data
->
maps
,
data
->
map_count
,
entry
->
value
);
else
error
=
git_config_parse_bool
(
out
,
entry
->
value
);
return
error
;
}
int
git_repository__cvar
(
int
*
out
,
git_repository
*
repo
,
git_cvar_cached
cvar
)
{
*
out
=
repo
->
cvar_cache
[(
int
)
cvar
];
if
(
*
out
==
GIT_CVAR_NOT_CACHED
)
{
struct
map_data
*
data
=
&
_cvar_maps
[(
int
)
cvar
];
git_config
*
config
;
int
error
;
const
git_config_entry
*
entry
;
if
((
error
=
git_repository_config__weakptr
(
&
config
,
repo
))
<
0
)
return
error
;
git_config__lookup_entry
(
&
entry
,
config
,
data
->
cvar_name
,
false
);
if
(
!
entry
)
*
out
=
data
->
default_value
;
else
if
(
data
->
maps
)
error
=
git_config_lookup_map_value
(
out
,
data
->
maps
,
data
->
map_count
,
entry
->
value
);
else
error
=
git_config_parse_bool
(
out
,
entry
->
value
);
git_config
*
config
;
if
(
error
<
0
)
if
((
error
=
git_repository_config__weakptr
(
&
config
,
repo
))
<
0
||
(
error
=
git_config__cvar
(
out
,
config
,
cvar
))
<
0
)
return
error
;
repo
->
cvar_cache
[(
int
)
cvar
]
=
*
out
;
...
...
src/config_file.c
View file @
2bcc1afd
...
...
@@ -313,6 +313,7 @@ static int config__refresh(git_config_backend *cfg)
goto
out
;
reader
=
git_array_get
(
b
->
readers
,
git_array_size
(
b
->
readers
)
-
1
);
GITERR_CHECK_ALLOC
(
reader
);
if
((
error
=
config_parse
(
values
->
values
,
b
,
reader
,
b
->
level
,
0
))
<
0
)
goto
out
;
...
...
@@ -327,7 +328,8 @@ static int config__refresh(git_config_backend *cfg)
out:
refcounted_strmap_free
(
values
);
git_buf_free
(
&
reader
->
buffer
);
if
(
reader
)
git_buf_free
(
&
reader
->
buffer
);
return
error
;
}
...
...
@@ -344,8 +346,8 @@ static int config_refresh(git_config_backend *cfg)
&
reader
->
buffer
,
reader
->
file_path
,
&
reader
->
file_mtime
,
&
reader
->
file_size
,
&
updated
);
if
(
error
<
0
)
return
(
error
==
GIT_ENOTFOUND
)
?
0
:
error
;
if
(
error
<
0
&&
error
!=
GIT_ENOTFOUND
)
return
error
;
if
(
updated
)
any_updated
=
1
;
...
...
src/diff.c
View file @
2bcc1afd
...
...
@@ -381,7 +381,7 @@ static int diff_list_apply_options(
git_diff
*
diff
,
const
git_diff_options
*
opts
)
{
git_config
*
cfg
;
git_config
*
cfg
=
NULL
;
git_repository
*
repo
=
diff
->
repo
;
git_pool
*
pool
=
&
diff
->
pool
;
int
val
;
...
...
@@ -406,20 +406,20 @@ static int diff_list_apply_options(
diff
->
opts
.
flags
|=
GIT_DIFF_INCLUDE_UNTRACKED
;
/* load config values that affect diff behavior */
if
((
val
=
git_repository_config_
_weakptr
(
&
cfg
,
repo
))
<
0
)
if
((
val
=
git_repository_config_
snapshot
(
&
cfg
,
repo
))
<
0
)
return
val
;
if
(
!
git_
repository__cvar
(
&
val
,
repo
,
GIT_CVAR_SYMLINKS
)
&&
val
)
if
(
!
git_
config__cvar
(
&
val
,
cfg
,
GIT_CVAR_SYMLINKS
)
&&
val
)
diff
->
diffcaps
=
diff
->
diffcaps
|
GIT_DIFFCAPS_HAS_SYMLINKS
;
if
(
!
git_
repository__cvar
(
&
val
,
repo
,
GIT_CVAR_IGNORESTAT
)
&&
val
)
if
(
!
git_
config__cvar
(
&
val
,
cfg
,
GIT_CVAR_IGNORESTAT
)
&&
val
)
diff
->
diffcaps
=
diff
->
diffcaps
|
GIT_DIFFCAPS_IGNORE_STAT
;
if
((
diff
->
opts
.
flags
&
GIT_DIFF_IGNORE_FILEMODE
)
==
0
&&
!
git_
repository__cvar
(
&
val
,
repo
,
GIT_CVAR_FILEMODE
)
&&
val
)
!
git_
config__cvar
(
&
val
,
cfg
,
GIT_CVAR_FILEMODE
)
&&
val
)
diff
->
diffcaps
=
diff
->
diffcaps
|
GIT_DIFFCAPS_TRUST_MODE_BITS
;
if
(
!
git_
repository__cvar
(
&
val
,
repo
,
GIT_CVAR_TRUSTCTIME
)
&&
val
)
if
(
!
git_
config__cvar
(
&
val
,
cfg
,
GIT_CVAR_TRUSTCTIME
)
&&
val
)
diff
->
diffcaps
=
diff
->
diffcaps
|
GIT_DIFFCAPS_TRUST_CTIME
;
/* Don't set GIT_DIFFCAPS_USE_DEV - compile time option in core git */
...
...
@@ -481,8 +481,6 @@ static int diff_list_apply_options(
/* strdup prefix from pool so we're not dependent on external data */
diff
->
opts
.
old_prefix
=
diff_strdup_prefix
(
pool
,
diff
->
opts
.
old_prefix
);
diff
->
opts
.
new_prefix
=
diff_strdup_prefix
(
pool
,
diff
->
opts
.
new_prefix
);
if
(
!
diff
->
opts
.
old_prefix
||
!
diff
->
opts
.
new_prefix
)
return
-
1
;
if
(
DIFF_FLAG_IS_SET
(
diff
,
GIT_DIFF_REVERSE
))
{
const
char
*
tmp_prefix
=
diff
->
opts
.
old_prefix
;
...
...
@@ -490,7 +488,10 @@ static int diff_list_apply_options(
diff
->
opts
.
new_prefix
=
tmp_prefix
;
}
return
0
;
git_config_free
(
cfg
);
/* check strdup results for error */
return
(
!
diff
->
opts
.
old_prefix
||
!
diff
->
opts
.
new_prefix
)
?
-
1
:
0
;
}
static
void
diff_list_free
(
git_diff
*
diff
)
...
...
src/diff_driver.c
View file @
2bcc1afd
...
...
@@ -233,17 +233,17 @@ static int git_diff_driver_load(
return
0
;
}
drv
=
git__calloc
(
1
,
sizeof
(
git_diff_driver
)
+
namelen
+
1
);
GITERR_CHECK_ALLOC
(
drv
);
drv
->
type
=
DIFF_DRIVER_AUTO
;
memcpy
(
drv
->
name
,
driver_name
,
namelen
);
/* if you can't read config for repo, just use default driver */
if
(
git_repository_config_snapshot
(
&
cfg
,
repo
)
<
0
)
{
giterr_clear
();
goto
done
;
}
drv
=
git__calloc
(
1
,
sizeof
(
git_diff_driver
)
+
namelen
+
1
);
GITERR_CHECK_ALLOC
(
drv
);
drv
->
type
=
DIFF_DRIVER_AUTO
;
memcpy
(
drv
->
name
,
driver_name
,
namelen
);
if
((
error
=
git_buf_printf
(
&
name
,
"diff.%s.binary"
,
driver_name
))
<
0
)
goto
done
;
...
...
src/refdb_fs.c
View file @
2bcc1afd
...
...
@@ -927,19 +927,15 @@ static int has_reflog(git_repository *repo, const char *name);
/* We only write if it's under heads/, remotes/ or notes/ or if it already has a log */
static
int
should_write_reflog
(
int
*
write
,
git_repository
*
repo
,
const
char
*
name
)
{
git_config
*
config
;
int
error
,
logall
,
is_bare
;
int
error
,
logall
;
/* Defaults to the opposite of the repo being bare */
is_bare
=
git_repository_is_bare
(
repo
);
logall
=
!
is_bare
;
if
((
error
=
git_repository_config__weakptr
(
&
config
,
repo
))
<
0
)
error
=
git_repository__cvar
(
&
logall
,
repo
,
GIT_CVAR_LOGALLREFUPDATES
);
if
(
error
<
0
)
return
error
;
error
=
git_config_get_bool
(
&
logall
,
config
,
"core.logallrefupdates"
);
if
(
error
<
0
&&
error
!=
GIT_ENOTFOUND
)
return
error
;
/* Defaults to the opposite of the repo being bare */
if
(
logall
==
GIT_LOGALLREFUPDATES_UNSET
)
logall
=
!
git_repository_is_bare
(
repo
)
;
if
(
!
logall
)
{
*
write
=
0
;
...
...
src/repository.c
View file @
2bcc1afd
...
...
@@ -443,7 +443,6 @@ int git_repository_open_ext(
int
error
;
git_buf
path
=
GIT_BUF_INIT
,
parent
=
GIT_BUF_INIT
;
git_repository
*
repo
;
git_config
*
config
;
if
(
repo_ptr
)
*
repo_ptr
=
NULL
;
...
...
@@ -458,23 +457,24 @@ int git_repository_open_ext(
repo
->
path_repository
=
git_buf_detach
(
&
path
);
GITERR_CHECK_ALLOC
(
repo
->
path_repository
);
if
((
error
=
git_repository_config_snapshot
(
&
config
,
repo
))
<
0
)
return
error
;
if
((
flags
&
GIT_REPOSITORY_OPEN_BARE
)
!=
0
)
repo
->
is_bare
=
1
;
else
if
((
error
=
load_config_data
(
repo
,
config
))
<
0
||
(
error
=
load_workdir
(
repo
,
config
,
&
parent
))
<
0
)
{
else
{
git_config
*
config
=
NULL
;
if
((
error
=
git_repository_config_snapshot
(
&
config
,
repo
))
<
0
||
(
error
=
load_config_data
(
repo
,
config
))
<
0
||
(
error
=
load_workdir
(
repo
,
config
,
&
parent
))
<
0
)
git_repository_free
(
repo
);
git_config_free
(
config
);
git_repository_free
(
repo
);
return
error
;
}
git_config_free
(
config
);
if
(
!
error
)
*
repo_ptr
=
repo
;
git_buf_free
(
&
parent
);
*
repo_ptr
=
repo
;
return
0
;
return
error
;
}
int
git_repository_open
(
git_repository
**
repo_out
,
const
char
*
path
)
...
...
src/repository.h
View file @
2bcc1afd
...
...
@@ -39,6 +39,7 @@ typedef enum {
GIT_CVAR_ABBREV
,
/* core.abbrev */
GIT_CVAR_PRECOMPOSE
,
/* core.precomposeunicode */
GIT_CVAR_SAFE_CRLF
,
/* core.safecrlf */
GIT_CVAR_LOGALLREFUPDATES
,
/* core.logallrefupdates */
GIT_CVAR_CACHE_MAX
}
git_cvar_cached
;
...
...
@@ -92,6 +93,9 @@ typedef enum {
GIT_PRECOMPOSE_DEFAULT
=
GIT_CVAR_FALSE
,
/* core.safecrlf */
GIT_SAFE_CRLF_DEFAULT
=
GIT_CVAR_FALSE
,
/* core.logallrefupdates */
GIT_LOGALLREFUPDATES_UNSET
=
2
,
GIT_LOGALLREFUPDATES_DEFAULT
=
GIT_LOGALLREFUPDATES_UNSET
,
}
git_cvar_value
;
/* internal repository init flags */
...
...
src/tag.c
View file @
2bcc1afd
...
...
@@ -363,20 +363,22 @@ int git_tag_create_frombuffer(git_oid *oid, git_repository *repo, const char *bu
}
/* write the buffer */
if
(
git_odb_open_wstream
(
&
stream
,
odb
,
strlen
(
buffer
),
GIT_OBJ_TAG
)
<
0
)
return
-
1
;
if
((
error
=
git_odb_open_wstream
(
&
stream
,
odb
,
strlen
(
buffer
),
GIT_OBJ_TAG
))
<
0
)
return
error
;
git_odb_stream_write
(
stream
,
buffer
,
strlen
(
buffer
));
if
(
!
(
error
=
git_odb_stream_write
(
stream
,
buffer
,
strlen
(
buffer
))))
error
=
git_odb_stream_finalize_write
(
oid
,
stream
);
error
=
git_odb_stream_finalize_write
(
oid
,
stream
);
git_odb_stream_free
(
stream
);
if
(
error
<
0
)
{
git_buf_free
(
&
ref_name
);
return
-
1
;
return
error
;
}
error
=
git_reference_create
(
&
new_ref
,
repo
,
ref_name
.
ptr
,
oid
,
allow_ref_overwrite
,
NULL
,
NULL
);
error
=
git_reference_create
(
&
new_ref
,
repo
,
ref_name
.
ptr
,
oid
,
allow_ref_overwrite
,
NULL
,
NULL
);
git_reference_free
(
new_ref
);
git_buf_free
(
&
ref_name
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment