push: further simplify the logic to assign rejection reason
authorJunio C Hamano <gitster@pobox.com>
Wed, 23 Jan 2013 21:14:48 +0000 (13:14 -0800)
committerJunio C Hamano <gitster@pobox.com>
Thu, 24 Jan 2013 22:37:22 +0000 (14:37 -0800)
First compute the reason why this push would fail if done without
"--force", and then fail it by assigning that reason when the push
was not forced (or if there is no reason to require force, allow it
to succeed).

Record the fact that the push was forced in the forced_update field
only when the push would have failed without the option.

The code becomes shorter, less repetitive and easier to read this
way, especially given that the set of rejection reasons will be
extended in a later patch.

Signed-off-by: Junio C Hamano <gitster@pobox.com>
remote.c

index 3375914abca3f7f1e5f1844f0674fe1543ca4d64..969aa1169036ce8978790e4dae2df66b3f2e4190 100644 (file)
--- a/remote.c
+++ b/remote.c
@@ -1318,23 +1318,18 @@ void set_ref_status_for_push(struct ref *remote_refs, int send_mirror,
                 */
 
                if (!ref->deletion && !is_null_sha1(ref->old_sha1)) {
-                       int nonfastforward =
-                               !has_sha1_file(ref->old_sha1)
-                               || !ref_newer(ref->new_sha1, ref->old_sha1);
-
-                       if (!prefixcmp(ref->name, "refs/tags/")) {
-                               if (!force_ref_update) {
-                                       ref->status = REF_STATUS_REJECT_ALREADY_EXISTS;
-                                       continue;
-                               }
-                               ref->forced_update = 1;
-                       } else if (nonfastforward) {
-                               if (!force_ref_update) {
-                                       ref->status = REF_STATUS_REJECT_NONFASTFORWARD;
-                                       continue;
-                               }
+                       int why = 0; /* why would this push require --force? */
+
+                       if (!prefixcmp(ref->name, "refs/tags/"))
+                               why = REF_STATUS_REJECT_ALREADY_EXISTS;
+                       else if (!has_sha1_file(ref->old_sha1)
+                                || !ref_newer(ref->new_sha1, ref->old_sha1))
+                               why = REF_STATUS_REJECT_NONFASTFORWARD;
+
+                       if (!force_ref_update)
+                               ref->status = why;
+                       else if (why)
                                ref->forced_update = 1;
-                       }
                }
        }
 }