All of lore.kernel.org
 help / color / mirror / Atom feed
From: Junio C Hamano <gitster@pobox.com>
To: "Bradford C. Smith" <bradford.carl.smith@gmail.com>
Cc: git@vger.kernel.org
Subject: Re: [PATCH 1/2] resolve symlinks when creating lockfiles
Date: Wed, 25 Jul 2007 16:35:45 -0700	[thread overview]
Message-ID: <7vbqe0cazy.fsf@assigned-by-dhcp.cox.net> (raw)
In-Reply-To: <11853821951367-git-send-email-bradford.carl.smith@gmail.com> (Bradford C. Smith's message of "Wed, 25 Jul 2007 12:49:52 -0400")

This probably is going in the right direction, but the code is
too densely formatted and unreviewable.  Please imitate the
layout convention of the other parts of the code.

> +/**
> + * p = absolute or relative path name
> + *
> + * Return a pointer into p showing the beginning of the last path name
> + * element.  If p is empty or the root directory ("/"), just return p.
> + */

	/*
         * multi-line comments look like this without the extra
         * asterisk at the beginning of the first line.
         */

> +static char * last_path_elm(char * p)

char *last_path_elem(char *p)

> +{
> +	int	p_len = strlen(p);
> +	char *	r;
> +
> +	if (p_len < 1) return p;

        char *r;
	int p_len = strlen(p);

        if (p_len < 1)
                return p;

Aren't p and r of type "const char *", I wonder...

> +	/* r points to last non-null character in p */
> +	r = p + p_len - 1;
> +	/* first skip any trailing slashes */
> +	while (*r == '/' && r > p) r--;

That is

	r = strrchr(p, '/');

isn't it?

> +/**
> + * p = char array containing path to existing file or symlink
> + * s = size of p
> + *
> + * If p indicates a valid symlink to an existing file, overwrite p with
> + * the path to the real file.  Otherwise, leave p unmodified.

I suspect some callers use lockfile interface to create a new
file.  There will be a symlink to not-yet-created real file,
that is.

  parent reply	other threads:[~2007-07-25 23:35 UTC|newest]

Thread overview: 28+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-07-15 21:27 git-config: replaces ~/.gitconfig symlink with real file Bradford Smith
2007-07-15 23:30 ` Johannes Schindelin
2007-07-16  9:37 ` Nikolai Weibull
2007-07-16 11:33   ` Bradford Smith
2007-07-16 13:26     ` Bradford Smith
2007-07-16 22:46       ` Junio C Hamano
2007-07-25 16:49         ` [PATCH 0/2] git-config should not replace symlink Bradford C. Smith
2007-07-25 16:49           ` [PATCH 1/2] resolve symlinks when creating lockfiles Bradford C. Smith
2007-07-25 16:49             ` [PATCH 2/2] use lockfile.c routines in git_commit_set_multivar() Bradford C. Smith
2007-07-25 23:35             ` Junio C Hamano [this message]
2007-07-26 16:55               ` [PATCH] " Bradford C. Smith
2007-07-26 18:31                 ` Johannes Schindelin
2007-07-26 18:48                   ` Bradford Smith
2007-07-27  4:30                     ` Junio C Hamano
2007-07-27  4:53                       ` Junio C Hamano
2007-07-27  9:05                         ` Johannes Schindelin
2007-07-27 18:24                         ` Bradford Smith
2007-07-26 17:34               ` [PATCH] fully resolve symlinks when creating lockfiles Bradford C. Smith
2007-07-26 18:35                 ` Johannes Schindelin
2007-07-26 19:34                 ` Morten Welinder
2007-07-27 16:50                   ` Bradford Smith
2007-07-27  7:05                 ` Junio C Hamano
2007-07-17 13:56       ` git-config: replaces ~/.gitconfig symlink with real file Johannes Schindelin
2007-07-17 14:27         ` Matthieu Moy
2007-07-17 20:35         ` Fredrik Tolf
2007-07-17 20:48           ` Johannes Schindelin
2007-07-17 13:39 ` Catalin Marinas
2007-07-17 16:09   ` Johannes Schindelin

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=7vbqe0cazy.fsf@assigned-by-dhcp.cox.net \
    --to=gitster@pobox.com \
    --cc=bradford.carl.smith@gmail.com \
    --cc=git@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.