home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / octa21fs.zip / octave / kpathsea / types.h < prev    next >
C/C++ Source or Header  |  2000-01-15  |  2KB  |  54 lines

  1. /* types.h: general types.
  2.  
  3. Copyright (C) 1993, 95, 96 Free Software Foundation, Inc.
  4.  
  5. This library is free software; you can redistribute it and/or
  6. modify it under the terms of the GNU Library General Public
  7. License as published by the Free Software Foundation; either
  8. version 2 of the License, or (at your option) any later version.
  9.  
  10. This library is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13. Library General Public License for more details.
  14.  
  15. You should have received a copy of the GNU Library General Public
  16. License along with this library; if not, write to the Free Software
  17. Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
  18.  
  19. #ifndef KPATHSEA_TYPES_H
  20. #define KPATHSEA_TYPES_H
  21.  
  22. /* Booleans.  */
  23. #ifdef __cplusplus
  24. /* `true' and `false' are reserved words in C++.  Sigh.  Although sizeof
  25.    (bool) may not equal sizeof (boolean), so this isn't completely
  26.    correct, we never rely on the size of the type.  */
  27. #define boolean bool
  28. #else
  29. /* NeXT wants to define their own boolean type.  */
  30. #ifndef HAVE_BOOLEAN
  31. #define HAVE_BOOLEAN
  32. typedef enum { false = 0, true = 1 } boolean;
  33. #endif /* not HAVE_BOOLEAN */
  34. #endif /* not C++ */
  35.  
  36. /* The X library (among other things) defines `FALSE' and `TRUE', and so
  37.    we only want to define them if necessary, for use by application code.  */
  38. #ifndef FALSE
  39. #define FALSE false
  40. #define TRUE true
  41. #endif /* FALSE */
  42.  
  43. /* The usual null-terminated string.  */
  44. typedef char *string;
  45.  
  46. /* A pointer to constant data.  (ANSI says `const string' is
  47.    `char * const', which is a constant pointer to non-constant data.)  */
  48. typedef const char *const_string;
  49.  
  50. /* A generic pointer.  */
  51. typedef void *address;
  52.  
  53. #endif /* not KPATHSEA_TYPES_H */
  54.