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
b8408557
Commit
b8408557
authored
Jun 29, 2018
by
Nelson Elhage
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master' into no-pkt-pack
parents
895a668e
967da2c7
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
112 additions
and
57 deletions
+112
-57
deps/http-parser/CMakeLists.txt
+2
-0
src/config_file.c
+12
-18
src/config_parse.c
+27
-21
src/config_parse.h
+2
-2
src/revwalk.c
+3
-2
src/transports/smart.c
+12
-3
src/transports/smart_pkt.c
+8
-0
src/transports/smart_protocol.c
+21
-11
tests/revwalk/basic.c
+25
-0
No files found.
deps/http-parser/CMakeLists.txt
View file @
b8408557
FILE
(
GLOB SRC_HTTP
"*.c"
"*.h"
)
FILE
(
GLOB SRC_HTTP
"*.c"
"*.h"
)
ADD_LIBRARY
(
http-parser OBJECT
${
SRC_HTTP
}
)
ADD_LIBRARY
(
http-parser OBJECT
${
SRC_HTTP
}
)
ENABLE_WARNINGS
(
implicit-fallthrough=1
)
src/config_file.c
View file @
b8408557
...
@@ -876,10 +876,8 @@ static char *escape_value(const char *ptr)
...
@@ -876,10 +876,8 @@ static char *escape_value(const char *ptr)
ptr
++
;
ptr
++
;
}
}
if
(
git_buf_oom
(
&
buf
))
{
if
(
git_buf_oom
(
&
buf
))
git_buf_dispose
(
&
buf
);
return
NULL
;
return
NULL
;
}
return
git_buf_detach
(
&
buf
);
return
git_buf_detach
(
&
buf
);
}
}
...
@@ -1022,8 +1020,8 @@ static int parse_conditional_include(git_config_parser *reader,
...
@@ -1022,8 +1020,8 @@ static int parse_conditional_include(git_config_parser *reader,
static
int
read_on_variable
(
static
int
read_on_variable
(
git_config_parser
*
reader
,
git_config_parser
*
reader
,
const
char
*
current_section
,
const
char
*
current_section
,
char
*
var_name
,
c
onst
c
har
*
var_name
,
char
*
var_value
,
c
onst
c
har
*
var_value
,
const
char
*
line
,
const
char
*
line
,
size_t
line_len
,
size_t
line_len
,
void
*
data
)
void
*
data
)
...
@@ -1031,24 +1029,24 @@ static int read_on_variable(
...
@@ -1031,24 +1029,24 @@ static int read_on_variable(
diskfile_parse_state
*
parse_data
=
(
diskfile_parse_state
*
)
data
;
diskfile_parse_state
*
parse_data
=
(
diskfile_parse_state
*
)
data
;
git_buf
buf
=
GIT_BUF_INIT
;
git_buf
buf
=
GIT_BUF_INIT
;
git_config_entry
*
entry
;
git_config_entry
*
entry
;
const
char
*
c
;
int
result
=
0
;
int
result
=
0
;
GIT_UNUSED
(
line
);
GIT_UNUSED
(
line
);
GIT_UNUSED
(
line_len
);
GIT_UNUSED
(
line_len
);
git__strtolower
(
var_name
);
git_buf_puts
(
&
buf
,
current_section
);
git_buf_printf
(
&
buf
,
"%s.%s"
,
current_section
,
var_name
);
git_buf_putc
(
&
buf
,
'.'
);
git__free
(
var_name
);
for
(
c
=
var_name
;
*
c
;
c
++
)
git_buf_putc
(
&
buf
,
git__tolower
(
*
c
));
if
(
git_buf_oom
(
&
buf
))
{
if
(
git_buf_oom
(
&
buf
))
git__free
(
var_value
);
return
-
1
;
return
-
1
;
}
entry
=
git__calloc
(
1
,
sizeof
(
git_config_entry
));
entry
=
git__calloc
(
1
,
sizeof
(
git_config_entry
));
GITERR_CHECK_ALLOC
(
entry
);
GITERR_CHECK_ALLOC
(
entry
);
entry
->
name
=
git_buf_detach
(
&
buf
);
entry
->
name
=
git_buf_detach
(
&
buf
);
entry
->
value
=
var_value
;
entry
->
value
=
var_value
?
git__strdup
(
var_value
)
:
NULL
;
entry
->
level
=
parse_data
->
level
;
entry
->
level
=
parse_data
->
level
;
entry
->
include_depth
=
parse_data
->
depth
;
entry
->
include_depth
=
parse_data
->
depth
;
...
@@ -1065,7 +1063,6 @@ static int read_on_variable(
...
@@ -1065,7 +1063,6 @@ static int read_on_variable(
result
=
parse_conditional_include
(
reader
,
parse_data
,
result
=
parse_conditional_include
(
reader
,
parse_data
,
entry
->
name
,
entry
->
value
);
entry
->
name
,
entry
->
value
);
return
result
;
return
result
;
}
}
...
@@ -1249,8 +1246,8 @@ static int write_on_section(
...
@@ -1249,8 +1246,8 @@ static int write_on_section(
static
int
write_on_variable
(
static
int
write_on_variable
(
git_config_parser
*
reader
,
git_config_parser
*
reader
,
const
char
*
current_section
,
const
char
*
current_section
,
char
*
var_name
,
c
onst
c
har
*
var_name
,
char
*
var_value
,
c
onst
c
har
*
var_value
,
const
char
*
line
,
const
char
*
line
,
size_t
line_len
,
size_t
line_len
,
void
*
data
)
void
*
data
)
...
@@ -1279,9 +1276,6 @@ static int write_on_variable(
...
@@ -1279,9 +1276,6 @@ static int write_on_variable(
if
(
has_matched
&&
write_data
->
preg
!=
NULL
)
if
(
has_matched
&&
write_data
->
preg
!=
NULL
)
has_matched
=
(
regexec
(
write_data
->
preg
,
var_value
,
0
,
NULL
,
0
)
==
0
);
has_matched
=
(
regexec
(
write_data
->
preg
,
var_value
,
0
,
NULL
,
0
)
==
0
);
git__free
(
var_name
);
git__free
(
var_value
);
/* If this isn't the name/value we're looking for, simply dump the
/* If this isn't the name/value we're looking for, simply dump the
* existing data back out and continue on.
* existing data back out and continue on.
*/
*/
...
...
src/config_parse.c
View file @
b8408557
...
@@ -404,22 +404,21 @@ static int parse_name(
...
@@ -404,22 +404,21 @@ static int parse_name(
static
int
parse_variable
(
git_config_parser
*
reader
,
char
**
var_name
,
char
**
var_value
)
static
int
parse_variable
(
git_config_parser
*
reader
,
char
**
var_name
,
char
**
var_value
)
{
{
const
char
*
value_start
=
NULL
;
const
char
*
value_start
=
NULL
;
char
*
line
;
char
*
line
=
NULL
,
*
name
=
NULL
,
*
value
=
NULL
;
int
quote_count
;
int
quote_count
,
error
;
bool
multiline
;
bool
multiline
;
*
var_name
=
NULL
;
*
var_value
=
NULL
;
git_parse_advance_ws
(
&
reader
->
ctx
);
git_parse_advance_ws
(
&
reader
->
ctx
);
line
=
git__strndup
(
reader
->
ctx
.
line
,
reader
->
ctx
.
line_len
);
line
=
git__strndup
(
reader
->
ctx
.
line
,
reader
->
ctx
.
line_len
);
if
(
line
==
NULL
)
GITERR_CHECK_ALLOC
(
line
);
return
-
1
;
quote_count
=
strip_comments
(
line
,
0
);
quote_count
=
strip_comments
(
line
,
0
);
/* If there is no value, boolean true is assumed */
if
((
error
=
parse_name
(
&
name
,
&
value_start
,
reader
,
line
))
<
0
)
*
var_value
=
NULL
;
goto
out
;
if
(
parse_name
(
var_name
,
&
value_start
,
reader
,
line
)
<
0
)
goto
on_error
;
/*
/*
* Now, let's try to parse the value
* Now, let's try to parse the value
...
@@ -428,30 +427,34 @@ static int parse_variable(git_config_parser *reader, char **var_name, char **var
...
@@ -428,30 +427,34 @@ static int parse_variable(git_config_parser *reader, char **var_name, char **var
while
(
git__isspace
(
value_start
[
0
]))
while
(
git__isspace
(
value_start
[
0
]))
value_start
++
;
value_start
++
;
if
(
unescape_line
(
var_value
,
&
multiline
,
value_start
,
0
)
<
0
)
if
(
(
error
=
unescape_line
(
&
value
,
&
multiline
,
value_start
,
0
)
)
<
0
)
goto
o
n_error
;
goto
o
ut
;
if
(
multiline
)
{
if
(
multiline
)
{
git_buf
multi_value
=
GIT_BUF_INIT
;
git_buf
multi_value
=
GIT_BUF_INIT
;
git_buf_attach
(
&
multi_value
,
*
var_
value
,
0
);
git_buf_attach
(
&
multi_value
,
value
,
0
);
if
(
parse_multiline_variable
(
reader
,
&
multi_value
,
quote_count
)
<
0
||
if
(
parse_multiline_variable
(
reader
,
&
multi_value
,
quote_count
)
<
0
||
git_buf_oom
(
&
multi_value
))
{
git_buf_oom
(
&
multi_value
))
{
error
=
-
1
;
git_buf_dispose
(
&
multi_value
);
git_buf_dispose
(
&
multi_value
);
goto
o
n_error
;
goto
o
ut
;
}
}
*
var_
value
=
git_buf_detach
(
&
multi_value
);
value
=
git_buf_detach
(
&
multi_value
);
}
}
}
}
git__free
(
line
);
*
var_name
=
name
;
return
0
;
*
var_value
=
value
;
name
=
NULL
;
value
=
NULL
;
on_error
:
out
:
git__free
(
*
var_name
);
git__free
(
name
);
git__free
(
value
);
git__free
(
line
);
git__free
(
line
);
return
-
1
;
return
error
;
}
}
int
git_config_parse
(
int
git_config_parse
(
...
@@ -463,7 +466,7 @@ int git_config_parse(
...
@@ -463,7 +466,7 @@ int git_config_parse(
void
*
data
)
void
*
data
)
{
{
git_parse_ctx
*
ctx
;
git_parse_ctx
*
ctx
;
char
*
current_section
=
NULL
,
*
var_name
,
*
var_value
;
char
*
current_section
=
NULL
,
*
var_name
=
NULL
,
*
var_value
=
NULL
;
int
result
=
0
;
int
result
=
0
;
ctx
=
&
parser
->
ctx
;
ctx
=
&
parser
->
ctx
;
...
@@ -508,7 +511,10 @@ int git_config_parse(
...
@@ -508,7 +511,10 @@ int git_config_parse(
default
:
/* assume variable declaration */
default
:
/* assume variable declaration */
if
((
result
=
parse_variable
(
parser
,
&
var_name
,
&
var_value
))
==
0
&&
on_variable
)
{
if
((
result
=
parse_variable
(
parser
,
&
var_name
,
&
var_value
))
==
0
&&
on_variable
)
{
result
=
on_variable
(
parser
,
current_section
,
var_name
,
var_value
,
line_start
,
line_len
,
data
);
result
=
on_variable
(
parser
,
current_section
,
var_name
,
var_value
,
line_start
,
line_len
,
data
);
git__free
(
var_name
);
git__free
(
var_value
);
}
}
break
;
break
;
}
}
...
...
src/config_parse.h
View file @
b8408557
...
@@ -36,8 +36,8 @@ typedef int (*git_config_parser_section_cb)(
...
@@ -36,8 +36,8 @@ typedef int (*git_config_parser_section_cb)(
typedef
int
(
*
git_config_parser_variable_cb
)(
typedef
int
(
*
git_config_parser_variable_cb
)(
git_config_parser
*
parser
,
git_config_parser
*
parser
,
const
char
*
current_section
,
const
char
*
current_section
,
char
*
var_name
,
c
onst
c
har
*
var_name
,
char
*
var_value
,
c
onst
c
har
*
var_value
,
const
char
*
line
,
const
char
*
line
,
size_t
line_len
,
size_t
line_len
,
void
*
data
);
void
*
data
);
...
...
src/revwalk.c
View file @
b8408557
...
@@ -455,7 +455,7 @@ static int get_revision(git_commit_list_node **out, git_revwalk *walk, git_commi
...
@@ -455,7 +455,7 @@ static int get_revision(git_commit_list_node **out, git_revwalk *walk, git_commi
*/
*/
if
(
!
walk
->
limited
)
{
if
(
!
walk
->
limited
)
{
if
((
error
=
add_parents_to_list
(
walk
,
commit
,
list
))
<
0
)
if
((
error
=
add_parents_to_list
(
walk
,
commit
,
list
))
<
0
)
return
error
;
return
error
;
}
}
*
out
=
commit
;
*
out
=
commit
;
...
@@ -678,7 +678,7 @@ void git_revwalk_sorting(git_revwalk *walk, unsigned int sort_mode)
...
@@ -678,7 +678,7 @@ void git_revwalk_sorting(git_revwalk *walk, unsigned int sort_mode)
walk
->
enqueue
=
&
revwalk_enqueue_unsorted
;
walk
->
enqueue
=
&
revwalk_enqueue_unsorted
;
}
}
if
(
sort_mode
!=
GIT_SORT_NONE
)
if
(
walk
->
sorting
!=
GIT_SORT_NONE
)
walk
->
limited
=
1
;
walk
->
limited
=
1
;
}
}
...
@@ -737,6 +737,7 @@ void git_revwalk_reset(git_revwalk *walk)
...
@@ -737,6 +737,7 @@ void git_revwalk_reset(git_revwalk *walk)
walk
->
walking
=
0
;
walk
->
walking
=
0
;
walk
->
limited
=
0
;
walk
->
limited
=
0
;
walk
->
did_push
=
walk
->
did_hide
=
0
;
walk
->
did_push
=
walk
->
did_hide
=
0
;
walk
->
sorting
=
GIT_SORT_NONE
;
}
}
int
git_revwalk_add_hide_cb
(
int
git_revwalk_add_hide_cb
(
...
...
src/transports/smart.c
View file @
b8408557
...
@@ -167,8 +167,10 @@ int git_smart__update_heads(transport_smart *t, git_vector *symrefs)
...
@@ -167,8 +167,10 @@ int git_smart__update_heads(transport_smart *t, git_vector *symrefs)
git_vector_foreach
(
symrefs
,
j
,
spec
)
{
git_vector_foreach
(
symrefs
,
j
,
spec
)
{
git_buf_clear
(
&
buf
);
git_buf_clear
(
&
buf
);
if
(
git_refspec_src_matches
(
spec
,
ref
->
head
.
name
)
&&
if
(
git_refspec_src_matches
(
spec
,
ref
->
head
.
name
)
&&
!
(
error
=
git_refspec_transform
(
&
buf
,
spec
,
ref
->
head
.
name
)))
!
(
error
=
git_refspec_transform
(
&
buf
,
spec
,
ref
->
head
.
name
)))
{
git__free
(
ref
->
head
.
symref_target
);
ref
->
head
.
symref_target
=
git_buf_detach
(
&
buf
);
ref
->
head
.
symref_target
=
git_buf_detach
(
&
buf
);
}
}
}
git_buf_dispose
(
&
buf
);
git_buf_dispose
(
&
buf
);
...
@@ -266,14 +268,21 @@ static int git_smart__connect(
...
@@ -266,14 +268,21 @@ static int git_smart__connect(
/* We now have loaded the refs. */
/* We now have loaded the refs. */
t
->
have_refs
=
1
;
t
->
have_refs
=
1
;
first
=
(
git_pkt_ref
*
)
git_vector_get
(
&
t
->
refs
,
0
);
pkt
=
(
git_pkt
*
)
git_vector_get
(
&
t
->
refs
,
0
);
if
(
pkt
&&
GIT_PKT_REF
!=
pkt
->
type
)
{
giterr_set
(
GITERR_NET
,
"invalid response"
);
return
-
1
;
}
first
=
(
git_pkt_ref
*
)
pkt
;
if
((
error
=
git_vector_init
(
&
symrefs
,
1
,
NULL
))
<
0
)
if
((
error
=
git_vector_init
(
&
symrefs
,
1
,
NULL
))
<
0
)
return
error
;
return
error
;
/* Detect capabilities */
/* Detect capabilities */
if
(
git_smart__detect_caps
(
first
,
&
t
->
caps
,
&
symrefs
)
<
0
)
if
(
git_smart__detect_caps
(
first
,
&
t
->
caps
,
&
symrefs
)
<
0
)
{
free_symrefs
(
&
symrefs
);
return
-
1
;
return
-
1
;
}
/* If the only ref in the list is capabilities^{} with OID_ZERO, remove it */
/* If the only ref in the list is capabilities^{} with OID_ZERO, remove it */
if
(
1
==
t
->
refs
.
length
&&
!
strcmp
(
first
->
head
.
name
,
"capabilities^{}"
)
&&
if
(
1
==
t
->
refs
.
length
&&
!
strcmp
(
first
->
head
.
name
,
"capabilities^{}"
)
&&
...
...
src/transports/smart_pkt.c
View file @
b8408557
...
@@ -203,6 +203,11 @@ static int ref_pkt(git_pkt **out, const char *line, size_t len)
...
@@ -203,6 +203,11 @@ static int ref_pkt(git_pkt **out, const char *line, size_t len)
git_pkt_ref
*
pkt
;
git_pkt_ref
*
pkt
;
size_t
alloclen
;
size_t
alloclen
;
if
(
len
<
GIT_OID_HEXSZ
+
1
)
{
giterr_set
(
GITERR_NET
,
"error parsing pkt-line"
);
return
-
1
;
}
pkt
=
git__malloc
(
sizeof
(
git_pkt_ref
));
pkt
=
git__malloc
(
sizeof
(
git_pkt_ref
));
GITERR_CHECK_ALLOC
(
pkt
);
GITERR_CHECK_ALLOC
(
pkt
);
...
@@ -470,6 +475,9 @@ int git_pkt_parse_line(
...
@@ -470,6 +475,9 @@ int git_pkt_parse_line(
void
git_pkt_free
(
git_pkt
*
pkt
)
void
git_pkt_free
(
git_pkt
*
pkt
)
{
{
if
(
pkt
==
NULL
)
{
return
;
}
if
(
pkt
->
type
==
GIT_PKT_REF
)
{
if
(
pkt
->
type
==
GIT_PKT_REF
)
{
git_pkt_ref
*
p
=
(
git_pkt_ref
*
)
pkt
;
git_pkt_ref
*
p
=
(
git_pkt_ref
*
)
pkt
;
git__free
(
p
->
head
.
name
);
git__free
(
p
->
head
.
name
);
...
...
src/transports/smart_protocol.c
View file @
b8408557
...
@@ -70,6 +70,12 @@ int git_smart__store_refs(transport_smart *t, int flushes)
...
@@ -70,6 +70,12 @@ int git_smart__store_refs(transport_smart *t, int flushes)
return
-
1
;
return
-
1
;
}
}
if
(
pkt
->
type
==
GIT_PKT_PACK
)
{
giterr_set
(
GITERR_NET
,
"unexpected packfile"
);
git__free
(
pkt
);
return
-
1
;
}
if
(
pkt
->
type
!=
GIT_PKT_FLUSH
&&
git_vector_insert
(
refs
,
pkt
)
<
0
)
if
(
pkt
->
type
!=
GIT_PKT_FLUSH
&&
git_vector_insert
(
refs
,
pkt
)
<
0
)
return
-
1
;
return
-
1
;
...
@@ -317,27 +323,30 @@ on_error:
...
@@ -317,27 +323,30 @@ on_error:
static
int
wait_while_ack
(
gitno_buffer
*
buf
)
static
int
wait_while_ack
(
gitno_buffer
*
buf
)
{
{
int
error
;
int
error
;
git_pkt_ack
*
pkt
=
NULL
;
git_pkt
*
pkt
=
NULL
;
git_pkt_ack
*
ack
=
NULL
;
while
(
1
)
{
while
(
1
)
{
git__free
(
pkt
);
git_
pkt
_free
(
pkt
);
if
((
error
=
recv_pkt
(
(
git_pkt
**
)
&
pkt
,
NULL
,
buf
))
<
0
)
if
((
error
=
recv_pkt
(
&
pkt
,
NULL
,
buf
))
<
0
)
return
error
;
return
error
;
if
(
pkt
->
type
==
GIT_PKT_NAK
)
if
(
pkt
->
type
==
GIT_PKT_NAK
)
break
;
break
;
if
(
pkt
->
type
!=
GIT_PKT_ACK
)
continue
;
if
(
pkt
->
type
==
GIT_PKT_ACK
&&
ack
=
(
git_pkt_ack
*
)
pkt
;
(
pkt
->
status
!=
GIT_ACK_CONTINUE
&&
pkt
->
status
!=
GIT_ACK_COMMON
&&
if
(
ack
->
status
!=
GIT_ACK_CONTINUE
&&
pkt
->
status
!=
GIT_ACK_READY
))
{
ack
->
status
!=
GIT_ACK_COMMON
&&
git__free
(
pkt
);
ack
->
status
!=
GIT_ACK_READY
)
{
return
0
;
break
;
}
}
}
}
git__free
(
pkt
);
git_
pkt
_free
(
pkt
);
return
0
;
return
0
;
}
}
...
@@ -615,7 +624,8 @@ int git_smart__download_pack(
...
@@ -615,7 +624,8 @@ int git_smart__download_pack(
}
}
}
}
git__free
(
pkt
);
git_pkt_free
(
pkt
);
if
(
error
<
0
)
if
(
error
<
0
)
goto
done
;
goto
done
;
...
...
tests/revwalk/basic.c
View file @
b8408557
...
@@ -197,6 +197,31 @@ void test_revwalk_basic__push_head(void)
...
@@ -197,6 +197,31 @@ void test_revwalk_basic__push_head(void)
cl_assert_equal_i
(
i
,
7
);
cl_assert_equal_i
(
i
,
7
);
}
}
void
test_revwalk_basic__sorted_after_reset
(
void
)
{
int
i
=
0
;
git_oid
oid
;
revwalk_basic_setup_walk
(
NULL
);
git_oid_fromstr
(
&
oid
,
commit_head
);
/* push, sort, and test the walk */
cl_git_pass
(
git_revwalk_push
(
_walk
,
&
oid
));
git_revwalk_sorting
(
_walk
,
GIT_SORT_TIME
);
cl_git_pass
(
test_walk_only
(
_walk
,
commit_sorting_time
,
2
));
/* reset, push, and test again - we should see all entries */
git_revwalk_reset
(
_walk
);
cl_git_pass
(
git_revwalk_push
(
_walk
,
&
oid
));
while
(
git_revwalk_next
(
&
oid
,
_walk
)
==
0
)
i
++
;
cl_assert_equal_i
(
i
,
commit_count
);
}
void
test_revwalk_basic__push_head_hide_ref
(
void
)
void
test_revwalk_basic__push_head_hide_ref
(
void
)
{
{
int
i
=
0
;
int
i
=
0
;
...
...
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