title | layout | date | author | categories | navbar | |
---|---|---|---|---|---|---|
Git Rev News Edition 34 (December 20th, 2017) |
default |
2017-12-20 12:06:51 +0100 |
chriscool |
|
false |
Welcome to the 34th edition of Git Rev News, a digest of all things Git. For our goals, the archives, the way we work, and how to contribute or to subscribe, see the Git Rev News page on git.github.io.
This edition covers what happened during the month of November 2017.
- Thank you Thomas and call for help!
From the beginning in March 2015, Thomas Ferris Nicolaisen very actively contributed to many aspects of Git Rev News. He especially was the main contributor and editor of the Other News and Releases sections. He also reviewed and merged a large number of pull requests and did a lot to improve Git Rev News in general.
Unfortunately, as his daily work has been focusing on higher level things like agile and DevOps for some time, he asked to be de-installed from being an editor.
As there is more and more to do to have a relevant, vibrant and entertaining newsletter for the Git Community, we are thanking Thomas for his huge contribution, and looking for other people to join our small Git Rev News editor team.
There is no need to even know Git well for that. It's possible to participate by just gathering articles about Git, or just checking which are the latest releases for example. Please contact us (see our emails at the bottom) if you are interested.
During the Bloomberg hackathon in London November 11 - 12
Haaris Mehmood prepared a patch to add an --expiry-date
option to
git config
, and then sent it to the mailing list.
Kevin Daudt replied with usual advice to newcomers and the suggestion to look at the SubmittingPatches documentation. Kevin also noticed that a commit message that should explain the motivation for the patch was missing.
Jeff King, alias Peff, replied to both Kevin and Haaris. Peff explained to the mailing list that the patch had been made to complete a task that was proposed during the hackathon, and that the patch has been submitted using submitGit, and that there were explanations in the merge request that Haaris had created with submitGit.
Peff also suggested some ways to improve the patch, and described the motivation for such a patch:
We do parse expiration dates from config in a few places, like gc.reflogexpire, etc. There's no way for a script using git-config to do the same (either adding an option specific to the script, or trying to do some analysis on gc.reflogexpire)..
Haaris replied to Peff saying about the hackathon "It was a pleasure meeting everyone and a great experience!", and discussing the suggestions to improve the patch.
He then came up a few days later with a version 2 of the patch. A few more suggestions to improve it were discussed by Junio Hamano, Marc Branchaud and Christian Couder.
Haaris sent a version 3 a few days later which was reviewed again by Junio who eventually agreed to queue the version 4 which has now been merged into the master branch.
A discussion between Peff, Stefan Beller and Heiko Voigt followed for some time though. This was about clarifying why it is not a good idea, as Junio had told Haaris, for functions that parse config files to die in case of errors.
It appears that those functions are also used to parse .gitmodules
files and that these files are often committed into Git repositories,
so that these files are not always easy to fix if they are malformed.
Doron Behar asked for help about git imap-send
which errored out
when he tried to use it with Gmail:
Password for 'imaps://[email protected]@imap.gmail.com':
sending 3 messages
curl_easy_perform() failed: URL using bad/illegal format or missing URL
Doron thought that it would work better with imap.user = doron.behar
instead of imap.user = [email protected]
in his config file, but
the error was the same.
Replying to Doron Jonathan Nieder asked him a few questions, suggested that a recent commit that makes Git use curl by default for imap might be responsible for the regression, and put Nicolas Morey-Chaisemartin, the commit author, in CC.
Jeff King, alias Peff, followed up by suggesting --no-curl
as a
possible workaround and GIT_TRACE_CURL=1
to get more debug
information.
Peff warned that the trace output enabled by GIT_TRACE_CURL=1
will
contain the IMAP password though. He then sent a patch to redact auth
information from the trace output, but wrote that the patch ended up
being "a lot more complicated" than he would have liked.
Nicolas Morey-Chaisemartin replied to Jonathan saying that Doron's
imap.folder = "[Gmail]/Drafts"
config option was causing the problem
as it appeared to work when he used %5BGmail%5D/Drafts
instead of
"[Gmail]/Drafts"
.
He further explained:
curl is doing some fancy handling with brackets and braces. It make sense for multiple FTP downloads like ftp://ftp.numericals.com/file[1-100].txt, not in our case. The curl command line has a --globoff argument to disable this "regexp" support and it seems to fix the gmail case. However I couldn't find a way to change this value through the API...
Daniel Stenberg, the curl maintainer, replied to Nicolas that globbing isn't part of libcurl which 'actually "just" expects a plain old URL':
But with the risk of falling through the cracks into the rathole that is "what is a URL" (I've blogged about the topic several times in the past and I will surely do it again in the future):
A "legal" URL (as per RFC 3986) does not contain brackets, such symbols should be used URL encoded: %5B and %5D.
This said: I don't know exactly why brackets cause a problem in this case. It could still be worth digging into and see if libcurl could deal with them better here...
Nicolas replied that "it would make sense to have a way to ask libcurl to URI encode for us". But Daniel responded that using the existing curl_easy_escape() function, which URL encodes a string, would not work "on an entire existing URL or path since it would then also encode the slashes etc". Daniel suggested:
You want to encode the relevant pieces and then put them together appropriately into the final URL...
Nicolas recently sent a patch to "URI encode the server folder string before passing it to libcurl".
Eric Sunshine replied that the commit message could be expanded to include information like the error message and "legal" URL not containing brackets. Junio Hamano agreed with Eric, but it looks like Nicolas has not sent an updated patch yet.
- Who are you and what do you do?
In my distant past I spent a long time in academia doing theoretical and computational physics. Around 2001, I switched to full-time software development. I currently work at GitHub, where I get to spend some of my time working on Git development and the rest keeping a large fraction of the world's Git repositories safe and performant. I'm from the U.S., but now live in Berlin with my wife and two kids.
- How did you get involved in the Git project?
My first exposure to Git was as a maintainer of
cvs2svn
, a tool for migrating CVS
repositories to Subversion. After working on that project for a while,
I thought it would be nice to teach it how to convert CVS repositories
to Git, too. Before that I had never even used Git.
Soon I started contributing to Git itself, first by scratching my own
itches (e.g., the fixup
command in interactive rebase, git check-attr --all
, git multimail
, and git diff
heuristics for
producing better diffs).
- What would you name your most important contribution to Git?
At some point I was running git filter-branch
, and I discovered
that it had really terrible performance when processing a lot of
references (branches and tags). That led me deeper and deeper into
Git's code for storing references, and by now it is probably fair to
say that I am the primary maintainer of that part of the code.
For people who don't know, Git stores references in two ways:
-
"Loose" references are stored under
.git/refs/
, as one small file for each reference. These are very fast if you need to read or update only a few references, but it is slow to read many loose references. -
"Packed" references are stored in a big text file called
.git/packed-refs
. It is quite fast to read all of the packed references, but it is slow to change or delete a packed reference because the whole file needs to be rewritten. And until recently, to read even a single packed reference the whole file was read into memory.
Git tries to store active references as "loose" references and the rest as "packed" references. That's a decent compromise, but it has some corner cases with bad performance, and since it has to manage multiple files, it is quite tricky to avoid data races.
I've done a lot to improve the performance of the references code and to support all-or-nothing reference update transactions. Along the way I've fixed a bunch of bugs and data races (hopefully without adding too many new ones).
A big part of my work was abstracting out an internal references API
and modularizing the code. That effort is now paying off by making it
feasible to change fundamentally how references are handled. The first
of these changes just shipped in Git 2.15: now the packed-refs
file
is mmapped to reduce memory usage, and only packed references that are
needed are actually read. This should give a noticeable speedup for
repositories with a lot of references, with another related speed
boost coming in Git 2.16.
- What are you doing on the Git project these days, and why?
If I find some time, I hope to implement "reftables", a new format for storing Git references, in Git. This would further improve reference-handling performance, even for repositories with a huge number of references.
I'm also currently working on a little tool that computes various statistics about a Git repository, to warn users about questionable practices that might lead to performance problems. For example, many people don't realize that using Git to store a directory that has a huge number of entries can lead to terrible performance. It is far better to shard your files into multiple smaller, nested directories. This tool hasn't been open-sourced yet, but should be coming soon.
- What is your favorite Git feature?
The ability to rewrite history, hands down. Thorough code review is
so hard that, in my opinion, code authors should do everything they
can to make their code easy to read. Part of that is breaking changes
down into logical, self-contained baby steps, and making it as obvious
as possible that each step is correct. Nobody wants to read your
stream of consciousness, including false trails and "Oops" commits.
Git has tools, like git rebase --interactive
, that let you revise
your jumbled thoughts into a clear narrative. While I'm putting
together a complicated patch series, I sometimes rebase it dozens of
times before presenting it to the world. (And in the process I usually
discover bugs in my own changes that—thank you Git!—the rest of the
world never has to see.)
If I encounter conflicts, I usually switch to my own tool,
git-imerge
. This breaks
down complicated merge and rebase operations into smaller
"incremental" merges that are done one after the other. This, in my
opinion, makes merge conflicts easier to resolve.
- If you could get a team of expert developers to work full time on something in Git for a full year, what would it be?
First I'd have them spend some time modularizing other parts of the Git codebase, adding docstrings, and improving internal libraries. After that, it'd be easier to implement useful user-facing changes, like making Git scale more gracefully to very large projects.
- If you could remove something from Git without worrying about backward compatibility, what would it be?
I'd make the git checkout
command do only one thing.
- Git 2.15.1
- Git for Windows 2.15.1 and v2.15.1(2)
- tig 2.3.2
- GitLab 10.2.5, 10.1.5 and 10.0.7
- GitHub Enterprise 2.12.1
- Bitbucket Server 5.6
Various
- The next Git Merge conference will be on March 8 in Barcelona, Spain. Hopefully there will be a contributor summit on March 7 at the same venue.
- Packt is doing every book for $5/€5 promo, which includes some books about Git, among others:
- Git: Mastering Version Control course, which is composed of:
- Git Essentials, 2nd Edition
- Git: Version Control for Everyone (which was reviewed by Junio C Hamano on his blog)
- Discussions on Hacker News about the hash transition plan.
- Protecting code integrity with PGP (beta), part of Useful IT Policies project
- Effortlessly maintain a high quality change log with Git notes by Lee Hambley
- In Git Rev News #6 there was link to Using git-notes for marking test suite successes article on the similar topic, by Peter Hutterer
- Welp, there go my Git signatures by Karl Kornel, about what one can do about PGP signatures made with key affected by RoCA vulnerability
Light reading
- Olga Telezhnaia, an Outreachy intern working on Git, is blogging about her experience.
- I Haskell a Git by Vaibhav Sagar, on Git being functional like Haskell and on implementing Git in Haskell, sharing how Git looks like from the inside out
- Squash-merging and other problems with GitHub by Adam Spiers, who posits that "squash before submitting a PR" policy is a poor-man's workaround for the lack of a real solution to the underlying problems
- Introducing container-diff, a tool for quickly comparing container images, on Google Open Source Blog
Git tools and sites
- A bug tracker for Git based on Monorail has been announced by Jonathan Nieder who volunteered to triage bugs. Contact him if you want to help on this.
- git-undo-el -- a command for Emacs to regress or "undo" a region back through its Git history
- Magit Log for a File; Magit is A Git Porcelain inside Emacs and was mentioned multiple times in Git Rev News
- Tools for porting drivers [LWN.net] by Jake Edge, describes Prequel tool (Patch Query Language) that mines the commit history of a code base, among others to help make both forward-porting and back-porting drivers easier
Listening and watching
- All Things Git podcast with Edward Thomson and Martin Woodward release two new episodes in November. One on "Learning Git and Human factors" with Sara Ford, and one about GitHub Universe 2017.
This edition of Git Rev News was curated by Christian Couder <[email protected]>, Jakub Narębski <[email protected]> and Markus Jansen <[email protected]> with help from Michael Haggerty and Johan Abildskov.