From: Phillip Wood <phillip.wood123@gmail.com>
To: Johannes Schindelin via GitGitGadget <gitgitgadget@gmail.com>,
git@vger.kernel.org
Cc: "brian m. carlson" <sandals@crustytoothpaste.net>,
Johannes Schindelin <johannes.schindelin@gmx.de>
Subject: Re: [PATCH v3 0/7] var(win32): do report the GIT_SHELL_PATH that is actually used
Date: Wed, 17 Jul 2024 15:51:40 +0100 [thread overview]
Message-ID: <93ed998e-d331-4d16-a4e5-1ae449763205@gmail.com> (raw)
In-Reply-To: <pull.1760.v3.git.1720904905.gitgitgadget@gmail.com>
Hi Johannes
On 13/07/2024 22:08, Johannes Schindelin via GitGitGadget wrote:
> Changes since v2:
>
> * Now fspathncmp() is overridden on Windows just like fspathcmp().
> * The win32_fspath*cmp() functions now respect core.ignoreCase.
These changes in patch 3 look good. Thanks for fixing this
Phillip
> Changes since v1:
>
> * This patch series now shares the logic that determines the path of the
> Unix shell that Git uses between prepare_shell_cmd() and git var
> GIT_SHELL_PATH.
>
> Johannes Schindelin (7):
> run-command: refactor getting the Unix shell path into its own
> function
> strvec: declare the `strvec_push_nodup()` function globally
> win32: override `fspathcmp()` with a directory separator-aware version
> mingw(is_msys2_sh): handle forward slashes in the `sh.exe` path, too
> run-command(win32): resolve the path to the Unix shell early
> run-command: declare the `git_shell_path()` function globally
> var(win32): do report the GIT_SHELL_PATH that is actually used
>
> builtin/var.c | 3 ++-
> compat/mingw.c | 2 +-
> compat/win32/path-utils.c | 37 +++++++++++++++++++++++++++++++++++++
> compat/win32/path-utils.h | 4 ++++
> dir.c | 4 ++--
> dir.h | 4 ++--
> git-compat-util.h | 8 ++++++++
> run-command.c | 17 ++++++++++++-----
> run-command.h | 5 +++++
> strvec.c | 2 +-
> strvec.h | 3 +++
> t/t0007-git-var.sh | 2 +-
> 12 files changed, 78 insertions(+), 13 deletions(-)
>
>
> base-commit: 06e570c0dfb2a2deb64d217db78e2ec21672f558
> Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1760%2Fdscho%2Fgit-var-on-windows-v3
> Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1760/dscho/git-var-on-windows-v3
> Pull-Request: https://github.com/gitgitgadget/git/pull/1760
>
> Range-diff vs v2:
>
> 1: e0970381042 = 1: e0970381042 run-command: refactor getting the Unix shell path into its own function
> 2: 91ebccbc39f = 2: 91ebccbc39f strvec: declare the `strvec_push_nodup()` function globally
> 3: a718183bb3b ! 3: f46315ac0b2 win32: override `fspathcmp()` with a directory separator-aware version
> @@ Commit message
> This means that the paths `a/b` and `a\b` are equivalent, and
> `fspathcmp()` needs to be made aware of that fact.
>
> + Note that we have to override both `fspathcmp()` and `fspathncmp()`, and
> + the former cannot be a mere pre-processor constant that transforms calls
> + to `fspathcmp(a, b)` into `fspathncmp(a, b, (size_t)-1)` because the
> + function `report_collided_checkout()` in `unpack-trees.c` wants to
> + assign `list.cmp = fspathcmp`.
> +
> + Also note that `fspatheq()` does _not_ need to be overridden because it
> + calls `fspathcmp()` internally.
> +
> Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
>
> ## compat/win32/path-utils.c ##
> +@@
> + #include "../../git-compat-util.h"
> ++#include "../../environment.h"
> +
> + int win32_has_dos_drive_prefix(const char *path)
> + {
> @@ compat/win32/path-utils.c: int win32_offset_1st_component(const char *path)
>
> return pos + is_dir_sep(*pos) - path;
> }
> +
> -+int win32_fspathcmp(const char *a, const char *b)
> ++int win32_fspathncmp(const char *a, const char *b, size_t count)
> +{
> + int diff;
> +
> + for (;;) {
> ++ if (!count--)
> ++ return 0;
> + if (!*a)
> -+ return !*b ? 0 : -1;
> ++ return *b ? -1 : 0;
> + if (!*b)
> + return +1;
> +
> @@ compat/win32/path-utils.c: int win32_offset_1st_component(const char *path)
> + } else if (is_dir_sep(*b))
> + return +1;
> +
> -+ diff = (unsigned char)tolower(*(a++)) - (unsigned char)tolower(*(b++));
> ++ diff = ignore_case ?
> ++ (unsigned char)tolower(*a) - (int)(unsigned char)tolower(*b) :
> ++ (unsigned char)*a - (int)(unsigned char)*b;
> + if (diff)
> + return diff;
> ++ a++;
> ++ b++;
> + }
> ++}
> ++
> ++int win32_fspathcmp(const char *a, const char *b)
> ++{
> ++ return win32_fspathncmp(a, b, (size_t)-1);
> +}
>
> ## compat/win32/path-utils.h ##
> @@ compat/win32/path-utils.h: static inline int win32_has_dir_sep(const char *path)
> #define offset_1st_component win32_offset_1st_component
> +int win32_fspathcmp(const char *a, const char *b);
> +#define fspathcmp win32_fspathcmp
> ++int win32_fspathncmp(const char *a, const char *b, size_t count);
> ++#define fspathncmp win32_fspathncmp
>
> #endif
>
> @@ dir.c: int count_slashes(const char *s)
> {
> return ignore_case ? strcasecmp(a, b) : strcmp(a, b);
> }
> +@@ dir.c: int fspatheq(const char *a, const char *b)
> + return !fspathcmp(a, b);
> + }
> +
> +-int fspathncmp(const char *a, const char *b, size_t count)
> ++int git_fspathncmp(const char *a, const char *b, size_t count)
> + {
> + return ignore_case ? strncasecmp(a, b, count) : strncmp(a, b, count);
> + }
>
> ## dir.h ##
> @@ dir.h: int remove_dir_recursively(struct strbuf *path, int flag);
> @@ dir.h: int remove_dir_recursively(struct strbuf *path, int flag);
> -int fspathcmp(const char *a, const char *b);
> +int git_fspathcmp(const char *a, const char *b);
> int fspatheq(const char *a, const char *b);
> - int fspathncmp(const char *a, const char *b, size_t count);
> +-int fspathncmp(const char *a, const char *b, size_t count);
> ++int git_fspathncmp(const char *a, const char *b, size_t count);
> unsigned int fspathhash(const char *str);
> +
> + /*
>
> ## git-compat-util.h ##
> @@ git-compat-util.h: static inline int git_offset_1st_component(const char *path)
> #define offset_1st_component git_offset_1st_component
> #endif
>
> -+
> +#ifndef fspathcmp
> +#define fspathcmp git_fspathcmp
> +#endif
> ++
> ++#ifndef fspathncmp
> ++#define fspathncmp git_fspathncmp
> ++#endif
> +
> #ifndef is_valid_path
> #define is_valid_path(path) 1
> 4: f04cfd91bd9 = 4: 60fde81d35c mingw(is_msys2_sh): handle forward slashes in the `sh.exe` path, too
> 5: 707daf246bd = 5: 797cf9094ea run-command(win32): resolve the path to the Unix shell early
> 6: a74a7b4bb11 = 6: 7c53a4f4707 run-command: declare the `git_shell_path()` function globally
> 7: 8bfd23cfa00 = 7: 7c8eba5bfd8 var(win32): do report the GIT_SHELL_PATH that is actually used
>
next prev parent reply other threads:[~2024-07-17 14:51 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-07-08 13:02 [PATCH] var(win32): do report the GIT_SHELL_PATH that is actually used Johannes Schindelin via GitGitGadget
2024-07-08 18:54 ` Junio C Hamano
2024-07-08 23:40 ` brian m. carlson
2024-07-08 23:55 ` Junio C Hamano
2024-07-09 0:25 ` brian m. carlson
2024-07-09 16:31 ` Junio C Hamano
2024-07-09 13:53 ` Phillip Wood
2024-07-08 19:03 ` Junio C Hamano
2024-07-09 8:55 ` Phillip Wood
2024-07-11 12:03 ` Johannes Schindelin
2024-07-17 14:55 ` phillip.wood123
2024-07-11 23:11 ` [PATCH v2 0/7] " Johannes Schindelin via GitGitGadget
2024-07-11 23:11 ` [PATCH v2 1/7] run-command: refactor getting the Unix shell path into its own function Johannes Schindelin via GitGitGadget
2024-07-11 23:11 ` [PATCH v2 2/7] strvec: declare the `strvec_push_nodup()` function globally Johannes Schindelin via GitGitGadget
2024-07-11 23:11 ` [PATCH v2 3/7] win32: override `fspathcmp()` with a directory separator-aware version Johannes Schindelin via GitGitGadget
2024-07-12 13:46 ` Phillip Wood
2024-07-11 23:11 ` [PATCH v2 4/7] mingw(is_msys2_sh): handle forward slashes in the `sh.exe` path, too Johannes Schindelin via GitGitGadget
2024-07-12 13:49 ` Phillip Wood
2024-07-11 23:11 ` [PATCH v2 5/7] run-command(win32): resolve the path to the Unix shell early Johannes Schindelin via GitGitGadget
2024-07-11 23:11 ` [PATCH v2 6/7] run-command: declare the `git_shell_path()` function globally Johannes Schindelin via GitGitGadget
2024-07-11 23:11 ` [PATCH v2 7/7] var(win32): do report the GIT_SHELL_PATH that is actually used Johannes Schindelin via GitGitGadget
2024-07-12 15:35 ` Junio C Hamano
2024-07-12 13:51 ` [PATCH v2 0/7] " Phillip Wood
2024-07-12 22:16 ` Junio C Hamano
2024-07-13 21:08 ` [PATCH v3 " Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 1/7] run-command: refactor getting the Unix shell path into its own function Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 2/7] strvec: declare the `strvec_push_nodup()` function globally Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 3/7] win32: override `fspathcmp()` with a directory separator-aware version Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 4/7] mingw(is_msys2_sh): handle forward slashes in the `sh.exe` path, too Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 5/7] run-command(win32): resolve the path to the Unix shell early Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 6/7] run-command: declare the `git_shell_path()` function globally Johannes Schindelin via GitGitGadget
2024-07-13 21:08 ` [PATCH v3 7/7] var(win32): do report the GIT_SHELL_PATH that is actually used Johannes Schindelin via GitGitGadget
2024-07-17 14:51 ` Phillip Wood [this message]
2024-07-17 22:47 ` [PATCH v3 0/7] " brian m. carlson
2024-07-17 22:51 ` Junio C Hamano
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=93ed998e-d331-4d16-a4e5-1ae449763205@gmail.com \
--to=phillip.wood123@gmail.com \
--cc=git@vger.kernel.org \
--cc=gitgitgadget@gmail.com \
--cc=johannes.schindelin@gmx.de \
--cc=phillip.wood@dunelm.org.uk \
--cc=sandals@crustytoothpaste.net \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).