Re: [PATCH] Functions for updating refs.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



2007/9/4, Junio C Hamano <gitster@xxxxxxxxx>:
> Carlos Rica <jasampler@xxxxxxxxx> writes:
>
> > diff --git a/refs.c b/refs.c
> > index 09a2c87..4fd5065 100644
> > --- a/refs.c
> > +++ b/refs.c
> > @@ -1455,3 +1455,35 @@ int for_each_reflog(each_ref_fn fn, void *cb_data)
> >  {
> >       return do_for_each_reflog("", fn, cb_data);
> >  }
> > +
> > +int update_ref_or_die(const char *action, const char *refname,
> > +                             const unsigned char *sha1,
> > +                             const unsigned char *oldval, int flags)
> > +{
> > +     static struct ref_lock *lock;
> > +     lock = lock_any_ref_for_update(refname, oldval, flags);
> > +     if (!lock)
> > +             die("Cannot lock the ref '%s'.", refname);
> > +     if (write_ref_sha1(lock, sha1, action) < 0)
> > +             die("Cannot update the ref '%s'.", refname);
> > +     return 0;
> > +}
> > +
> > +int update_ref_or_error(const char *action, const char *refname,
> > +                             const unsigned char *sha1,
> > +                             const unsigned char *oldval, int quiet)
> > +{
> > +     static struct ref_lock *lock;
> > +     lock = lock_any_ref_for_update(refname, oldval, 0);
> > +     if (!lock) {
> > +             if (!quiet)
> > +                     error("Cannot lock the ref '%s'.", refname);
> > +             return 1;
> > +     }
> > +     if (write_ref_sha1(lock, sha1, action) < 0) {
> > +             if (!quiet)
> > +                     error("Cannot update the ref '%s'.", refname);
> > +             return 1;
> > +     }
> > +     return 0;
> > +}
>
> This makes me wonder three things:
>
>  - Why doesn't "or_error" side allow "flags" as "or_die" one?
>    Could the 'quiet' option become part of "flags" perhaps?

I saw that the only code that needed the flags was the
builtin-update-ref.c, and it also needed to die(). The
others I saw only want that parameter set to 0.
builtin-tag.c was doing die() also, not using flags, though.

>  - They look quite similar.  Is it a good idea to refactor them
>    further, or they are so small it does not matter?

I would like to know how to refactor it, however the code I saw
sometimes needs to call die(), others to error() and others
need to get only a value of success or not.

The function die() returns 128 and terminates the program,
prepending "fatal: " in the message, while error() doesn't exit
and prepend "error: ", so they were very different and I
resolved to separate them.

Another option is returning different error codes, so
the caller could decide what to output in each case, but
I thought that these functions were only useful to unify those
instructions with those error messages for this common
operation that many builtins use, specially when they come
from scripts who call to "git update-ref".

>
>  - Why isn't lock released with unlock_ref()?

I inspected this some weeks ago, and I finally came to think
that it is released in the write_ref_sha1 call after the lock.
But the code was complex, can someone confirm this?
-
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

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux