From: René Scharfe Date: Sat, 16 Aug 2014 21:48:33 +0000 (+0200) Subject: turn path macros into inline function X-Git-Tag: v2.2.0-rc0~154^2 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=bf7283465b42e43b8822a8575abd1a7c6c82e7c9;p=thirdparty%2Fgit.git turn path macros into inline function Use static inline functions instead of macros for has_dos_drive_prefix, offset_1st_component, is_dir_sep and find_last_dir_sep in order to let the compiler do type checking. The definitions of offset_1st_component and is_dir_sep are switched around because the former uses the latter. Signed-off-by: Rene Scharfe Signed-off-by: Junio C Hamano --- diff --git a/git-compat-util.h b/git-compat-util.h index ec41cfb23c..73a0f3e139 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -267,19 +267,35 @@ extern char *gitbasename(char *); #endif #ifndef has_dos_drive_prefix -#define has_dos_drive_prefix(path) 0 +static inline int git_has_dos_drive_prefix(const char *path) +{ + return 0; +} +#define has_dos_drive_prefix git_has_dos_drive_prefix #endif -#ifndef offset_1st_component -#define offset_1st_component(path) (is_dir_sep((path)[0])) +#ifndef is_dir_sep +static inline int git_is_dir_sep(int c) +{ + return c == '/'; +} +#define is_dir_sep git_is_dir_sep #endif -#ifndef is_dir_sep -#define is_dir_sep(c) ((c) == '/') +#ifndef offset_1st_component +static inline int git_offset_1st_component(const char *path) +{ + return is_dir_sep(path[0]); +} +#define offset_1st_component git_offset_1st_component #endif #ifndef find_last_dir_sep -#define find_last_dir_sep(path) strrchr(path, '/') +static inline char *git_find_last_dir_sep(const char *path) +{ + return strrchr(path, '/'); +} +#define find_last_dir_sep git_find_last_dir_sep #endif #if defined(__HP_cc) && (__HP_cc >= 61000)