Unlocalized isspace and friends

Do our own ctype.h, just to get the sane semantics: we want
locale-independence, _and_ we want the right signed behaviour. Plus we
only use a very small subset of ctype.h anyway (isspace, isalpha,
isdigit and isalnum).

Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Linus Torvalds 2005-10-13 11:03:18 -07:00 committed by Junio C Hamano
parent d402d5566f
commit 4546738b58
16 changed files with 51 additions and 14 deletions

View File

@ -159,7 +159,8 @@ LIB_OBJS = \
object.o pack-check.o patch-delta.o path.o pkt-line.o \ object.o pack-check.o patch-delta.o path.o pkt-line.o \
quote.o read-cache.o refs.o run-command.o \ quote.o read-cache.o refs.o run-command.o \
server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \ server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \
tag.o tree.o usage.o config.o environment.o $(DIFF_OBJS) tag.o tree.o usage.o config.o environment.o ctype.o \
$(DIFF_OBJS)
LIBS = $(LIB_FILE) LIBS = $(LIB_FILE)
LIBS += -lz LIBS += -lz

View File

@ -6,7 +6,6 @@
* This applies patches on top of some (arbitrary) version of the SCM. * This applies patches on top of some (arbitrary) version of the SCM.
* *
*/ */
#include <ctype.h>
#include <fnmatch.h> #include <fnmatch.h>
#include "cache.h" #include "cache.h"

26
cache.h
View File

@ -387,4 +387,30 @@ extern int git_config_bool(const char *, const char *);
extern char git_default_email[MAX_GITNAME]; extern char git_default_email[MAX_GITNAME];
extern char git_default_name[MAX_GITNAME]; extern char git_default_name[MAX_GITNAME];
/* Sane ctype - no locale, and works with signed chars */
#undef isspace
#undef isdigit
#undef isalpha
#undef isalnum
#undef tolower
#undef toupper
extern unsigned char sane_ctype[256];
#define GIT_SPACE 0x01
#define GIT_DIGIT 0x02
#define GIT_ALPHA 0x04
#define sane_istest(x,mask) ((sane_ctype[(unsigned char)(x)] & (mask)) != 0)
#define isspace(x) sane_istest(x,GIT_SPACE)
#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 tolower(x) sane_case((unsigned char)(x), 0x20)
#define toupper(x) sane_case((unsigned char)(x), 0)
static inline int sane_case(int x, int high)
{
if (sane_istest(x, GIT_ALPHA))
x = (x & ~0x20) | high;
return x;
}
#endif /* CACHE_H */ #endif /* CACHE_H */

View File

@ -7,7 +7,6 @@
#include <pwd.h> #include <pwd.h>
#include <time.h> #include <time.h>
#include <ctype.h>
#define BLOCKING (1ul << 14) #define BLOCKING (1ul << 14)

View File

@ -1,4 +1,3 @@
#include <ctype.h>
#include "tag.h" #include "tag.h"
#include "commit.h" #include "commit.h"
#include "cache.h" #include "cache.h"

View File

@ -1,4 +1,3 @@
#include <ctype.h>
#include "cache.h" #include "cache.h"

View File

@ -1,6 +1,5 @@
#define _XOPEN_SOURCE /* glibc2 needs this */ #define _XOPEN_SOURCE /* glibc2 needs this */
#include <time.h> #include <time.h>
#include <ctype.h>
#include "cache.h" #include "cache.h"
struct entry { struct entry {

23
ctype.c Normal file
View File

@ -0,0 +1,23 @@
/*
* Sane locale-independent, ASCII ctype.
*
* No surprises, and works with signed and unsigned chars.
*/
#include "cache.h"
#define SS GIT_SPACE
#define AA GIT_ALPHA
#define DD GIT_DIGIT
unsigned char sane_ctype[256] = {
0, 0, 0, 0, 0, 0, 0, 0, 0, SS, SS, 0, 0, SS, 0, 0, /* 0-15 */
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* 16-15 */
SS, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, /* 32-15 */
DD, DD, DD, DD, DD, DD, DD, DD, DD, DD, 0, 0, 0, 0, 0, 0, /* 48-15 */
0, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, /* 64-15 */
AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, 0, 0, 0, 0, 0, /* 80-15 */
0, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, /* 96-15 */
AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, AA, 0, 0, 0, 0, 0, /* 112-15 */
/* Nothing in the 128.. range */
};

1
date.c
View File

@ -4,7 +4,6 @@
* Copyright (C) Linus Torvalds, 2005 * Copyright (C) Linus Torvalds, 2005
*/ */
#include <ctype.h>
#include <time.h> #include <time.h>
#include "cache.h" #include "cache.h"

View File

@ -1,4 +1,3 @@
#include <ctype.h>
#include "cache.h" #include "cache.h"
#include "diff.h" #include "diff.h"
#include "commit.h" #include "commit.h"

View File

@ -9,7 +9,6 @@
#include <pwd.h> #include <pwd.h>
#include <time.h> #include <time.h>
#include <ctype.h>
static char git_default_date[50]; static char git_default_date[50];

View File

@ -11,7 +11,6 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <string.h> #include <string.h>
#include <stdio.h> #include <stdio.h>
#include <ctype.h>
#include <assert.h> #include <assert.h>
#include "cache.h" #include "cache.h"

View File

@ -1,4 +1,3 @@
#include <ctype.h>
#include "cache.h" #include "cache.h"
#include "object.h" #include "object.h"
#include "delta.h" #include "delta.h"

View File

@ -1,4 +1,3 @@
#include <ctype.h>
#include "cache.h" #include "cache.h"
static void flush_current_id(int patchlen, unsigned char *id, SHA_CTX *c) static void flush_current_id(int patchlen, unsigned char *id, SHA_CTX *c)

1
refs.c
View File

@ -2,7 +2,6 @@
#include "cache.h" #include "cache.h"
#include <errno.h> #include <errno.h>
#include <ctype.h>
/* We allow "recursive" symbolic refs. Only within reason, though */ /* We allow "recursive" symbolic refs. Only within reason, though */
#define MAXDEPTH 5 #define MAXDEPTH 5

View File

@ -1,6 +1,5 @@
#include "cache.h" #include "cache.h"
#include "refs.h" #include "refs.h"
#include <ctype.h>
static const char git_update_ref_usage[] = "git-update-ref <refname> <value> [<oldval>]"; static const char git_update_ref_usage[] = "git-update-ref <refname> <value> [<oldval>]";