diff options
Diffstat (limited to 'git-compat-util.h')
| -rw-r--r-- | git-compat-util.h | 30 | 
1 files changed, 30 insertions, 0 deletions
| diff --git a/git-compat-util.h b/git-compat-util.h index 8f3972cd32..35b095e8ae 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -153,6 +153,15 @@  #endif  #endif +/* used on Mac OS X */ +#ifdef PRECOMPOSE_UNICODE +#include "compat/precompose_utf8.h" +#else +#define precompose_str(in,i_nfd2nfc) +#define precompose_argv(c,v) +#define probe_utf8_pathname_composition(a,b) +#endif +  #ifndef NO_LIBGEN_H  #include <libgen.h>  #else @@ -457,12 +466,17 @@ static inline int has_extension(const char *filename, const char *ext)  	return len > extlen && !memcmp(filename + len - extlen, ext, extlen);  } +/* in ctype.c, for kwset users */ +extern const char tolower_trans_tbl[256]; +  /* Sane ctype - no locale, and works with signed chars */  #undef isascii  #undef isspace  #undef isdigit  #undef isalpha  #undef isalnum +#undef islower +#undef isupper  #undef tolower  #undef toupper  extern unsigned char sane_ctype[256]; @@ -478,6 +492,8 @@ extern unsigned char sane_ctype[256];  #define isdigit(x) sane_istest(x,GIT_DIGIT)  #define isalpha(x) sane_istest(x,GIT_ALPHA)  #define isalnum(x) sane_istest(x,GIT_ALPHA | GIT_DIGIT) +#define islower(x) sane_iscase(x, 1) +#define isupper(x) sane_iscase(x, 0)  #define is_glob_special(x) sane_istest(x,GIT_GLOB_SPECIAL)  #define is_regex_special(x) sane_istest(x,GIT_GLOB_SPECIAL | GIT_REGEX_SPECIAL)  #define tolower(x) sane_case((unsigned char)(x), 0x20) @@ -491,6 +507,17 @@ static inline int sane_case(int x, int high)  	return x;  } +static inline int sane_iscase(int x, int is_lower) +{ +	if (!sane_istest(x, GIT_ALPHA)) +		return 0; + +	if (is_lower) +		return (x & 0x20) != 0; +	else +		return (x & 0x20) == 0; +} +  static inline int strtoul_ui(char const *s, int base, unsigned int *result)  {  	unsigned long ul; @@ -577,4 +604,7 @@ int rmdir_or_warn(const char *path);   */  int remove_or_warn(unsigned int mode, const char *path); +/* Get the passwd entry for the UID of the current process. */ +struct passwd *xgetpwuid_self(void); +  #endif | 
