revert most files from origtgz deleted in MirBSD base to origtgz
[alioth/cvs.git] / os2 / config.h
1 /* config.h --- configuration file for OS/2
2    Karl Fogel <kfogel@cyclic.com> --- Oct 1995  */
3
4 /* This program is free software; you can redistribute it and/or modify
5    it under the terms of the GNU General Public License as published by
6    the Free Software Foundation; either version 2, or (at your option)
7    any later version.
8
9    This program is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12    GNU General Public License for more details.  */
13
14 /* This file lives in the os2/ subdirectory, which is only included
15  * in your header search path if you're working under IBM C++,
16  * and use os2/makefile (with GNU make for OS/2).  Thus, this is the
17  * right place to put configuration information for OS/2.
18  */
19
20
21 /* We need some system header files here since we evaluate values from
22  * these files below.
23  */
24 #include <stdio.h>
25 #include <errno.h>
26
27
28
29 #ifndef __STDC__
30 /* You bet! */
31 #define __STDC__ 1
32 #endif
33
34 /* The IBM compiler uses the (non-standard) error code EACCESS instead of
35    EACCES (note: one 'S'). Define EACCESS to be EACCES and use the standard
36    name in the code. */
37 #ifndef EACCES
38 #define EACCES EACCESS
39 #endif
40
41 /* Handle some other name differences between the IBM and the Watcom
42  * compiler.
43  */
44 #ifdef __WATCOMC__
45 #define _setmode        setmode
46 #define _cwait          cwait
47 #endif
48
49 /* Some more WATCOM stuff: The watcom compiler defines va_list as an array,
50  * not as a pointer, which will make the vasprintf code break without the
51  * following define:
52  */
53 #ifdef  __WATCOMC__
54 #define VA_LIST_IS_ARRAY
55 #endif
56
57 /* Define if on AIX 3.
58    System headers sometimes define this.
59    We just want to avoid a redefinition error message.  */
60 #undef _ALL_SOURCE
61
62 /* Define to empty if the keyword does not work.  */
63 /* Const is working.  */
64 #undef const
65
66 /* Define to `int' if <sys/types.h> doesn't define.  */
67 /* OS/2 doesn't have gid_t.  It doesn't even really have group
68    numbers, I think.  This will take more thought to get right, but
69    let's get it running first.  */
70 #define gid_t int
71
72 /* Define if you support file names longer than 14 characters.  */
73 /* We support long file names, but not long corporate acronyms. */
74 #define HAVE_LONG_FILE_NAMES 1
75
76 /* Define if you have <sys/wait.h> that is POSIX.1 compatible.  */
77 /* If POSIX.1 requires this, why doesn't WNT have it?  */
78 /* Maybe POSIX only says that if it is present, it must behave a
79    certain way, but that it can simply be not present too.  I
80    dunno. */
81 /* Anyway, OS/2 ain't got it. */
82 #undef HAVE_SYS_WAIT_H
83
84 /* Define if utime(file, NULL) sets file's timestamp to the present.  */
85 /* Documentation says yup; haven't verified experimentally. */
86 #define HAVE_UTIME_NULL 1
87
88 /* Define if on MINIX.  */
89 /* Hah.  */
90 #undef _MINIX
91
92 /* Define to `int' if <sys/types.h> doesn't define.  */
93 #define mode_t int
94
95 /* Define to `int' if <sys/types.h> doesn't define.  */
96 #define pid_t int
97
98 /* Define if the system does not provide POSIX.1 features except
99    with this defined.  */
100 /* This string doesn't appear anywhere in the system header files,
101    so I assume it's irrelevant.  */
102 #undef _POSIX_1_SOURCE
103
104 /* Define if you need to in order for stat and other things to work.  */
105 /* Same as for _POSIX_1_SOURCE, above.  */
106 #undef _POSIX_SOURCE
107
108 /* Define as the return type of signal handlers (int or void).  */
109 /* IBMCPP manual indicates they are void.  */
110 #define RETSIGTYPE void
111
112 /* The default remote shell to use, if one does not specify the CVS_RSH
113    environment variable. */
114 #define RSH_DFLT "rsh"
115
116 /* Define to `unsigned' if <sys/types.h> doesn't define.  */
117 /* sys/types.h doesn't define it, but stdio.h does, which cvs.h
118    #includes, so things should be okay.  */
119 /* #undef size_t */
120
121 /* Define if the `S_IS*' macros in <sys/stat.h> do not work properly. */
122 /* sys/stat.h apparently doesn't even have them; setting this will let
123    ../lib/system.h define them. */
124 #define STAT_MACROS_BROKEN 1
125  
126 /* Define if you have the ANSI C header files.  */
127 /* We have at least a reasonable facsimile thereof. */
128 #define STDC_HEADERS 1
129
130 /* Define if you can safely include both <sys/time.h> and <time.h>.  */
131 /* We don't have <sys/time.h> at all.  Why isn't there a definition
132    for HAVE_SYS_TIME_H anywhere in config.h.in?  */
133 #undef TIME_WITH_SYS_TIME
134
135 /* Define to `int' if <sys/types.h> doesn't define.  */
136 #define uid_t int
137
138 /* Define if you have MIT Kerberos version 4 available.  */
139 /* We don't. */
140 #undef HAVE_KERBEROS
141
142 /* Define if you want CVS to be able to be a remote repository client.  */
143 /* That's all we want.  */
144 #define CLIENT_SUPPORT
145
146 /* Define if you want CVS to be able to serve repositories to remote
147    clients.  */
148 /* No server support yet.  Note that you don't have to define
149    CLIENT_SUPPORT or SERVER_SUPPORT to enable the non-remote code;
150    that's always there.  */
151 #undef SERVER_SUPPORT
152
153 /* Define if you have the connect function.  */
154 /* Not used?  */
155 /* It appears to be used in client.c now... don't know yet it OS/2 has it. */
156 #define HAVE_CONNECT
157
158 /* Define if you have the fchdir function.  */
159 #undef HAVE_FCHDIR
160
161 /* Define if you have the fchmod function.  */
162 #undef HAVE_FCHMOD
163
164 /* Define if you have the fsync function.  */
165 #undef HAVE_FSYNC
166
167 /* Define if you have the ftime function.  */
168 #define HAVE_FTIME 1
169
170 /* Define if you have the ftruncate function.  */
171 #undef HAVE_FTRUNCATE
172
173 /* Define if you have the getpagesize function.  */
174 #undef HAVE_GETPAGESIZE
175
176 /* Define if you have the krb_get_err_text function.  */
177 #undef HAVE_KRB_GET_ERR_TEXT
178
179 /* Define if you have the putenv function.  */
180 #define HAVE_PUTENV 1
181
182 /* Define if you have the sigaction function.  */
183 #undef HAVE_SIGACTION
184
185 /* Define if you have the sigblock function.  */
186 #undef HAVE_SIGBLOCK
187
188 /* Define if you have the sigprocmask function.  */
189 #undef HAVE_SIGPROCMASK
190
191 /* Define if you have the sigsetmask function.  */
192 #undef HAVE_SIGSETMASK
193
194 /* Define if you have the sigvec function.  */
195 #undef HAVE_SIGVEC
196
197 /* Define if you have the timezone function.  */
198 /* Hmm, I actually rather think it's an extern long
199    variable; that message was mechanically generated
200    by autoconf.  And I don't see any actual uses of
201    this function in the code anyway, hmm.  */
202 #undef HAVE_TIMEZONE
203
204 /* Define if you have the tzset function.  */
205 #define HAVE_TZSET 1
206
207 /* Define if you have the vfork function.  */
208 #undef HAVE_VFORK
209
210 /* Define if you have the vprintf function.  */
211 #define HAVE_VPRINTF 1
212
213 /* Define if you have the <direct.h> header file.  */
214 #define HAVE_DIRECT_H 1
215
216 /* Define if you have the <dirent.h> header file.  */
217 /* We have our own dirent.h and dirent.c. */
218 #ifdef __WATCOMC__
219 #undef HAVE_DIRENT_H
220 #else
221 #define HAVE_DIRENT_H 1
222 #endif
223
224 /* Define if you have the <errno.h> header file.  */
225 #define HAVE_ERRNO_H 1
226
227 /* Define if you have the <fcntl.h> header file.  */
228 #define HAVE_FCNTL_H 1
229
230 /* Define if you have the <io.h> header file.  */
231 /* Low-level Unix I/O routines like open, creat, etc.  */
232 #define HAVE_IO_H 1
233
234 /* Define if you have the <memory.h> header file.  */
235 #define HAVE_MEMORY_H 1
236
237 /* Define if you have the <ndbm.h> header file.  */
238 #undef HAVE_NDBM_H
239
240 /* Define if you have the <ndir.h> header file.  */
241 #undef HAVE_NDIR_H
242
243 /* Define if you have the <string.h> header file.  */
244 #define HAVE_STRING_H 1
245
246 /* Define if you have the <sys/bsdtypes.h> header file.  */
247 #undef HAVE_SYS_BSDTYPES_H
248
249 /* Define if you have the <sys/dir.h> header file.  */
250 #undef HAVE_SYS_DIR_H
251
252 /* Define if you have the <sys/ndir.h> header file.  */
253 #undef HAVE_SYS_NDIR_H
254
255 /* Define if you have the <sys/param.h> header file.  */        
256 #undef HAVE_SYS_PARAM_H
257
258 /* Define if you have the <sys/select.h> header file.  */
259 #undef HAVE_SYS_SELECT_H
260
261 /* Define if you have the <sys/time.h> header file.  */
262 #undef HAVE_SYS_TIME_H
263
264 /* Define if you have the <unistd.h> header file.  */
265 #undef HAVE_UNISTD_H
266
267 /* Define if you have the <utime.h> header file.  */
268 #undef HAVE_UTIME_H
269
270 /* Define if you have the <sys/utime.h> header file.  */
271 #define HAVE_SYS_UTIME_H 1
272
273 /* Define if you have the inet library (-linet).  */
274 #undef HAVE_LIBINET
275
276 /* Define if you have the nsl library (-lnsl).  */
277 /* This is not used anywhere in the source code.  */
278 #undef HAVE_LIBNSL
279
280 /* Define if you have the nsl_s library (-lnsl_s).  */
281 #undef HAVE_LIBNSL_S
282
283 /* Define if you have the socket library (-lsocket).  */
284 /* This isn't ever used either.  */
285 #undef HAVE_LIBSOCKET
286
287 /* Under OS/2, mkdir only takes one argument.  */
288 #define CVS_MKDIR os2_mkdir
289 extern int os2_mkdir (const char *PATH, int MODE);
290
291 /* OS/2 needs a special chdir functions that handles drives */
292 #define CVS_CHDIR os2_chdir
293 extern int os2_chdir (const char *Dir);
294
295 /* This function doesn't exist under OS/2; we provide a stub. */
296 extern int readlink (char *path, char *buf, int buf_size);
297
298 /* This is just a call to GetCurrentProcessID.  */
299 #ifndef __WATCOMC__
300 extern pid_t getpid (void);
301 #endif
302
303 /* Under OS/2, filenames are case-insensitive, and both / and \
304    are path component separators.  */
305 #define FOLD_FN_CHAR(c) (OS2_filename_classes[(unsigned char) (c)])
306 extern unsigned char OS2_filename_classes[];
307
308 /* Is the character C a path name separator?  Under OS/2, you can use
309    either / or \.  */
310 #define ISDIRSEP(c) (FOLD_FN_CHAR(c) == '/')
311
312 /* Like strcmp, but with the appropriate tweaks for file names.
313    Under OS/2, filenames are case-insensitive but case-preserving,
314    and both \ and / are path element separators.  */
315 extern int fncmp (const char *n1, const char *n2);
316
317 /* Fold characters in FILENAME to their canonical forms.  
318    If FOLD_FN_CHAR is not #defined, the system provides a default
319    definition for this.  */
320 extern void fnfold (char *FILENAME);
321
322 /* This is where old bits go to die under OS/2 as well as WinNT.  */
323 #define DEVNULL "nul"
324
325 /* Make sure that we don't try to perform operations on RCS files on the
326    local machine.  I think I neglected to apply some changes from
327    MHI's port in that area of code, or found some issues I didn't want
328    to deal with.  */
329 #define CLIENT_ONLY
330
331 /* We actually do have a transparent rsh, whew. */
332 #undef RSH_NOT_TRANSPARENT
333 /* But it won't be transparent unless we ask it nicely! */
334 #define RSH_NEEDS_BINARY_FLAG 1
335
336 /* OS/2 doesn't really have user/group permissions, at least not
337    according to the C library manual pages.  So we'll make decoys.
338    (This was partly introduced for an obsolete reason, now taken care
339    of by CHMOD_BROKEN, but I haven't carefully looked at every case
340    (in particular mode_to_string), so it might still be needed).
341    We do not need that for the watcom compiler since watcom already
342    all those permission bits defined. It would probably be better to
343    include the necessary system header files in system.h, and then make
344    each permission define only if it is not already defined.
345 */
346 #ifndef __WATCOMC__
347 #define NEED_DECOY_PERMISSIONS 1     /* see system.h */
348 #endif
349
350 \f
351
352 /* For the access() function, for which IBM OS/2 compiler has no pre-defined
353    mnemonic masks. */
354 #ifndef __WATCOMC__
355 #define R_OK 04
356 #define W_OK 02
357 #define F_OK 00
358 #define X_OK R_OK  /* I think this is right for OS/2. */
359 #endif
360
361 /* For getpid() */
362 #include <process.h>
363
364 /* So "tcpip.h" gets included in lib/system.h: */
365 #define USE_OWN_TCPIP_H 1
366 /* The IBM TCP/IP library gets initialized in main(): */
367 #define SYSTEM_INITIALIZE(pargc,pargv) init_sockets()
368 extern void init_sockets();
369
370 /* Under OS/2, we have our own popen() and pclose()... */
371 #define USE_OWN_POPEN 1
372 /* ... and we use popenRW to start the rsh server. */
373 #define START_RSH_WITH_POPEN_RW 1
374
375 /*
376  * This tells the client that it must use send()/recv() to talk to the
377  * server if it is connected to the server via a socket.  Sigh.
378  * Windows 95 and VMS cannot convert sockets to file descriptors either,
379  * apparently.
380  */
381 #define NO_SOCKET_TO_FD 1
382
383 /* chmod() doesn't seem to work -- IBM's own example program does not
384  * behave as its documentation claims, in fact!  I suspect that
385  * DosSetPathInfo is the way to go, but can't seem to make that work
386  * either.  For now, we can deal with some cases by invoking the DOS
387  * "attrib" command via system().  */
388 #define CHMOD_BROKEN 1
389
390 /* Rule Number 1 of OS/2 Programming: If the function you're looking
391    for doesn't exist, try putting "Dos" in front of it.
392    Do not forget to include the os2 header file if we use DosSleep. */
393 #ifndef sleep
394 #include "os2inc.h"
395 #define sleep(x) DosSleep(((long)(x))*1000L)
396 #endif /* sleep */
397
398 /* Set to 1 for some debugging messages. */
399 #if 0
400 #define KFF_DEBUG(call) printf("*** %s:%d: ", __FILE__, __LINE__); \
401                         call; fflush(stdout);
402 #else
403 #define KFF_DEBUG(call)
404 #endif
405
406 /*
407  * The following configuration options used to be defined in options.h.
408  */
409
410 /*
411  * When committing a permanent change, CVS and RCS make a log entry of
412  * who committed the change.  If you are committing the change logged in
413  * as "root" (not under "su" or other root-priv giving program), CVS/RCS
414  * cannot determine who is actually making the change.
415  *
416  * As such, by default, CVS disallows changes to be committed by users
417  * logged in as "root".  You can disable this option by commenting
418  * out the lines below.
419  *
420  * Under Windows NT, privileges are associated with groups, not users,
421  * so the case in which someone has logged in as root does not occur.
422  * Thus, there is no need for this hack.
423  *
424  * todo: I don't know about OS/2 yet.  -kff
425  */
426 #undef CVS_BADROOT
427
428 /* This prototype is unique to OS2 */
429 #ifdef AUTH_CLIENT_SUPPORT
430 char *getpass (char *passbuf);
431 #endif /* AUTH_CLIENT_SUPPORT */
432
433 /*
434  * For portability and heterogeneity reasons, CVS is shipped by default using
435  * my own text-file version of the ndbm database library in the src/myndbm.c
436  * file.  If you want better performance and are not concerned about
437  * heterogeneous hosts accessing your modules file, turn this option off.
438  */
439 #ifndef MY_NDBM
440 #define MY_NDBM
441 #endif
442
443 /* Directory used for storing temporary files, if not overridden by
444    environment variables or the -T global option.  There should be little
445    need to change this (-T is a better mechanism if you need to use a
446    different directory for temporary files).  */
447 #ifndef TMPDIR_DFLT
448 #define TMPDIR_DFLT     "c:\\temp"
449 #endif
450
451 /*
452  * The default editor to use, if one does not specify the "-e" option to cvs,
453  * or does not have an EDITOR environment variable.  I set this to just "vi",
454  * and use the shell to find where "vi" actually is.  This allows sites with
455  * /usr/bin/vi or /usr/ucb/vi to work equally well (assuming that your PATH
456  * is reasonable).
457  *
458  * The notepad program seems to be Windows NT's bare-bones text editor.
459  */
460 #ifndef EDITOR_DFLT
461 #define EDITOR_DFLT     "notepad"
462 #endif
463
464 /*
465  * The default umask to use when creating or otherwise setting file or
466  * directory permissions in the repository.  Must be a value in the
467  * range of 0 through 0777.  For example, a value of 002 allows group
468  * rwx access and world rx access; a value of 007 allows group rwx
469  * access but no world access.  This value is overridden by the value
470  * of the CVSUMASK environment variable, which is interpreted as an
471  * octal number.
472  */
473 #ifndef UMASK_DFLT
474 #define UMASK_DFLT      002
475 #endif
476
477 /*
478  * The cvs admin command is restricted to the members of the group
479  * CVS_ADMIN_GROUP.  If this group does not exist, all users are
480  * allowed to run cvs admin.  To disable the cvs admin for all users,
481  * create an empty group CVS_ADMIN_GROUP.  To disable access control for
482  * cvs admin, comment out the define below.
483  *
484  * Under Windows NT and OS/2, this must not be used because it tries
485  * to include <grp.h>.
486  */
487 #ifdef CVS_ADMIN_GROUP
488 /* #define CVS_ADMIN_GROUP "cvsadmin" */
489 #endif
490
491 /*
492  * When committing or importing files, you must enter a log message.
493  * Normally, you can do this either via the -m flag on the command line or an
494  * editor will be started for you.  If you like to use logging templates (the
495  * rcsinfo file within the $CVSROOT/CVSROOT directory), you might want to
496  * force people to use the editor even if they specify a message with -m.
497  * Enabling FORCE_USE_EDITOR will cause the -m message to be appended to the
498  * temp file when the editor is started.
499  */
500 #ifndef FORCE_USE_EDITOR
501 /* #define      FORCE_USE_EDITOR */
502 #endif
503
504 /*
505  * Under OS/2, we build the authenticated client by default.
506  */
507 #define AUTH_CLIENT_SUPPORT 1
508
509 /* End of CVS options.h section */
510
511 /* FIXME: This is the same definition used for WOE32 in lib/system.h.  It
512  * should be consolidated.
513  */
514 #define ISABSOLUTE(s) (ISDIRSEP(s[0]) || FOLD_FN_CHAR(s[0]) >= 'a' && FOLD_FN_CHAR(s[0]) <= 'z' && s[1] == ':' && ISDIRSEP(s[2]))