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
2c0cdc3a
Commit
2c0cdc3a
authored
May 08, 2012
by
Russell Belfer
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #674 from nulltoken/topic/GIT_ENOTFOUND
Improve the interop with bindings
parents
65ca81a6
722c08af
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
133 additions
and
32 deletions
+133
-32
src/object.c
+2
-2
src/path.c
+5
-1
src/remote.c
+16
-10
src/repository.c
+3
-2
src/status.c
+4
-4
src/win32/posix_w32.c
+17
-4
tests-clar/core/path.c
+13
-0
tests-clar/network/remotes.c
+5
-0
tests-clar/object/lookup.c
+35
-0
tests-clar/repo/discover.c
+6
-6
tests-clar/repo/open.c
+10
-3
tests-clar/status/worktree.c
+17
-0
No files found.
src/object.c
View file @
2c0cdc3a
...
...
@@ -150,8 +150,8 @@ int git_object_lookup_prefix(
if
(
type
!=
GIT_OBJ_ANY
&&
type
!=
odb_obj
->
raw
.
type
)
{
git_odb_object_free
(
odb_obj
);
giterr_set
(
GITERR_
INVALID
,
"The given type does not match the type on the ODB"
);
return
-
1
;
giterr_set
(
GITERR_
ODB
,
"The given type does not match the type on the ODB"
);
return
GIT_ENOTFOUND
;
}
type
=
odb_obj
->
raw
.
type
;
...
...
src/path.c
View file @
2c0cdc3a
...
...
@@ -205,9 +205,13 @@ int git_path_prettify(git_buf *path_out, const char *path, const char *base)
}
if
(
p_realpath
(
path
,
buf
)
==
NULL
)
{
/* giterr_set resets the errno when dealing with a GITERR_OS kind of error */
int
error
=
(
errno
==
ENOENT
||
errno
==
ENOTDIR
)
?
GIT_ENOTFOUND
:
-
1
;
giterr_set
(
GITERR_OS
,
"Failed to resolve path '%s'"
,
path
);
git_buf_clear
(
path_out
);
return
(
errno
==
ENOENT
)
?
GIT_ENOTFOUND
:
-
1
;
return
error
;
}
return
git_buf_sets
(
path_out
,
buf
);
...
...
src/remote.c
View file @
2c0cdc3a
...
...
@@ -102,24 +102,28 @@ int git_remote_load(git_remote **out, git_repository *repo, const char *name)
remote
->
name
=
git__strdup
(
name
);
GITERR_CHECK_ALLOC
(
remote
->
name
);
if
(
git_vector_init
(
&
remote
->
refs
,
32
,
NULL
)
<
0
)
return
-
1
;
if
(
git_buf_printf
(
&
buf
,
"remote.%s.url"
,
name
)
<
0
)
return
-
1
;
if
(
git_vector_init
(
&
remote
->
refs
,
32
,
NULL
)
<
0
)
{
error
=
-
1
;
goto
cleanup
;
}
if
(
git_
config_get_string
(
config
,
git_buf_cstr
(
&
buf
),
&
val
)
<
0
)
{
if
(
git_
buf_printf
(
&
buf
,
"remote.%s.url"
,
name
)
<
0
)
{
error
=
-
1
;
goto
cleanup
;
}
if
((
error
=
git_config_get_string
(
config
,
git_buf_cstr
(
&
buf
),
&
val
))
<
0
)
goto
cleanup
;
remote
->
repo
=
repo
;
remote
->
url
=
git__strdup
(
val
);
GITERR_CHECK_ALLOC
(
remote
->
url
);
git_buf_clear
(
&
buf
);
if
(
git_buf_printf
(
&
buf
,
"remote.%s.fetch"
,
name
)
<
0
)
return
-
1
;
if
(
git_buf_printf
(
&
buf
,
"remote.%s.fetch"
,
name
)
<
0
)
{
error
=
-
1
;
goto
cleanup
;
}
error
=
parse_remote_refspec
(
config
,
&
remote
->
fetch
,
git_buf_cstr
(
&
buf
));
if
(
error
==
GIT_ENOTFOUND
)
...
...
@@ -131,8 +135,10 @@ int git_remote_load(git_remote **out, git_repository *repo, const char *name)
}
git_buf_clear
(
&
buf
);
if
(
git_buf_printf
(
&
buf
,
"remote.%s.push"
,
name
)
<
0
)
return
-
1
;
if
(
git_buf_printf
(
&
buf
,
"remote.%s.push"
,
name
)
<
0
)
{
error
=
-
1
;
goto
cleanup
;
}
error
=
parse_remote_refspec
(
config
,
&
remote
->
push
,
git_buf_cstr
(
&
buf
));
if
(
error
==
GIT_ENOTFOUND
)
...
...
src/repository.c
View file @
2c0cdc3a
...
...
@@ -397,13 +397,14 @@ int git_repository_discover(
{
git_buf
path
=
GIT_BUF_INIT
;
uint32_t
flags
=
across_fs
?
GIT_REPOSITORY_OPEN_CROSS_FS
:
0
;
int
error
;
assert
(
start_path
&&
repository_path
&&
size
>
0
);
*
repository_path
=
'\0'
;
if
(
find_repo
(
&
path
,
NULL
,
start_path
,
flags
,
ceiling_dirs
)
<
0
)
return
-
1
;
if
(
(
error
=
find_repo
(
&
path
,
NULL
,
start_path
,
flags
,
ceiling_dirs
)
)
<
0
)
return
error
!=
GIT_ENOTFOUND
?
-
1
:
error
;
if
(
size
<
(
size_t
)(
path
.
size
+
1
))
{
giterr_set
(
GITERR_REPOSITORY
,
...
...
src/status.c
View file @
2c0cdc3a
...
...
@@ -340,17 +340,17 @@ int git_status_file(
assert
(
status_flags
&&
repo
&&
path
);
if
((
workdir
=
git_repository_workdir
(
repo
))
==
NULL
)
{
giterr_set
(
GITERR_
OS
,
"Cannot get file status from bare repo"
);
return
GIT_ENOTFOUND
;
giterr_set
(
GITERR_
INVALID
,
"Cannot get file status from bare repo"
);
return
-
1
;
}
if
(
git_buf_joinpath
(
&
temp_path
,
workdir
,
path
)
<
0
)
return
-
1
;
if
(
git_path_isdir
(
temp_path
.
ptr
))
{
giterr_set
(
GITERR_
OS
,
"Cannot get file status for directory '%s'"
,
temp_path
.
ptr
);
giterr_set
(
GITERR_
INVALID
,
"Cannot get file status for directory '%s'"
,
temp_path
.
ptr
);
git_buf_free
(
&
temp_path
);
return
GIT_ENOTFOUND
;
return
-
1
;
}
e
=
status_entry_new
(
NULL
,
path
);
...
...
src/win32/posix_w32.c
View file @
2c0cdc3a
...
...
@@ -326,7 +326,7 @@ int p_hide_directory__w32(const char *path)
char
*
p_realpath
(
const
char
*
orig_path
,
char
*
buffer
)
{
int
ret
;
int
ret
,
buffer_sz
=
0
;
wchar_t
*
orig_path_w
=
gitwin_to_utf16
(
orig_path
);
wchar_t
*
buffer_w
=
(
wchar_t
*
)
git__malloc
(
GIT_PATH_MAX
*
sizeof
(
wchar_t
));
...
...
@@ -336,13 +336,14 @@ char *p_realpath(const char *orig_path, char *buffer)
ret
=
GetFullPathNameW
(
orig_path_w
,
GIT_PATH_MAX
,
buffer_w
,
NULL
);
git__free
(
orig_path_w
);
if
(
!
ret
||
ret
>
GIT_PATH_MAX
)
{
/* According to MSDN, a return value equals to zero means a failure. */
if
(
ret
==
0
||
ret
>
GIT_PATH_MAX
)
{
buffer
=
NULL
;
goto
done
;
}
if
(
buffer
==
NULL
)
{
int
buffer_sz
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
buffer_w
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
buffer_sz
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
buffer_w
,
-
1
,
NULL
,
0
,
NULL
,
NULL
);
if
(
!
buffer_sz
||
!
(
buffer
=
(
char
*
)
git__malloc
(
buffer_sz
))
||
...
...
@@ -350,10 +351,22 @@ char *p_realpath(const char *orig_path, char *buffer)
{
git__free
(
buffer
);
buffer
=
NULL
;
goto
done
;
}
}
else
{
if
(
!
WideCharToMultiByte
(
CP_UTF8
,
0
,
buffer_w
,
-
1
,
buffer
,
GIT_PATH_MAX
,
NULL
,
NULL
))
if
(
!
WideCharToMultiByte
(
CP_UTF8
,
0
,
buffer_w
,
-
1
,
buffer
,
GIT_PATH_MAX
,
NULL
,
NULL
))
{
buffer
=
NULL
;
goto
done
;
}
}
if
(
!
git_path_exists
(
buffer
))
{
if
(
buffer_sz
>
0
)
git__free
(
buffer
);
buffer
=
NULL
;
errno
=
ENOENT
;
}
done
:
...
...
tests-clar/core/path.c
View file @
2c0cdc3a
...
...
@@ -405,3 +405,16 @@ void test_core_path__12_offset_to_path_root(void)
cl_assert
(
git_path_root
(
"//computername"
)
==
-
1
);
#endif
}
#define NON_EXISTING_FILEPATH "i_hope_i_do_not_exist"
void
test_core_path__13_cannot_prettify_a_non_existing_file
(
void
)
{
git_buf
p
=
GIT_BUF_INIT
;
cl_must_pass
(
git_path_exists
(
NON_EXISTING_FILEPATH
)
==
false
);
cl_assert_equal_i
(
GIT_ENOTFOUND
,
git_path_prettify
(
&
p
,
NON_EXISTING_FILEPATH
,
NULL
));
cl_assert_equal_i
(
GIT_ENOTFOUND
,
git_path_prettify
(
&
p
,
NON_EXISTING_FILEPATH
"/so-do-i"
,
NULL
));
git_buf_free
(
&
p
);
}
tests-clar/network/remotes.c
View file @
2c0cdc3a
...
...
@@ -153,3 +153,8 @@ void test_network_remotes__list(void)
git_config_free
(
cfg
);
}
void
test_network_remotes__loading_a_missing_remote_returns_ENOTFOUND
(
void
)
{
cl_assert_equal_i
(
GIT_ENOTFOUND
,
git_remote_load
(
&
_remote
,
_repo
,
"just-left-few-minutes-ago"
));
}
tests-clar/object/lookup.c
0 → 100644
View file @
2c0cdc3a
#include "clar_libgit2.h"
#include "repository.h"
static
git_repository
*
g_repo
;
void
test_object_lookup__initialize
(
void
)
{
cl_git_pass
(
git_repository_open
(
&
g_repo
,
cl_fixture
(
"testrepo.git"
)));
}
void
test_object_lookup__cleanup
(
void
)
{
git_repository_free
(
g_repo
);
}
void
test_object_lookup__looking_up_an_exisiting_object_by_its_wrong_type_returns_ENOTFOUND
(
void
)
{
const
char
*
commit
=
"e90810b8df3e80c413d903f631643c716887138d"
;
git_oid
oid
;
git_object
*
object
;
cl_git_pass
(
git_oid_fromstr
(
&
oid
,
commit
));
cl_assert_equal_i
(
GIT_ENOTFOUND
,
git_object_lookup
(
&
object
,
g_repo
,
&
oid
,
GIT_OBJ_TAG
));
}
void
test_object_lookup__looking_up_a_non_exisiting_object_returns_ENOTFOUND
(
void
)
{
const
char
*
unknown
=
"deadbeefdeadbeefdeadbeefdeadbeefdeadbeef"
;
git_oid
oid
;
git_object
*
object
;
cl_git_pass
(
git_oid_fromstr
(
&
oid
,
unknown
));
cl_assert_equal_i
(
GIT_ENOTFOUND
,
git_object_lookup
(
&
object
,
g_repo
,
&
oid
,
GIT_OBJ_ANY
));
}
tests-clar/repo/discover.c
View file @
2c0cdc3a
...
...
@@ -82,7 +82,7 @@ void test_repo_discover__0(void)
append_ceiling_dir
(
&
ceiling_dirs_buf
,
TEMP_REPO_FOLDER
);
ceiling_dirs
=
git_buf_cstr
(
&
ceiling_dirs_buf
);
cl_
git_fail
(
git_repository_discover
(
repository_path
,
sizeof
(
repository_path
),
DISCOVER_FOLDER
,
0
,
ceiling_dirs
));
cl_
assert_equal_i
(
GIT_ENOTFOUND
,
git_repository_discover
(
repository_path
,
sizeof
(
repository_path
),
DISCOVER_FOLDER
,
0
,
ceiling_dirs
));
cl_git_pass
(
git_repository_init
(
&
repo
,
DISCOVER_FOLDER
,
1
));
cl_git_pass
(
git_repository_discover
(
repository_path
,
sizeof
(
repository_path
),
DISCOVER_FOLDER
,
0
,
ceiling_dirs
));
...
...
@@ -117,7 +117,7 @@ void test_repo_discover__0(void)
cl_git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
ALTERNATE_MALFORMED_FOLDER1
,
0
,
ceiling_dirs
));
cl_git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
ALTERNATE_MALFORMED_FOLDER2
,
0
,
ceiling_dirs
));
cl_git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
ALTERNATE_MALFORMED_FOLDER3
,
0
,
ceiling_dirs
));
cl_
git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
ALTERNATE_NOT_FOUND_FOLDER
,
0
,
ceiling_dirs
));
cl_
assert_equal_i
(
GIT_ENOTFOUND
,
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
ALTERNATE_NOT_FOUND_FOLDER
,
0
,
ceiling_dirs
));
append_ceiling_dir
(
&
ceiling_dirs_buf
,
SUB_REPOSITORY_FOLDER
);
ceiling_dirs
=
git_buf_cstr
(
&
ceiling_dirs_buf
);
...
...
@@ -125,9 +125,9 @@ void test_repo_discover__0(void)
//this must pass as ceiling_directories cannot predent the current
//working directory to be checked
cl_git_pass
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER
,
0
,
ceiling_dirs
));
cl_
git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER_SUB
,
0
,
ceiling_dirs
));
cl_
git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER_SUB_SUB
,
0
,
ceiling_dirs
));
cl_
git_fail
(
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER_SUB_SUB_SUB
,
0
,
ceiling_dirs
));
cl_
assert_equal_i
(
GIT_ENOTFOUND
,
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER_SUB
,
0
,
ceiling_dirs
));
cl_
assert_equal_i
(
GIT_ENOTFOUND
,
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER_SUB_SUB
,
0
,
ceiling_dirs
));
cl_
assert_equal_i
(
GIT_ENOTFOUND
,
git_repository_discover
(
found_path
,
sizeof
(
found_path
),
SUB_REPOSITORY_FOLDER_SUB_SUB_SUB
,
0
,
ceiling_dirs
));
//.gitfile redirection should not be affected by ceiling directories
ensure_repository_discover
(
REPOSITORY_ALTERNATE_FOLDER
,
ceiling_dirs
,
sub_repository_path
);
...
...
@@ -135,7 +135,7 @@ void test_repo_discover__0(void)
ensure_repository_discover
(
REPOSITORY_ALTERNATE_FOLDER_SUB_SUB
,
ceiling_dirs
,
sub_repository_path
);
ensure_repository_discover
(
REPOSITORY_ALTERNATE_FOLDER_SUB_SUB_SUB
,
ceiling_dirs
,
repository_path
);
cl_git_pass
(
git_futils_rmdir_r
(
TEMP_REPO_FOLDER
,
1
));
cl_git_pass
(
git_futils_rmdir_r
(
TEMP_REPO_FOLDER
,
GIT_DIRREMOVAL_FILES_AND_DIRS
));
git_repository_free
(
repo
);
git_buf_free
(
&
ceiling_dirs_buf
);
}
...
...
tests-clar/repo/open.c
View file @
2c0cdc3a
...
...
@@ -7,7 +7,7 @@ void test_repo_open__cleanup(void)
cl_git_sandbox_cleanup
();
if
(
git_path_isdir
(
"alternate"
))
git_futils_rmdir_r
(
"alternate"
,
1
);
git_futils_rmdir_r
(
"alternate"
,
GIT_DIRREMOVAL_FILES_AND_DIRS
);
}
void
test_repo_open__bare_empty_repo
(
void
)
...
...
@@ -202,8 +202,8 @@ void test_repo_open__bad_gitlinks(void)
cl_git_fail
(
git_repository_open_ext
(
&
repo
,
"alternate"
,
0
,
NULL
));
}
git_futils_rmdir_r
(
"invalid"
,
1
);
git_futils_rmdir_r
(
"invalid2"
,
1
);
git_futils_rmdir_r
(
"invalid"
,
GIT_DIRREMOVAL_FILES_AND_DIRS
);
git_futils_rmdir_r
(
"invalid2"
,
GIT_DIRREMOVAL_FILES_AND_DIRS
);
}
#ifdef GIT_WIN32
...
...
@@ -274,3 +274,9 @@ void test_repo_open__win32_path(void)
git_buf_free
(
&
winpath
);
#endif
}
void
test_repo_open__opening_a_non_existing_repository_returns_ENOTFOUND
(
void
)
{
git_repository
*
repo
;
cl_assert_equal_i
(
GIT_ENOTFOUND
,
git_repository_open
(
&
repo
,
"i-do-not/exist"
));
}
\ No newline at end of file
tests-clar/status/worktree.c
View file @
2c0cdc3a
...
...
@@ -275,6 +275,7 @@ void test_status_worktree__single_folder(void)
error
=
git_status_file
(
&
status_flags
,
repo
,
"subdir"
);
cl_git_fail
(
error
);
cl_assert
(
error
!=
GIT_ENOTFOUND
);
}
...
...
@@ -384,3 +385,18 @@ void test_status_worktree__issue_592_5(void)
git_buf_free
(
&
path
);
}
void
test_status_worktree__cannot_retrieve_the_status_of_a_bare_repository
(
void
)
{
git_repository
*
repo
;
int
error
,
status
=
0
;
cl_git_pass
(
git_repository_open
(
&
repo
,
cl_fixture
(
"testrepo.git"
)));
error
=
git_status_file
(
&
status
,
repo
,
"dummy"
);
cl_git_fail
(
error
);
cl_assert
(
error
!=
GIT_ENOTFOUND
);
git_repository_free
(
repo
);
}
\ No newline at end of file
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