/* GNU SED, a batch stream editor. Copyright (C) 1998, 1999, 2002, 2003 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef BASICDEFS_H #define BASICDEFS_H #include <alloca.h> #ifdef HAVE_WCHAR_H # include <wchar.h> #endif #ifdef HAVE_LOCALE_H # include <locale.h> #endif #ifdef HAVE_WCTYPE_H # include <wctype.h> #endif #ifdef BOOTSTRAP # define false 0 # define true 1 # define bool unsigned # define __bool_true_false_are_defined 1 #else # include <stdbool.h> #endif #include <gettext.h> #define N_(String) gettext_noop(String) #define _(String) gettext(String) /* type countT is used to keep track of line numbers, etc. */ typedef unsigned long countT; /* Oftentimes casts are used as an ugly hack to silence warnings * from the compiler. However, sometimes those warnings really * do point to something worth avoiding. I define this * dummy marker to make searching for them with a text editor * much easier, in case I want to verify that they are all * legitimate. It is defined in the way it is so that it is * easy to disable all casts so that the compiler (or lint) * can tell me potentially interesting things about what would * happen to the code without the explicit casts. */ #ifdef LOUD_LINT # define CAST(x) #else # define CAST(x) (x) #endif /* Can the compiler grok function prototypes? */ #if (defined __STDC__ && __STDC__-0) || defined __GNUC__ || __PROTOTYPES # define P_(s) s #else # define P_(s) () #endif /* (VOID *) is the generic pointer type; some ancient compilers don't know about (void *), and typically use (char *) instead. VCAST() is used to cast to and from (VOID *)s --- but if the compiler *does* support (void *) make this a no-op, so that the compiler can detect if we omitted an essential function declaration somewhere. */ #ifndef VOID # define VOID void # define VCAST(t) #else # define VCAST(t) (t) #endif /* some basic definitions to avoid undue promulgating of VCAST ugliness */ #define MALLOC(n,t) (VCAST(t *)ck_malloc((n)*sizeof(t))) #define REALLOC(x,n,t) (VCAST(t *)ck_realloc(VCAST(VOID *)(x),(n)*sizeof(t))) #define MEMDUP(x,n,t) (VCAST(t *)ck_memdup(VCAST(VOID *)(x),(n)*sizeof(t))) #define FREE(x) (ck_free(VCAST(VOID *)x)) #define MEMCPY(d,s,l) (memcpy(VCAST(VOID *)(d),VCAST(const VOID *)(s),l)) #define MEMMOVE(d,s,l) (memmove(VCAST(VOID *)(d),VCAST(const VOID *)(s),l)) #define OB_MALLOC(o,n,t) ((t *)(void *)obstack_alloc(o,(n)*sizeof(t))) #define obstack_chunk_alloc ck_malloc #define obstack_chunk_free ck_free #ifdef HAVE_MEMORY_H # include <memory.h> #endif #ifndef HAVE_MEMMOVE # ifndef memmove /* ../lib/libsed.a provides a memmove() if the system doesn't. Here is where we declare its return type; we don't prototype it because that sometimes causes problems when we're running in bootstrap mode on a system which really does support memmove(). */ extern VOID *memmove(); # endif #endif #ifndef HAVE_MEMCPY # ifndef memcpy # define memcpy(d, s, n) memmove(d, s, n) # endif #endif #ifndef HAVE_STRERROR extern char *strerror P_((int e)); #endif /* handle misdesigned <ctype.h> macros (snarfed from lib/regex.c) */ /* Jim Meyering writes: "... Some ctype macros are valid only for character codes that isascii says are ASCII (SGI's IRIX-4.0.5 is one such system --when using /bin/cc or gcc but without giving an ansi option). So, all ctype uses should be through macros like ISPRINT... If STDC_HEADERS is defined, then autoconf has verified that the ctype macros don't need to be guarded with references to isascii. ... Defining isascii to 1 should let any compiler worth its salt eliminate the && through constant folding." Solaris defines some of these symbols so we must undefine them first. */ #undef ISASCII #if defined STDC_HEADERS || (!defined isascii && !defined HAVE_ISASCII) # define ISASCII(c) 1 #else # define ISASCII(c) isascii(c) #endif #if defined isblank || defined HAVE_ISBLANK # define ISBLANK(c) (ISASCII (c) && isblank (c)) #else # define ISBLANK(c) ((c) == ' ' || (c) == '\t') #endif #undef ISPRINT #define ISPRINT(c) (ISASCII (c) && isprint (c)) #define ISDIGIT(c) (ISASCII (c) && isdigit (c)) #define ISALNUM(c) (ISASCII (c) && isalnum (c)) #define ISALPHA(c) (ISASCII (c) && isalpha (c)) #define ISCNTRL(c) (ISASCII (c) && iscntrl (c)) #define ISLOWER(c) (ISASCII (c) && islower (c)) #define ISPUNCT(c) (ISASCII (c) && ispunct (c)) #define ISSPACE(c) (ISASCII (c) && isspace (c)) #define ISUPPER(c) (ISASCII (c) && isupper (c)) #define ISXDIGIT(c) (ISASCII (c) && isxdigit (c)) #ifndef initialize_main # ifdef __EMX__ # define initialize_main(argcp, argvp) \ { _response(argcp, argvp); _wildcard(argcp, argvp); } # else /* NOT __EMX__ */ # define initialize_main(argcp, argvp) # endif #endif #endif /*!BASICDEFS_H*/