I've a new_git_repository
containing:
new_git_repository(
name = "hyperscan",
build_file = "//external-deps/hyperscan:BUILD",
commit = "[COMMIT_HASH]",
remote = "https://github.com/intel/hyperscan.git",
shallow_since = "2018-07-09",
)
When building it says:
DEBUG: Rule 'hyperscan' indicated that a canonical reproducible form can be obtained by modifying arguments shallow_since = "1531154744 -0400"
According to this, shouldn't the shallow_since
format be of YYYY-MM-DD
?
And next, what does shallow_since = "1531154744 -0400"
mean?!
Bazel does not process the string specified as shallow_since
attribute and passes it directly to git as --shallow-since
parameter. It can be seen in Bazel source code here.
The value you see is Git internal date format which is <unix timestamp> <time zone offset>
, where <unix timestamp>
is the number of seconds since the UNIX epoch. <time zone offset>
is a positive or negative offset from UTC. For example CET (which is 1 hour ahead of UTC) is +0100
.
Here is the tool for unix timestamp
conversion to the human-readable date/time and back.
Bazel uses git log --date=raw to get the timestamp of the commit, and then does a string comparison with the value of shallow_since. In my opinion, it is a bug in Bazel - it should do a date comparison instead.