On Mon, Apr 01, 2019 at 06:40:36PM +0200, Christian Couder wrote:
> diff --git a/promisor-remote.c b/promisor-remote.c
> new file mode 100644
> index 0000000000..0c768210ee
> --- /dev/null
> +++ b/promisor-remote.c
> @@ -0,0 +1,92 @@
> +#include "cache.h"
> +#include "promisor-remote.h"
> +#include "config.h"
> +
> +static struct promisor_remote *promisors;
> +static struct promisor_remote **promisors_tail = &promisors;
> +
> +static struct promisor_remote *promisor_remote_new(const char *remote_name)
> +{
> +     struct promisor_remote *r;
> +
> +     if (*remote_name == '/') {
> +             warning(_("promisor remote name cannot begin with '/': %s"),
> +                     remote_name);
> +             return NULL;
> +     }
> +
> +     FLEX_ALLOC_STR(r, name, remote_name);
> +
> +     *promisors_tail = r;
> +     promisors_tail = &r->next;
> +
> +     return r;
> +}
> +
> +static struct promisor_remote *promisor_remote_lookup(const char 
> *remote_name,
> +                                                   struct promisor_remote 
> **previous)
> +{
> +     struct promisor_remote *r, *p;
> +
> +     for (p = NULL, r = promisors; r; p = r, r = r->next)
> +             if (r->name && !strcmp(r->name, remote_name)) {

r->name is a FLEX_ARRAY, and Clang complains about this condition:

  promisor-remote.c:34:10: error: address of array 'r->name' will always 
evaluate to 'true' [-Werror,-Wpointer-bool-conversion]
                  if (r->name && !strcmp(r->name, remote_name)) {
                      ~~~^~~~ ~~
  1 error generated.
  make: *** [promisor-remote.o] Error 1

Reply via email to