diff options
author | Junio C Hamano <gitster@pobox.com> | 2016-04-06 11:39:06 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-04-06 11:39:06 -0700 |
commit | 67827f582f06b291062389fe43b14db679cc832d (patch) | |
tree | 661a15b2a5225ddf63436e7a4eac6dc4693d36a6 /credential-cache--daemon.c | |
parent | 2f03d174f076d318e45f6b5d4def7451ceaeaa46 (diff) | |
parent | 7d5e9c9849a809ff70223037bf6d569a8e2d3e66 (diff) | |
download | git-67827f582f06b291062389fe43b14db679cc832d.tar.gz |
Merge branch 'jk/credential-cache-comment-exit'
A code clarification.
* jk/credential-cache-comment-exit:
credential-cache--daemon: clarify "exit" action semantics
Diffstat (limited to 'credential-cache--daemon.c')
-rw-r--r-- | credential-cache--daemon.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/credential-cache--daemon.c b/credential-cache--daemon.c index caef21e4fc..291c0fd5e9 100644 --- a/credential-cache--daemon.c +++ b/credential-cache--daemon.c @@ -126,8 +126,17 @@ static void serve_one_client(FILE *in, FILE *out) fprintf(out, "password=%s\n", e->item.password); } } - else if (!strcmp(action.buf, "exit")) + else if (!strcmp(action.buf, "exit")) { + /* + * It's important that we clean up our socket first, and then + * signal the client only once we have finished the cleanup. + * Calling exit() directly does this, because we clean up in + * our atexit() handler, and then signal the client when our + * process actually ends, which closes the socket and gives + * them EOF. + */ exit(0); + } else if (!strcmp(action.buf, "erase")) remove_credential(&c); else if (!strcmp(action.buf, "store")) { |