Steven Walter <stevenrwalter@xxxxxxxxx> writes: > If two processes are racing to create the same directory tree, they will > both see that the directory doesn't exist, both try to mkdir(), and one > of them will fail. This is okay, as we only care that the directory > gets created. So, we add a check for EEXIST from mkdir, and continue if > the directory now exists. > --- Thanks. Please sign-off your patch. > sha1_file.c | 7 +++++++ > 1 file changed, 7 insertions(+) > > diff --git a/sha1_file.c b/sha1_file.c > index 40b2329..c7b7fec 100644 > --- a/sha1_file.c > +++ b/sha1_file.c > @@ -123,6 +123,13 @@ int safe_create_leading_directories(char *path) > } > } > else if (mkdir(path, 0777)) { > + if (errno == EEXIST) { > + /* We could be racing with another process to > + * create the directory. As long as the > + * directory gets created, we don't care. */ > + if (stat(path, &st) && S_ISDIR(st.st_mode)) > + continue; /* * Nice explanation, but we try to format our * multi-line comments like this, slash-asterisk * and nothing else on the opening line, and * asterisk-slash and nothing else on the closing * line. */ Thanks. > + } > *pos = '/'; > return -1; > } -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html