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
fd1492e8
Unverified
Commit
fd1492e8
authored
Nov 12, 2017
by
Patrick Steinhardt
Committed by
GitHub
Nov 12, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #4408 from hkleynhans/pos_neg_zero_offset_sig
signature: distinguish +0000 and -0000 UTC offsets
parents
8c928be4
f063dafb
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
35 additions
and
2 deletions
+35
-2
include/git2/types.h
+1
-0
src/signature.c
+7
-2
tests/commit/signature.c
+27
-0
No files found.
include/git2/types.h
View file @
fd1492e8
...
@@ -159,6 +159,7 @@ typedef struct git_packbuilder git_packbuilder;
...
@@ -159,6 +159,7 @@ typedef struct git_packbuilder git_packbuilder;
typedef
struct
git_time
{
typedef
struct
git_time
{
git_time_t
time
;
/**< time in seconds from epoch */
git_time_t
time
;
/**< time in seconds from epoch */
int
offset
;
/**< timezone offset, in minutes */
int
offset
;
/**< timezone offset, in minutes */
char
sign
;
/**< indicator for questionable '-0000' offsets in signature */
}
git_time
;
}
git_time
;
/** An action signature (e.g. for committers, taggers, etc) */
/** An action signature (e.g. for committers, taggers, etc) */
...
...
src/signature.c
View file @
fd1492e8
...
@@ -90,6 +90,7 @@ int git_signature_new(git_signature **sig_out, const char *name, const char *ema
...
@@ -90,6 +90,7 @@ int git_signature_new(git_signature **sig_out, const char *name, const char *ema
p
->
when
.
time
=
time
;
p
->
when
.
time
=
time
;
p
->
when
.
offset
=
offset
;
p
->
when
.
offset
=
offset
;
p
->
when
.
sign
=
(
offset
<
0
)
?
'-'
:
'+'
;
*
sig_out
=
p
;
*
sig_out
=
p
;
return
0
;
return
0
;
...
@@ -113,6 +114,7 @@ int git_signature_dup(git_signature **dest, const git_signature *source)
...
@@ -113,6 +114,7 @@ int git_signature_dup(git_signature **dest, const git_signature *source)
signature
->
when
.
time
=
source
->
when
.
time
;
signature
->
when
.
time
=
source
->
when
.
time
;
signature
->
when
.
offset
=
source
->
when
.
offset
;
signature
->
when
.
offset
=
source
->
when
.
offset
;
signature
->
when
.
sign
=
source
->
when
.
sign
;
*
dest
=
signature
;
*
dest
=
signature
;
...
@@ -137,6 +139,7 @@ int git_signature__pdup(git_signature **dest, const git_signature *source, git_p
...
@@ -137,6 +139,7 @@ int git_signature__pdup(git_signature **dest, const git_signature *source, git_p
signature
->
when
.
time
=
source
->
when
.
time
;
signature
->
when
.
time
=
source
->
when
.
time
;
signature
->
when
.
offset
=
source
->
when
.
offset
;
signature
->
when
.
offset
=
source
->
when
.
offset
;
signature
->
when
.
sign
=
source
->
when
.
sign
;
*
dest
=
signature
;
*
dest
=
signature
;
...
@@ -257,6 +260,7 @@ int git_signature__parse(git_signature *sig, const char **buffer_out,
...
@@ -257,6 +260,7 @@ int git_signature__parse(git_signature *sig, const char **buffer_out,
*/
*/
if
(
hours
<=
14
&&
mins
<=
59
)
{
if
(
hours
<=
14
&&
mins
<=
59
)
{
sig
->
when
.
offset
=
(
hours
*
60
)
+
mins
;
sig
->
when
.
offset
=
(
hours
*
60
)
+
mins
;
sig
->
when
.
sign
=
tz_start
[
0
];
if
(
tz_start
[
0
]
==
'-'
)
if
(
tz_start
[
0
]
==
'-'
)
sig
->
when
.
offset
=
-
sig
->
when
.
offset
;
sig
->
when
.
offset
=
-
sig
->
when
.
offset
;
}
}
...
@@ -299,7 +303,7 @@ void git_signature__writebuf(git_buf *buf, const char *header, const git_signatu
...
@@ -299,7 +303,7 @@ void git_signature__writebuf(git_buf *buf, const char *header, const git_signatu
assert
(
buf
&&
sig
);
assert
(
buf
&&
sig
);
offset
=
sig
->
when
.
offset
;
offset
=
sig
->
when
.
offset
;
sign
=
(
sig
->
when
.
offset
<
0
)
?
'-'
:
'+'
;
sign
=
(
sig
->
when
.
offset
<
0
||
sig
->
when
.
sign
==
'-'
)
?
'-'
:
'+'
;
if
(
offset
<
0
)
if
(
offset
<
0
)
offset
=
-
offset
;
offset
=
-
offset
;
...
@@ -320,6 +324,7 @@ bool git_signature__equal(const git_signature *one, const git_signature *two)
...
@@ -320,6 +324,7 @@ bool git_signature__equal(const git_signature *one, const git_signature *two)
git__strcmp
(
one
->
name
,
two
->
name
)
==
0
&&
git__strcmp
(
one
->
name
,
two
->
name
)
==
0
&&
git__strcmp
(
one
->
email
,
two
->
email
)
==
0
&&
git__strcmp
(
one
->
email
,
two
->
email
)
==
0
&&
one
->
when
.
time
==
two
->
when
.
time
&&
one
->
when
.
time
==
two
->
when
.
time
&&
one
->
when
.
offset
==
two
->
when
.
offset
;
one
->
when
.
offset
==
two
->
when
.
offset
&&
one
->
when
.
sign
==
two
->
when
.
sign
;
}
}
tests/commit/signature.c
View file @
fd1492e8
#include "clar_libgit2.h"
#include "clar_libgit2.h"
#include "signature.h"
static
int
try_build_signature
(
const
char
*
name
,
const
char
*
email
,
git_time_t
time
,
int
offset
)
static
int
try_build_signature
(
const
char
*
name
,
const
char
*
email
,
git_time_t
time
,
int
offset
)
{
{
...
@@ -99,3 +100,29 @@ void test_commit_signature__from_buf(void)
...
@@ -99,3 +100,29 @@ void test_commit_signature__from_buf(void)
git_signature_free
(
sign
);
git_signature_free
(
sign
);
}
}
void
test_commit_signature__from_buf_with_neg_zero_offset
(
void
)
{
git_signature
*
sign
;
cl_git_pass
(
git_signature_from_buffer
(
&
sign
,
"Test User <test@test.tt> 1461698487 -0000"
));
cl_assert_equal_s
(
"Test User"
,
sign
->
name
);
cl_assert_equal_s
(
"test@test.tt"
,
sign
->
email
);
cl_assert_equal_i
(
1461698487
,
sign
->
when
.
time
);
cl_assert_equal_i
(
0
,
sign
->
when
.
offset
);
cl_assert_equal_i
(
'-'
,
sign
->
when
.
sign
);
git_signature_free
(
sign
);
}
void
test_commit_signature__pos_and_neg_zero_offsets_dont_match
(
void
)
{
git_signature
*
with_neg_zero
;
git_signature
*
with_pos_zero
;
cl_git_pass
(
git_signature_from_buffer
(
&
with_neg_zero
,
"Test User <test@test.tt> 1461698487 -0000"
));
cl_git_pass
(
git_signature_from_buffer
(
&
with_pos_zero
,
"Test User <test@test.tt> 1461698487 +0000"
));
cl_assert
(
!
git_signature__equal
(
with_neg_zero
,
with_pos_zero
));
git_signature_free
((
git_signature
*
)
with_neg_zero
);
git_signature_free
((
git_signature
*
)
with_pos_zero
);
}
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