xref: /openbsd-src/gnu/usr.bin/cvs/os2/options.h (revision 780d15dfff9934c79e6717020f46114c9b7d7d04)
1 /*
2  * Copyright (c) 1992, Brian Berliner and Jeff Polk
3  * Copyright (c) 1989-1992, Brian Berliner
4  *
5  * You may distribute under the terms of the GNU General Public License as
6  * specified in the README file that comes with the CVS 1.4 kit.
7  *
8  * This file holds (most of) the configuration tweaks that can be made to
9  * customize CVS for your site.  CVS comes configured for a typical SunOS 4.x
10  * environment.  The comments for each configurable item are intended to be
11  * self-explanatory.  All #defines are tested first to see if an over-riding
12  * option was specified on the "make" command line.
13  *
14  * If special libraries are needed, you will have to edit the Makefile.in file
15  * or the configure script directly.  Sorry.
16  */
17 
18 /*
19  * CVS provides the most features when used in conjunction with the Version-5
20  * release of RCS.  Thus, it is the default.  This also assumes that GNU diff
21  * Version-1.15 is being used as well -- you will have to configure your RCS
22  * V5 release separately to make this the case. If you do not have RCS V5 and
23  * GNU diff V1.15, comment out this define. You should not try mixing and
24  * matching other combinations of these tools.
25  */
26 #ifndef HAVE_RCS5
27 #define	HAVE_RCS5
28 #endif
29 
30 /*
31  * For portability and heterogeneity reasons, CVS is shipped by default using
32  * my own text-file version of the ndbm database library in the src/myndbm.c
33  * file.  If you want better performance and are not concerned about
34  * heterogeneous hosts accessing your modules file, turn this option off.
35  */
36 #ifndef MY_NDBM
37 #define	MY_NDBM
38 #endif
39 
40 /*
41  * The "diff" program to execute when creating patch output.  This "diff"
42  * must support the "-c" option for context diffing.  Specify a full
43  * pathname if your site wants to use a particular diff.  If you are
44  * using the GNU version of diff (version 1.15 or later), this should
45  * be "diff -a".
46  *
47  * NOTE: this program is only used for the ``patch'' sub-command (and
48  * for ``update'' if you are using the server).  The other commands
49  * use rcsdiff which will use whatever version of diff was specified
50  * when rcsdiff was built on your system.
51  */
52 
53 #ifndef DIFF
54 #define	DIFF	"diff"
55 #endif
56 
57 /*
58  * The "patch" program to run when using the CVS server and accepting
59  * patches across the network.  Specify a full pathname if your site
60  * wants to use a particular patch.
61  *
62  * We call this "cvspatch" because of reports of a native OS/2 "patch"
63  * program that does not behave the way CVS expects.  So OS/2 users
64  * should get a GNU patch and call it "cvspatch.exe".
65  */
66 #ifndef PATCH_PROGRAM
67 #define PATCH_PROGRAM	"cvspatch"
68 #endif
69 
70 /*
71  * By default, RCS programs are executed with the shell or through execlp(),
72  * so the user's PATH environment variable is searched.  If you'd like to
73  * bind all RCS programs to a certain directory (perhaps one not in most
74  * people's PATH) then set the default in RCSBIN_DFLT.  Note that setting
75  * this here will cause all RCS programs to be executed from this directory,
76  * unless the user overrides the default with the RCSBIN environment variable
77  * or the "-b" option to CVS.
78  *
79  * If you use the password-authenticating server, then you need to
80  * make sure that the server can find the RCS programs to invoke them.
81  * The authenticating server starts out running as root, and then
82  * switches to run as the appropriate user once authentication is
83  * complete.  But no actual shell is ever started by that user, so the
84  * PATH environment variable may not contain the directory with the
85  * RCS binaries, even though if that user logged in normally, PATH
86  * would include the directory.
87  *
88  * One way to solve this problem is to set RCSBIN_DFLT here.  An
89  * alternative is to make sure that root has the right directory in
90  * its path already.  Another, probably better alternative is to
91  * specify -b in /etc/inetd.conf.
92  *
93  * This define should be either the empty string ("") or a full pathname to the
94  * directory containing all the installed programs from the RCS distribution.
95  */
96 #ifndef RCSBIN_DFLT
97 #define	RCSBIN_DFLT	""
98 #endif
99 
100 /* Directory used for storing temporary files, if not overridden by
101    environment variables or the -T global option.  There should be little
102    need to change this (-T is a better mechanism if you need to use a
103    different directory for temporary files).  */
104 #ifndef TMPDIR_DFLT
105 #define	TMPDIR_DFLT	"c:\\temp"
106 #endif
107 
108 /*
109  * The default editor to use, if one does not specify the "-e" option to cvs,
110  * or does not have an EDITOR environment variable.  I set this to just "vi",
111  * and use the shell to find where "vi" actually is.  This allows sites with
112  * /usr/bin/vi or /usr/ucb/vi to work equally well (assuming that your PATH
113  * is reasonable).
114  *
115  * The notepad program seems to be Windows NT's bare-bones text editor.
116  */
117 #ifndef EDITOR_DFLT
118 #define	EDITOR_DFLT	"notepad"
119 #endif
120 
121 /*
122  * The default umask to use when creating or otherwise setting file or
123  * directory permissions in the repository.  Must be a value in the
124  * range of 0 through 0777.  For example, a value of 002 allows group
125  * rwx access and world rx access; a value of 007 allows group rwx
126  * access but no world access.  This value is overridden by the value
127  * of the CVSUMASK environment variable, which is interpreted as an
128  * octal number.
129  */
130 #ifndef UMASK_DFLT
131 #define	UMASK_DFLT	002
132 #endif
133 
134 /*
135  * The cvs admin command is restricted to the members of the group
136  * CVS_ADMIN_GROUP.  If this group does not exist, all users are
137  * allowed to run cvs admin.  To disable the cvs admin for all users,
138  * create an empty group CVS_ADMIN_GROUP.  To disable access control for
139  * cvs admin, comment out the define below.
140  *
141  * Under Windows NT and OS/2, this must not be used because it tries
142  * to include <grp.h>.
143  */
144 #ifdef CVS_ADMIN_GROUP
145 /* #define CVS_ADMIN_GROUP "cvsadmin" */
146 #endif
147 
148 /*
149  * The Repository file holds the path to the directory within the source
150  * repository that contains the RCS ,v files for each CVS working directory.
151  * This path is either a full-path or a path relative to CVSROOT.
152  *
153  * The only advantage that I can see to having a relative path is that One can
154  * change the physical location of the master source repository, change one's
155  * CVSROOT environment variable, and CVS will work without problems.  I
156  * recommend using full-paths.
157  */
158 #ifndef RELATIVE_REPOS
159 /* #define	RELATIVE_REPOS	 */
160 #endif
161 
162 /*
163  * When committing or importing files, you must enter a log message.
164  * Normally, you can do this either via the -m flag on the command line or an
165  * editor will be started for you.  If you like to use logging templates (the
166  * rcsinfo file within the $CVSROOT/CVSROOT directory), you might want to
167  * force people to use the editor even if they specify a message with -m.
168  * Enabling FORCE_USE_EDITOR will cause the -m message to be appended to the
169  * temp file when the editor is started.
170  */
171 #ifndef FORCE_USE_EDITOR
172 /* #define 	FORCE_USE_EDITOR */
173 #endif
174 
175 /*
176  * When locking the repository, some sites like to remove locks and assume
177  * the program that created them went away if the lock has existed for a long
178  * time.  This used to be the default for previous versions of CVS.  CVS now
179  * attempts to be much more robust, so lock files should not be left around
180  * by mistake. The new behaviour will never remove old locks (they must now
181  * be removed by hand).  Enabling CVS_FUDGELOCKS will cause CVS to remove
182  * locks that are older than CVSLCKAGE seconds.
183  * Use of this option is NOT recommended.
184  */
185 #ifndef CVS_FUDGELOCKS
186 /* #define CVS_FUDGELOCKS */
187 #endif
188 
189 /*
190  * When committing a permanent change, CVS and RCS make a log entry of
191  * who committed the change.  If you are committing the change logged in
192  * as "root" (not under "su" or other root-priv giving program), CVS/RCS
193  * cannot determine who is actually making the change.
194  *
195  * As such, by default, CVS disallows changes to be committed by users
196  * logged in as "root".  You can disable this option by commenting
197  * out the lines below.
198  *
199  * Under Windows NT, privileges are associated with groups, not users,
200  * so the case in which someone has logged in as root does not occur.
201  * Thus, there is no need for this hack.
202  *
203  * todo: I don't know about OS/2 yet.  -kff
204  */
205 #undef CVS_BADROOT
206 
207 /*
208  * The "cvs diff" command accepts all the single-character options that GNU
209  * diff (1.15) accepts.  Except -D.  GNU diff uses -D as a way to put
210  * cpp-style #define's around the output differences.  CVS, by default, uses
211  * -D to specify a free-form date (like "cvs diff -D '1 week ago'").  If
212  * you would prefer that the -D option of "cvs diff" work like the GNU diff
213  * option, then comment out this define.
214  */
215 #ifndef CVS_DIFFDATE
216 #define	CVS_DIFFDATE
217 #endif
218 
219 /*
220  * define this to enable the SETXID support (see FAQ 4D.13)
221  * [ We have no such thing under OS/2, so far as I know. ]
222  */
223 #undef SETXID_SUPPORT
224 
225 /*
226  * Under OS/2, we build the authenticated client by default.
227  */
228 #define AUTH_CLIENT_SUPPORT 1
229 
230 /* End of CVS configuration section */
231 
232 /*
233  * Externs that are included in libc, but are used frequently enough to
234  * warrant defining here.
235  */
236 #ifndef STDC_HEADERS
237 extern void exit ();
238 #endif
239 
240 #ifndef getwd
241 extern char *getwd ();
242 #endif
243 
244 #ifdef AUTH_CLIENT_SUPPORT
245 char *getpass (char *passbuf);
246 #endif /* AUTH_CLIENT_SUPPORT */
247