Add missing algorithms to disable, and in particular, disable
[openssl.git] / makevms.com
1 $!
2 $! MAKEVMS.COM
3 $! Original Author:  UNKNOWN
4 $! Rewritten By:  Robert Byer
5 $!                Vice-President
6 $!                A-Com Computing, Inc.
7 $!                byer@mail.all-net.net
8 $!
9 $! Changes by Richard Levitte <richard@levitte.org>
10 $!            Zoltan Arpadffy <zoli@polarhome.com>
11 $!
12 $! This procedure creates the SSL libraries of "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB"
13 $! "[.xxx.EXE.SSL]LIBSSL.OLB"
14 $! The "xxx" denotes the machine architecture of ALPHA, IA64 or VAX.
15 $!
16 $! This procedures accepts two command line options listed below.
17 $!
18 $! P1 specifies one of the following build options:
19 $!
20 $!      ALL       Just build "everything".
21 $!      CONFIG    Just build the "[.CRYPTO._xxx]OPENSSLCONF.H" file.
22 $!      BUILDINF  Just build the "[.CRYPTO._xxx]BUILDINF.H" file.
23 $!      SOFTLINKS Just fix the Unix soft links.
24 $!      BUILDALL  Same as ALL, except CONFIG, BUILDINF and SOFTILNKS aren't done.
25 $!      CRYPTO    Just build the "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB" library.
26 $!      CRYPTO/x  Just build the x part of the
27 $!                "[.xxx.EXE.CRYPTO]LIBCRYPTO.OLB" library.
28 $!      SSL       Just build the "[.xxx.EXE.SSL]LIBSSL.OLB" library.
29 $!      SSL_TASK  Just build the "[.xxx.EXE.SSL]SSL_TASK.EXE" program.
30 $!      TEST      Just build the "[.xxx.EXE.TEST]" test programs for OpenSSL.
31 $!      APPS      Just build the "[.xxx.EXE.APPS]" application programs for OpenSSL.
32 $!      ENGINES   Just build the "[.xxx.EXE.ENGINES]" application programs for OpenSSL.
33 $!
34 $! P2, if defined, specifies the C pointer size.  Ignored on VAX.
35 $!      ("64=ARGV" gives more efficient code with HP C V7.3 or newer.)
36 $!      Supported values are:
37 $!
38 $!      ""       Compile with default (/NOPOINTER_SIZE).
39 $!      32       Compile with /POINTER_SIZE=32 (SHORT).
40 $!      64       Compile with /POINTER_SIZE=64[=ARGV] (LONG[=ARGV]).
41 $!               (Automatically select ARGV if compiler supports it.)
42 $!      64=      Compile with /POINTER_SIZE=64 (LONG).
43 $!      64=ARGV  Compile with /POINTER_SIZE=64=ARGV (LONG=ARGV).
44 $!
45 $! P3 specifies DEBUG or NODEBUG, to compile with or without debugging
46 $!    information.
47 $!
48 $! P4 specifies which compiler to try to compile under.
49 $!
50 $!        VAXC   For VAX C.
51 $!        DECC   For DEC C.
52 $!        GNUC   For GNU C.
53 $!        LINK   To only link the programs from existing object files.
54 $!               (not yet implemented)
55 $!
56 $! If you don't specify a compiler, it will try to determine which
57 $! "C" compiler to use.
58 $!
59 $! P5, if defined, sets a TCP/IP library to use, through one of the following
60 $! keywords:
61 $!
62 $!      UCX             for UCX or UCX emulation
63 $!      TCPIP           for TCP/IP Services or TCP/IP Services emulation
64 $!                      (this is prefered over UCX)
65 $!      SOCKETSHR       for SOCKETSHR+NETLIB
66 $!      NONE            to avoid specifying which TCP/IP implementation to
67 $!                      use at build time (this works with DEC C).  This is
68 $!                      the default.
69 $!
70 $! P6, if defined, sets a compiler thread NOT needed on OpenVMS 7.1 (and up).
71 $!
72 $! P7, if defined, specifies a directory where ZLIB files (zlib.h,
73 $! libz.olb) may be found.  Optionally, a non-default object library
74 $! name may be included ("dev:[dir]libz_64.olb", for example).
75 $!
76 $!
77 $! Announce/identify.
78 $!
79 $ proc = f$environment( "procedure")
80 $ write sys$output "@@@ "+ -
81    f$parse( proc, , , "name")+ f$parse( proc, , , "type")
82 $!
83 $ DEF_ORIG = F$ENVIRONMENT( "DEFAULT")
84 $ ON ERROR THEN GOTO TIDY
85 $ ON CONTROL_C THEN GOTO TIDY
86 $!
87 $! Check if we're in a batch job, and make sure we get to 
88 $! the directory this script is in
89 $!
90 $ IF F$MODE() .EQS. "BATCH"
91 $ THEN
92 $   COMNAME=F$ENVIRONMENT("PROCEDURE")
93 $   COMPATH=F$PARSE("A.;",COMNAME) - "A.;"
94 $   SET DEF 'COMPATH'
95 $ ENDIF
96 $!
97 $! Check What Architecture We Are Using.
98 $!
99 $ IF (F$GETSYI("CPU").LT.128)
100 $ THEN
101 $!
102 $!  The Architecture Is VAX.
103 $!
104 $   ARCH = "VAX"
105 $!
106 $! Else...
107 $!
108 $ ELSE
109 $!
110 $!  The Architecture Is Alpha, IA64 or whatever comes in the future.
111 $!
112 $   ARCH = F$EDIT( F$GETSYI( "ARCH_NAME"), "UPCASE")
113 $   IF (ARCH .EQS. "") THEN ARCH = "UNK"
114 $!
115 $! End The Architecture Check.
116 $!
117 $ ENDIF
118 $!
119 $ ARCHD = ARCH
120 $ LIB32 = "32"
121 $ POINTER_SIZE = ""
122 $!
123 $! Get VMS version.
124 $!
125 $ VMS_VERSION = f$edit( f$getsyi( "VERSION"), "TRIM")
126 $!
127 $! Check To Make Sure We Have Valid Command Line Parameters.
128 $!
129 $ GOSUB CHECK_OPTIONS
130 $!
131 $! Check To See What We Are To Do.
132 $!
133 $ IF (BUILDCOMMAND.EQS."ALL")
134 $ THEN
135 $!
136 $!  Start with building the OpenSSL configuration file.
137 $!
138 $   GOSUB CONFIG
139 $!
140 $!  Create The "BUILDINF.H" Include File.
141 $!
142 $   GOSUB BUILDINF
143 $!
144 $!  Fix The Unix Softlinks.
145 $!
146 $   GOSUB SOFTLINKS
147 $!
148 $ ENDIF
149 $!
150 $ IF (BUILDCOMMAND.EQS."ALL".OR.BUILDCOMMAND.EQS."BUILDALL")
151 $ THEN
152 $!
153 $!  Build The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library.
154 $!
155 $   GOSUB CRYPTO
156 $!
157 $!  Build The [.xxx.EXE.SSL]LIBSSL.OLB Library.
158 $!
159 $   GOSUB SSL
160 $!
161 $!  Build The [.xxx.EXE.SSL]SSL_TASK.EXE DECNet SSL Engine.
162 $!
163 $   GOSUB SSL_TASK
164 $!
165 $!  Build The [.xxx.EXE.TEST] OpenSSL Test Utilities.
166 $!
167 $   GOSUB TEST
168 $!
169 $!  Build The [.xxx.EXE.APPS] OpenSSL Application Utilities.
170 $!
171 $   GOSUB APPS
172 $!
173 $!  Build The [.xxx.EXE.ENGINES] OpenSSL Shareable Engines.
174 $!
175 $   GOSUB ENGINES
176 $!
177 $! Else...
178 $!
179 $ ELSE
180 $!
181 $!    Build Just What The User Wants Us To Build.
182 $!
183 $     GOSUB 'BUILDCOMMAND'
184 $!
185 $ ENDIF
186 $!
187 $! Time To EXIT.
188 $!
189 $ GOTO TIDY
190 $!
191 $! Rebuild The [.CRYPTO._xxx]OPENSSLCONF.H" file.
192 $!
193 $ CONFIG:
194 $!
195 $! Tell The User We Are Creating The [.CRYPTO._xxx]OPENSSLCONF.H File.
196 $!
197 $ WRITE SYS$OUTPUT "Creating [.CRYPTO.''ARCHD']OPENSSLCONF.H Include File."
198 $!
199 $! First, make sure the directory exists.
200 $!
201 $ IF F$PARSE("SYS$DISK:[.CRYPTO.''ARCHD']") .EQS. "" THEN -
202      CREATE/DIRECTORY SYS$DISK:[.CRYPTO.'ARCHD']
203 $!
204 $! Different tar/UnZip versions/option may have named the file differently
205 $ IF F$SEARCH("[.crypto]opensslconf.h_in") .NES. ""
206 $ THEN
207 $   OPENSSLCONF_H_IN = "[.crypto]opensslconf.h_in"
208 $ ELSE
209 $   IF F$SEARCH( "[.crypto]opensslconf_h.in") .NES. ""
210 $   THEN
211 $     OPENSSLCONF_H_IN = "[.crypto]opensslconf_h.in"
212 $   ELSE
213 $     ! For ODS-5
214 $     IF F$SEARCH( "[.crypto]opensslconf.h.in") .NES. ""
215 $     THEN
216 $       OPENSSLCONF_H_IN = "[.crypto]opensslconf.h.in"
217 $     ELSE
218 $       WRITE SYS$ERROR "Couldn't find a [.crypto]opensslconf.h.in.  Exiting!"
219 $       $STATUS = %X00018294 ! "%RMS-F-FNF, file not found".
220 $       GOTO TIDY
221 $     ENDIF
222 $   ENDIF
223 $ ENDIF
224 $!
225 $! Create The [.CRYPTO._xxx]OPENSSLCONF.H File.
226 $! Make sure it has the right format.
227 $!
228 $ OSCH_NAME = "SYS$DISK:[.CRYPTO.''ARCHD']OPENSSLCONF.H"
229 $ CREATE /FDL=SYS$INPUT: 'OSCH_NAME'
230 RECORD
231         FORMAT stream_lf
232 $ OPEN /APPEND H_FILE 'OSCH_NAME'
233 $!
234 $! Write The [.CRYPTO._xxx]OPENSSLCONF.H File.
235 $!
236 $ WRITE H_FILE "/* This file was automatically built using makevms.com */"
237 $ WRITE H_FILE "/* and ''OPENSSLCONF_H_IN' */"
238 $!
239 $! Write a few macros that indicate how this system was built.
240 $!
241 $ WRITE H_FILE ""
242 $ WRITE H_FILE "#ifndef OPENSSL_SYS_VMS"
243 $ WRITE H_FILE "# define OPENSSL_SYS_VMS"
244 $ WRITE H_FILE "#endif"
245 $
246 $! One of the best way to figure out what the list should be is to do
247 $! the following on a Unix system:
248 $!   grep OPENSSL_NO_ crypto/*/*.h ssl/*.h engines/*.h engines/*/*.h|grep ':# *if'|sed -e 's/^.*def //'|sort|uniq
249 $! For that reason, the list will also always end up in alphabetical order
250 $ CONFIG_LOGICALS := AES,-
251                      ASM,INLINE_ASM,-
252                      BF,-
253                      BIO,-
254                      BUFFER,-
255                      BUF_FREELISTS,-
256                      CAMELLIA,-
257                      CAST,-
258                      CMS,-
259                      COMP,-
260                      DEPRECATED,-
261                      DES,-
262                      DGRAM,-
263                      DH,-
264                      DSA,-
265                      EC,-
266                      EC2M,-
267                      ECDH,-
268                      ECDSA,-
269                      EC_NISTP_64_GCC_128,-
270                      ENGINE,-
271                      ERR,-
272                      EVP,-
273                      FP_API,-
274                      GMP,-
275                      GOST,-
276                      HASH_COMP,-
277                      HMAC,-
278                      IDEA,-
279                      JPAKE,-
280                      KRB5,-
281                      LHASH,-
282                      MD2,-
283                      MD4,-
284                      MD5,-
285                      MDC2,-
286                      NEXTPROTONEG,-
287                      OCSP,-
288                      PSK,-
289                      RC2,-
290                      RC4,-
291                      RC5,-
292                      RFC3779,-
293                      RIPEMD,-
294                      RSA,-
295                      SEED,-
296                      SHA,-
297                      SHA0,-
298                      SHA1,-
299                      SHA256,-
300                      SHA512,-
301                      SOCK,-
302                      SRP,-
303                      SSL2,-
304                      SSL_INTERN,-
305                      STACK,-
306                      STATIC_ENGINE,-
307                      STDIO,-
308                      STORE,-
309                      TLSEXT,-
310                      WHIRLPOOL,-
311                      X509
312 $! Add a few that we know about
313 $ CONFIG_LOGICALS := 'CONFIG_LOGICALS',-
314                      THREADS
315 $! The following rules, which dictate how some algorithm choices affect
316 $! others, are picked from Configure.
317 $! Quick syntax:
318 $!  list = item[ ; list]
319 $!  item = algos / dependents
320 $!  algos = algo [, algos]
321 $!  dependents = dependent [, dependents]
322 $! When a list of algos is specified in one item, it means that they must
323 $! all be disabled for the rule to apply.
324 $! When a list of dependents is specified in one item, it means that they
325 $! will all be disabled if the rule applies.
326 $! Rules are checked sequentially.  If a rule disables an algorithm, it will
327 $! affect all following rules that depend on that algorithm being disabled.
328 $! To force something to be enabled or disabled, have no algorithms in the
329 $! algos part.
330 $ CONFIG_DISABLE_RULES := RIJNDAEL/AES;-
331                           DES/MDC2;-
332                           EC/ECDSA,ECDH;-
333                           MD5/SSL2,SSL3,TLS1;-
334                           SHA/SSL3,TLS1;-
335                           RSA/SSL2;-
336                           RSA,DSA/SSL2;-
337                           DH/SSL3,TLS1;-
338                           TLS1/TLSEXT;-
339                           EC/GOST;-
340                           DSA/GOST;-
341                           DH/GOST;-
342                           /STATIC_ENGINE;-
343                           /KRB5;-
344                           /EC_NISTP_64_GCC_128
345 $ CONFIG_ENABLE_RULES := ZLIB_DYNAMIC/ZLIB;-
346                          /THREADS
347 $
348 $! Architecture specific rule addtions
349 $ IF ARCH .EQS. "VAX"
350 $ THEN
351 $   ! Disable algorithms that require 64-bit integers in C
352 $   CONFIG_DISABLE_RULES = CONFIG_DISABLE_RULES + -
353                            ";/GOST" + -
354                            ";/WHIRLPOOL"
355 $ ENDIF
356 $
357 $ CONFIG_LOG_I = 0
358 $ CONFIG_LOG_LOOP1:
359 $   CONFIG_LOG_E = F$EDIT(F$ELEMENT(CONFIG_LOG_I,",",CONFIG_LOGICALS),"TRIM")
360 $   CONFIG_LOG_I = CONFIG_LOG_I + 1
361 $   IF CONFIG_LOG_E .EQS. "" THEN GOTO CONFIG_LOG_LOOP1
362 $   IF CONFIG_LOG_E .EQS. "," THEN GOTO CONFIG_LOG_LOOP1_END
363 $   IF F$TRNLNM("OPENSSL_NO_"+CONFIG_LOG_E)
364 $   THEN
365 $       CONFIG_DISABLED_'CONFIG_LOG_E' := YES
366 $       CONFIG_ENABLED_'CONFIG_LOG_E' := NO
367 $       CONFIG_CHANGED_'CONFIG_LOG_E' := YES
368 $   ELSE
369 $       CONFIG_DISABLED_'CONFIG_LOG_E' := NO
370 $       CONFIG_ENABLED_'CONFIG_LOG_E' := YES
371 $       ! Because all algorithms are assumed enabled by default
372 $       CONFIG_CHANGED_'CONFIG_LOG_E' := NO
373 $   ENDIF
374 $   GOTO CONFIG_LOG_LOOP1
375 $ CONFIG_LOG_LOOP1_END:
376 $
377 $! Apply cascading disable rules
378 $ CONFIG_DISABLE_I = 0
379 $ CONFIG_DISABLE_LOOP0:
380 $   CONFIG_DISABLE_E = F$EDIT(F$ELEMENT(CONFIG_DISABLE_I,";", -
381      CONFIG_DISABLE_RULES),"TRIM")
382 $   CONFIG_DISABLE_I = CONFIG_DISABLE_I + 1
383 $   IF CONFIG_DISABLE_E .EQS. "" THEN GOTO CONFIG_DISABLE_LOOP0
384 $   IF CONFIG_DISABLE_E .EQS. ";" THEN GOTO CONFIG_DISABLE_LOOP0_END
385 $
386 $   CONFIG_DISABLE_ALGOS = F$EDIT(F$ELEMENT(0,"/",CONFIG_DISABLE_E),"TRIM")
387 $   CONFIG_DISABLE_DEPENDENTS = F$EDIT(F$ELEMENT(1,"/",CONFIG_DISABLE_E),"TRIM")
388 $   TO_DISABLE := YES
389 $   CONFIG_ALGO_I = 0
390 $   CONFIG_DISABLE_LOOP1:
391 $     CONFIG_ALGO_E = F$EDIT(F$ELEMENT(CONFIG_ALGO_I,",", -
392        CONFIG_DISABLE_ALGOS),"TRIM")
393 $     CONFIG_ALGO_I = CONFIG_ALGO_I + 1
394 $     IF CONFIG_ALGO_E .EQS. "" THEN GOTO CONFIG_DISABLE_LOOP1
395 $     IF CONFIG_ALGO_E .EQS. "," THEN GOTO CONFIG_DISABLE_LOOP1_END
396 $     IF F$TYPE(CONFIG_DISABLED_'CONFIG_ALGO_E') .EQS. ""
397 $     THEN
398 $       TO_DISABLE := NO
399 $     ELSE
400 $       IF .NOT. CONFIG_DISABLED_'CONFIG_ALGO_E' THEN TO_DISABLE := NO
401 $     ENDIF
402 $     GOTO CONFIG_DISABLE_LOOP1
403 $   CONFIG_DISABLE_LOOP1_END:
404 $
405 $   IF TO_DISABLE
406 $   THEN
407 $     CONFIG_DEPENDENT_I = 0
408 $     CONFIG_DISABLE_LOOP2:
409 $       CONFIG_DEPENDENT_E = F$EDIT(F$ELEMENT(CONFIG_DEPENDENT_I,",", -
410          CONFIG_DISABLE_DEPENDENTS),"TRIM")
411 $       CONFIG_DEPENDENT_I = CONFIG_DEPENDENT_I + 1
412 $       IF CONFIG_DEPENDENT_E .EQS. "" THEN GOTO CONFIG_DISABLE_LOOP2
413 $       IF CONFIG_DEPENDENT_E .EQS. "," THEN GOTO CONFIG_DISABLE_LOOP2_END
414 $       CONFIG_DISABLED_'CONFIG_DEPENDENT_E' := YES
415 $       CONFIG_ENABLED_'CONFIG_DEPENDENT_E' := NO
416 $       ! Better not to assume defaults at this point...
417 $       CONFIG_CHANGED_'CONFIG_DEPENDENT_E' := YES
418 $       WRITE SYS$ERROR -
419          "''CONFIG_DEPENDENT_E' disabled by rule ''CONFIG_DISABLE_E'"
420 $       GOTO CONFIG_DISABLE_LOOP2
421 $     CONFIG_DISABLE_LOOP2_END:
422 $   ENDIF
423 $   GOTO CONFIG_DISABLE_LOOP0
424 $ CONFIG_DISABLE_LOOP0_END:
425 $       
426 $! Apply cascading enable rules
427 $ CONFIG_ENABLE_I = 0
428 $ CONFIG_ENABLE_LOOP0:
429 $   CONFIG_ENABLE_E = F$EDIT(F$ELEMENT(CONFIG_ENABLE_I,";", -
430      CONFIG_ENABLE_RULES),"TRIM")
431 $   CONFIG_ENABLE_I = CONFIG_ENABLE_I + 1
432 $   IF CONFIG_ENABLE_E .EQS. "" THEN GOTO CONFIG_ENABLE_LOOP0
433 $   IF CONFIG_ENABLE_E .EQS. ";" THEN GOTO CONFIG_ENABLE_LOOP0_END
434 $
435 $   CONFIG_ENABLE_ALGOS = F$EDIT(F$ELEMENT(0,"/",CONFIG_ENABLE_E),"TRIM")
436 $   CONFIG_ENABLE_DEPENDENTS = F$EDIT(F$ELEMENT(1,"/",CONFIG_ENABLE_E),"TRIM")
437 $   TO_ENABLE := YES
438 $   CONFIG_ALGO_I = 0
439 $   CONFIG_ENABLE_LOOP1:
440 $     CONFIG_ALGO_E = F$EDIT(F$ELEMENT(CONFIG_ALGO_I,",", -
441        CONFIG_ENABLE_ALGOS),"TRIM")
442 $     CONFIG_ALGO_I = CONFIG_ALGO_I + 1
443 $     IF CONFIG_ALGO_E .EQS. "" THEN GOTO CONFIG_ENABLE_LOOP1
444 $     IF CONFIG_ALGO_E .EQS. "," THEN GOTO CONFIG_ENABLE_LOOP1_END
445 $     IF F$TYPE(CONFIG_ENABLED_'CONFIG_ALGO_E') .EQS. ""
446 $     THEN
447 $       TO_ENABLE := NO
448 $     ELSE
449 $       IF .NOT. CONFIG_ENABLED_'CONFIG_ALGO_E' THEN TO_ENABLE := NO
450 $     ENDIF
451 $     GOTO CONFIG_ENABLE_LOOP1
452 $   CONFIG_ENABLE_LOOP1_END:
453 $
454 $   IF TO_ENABLE
455 $   THEN
456 $     CONFIG_DEPENDENT_I = 0
457 $     CONFIG_ENABLE_LOOP2:
458 $       CONFIG_DEPENDENT_E = F$EDIT(F$ELEMENT(CONFIG_DEPENDENT_I,",", -
459          CONFIG_ENABLE_DEPENDENTS),"TRIM")
460 $       CONFIG_DEPENDENT_I = CONFIG_DEPENDENT_I + 1
461 $       IF CONFIG_DEPENDENT_E .EQS. "" THEN GOTO CONFIG_ENABLE_LOOP2
462 $       IF CONFIG_DEPENDENT_E .EQS. "," THEN GOTO CONFIG_ENABLE_LOOP2_END
463 $       CONFIG_DISABLED_'CONFIG_DEPENDENT_E' := NO
464 $       CONFIG_ENABLED_'CONFIG_DEPENDENT_E' := YES
465 $       ! Better not to assume defaults at this point...
466 $       CONFIG_CHANGED_'CONFIG_DEPENDENT_E' := YES
467 $       WRITE SYS$ERROR -
468          "''CONFIG_DEPENDENT_E' enabled by rule ''CONFIG_ENABLE_E'"
469 $       GOTO CONFIG_ENABLE_LOOP2
470 $     CONFIG_ENABLE_LOOP2_END:
471 $   ENDIF
472 $   GOTO CONFIG_ENABLE_LOOP0
473 $ CONFIG_ENABLE_LOOP0_END:
474 $
475 $! Write to the configuration
476 $ CONFIG_LOG_I = 0
477 $ CONFIG_LOG_LOOP2:
478 $   CONFIG_LOG_E = F$EDIT(F$ELEMENT(CONFIG_LOG_I,",",CONFIG_LOGICALS),"TRIM")
479 $   CONFIG_LOG_I = CONFIG_LOG_I + 1
480 $   IF CONFIG_LOG_E .EQS. "" THEN GOTO CONFIG_LOG_LOOP2
481 $   IF CONFIG_LOG_E .EQS. "," THEN GOTO CONFIG_LOG_LOOP2_END
482 $   IF CONFIG_CHANGED_'CONFIG_LOG_E'
483 $   THEN
484 $     IF CONFIG_DISABLED_'CONFIG_LOG_E'
485 $     THEN
486 $       WRITE H_FILE "#ifndef OPENSSL_NO_",CONFIG_LOG_E
487 $       WRITE H_FILE "# define OPENSSL_NO_",CONFIG_LOG_E
488 $       WRITE H_FILE "#endif"
489 $     ELSE
490 $       WRITE H_FILE "#ifndef OPENSSL_",CONFIG_LOG_E
491 $       WRITE H_FILE "# define OPENSSL_",CONFIG_LOG_E
492 $       WRITE H_FILE "#endif"
493 $     ENDIF
494 $   ENDIF
495 $   GOTO CONFIG_LOG_LOOP2
496 $ CONFIG_LOG_LOOP2_END:
497 $!
498 $ WRITE H_FILE ""
499 $ WRITE H_FILE "/* 2011-02-23 SMS."
500 $ WRITE H_FILE " * On VMS (V8.3), setvbuf() doesn't support a 64-bit"
501 $ WRITE H_FILE " * ""in"" pointer, and the help says:"
502 $ WRITE H_FILE " *       Please note that the previously documented"
503 $ WRITE H_FILE " *       value _IONBF is not supported."
504 $ WRITE H_FILE " * So, skip it on VMS."
505 $ WRITE H_FILE " */"
506 $ WRITE H_FILE "#define OPENSSL_NO_SETVBUF_IONBF"
507 $ WRITE H_FILE ""
508 $!
509 $! Add in the common "crypto/opensslconf.h.in".
510 $!
511 $ TYPE 'OPENSSLCONF_H_IN' /OUTPUT=H_FILE:
512 $!
513 $ IF ARCH .NES. "VAX"
514 $ THEN
515 $!
516 $!  Write the non-VAX specific data
517 $!
518 $   WRITE H_FILE "#if defined(HEADER_RC4_H)"
519 $   WRITE H_FILE "#undef RC4_INT"
520 $   WRITE H_FILE "#define RC4_INT unsigned int"
521 $   WRITE H_FILE "#undef RC4_CHUNK"
522 $   WRITE H_FILE "#define RC4_CHUNK unsigned long long"
523 $   WRITE H_FILE "#endif"
524 $!
525 $   WRITE H_FILE "#if defined(HEADER_DES_LOCL_H)"
526 $   WRITE H_FILE "#undef DES_LONG"
527 $   WRITE H_FILE "#define DES_LONG unsigned int"
528 $   WRITE H_FILE "#undef DES_PTR"
529 $   WRITE H_FILE "#define DES_PTR"
530 $   WRITE H_FILE "#undef DES_RISC1"
531 $   WRITE H_FILE "#undef DES_RISC2"
532 $   WRITE H_FILE "#define DES_RISC1"
533 $   WRITE H_FILE "#undef DES_UNROLL"
534 $   WRITE H_FILE "#define DES_UNROLL"
535 $   WRITE H_FILE "#endif"
536 $!
537 $   WRITE H_FILE "#if defined(HEADER_BN_H)"
538 $   WRITE H_FILE "#undef BN_LLONG"      ! Never define with SIXTY_FOUR_BIT
539 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT_LONG"
540 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT"
541 $   WRITE H_FILE "#define SIXTY_FOUR_BIT"
542 $   WRITE H_FILE "#undef THIRTY_TWO_BIT"
543 $   WRITE H_FILE "#undef SIXTEEN_BIT"
544 $   WRITE H_FILE "#undef EIGHT_BIT"
545 $   WRITE H_FILE "#endif"
546 $
547 $   WRITE H_FILE "#undef OPENSSL_EXPORT_VAR_AS_FUNCTION"
548 $!
549 $!  Else...
550 $!
551 $ ELSE
552 $!
553 $!  Write the VAX specific data
554 $!
555 $   WRITE H_FILE "#if defined(HEADER_RC4_H)"
556 $   WRITE H_FILE "#undef RC4_INT"
557 $   WRITE H_FILE "#define RC4_INT unsigned char"
558 $   WRITE H_FILE "#undef RC4_CHUNK"
559 $   WRITE H_FILE "#define RC4_CHUNK unsigned long"
560 $   WRITE H_FILE "#endif"
561 $!
562 $   WRITE H_FILE "#if defined(HEADER_DES_LOCL_H)"
563 $   WRITE H_FILE "#undef DES_LONG"
564 $   WRITE H_FILE "#define DES_LONG unsigned long"
565 $   WRITE H_FILE "#undef DES_PTR"
566 $   WRITE H_FILE "#define DES_PTR"
567 $   WRITE H_FILE "#undef DES_RISC1"
568 $   WRITE H_FILE "#undef DES_RISC2"
569 $   WRITE H_FILE "#undef DES_UNROLL"
570 $   WRITE H_FILE "#endif"
571 $!
572 $   WRITE H_FILE "#if defined(HEADER_BN_H)"
573 $   WRITE H_FILE "#undef BN_LLONG"      ! VAX C/DEC C doesn't have long long
574 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT_LONG"
575 $   WRITE H_FILE "#undef SIXTY_FOUR_BIT"
576 $   WRITE H_FILE "#undef THIRTY_TWO_BIT"
577 $   WRITE H_FILE "#define THIRTY_TWO_BIT"
578 $   WRITE H_FILE "#undef SIXTEEN_BIT"
579 $   WRITE H_FILE "#undef EIGHT_BIT"
580 $   WRITE H_FILE "#endif"
581 $!
582 $! Oddly enough, the following symbol is tested in crypto/sha/sha512.c
583 $! before sha.h gets included (and HEADER_SHA_H defined), so we will not
584 $! protect this one...
585 $   WRITE H_FILE "#undef OPENSSL_NO_SHA512"
586 $   WRITE H_FILE "#define OPENSSL_NO_SHA512"
587 $!
588 $   WRITE H_FILE "#undef OPENSSL_EXPORT_VAR_AS_FUNCTION"
589 $   WRITE H_FILE "#define OPENSSL_EXPORT_VAR_AS_FUNCTION"
590 $!
591 $!  End
592 $!
593 $ ENDIF
594 $!
595 $! Close the [.CRYPTO._xxx]OPENSSLCONF.H file
596 $!
597 $ CLOSE H_FILE
598 $!
599 $! Purge The [.CRYPTO._xxx]OPENSSLCONF.H file
600 $!
601 $ PURGE SYS$DISK:[.CRYPTO.'ARCHD']OPENSSLCONF.H
602 $!
603 $! That's All, Time To RETURN.
604 $!
605 $ RETURN
606 $!
607 $! Rebuild The "[.CRYPTO._xxx]BUILDINF.H" file.
608 $!
609 $ BUILDINF:
610 $!
611 $! Tell The User We Are Creating The [.CRYPTO._xxx]BUILDINF.H File.
612 $!
613 $ WRITE SYS$OUTPUT "Creating [.CRYPTO.''ARCHD']BUILDINF.H Include File."
614 $!
615 $! Create The [.CRYPTO._xxx]BUILDINF.H File.
616 $!
617 $ BIH_NAME = "SYS$DISK:[.CRYPTO.''ARCHD']BUILDINF.H"
618 $ CREATE /FDL=SYS$INPUT: 'BIH_NAME'
619 RECORD
620         FORMAT stream_lf
621 $!
622 $ OPEN /APPEND H_FILE 'bih_name'
623 $!
624 $! Get The Current Date & Time.
625 $!
626 $ TIME = F$TIME()
627 $!
628 $! Write The [.CRYPTO._xxx]BUILDINF.H File.
629 $!
630 $ CFLAGS = ""
631 $ if (POINTER_SIZE .nes. "")
632 $ then
633 $   CFLAGS = CFLAGS+ "/POINTER_SIZE=''POINTER_SIZE'"
634 $ endif
635 $ if (ZLIB .nes. "")
636 $ then
637 $   if (CFLAGS .nes. "") then CFLAGS = CFLAGS+ " "
638 $   CFLAGS = CFLAGS+ "/DEFINE=ZLIB"
639 $ endif
640 $! 
641 $ WRITE H_FILE "#define CFLAGS ""''CFLAGS'"""
642 $ WRITE H_FILE "#define PLATFORM ""VMS ''ARCHD' ''VMS_VERSION'"""
643 $ WRITE H_FILE "#define DATE ""''TIME'"" "
644 $!
645 $! Close The [.CRYPTO._xxx]BUILDINF.H File.
646 $!
647 $ CLOSE H_FILE
648 $!
649 $! Purge The [.CRYPTO._xxx]BUILDINF.H File.
650 $!
651 $ PURGE SYS$DISK:[.CRYPTO.'ARCHD']BUILDINF.H
652 $!
653 $! Delete [.CRYPTO]BUILDINF.H File, as there might be some residue from Unix.
654 $!
655 $ IF F$SEARCH("[.CRYPTO]BUILDINF.H") .NES. "" THEN -
656      DELETE SYS$DISK:[.CRYPTO]BUILDINF.H;*
657 $!
658 $! That's All, Time To RETURN.
659 $!
660 $ RETURN
661 $!
662 $! Copy a lot of files around.
663 $!
664 $ SOFTLINKS: 
665 $!
666 $!!!! Tell The User We Are Partly Rebuilding The [.APPS] Directory.
667 $!!!!
668 $!!! WRITE SYS$OUTPUT "Rebuilding The '[.APPS]MD4.C', '[.APPS]MD5.C' And '[.APPS]RD160.C' Files."
669 $!!!!
670 $!!! DELETE SYS$DISK:[.APPS]MD4.C;*,MD5.C;*,RMD160.C;*
671 $!!!!
672 $!!!! Copy MD4.C from [.CRYPTO.MD4] into [.APPS]
673 $!!!!
674 $!!! COPY SYS$DISK:[.CRYPTO.MD4]MD4.C SYS$DISK:[.APPS]
675 $!!!!
676 $!!!! Copy MD5.C from [.CRYPTO.MD5] into [.APPS]
677 $!!!! Tell The User We Are Rebuilding The [.include.openssl] Directory.
678 $!!!!
679 $!!!! Copy RMD160.C from [.CRYPTO.RIPEMD] into [.APPS]
680 $!!!!
681 $!!! COPY SYS$DISK:[.CRYPTO.RIPEMD]RMD160.C SYS$DISK:[.APPS]
682 $!
683 $! Ensure that the [.include.openssl] directory contains a full set of
684 $! real header files.  The distribution kit may have left real or fake
685 $! symlinks there.  Rather than think about what's there, simply delete
686 $! the destination files (fake or real symlinks) before copying the real
687 $! header files in.  (Copying a real header file onto a real symlink
688 $! merely duplicates the real header file at its source.)
689 $!
690 $! Tell The User We Are Rebuilding The [.include.openssl] Directory.
691 $!
692 $ WRITE SYS$OUTPUT "Rebuilding The '[.include.openssl]' Directory."
693 $!
694 $! First, make sure the directory exists.  If it did exist, delete all
695 $! the existing header files (or fake or real symlinks).
696 $!
697 $ if f$parse( "sys$disk:[.include.openssl]") .eqs. ""
698 $ then
699 $   create /directory sys$disk:[.include.openssl]
700 $ else
701 $   delete sys$disk:[.include.openssl]*.h;*
702 $ endif
703 $!
704 $! Copy All The ".H" Files From The Main Directory.
705 $!
706 $ EXHEADER := e_os2.h
707 $ copy 'exheader' sys$disk:[.include.openssl]
708 $!
709 $! Copy All The ".H" Files From The [.CRYPTO] Directory Tree.
710 $!
711 $ SDIRS := , -
712    'ARCHD', -
713    OBJECTS, -
714    MD2, MD4, MD5, SHA, MDC2, HMAC, RIPEMD, WHRLPOOL, -
715    DES, AES, RC2, RC4, RC5, IDEA, BF, CAST, CAMELLIA, SEED, MODES, -
716    BN, EC, RSA, DSA, ECDSA, DH, ECDH, DSO, ENGINE, -
717    BUFFER, BIO, STACK, LHASH, RAND, ERR, -
718    EVP, ASN1, PEM, X509, X509V3, CONF, TXT_DB, PKCS7, PKCS12, -
719    COMP, OCSP, UI, KRB5, -
720    CMS, PQUEUE, TS, JPAKE, SRP, STORE, CMAC
721 $!
722 $ EXHEADER_ := crypto.h, opensslv.h, ebcdic.h, symhacks.h, ossl_typ.h
723 $ EXHEADER_'ARCHD' := opensslconf.h
724 $ EXHEADER_OBJECTS := objects.h, obj_mac.h
725 $ EXHEADER_MD2 := md2.h
726 $ EXHEADER_MD4 := md4.h
727 $ EXHEADER_MD5 := md5.h
728 $ EXHEADER_SHA := sha.h
729 $ EXHEADER_MDC2 := mdc2.h
730 $ EXHEADER_HMAC := hmac.h
731 $ EXHEADER_RIPEMD := ripemd.h
732 $ EXHEADER_WHRLPOOL := whrlpool.h
733 $ EXHEADER_DES := des.h, des_old.h
734 $ EXHEADER_AES := aes.h
735 $ EXHEADER_RC2 := rc2.h
736 $ EXHEADER_RC4 := rc4.h
737 $ EXHEADER_RC5 := rc5.h
738 $ EXHEADER_IDEA := idea.h
739 $ EXHEADER_BF := blowfish.h
740 $ EXHEADER_CAST := cast.h
741 $ EXHEADER_CAMELLIA := camellia.h
742 $ EXHEADER_SEED := seed.h
743 $ EXHEADER_MODES := modes.h
744 $ EXHEADER_BN := bn.h
745 $ EXHEADER_EC := ec.h
746 $ EXHEADER_RSA := rsa.h
747 $ EXHEADER_DSA := dsa.h
748 $ EXHEADER_ECDSA := ecdsa.h
749 $ EXHEADER_DH := dh.h
750 $ EXHEADER_ECDH := ecdh.h
751 $ EXHEADER_DSO := dso.h
752 $ EXHEADER_ENGINE := engine.h
753 $ EXHEADER_BUFFER := buffer.h
754 $ EXHEADER_BIO := bio.h
755 $ EXHEADER_STACK := stack.h, safestack.h
756 $ EXHEADER_LHASH := lhash.h
757 $ EXHEADER_RAND := rand.h
758 $ EXHEADER_ERR := err.h
759 $ EXHEADER_EVP := evp.h
760 $ EXHEADER_ASN1 := asn1.h, asn1_mac.h, asn1t.h
761 $ EXHEADER_PEM := pem.h, pem2.h
762 $ EXHEADER_X509 := x509.h, x509_vfy.h
763 $ EXHEADER_X509V3 := x509v3.h
764 $ EXHEADER_CONF := conf.h, conf_api.h
765 $ EXHEADER_TXT_DB := txt_db.h
766 $ EXHEADER_PKCS7 := pkcs7.h
767 $ EXHEADER_PKCS12 := pkcs12.h
768 $ EXHEADER_COMP := comp.h
769 $ EXHEADER_OCSP := ocsp.h
770 $ EXHEADER_UI := ui.h, ui_compat.h
771 $ EXHEADER_KRB5 := krb5_asn.h
772 $ EXHEADER_CMS := cms.h
773 $ EXHEADER_PQUEUE := pqueue.h
774 $ EXHEADER_TS := ts.h
775 $ EXHEADER_JPAKE := jpake.h
776 $ EXHEADER_SRP := srp.h
777 $!!! EXHEADER_STORE := store.h, str_compat.h
778 $ EXHEADER_STORE := store.h
779 $ EXHEADER_CMAC := cmac.h
780 $!
781 $ i = 0
782 $ loop_sdirs:
783 $   sdir = f$edit( f$element( i, ",", sdirs), "trim")
784 $   i = i + 1
785 $   if (sdir .eqs. ",") then goto loop_sdirs_end
786 $   hdr_list = exheader_'sdir'
787 $   if (sdir .nes. "") then sdir = "."+ sdir
788 $   copy [.crypto'sdir']'hdr_list' sys$disk:[.include.openssl]
789 $ goto loop_sdirs
790 $ loop_sdirs_end:
791 $!
792 $! Copy All The ".H" Files From The [.SSL] Directory.
793 $!
794 $! (keep these in the same order as ssl/Makefile)
795 $ EXHEADER := ssl.h, ssl2.h, ssl3.h, ssl23.h, tls1.h, dtls1.h, kssl.h
796 $ copy sys$disk:[.ssl]'exheader' sys$disk:[.include.openssl]
797 $!
798 $! Purge the [.include.openssl] header files.
799 $!
800 $ purge sys$disk:[.include.openssl]*.h
801 $!
802 $! That's All, Time To RETURN.
803 $!
804 $ RETURN
805 $!
806 $! Build The "[.xxx.EXE.CRYPTO]SSL_LIBCRYPTO''LIB32'.OLB" Library.
807 $!
808 $ CRYPTO:
809 $!
810 $! Tell The User What We Are Doing.
811 $!
812 $ WRITE SYS$OUTPUT ""
813 $ WRITE SYS$OUTPUT -
814    "Building The [.",ARCHD,".EXE.CRYPTO]SSL_LIBCRYPTO''LIB32'.OLB Library."
815 $!
816 $! Go To The [.CRYPTO] Directory.
817 $!
818 $ SET DEFAULT SYS$DISK:[.CRYPTO]
819 $!
820 $! Build The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library.
821 $!  
822 $ @CRYPTO-LIB LIBRARY 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
823    "''ISSEVEN'" "''BUILDPART'" "''POINTER_SIZE'" "''ZLIB'"
824 $!
825 $! Build The [.xxx.EXE.CRYPTO]*.EXE Test Applications.
826 $!  
827 $ @CRYPTO-LIB APPS 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
828    "''ISSEVEN'" "''BUILDPART'" "''POINTER_SIZE'" "''ZLIB'"
829 $!
830 $! Go Back To The Main Directory.
831 $!
832 $ SET DEFAULT [-]
833 $!
834 $! Time To RETURN.
835 $!
836 $ RETURN
837 $!
838 $! Build The "[.xxx.EXE.SSL]SSL_LIBSSL''LIB32'.OLB" Library.
839 $!
840 $ SSL:
841 $!
842 $! Tell The User What We Are Doing.
843 $!
844 $ WRITE SYS$OUTPUT ""
845 $ WRITE SYS$OUTPUT -
846    "Building The [.",ARCHD,".EXE.SSL]SSL_LIBSSL''LIB32'.OLB Library."
847 $!
848 $! Go To The [.SSL] Directory.
849 $!
850 $ SET DEFAULT SYS$DISK:[.SSL]
851 $!
852 $! Build The [.xxx.EXE.SSL]LIBSSL.OLB Library.
853 $!
854 $ @SSL-LIB LIBRARY 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
855    "''ISSEVEN'" "''POINTER_SIZE'" "''ZLIB'"
856 $!
857 $! Go Back To The Main Directory.
858 $!
859 $ SET DEFAULT [-]
860 $!
861 $! Time To Return.
862 $!
863 $ RETURN
864 $!
865 $! Build The "[.xxx.EXE.SSL]SSL_TASK.EXE" Program.
866 $!
867 $ SSL_TASK:
868 $!
869 $! Tell The User What We Are Doing.
870 $!
871 $ WRITE SYS$OUTPUT ""
872 $ WRITE SYS$OUTPUT -
873    "Building DECNet Based SSL Engine, [.",ARCHD,".EXE.SSL]SSL_TASK.EXE"
874 $!
875 $! Go To The [.SSL] Directory.
876 $!
877 $ SET DEFAULT SYS$DISK:[.SSL]
878 $!
879 $! Build The [.xxx.EXE.SSL]SSL_TASK.EXE
880 $!
881 $ @SSL-LIB SSL_TASK 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
882    "''ISSEVEN'" "''POINTER_SIZE'" "''ZLIB'"
883 $!
884 $! Go Back To The Main Directory.
885 $!
886 $ SET DEFAULT [-]
887 $!
888 $! That's All, Time To RETURN.
889 $!
890 $ RETURN
891 $!
892 $! Build The OpenSSL Test Programs.
893 $!
894 $ TEST:
895 $!
896 $! Tell The User What We Are Doing.
897 $!
898 $ WRITE SYS$OUTPUT ""
899 $ WRITE SYS$OUTPUT "Building The OpenSSL [.",ARCHD,".EXE.TEST] Test Utilities."
900 $!
901 $! Go To The [.TEST] Directory.
902 $!
903 $ SET DEFAULT SYS$DISK:[.TEST]
904 $!
905 $! Build The Test Programs.
906 $!
907 $ @MAKETESTS 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" "''ISSEVEN'" -
908    "''POINTER_SIZE'" "''ZLIB'"
909 $!
910 $! Go Back To The Main Directory.
911 $!
912 $ SET DEFAULT [-]
913 $!
914 $! That's All, Time To RETURN.
915 $!
916 $ RETURN
917 $!
918 $! Build The OpenSSL Application Programs.
919 $!
920 $ APPS:
921 $!
922 $! Tell The User What We Are Doing.
923 $!
924 $ WRITE SYS$OUTPUT ""
925 $ WRITE SYS$OUTPUT "Building OpenSSL [.",ARCHD,".EXE.APPS] Applications."
926 $!
927 $! Go To The [.APPS] Directory.
928 $!
929 $ SET DEFAULT SYS$DISK:[.APPS]
930 $!
931 $! Build The Application Programs.
932 $!
933 $ @MAKEAPPS 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" "''ISSEVEN'" -
934    "" "''POINTER_SIZE'" "''ZLIB'"
935 $!
936 $! Go Back To The Main Directory.
937 $!
938 $ SET DEFAULT [-]
939 $!
940 $! That's All, Time To RETURN.
941 $!
942 $ RETURN
943 $!
944 $! Build The OpenSSL Application Programs.
945 $!
946 $ ENGINES:
947 $!
948 $! Tell The User What We Are Doing.
949 $!
950 $ WRITE SYS$OUTPUT ""
951 $ WRITE SYS$OUTPUT "Building OpenSSL [.",ARCHD,".EXE.ENGINES] Engines."
952 $!
953 $! Go To The [.ENGINES] Directory.
954 $!
955 $ SET DEFAULT SYS$DISK:[.ENGINES]
956 $!
957 $! Build The Application Programs.
958 $!
959 $ @MAKEENGINES ENGINES 'DEBUGGER' "''COMPILER'" "''TCPIP_TYPE'" -
960    "''ISSEVEN'" "''BUILDPART'" "''POINTER_SIZE'" "''ZLIB'"
961 $!
962 $! Go Back To The Main Directory.
963 $!
964 $ SET DEFAULT [-]
965 $!
966 $! That's All, Time To RETURN.
967 $!
968 $ RETURN
969 $!
970 $! Check The User's Options.
971 $!
972 $ CHECK_OPTIONS:
973 $!
974 $! Check if there's a "part", and separate it out
975 $!
976 $ BUILDPART = F$ELEMENT(1,"/",P1)
977 $ IF BUILDPART .EQS. "/"
978 $ THEN
979 $   BUILDPART = ""
980 $ ELSE
981 $   P1 = F$EXTRACT(0,F$LENGTH(P1) - F$LENGTH(BUILDPART) - 1, P1)
982 $ ENDIF
983 $!
984 $! Check To See If P1 Is Blank.
985 $!
986 $ IF (P1.EQS."ALL")
987 $ THEN
988 $!
989 $!   P1 Is ALL, So Build Everything.
990 $!
991 $    BUILDCOMMAND = "ALL"
992 $!
993 $! Else...
994 $!
995 $ ELSE
996 $!
997 $!  Else, Check To See If P1 Has A Valid Argument.
998 $!
999 $   IF (P1.EQS."CONFIG").OR.(P1.EQS."BUILDINF").OR.(P1.EQS."SOFTLINKS") -
1000        .OR.(P1.EQS."BUILDALL") -
1001        .OR.(P1.EQS."CRYPTO").OR.(P1.EQS."SSL") -
1002        .OR.(P1.EQS."SSL_TASK").OR.(P1.EQS."TEST").OR.(P1.EQS."APPS") -
1003        .OR.(P1.EQS."ENGINES")
1004 $   THEN
1005 $!
1006 $!    A Valid Argument.
1007 $!
1008 $     BUILDCOMMAND = P1
1009 $!
1010 $!  Else...
1011 $!
1012 $   ELSE
1013 $!
1014 $!    Tell The User We Don't Know What They Want.
1015 $!
1016 $     WRITE SYS$OUTPUT ""
1017 $     WRITE SYS$OUTPUT "USAGE:   @MAKEVMS.COM [Target] [Pointer size] [Debug option] <Compiler>"
1018 $     WRITE SYS$OUTPUT ""
1019 $     WRITE SYS$OUTPUT "Example: @MAKEVMS.COM ALL """" NODEBUG "
1020 $     WRITE SYS$OUTPUT ""
1021 $     WRITE SYS$OUTPUT "The Target ",P1," Is Invalid.  The Valid Target Options Are:"
1022 $     WRITE SYS$OUTPUT ""
1023 $     WRITE SYS$OUTPUT "    ALL      :  Just Build Everything."
1024 $     WRITE SYS$OUTPUT "    CONFIG   :  Just build the [.CRYPTO._xxx]OPENSSLCONF.H file."
1025 $     WRITE SYS$OUTPUT "    BUILDINF :  Just build the [.CRYPTO._xxx]BUILDINF.H file."
1026 $     WRITE SYS$OUTPUT "    SOFTLINKS:  Just Fix The Unix soft links."
1027 $     WRITE SYS$OUTPUT "    BUILDALL :  Same as ALL, except CONFIG, BUILDINF and SOFTILNKS aren't done."
1028 $     WRITE SYS$OUTPUT "    CRYPTO   :  To Build Just The [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library."
1029 $     WRITE SYS$OUTPUT "    CRYPTO/x :  To Build Just The x Part Of The"
1030 $     WRITE SYS$OUTPUT "                [.xxx.EXE.CRYPTO]LIBCRYPTO.OLB Library."
1031 $     WRITE SYS$OUTPUT "    SSL      :  To Build Just The [.xxx.EXE.SSL]LIBSSL.OLB Library."
1032 $     WRITE SYS$OUTPUT "    SSL_TASK :  To Build Just The [.xxx.EXE.SSL]SSL_TASK.EXE Program."
1033 $     WRITE SYS$OUTPUT "    TEST     :  To Build Just The OpenSSL Test Programs."
1034 $     WRITE SYS$OUTPUT "    APPS     :  To Build Just The OpenSSL Application Programs."
1035 $     WRITE SYS$OUTPUT "    ENGINES  :  To Build Just The ENGINES"
1036 $     WRITE SYS$OUTPUT ""
1037 $     WRITE SYS$OUTPUT " Where 'xxx' Stands For:"
1038 $     WRITE SYS$OUTPUT ""
1039 $     WRITE SYS$OUTPUT "    ALPHA[64]:  Alpha Architecture."
1040 $     WRITE SYS$OUTPUT "    IA64[64] :  IA64 Architecture."
1041 $     WRITE SYS$OUTPUT "    VAX      :  VAX Architecture."
1042 $     WRITE SYS$OUTPUT ""
1043 $!
1044 $!    Time To EXIT.
1045 $!
1046 $     GOTO TIDY
1047 $!
1048 $!  End The Valid Argument Check.
1049 $!
1050 $   ENDIF
1051 $!
1052 $! End The P1 Check.
1053 $!
1054 $ ENDIF
1055 $!
1056 $! Check P2 (POINTER_SIZE).
1057 $!
1058 $ IF (P2 .NES. "") .AND. (ARCH .NES. "VAX")
1059 $ THEN
1060 $!
1061 $   IF (P2 .EQS. "32")
1062 $   THEN
1063 $     POINTER_SIZE = "32"
1064 $   ELSE
1065 $     POINTER_SIZE = F$EDIT( P2, "COLLAPSE, UPCASE")
1066 $     IF ((POINTER_SIZE .EQS. "64") .OR. -
1067        (POINTER_SIZE .EQS. "64=") .OR. -
1068        (POINTER_SIZE .EQS. "64=ARGV"))
1069 $     THEN
1070 $       ARCHD = ARCH+ "_64"
1071 $       LIB32 = ""
1072 $     ELSE
1073 $!
1074 $!      Tell The User Entered An Invalid Option.
1075 $!
1076 $       WRITE SYS$OUTPUT ""
1077 $       WRITE SYS$OUTPUT "The Option ", P2, -
1078          " Is Invalid.  The Valid Options Are:"
1079 $       WRITE SYS$OUTPUT ""
1080 $       WRITE SYS$OUTPUT -
1081          "    """"       :  Compile with default (short) pointers."
1082 $       WRITE SYS$OUTPUT -
1083          "    32       :  Compile with 32-bit (short) pointers."
1084 $       WRITE SYS$OUTPUT -
1085          "    64       :  Compile with 64-bit (long) pointers (auto ARGV)."
1086 $       WRITE SYS$OUTPUT -
1087          "    64=      :  Compile with 64-bit (long) pointers (no ARGV)."
1088 $       WRITE SYS$OUTPUT -
1089          "    64=ARGV  :  Compile with 64-bit (long) pointers (ARGV)."
1090 $       WRITE SYS$OUTPUT ""
1091 $! 
1092 $!      Time To EXIT.
1093 $!
1094 $       GOTO TIDY
1095 $!
1096 $     ENDIF
1097 $!
1098 $   ENDIF
1099 $!
1100 $! End The P2 (POINTER_SIZE) Check.
1101 $!
1102 $ ENDIF
1103 $!
1104 $! Check To See If P3 Is Blank.
1105 $!
1106 $ IF (P3.EQS."NODEBUG")
1107 $ THEN
1108 $!
1109 $!   P3 Is NODEBUG, So Compile Without Debugger Information.
1110 $!
1111 $    DEBUGGER = "NODEBUG"
1112 $!
1113 $! Else...
1114 $!
1115 $ ELSE
1116 $!
1117 $!  Check To See If We Are To Compile With Debugger Information.
1118 $!
1119 $   IF (P3.EQS."DEBUG")
1120 $   THEN
1121 $!
1122 $!    Compile With Debugger Information.
1123 $!
1124 $     DEBUGGER = "DEBUG"
1125 $!
1126 $!  Else...
1127 $!
1128 $   ELSE
1129 $!
1130 $!    Tell The User Entered An Invalid Option.
1131 $!
1132 $     WRITE SYS$OUTPUT ""
1133 $     WRITE SYS$OUTPUT "The Option ",P3," Is Invalid.  The Valid Options Are:"
1134 $     WRITE SYS$OUTPUT ""
1135 $     WRITE SYS$OUTPUT "    DEBUG    :  Compile With The Debugger Information."
1136 $     WRITE SYS$OUTPUT "    NODEBUG  :  Compile Without The Debugger Information."
1137 $     WRITE SYS$OUTPUT ""
1138 $!
1139 $!    Time To EXIT.
1140 $!
1141 $     GOTO TIDY
1142 $!
1143 $!  End The Valid Argument Check.
1144 $!
1145 $   ENDIF
1146 $!
1147 $! End The P3 Check.
1148 $!
1149 $ ENDIF
1150 $!
1151 $! Check To See If P4 Is Blank.
1152 $!
1153 $ IF (P4.EQS."")
1154 $ THEN
1155 $!
1156 $!  O.K., The User Didn't Specify A Compiler, Let's Try To
1157 $!  Find Out Which One To Use.
1158 $!
1159 $!  Check To See If We Have GNU C.
1160 $!
1161 $   IF (F$TRNLNM("GNU_CC").NES."")
1162 $   THEN
1163 $!
1164 $!    Looks Like GNUC, Set To Use GNUC.
1165 $!
1166 $     COMPILER = "GNUC"
1167 $!
1168 $!    Tell The User We Are Using GNUC.
1169 $!
1170 $     WRITE SYS$OUTPUT "Using GNU 'C' Compiler."
1171 $!
1172 $!  End The GNU C Compiler Check.
1173 $!
1174 $   ENDIF
1175 $!
1176 $!  Check To See If We Have VAXC Or DECC.
1177 $!
1178 $   IF (F$GETSYI("CPU").GE.128).OR.(F$TRNLNM("DECC$CC_DEFAULT").EQS."/DECC")
1179 $   THEN 
1180 $!
1181 $!    Looks Like DECC, Set To Use DECC.
1182 $!
1183 $     COMPILER = "DECC"
1184 $!
1185 $!    Tell The User We Are Using DECC.
1186 $!
1187 $     WRITE SYS$OUTPUT "Using DECC 'C' Compiler."
1188 $!
1189 $!  Else...
1190 $!
1191 $   ELSE
1192 $!
1193 $!    Looks Like VAXC, Set To Use VAXC.
1194 $!
1195 $     COMPILER = "VAXC"
1196 $!
1197 $!    Tell The User We Are Using VAX C.
1198 $!
1199 $     WRITE SYS$OUTPUT "Using VAXC 'C' Compiler."
1200 $!
1201 $!  End The DECC & VAXC Compiler Check.
1202 $!
1203 $   ENDIF
1204 $!
1205 $! Else...
1206 $!
1207 $ ELSE
1208 $!
1209 $!  Check To See If The User Entered A Valid Parameter.
1210 $!
1211 $   IF (P4.EQS."VAXC").OR.(P4.EQS."DECC").OR.(P4.EQS."GNUC")!.OR.(P4.EQS."LINK")
1212 $   THEN
1213 $!
1214 $!    Check To See If The User Wanted To Just LINK.
1215 $!
1216 $     IF (P4.EQS."LINK")
1217 $     THEN
1218 $!
1219 $!      Looks Like LINK-only
1220 $!
1221 $       COMPILER = "LINK"
1222 $!
1223 $!      Tell The User We Are Only Linking.
1224 $!
1225 $       WRITE SYS$OUTPUT "LINK Only.  This actually NOT YET SUPPORTED!"
1226 $!
1227 $!    End LINK Check.
1228 $!
1229 $     ENDIF
1230 $!
1231 $!    Check To See If The User Wanted DECC.
1232 $!
1233 $     IF (P4.EQS."DECC")
1234 $     THEN
1235 $!
1236 $!      Looks Like DECC, Set To Use DECC.
1237 $!
1238 $       COMPILER = "DECC"
1239 $!
1240 $!      Tell The User We Are Using DECC.
1241 $!
1242 $       WRITE SYS$OUTPUT "Using DECC 'C' Compiler."
1243 $!
1244 $!    End DECC Check.
1245 $!
1246 $     ENDIF
1247 $!
1248 $!    Check To See If We Are To Use VAXC.
1249 $!
1250 $     IF (P4.EQS."VAXC")
1251 $     THEN
1252 $!
1253 $!      Looks Like VAXC, Set To Use VAXC.
1254 $!
1255 $       COMPILER = "VAXC"
1256 $!
1257 $!      Tell The User We Are Using VAX C.
1258 $!
1259 $       WRITE SYS$OUTPUT "Using VAXC 'C' Compiler."
1260 $!
1261 $!    End VAXC Check
1262 $!
1263 $     ENDIF
1264 $!
1265 $!    Check To See If We Are To Use GNU C.
1266 $!
1267 $     IF (P4.EQS."GNUC")
1268 $     THEN
1269 $!
1270 $!      Looks Like GNUC, Set To Use GNUC.
1271 $!
1272 $       COMPILER = "GNUC"
1273 $!
1274 $!      Tell The User We Are Using GNUC.
1275 $!
1276 $       WRITE SYS$OUTPUT "Using GNU 'C' Compiler."
1277 $!
1278 $!    End The GNU C Check.
1279 $!
1280 $     ENDIF
1281 $!
1282 $!  Else The User Entered An Invalid Argument.
1283 $!
1284 $   ELSE
1285 $!
1286 $!    Tell The User We Don't Know What They Want.
1287 $!
1288 $     WRITE SYS$OUTPUT ""
1289 $     WRITE SYS$OUTPUT "The Option ",P4," Is Invalid.  The Valid Options Are:"
1290 $     WRITE SYS$OUTPUT ""
1291 $     WRITE SYS$OUTPUT "    VAXC  :  To Compile With VAX C."
1292 $     WRITE SYS$OUTPUT "    DECC  :  To Compile With DEC C."
1293 $     WRITE SYS$OUTPUT "    GNUC  :  To Compile With GNU C."
1294 $     WRITE SYS$OUTPUT ""
1295 $!
1296 $!    Time To EXIT.
1297 $!
1298 $     GOTO TIDY
1299 $!
1300 $!  End The Valid Argument Check.
1301 $!
1302 $   ENDIF
1303 $!
1304 $! End The P4 Check.
1305 $!
1306 $ ENDIF
1307 $!
1308 $! Time to check the contents of P5, and to make sure we get the correct
1309 $! library.
1310 $!
1311 $ IF P5.EQS."SOCKETSHR" .OR. P5.EQS."MULTINET" .OR. P5.EQS."UCX" -
1312      .OR. P5.EQS."TCPIP" .OR. P5.EQS."NONE"
1313 $ THEN
1314 $!
1315 $!  Check to see if SOCKETSHR was chosen
1316 $!
1317 $   IF P5.EQS."SOCKETSHR"
1318 $   THEN
1319 $!
1320 $!    Set the library to use SOCKETSHR
1321 $!
1322 $     TCPIP_LIB = "SYS$DISK:[-.VMS]SOCKETSHR_SHR.OPT /OPTIONS"
1323 $!
1324 $!    Tell the user
1325 $!
1326 $     WRITE SYS$OUTPUT "Using SOCKETSHR for TCP/IP"
1327 $!
1328 $!    Done with SOCKETSHR
1329 $!
1330 $   ENDIF
1331 $!
1332 $!  Check to see if MULTINET was chosen
1333 $!
1334 $   IF P5.EQS."MULTINET"
1335 $   THEN
1336 $!
1337 $!    Set the library to use UCX emulation.
1338 $!
1339 $     P5 = "UCX"
1340 $!
1341 $!    Tell the user
1342 $!
1343 $     WRITE SYS$OUTPUT "Using MultiNet via UCX emulation for TCP/IP"
1344 $!
1345 $!    Done with MULTINET
1346 $!
1347 $   ENDIF
1348 $!
1349 $!  Check to see if UCX was chosen
1350 $!
1351 $   IF P5.EQS."UCX"
1352 $   THEN
1353 $!
1354 $!    Set the library to use UCX.
1355 $!
1356 $     TCPIP_LIB = "SYS$DISK:[-.VMS]UCX_SHR_DECC.OPT /OPTIONS"
1357 $!
1358 $!    Tell the user
1359 $!
1360 $     WRITE SYS$OUTPUT "Using UCX or an emulation thereof for TCP/IP"
1361 $!
1362 $!    Done with UCX
1363 $!
1364 $   ENDIF
1365 $!
1366 $!  Check to see if TCPIP was chosen
1367 $!
1368 $   IF P5.EQS."TCPIP"
1369 $   THEN
1370 $!
1371 $!    Set the library to use TCPIP (post UCX).
1372 $!
1373 $     TCPIP_LIB = "SYS$DISK:[-.VMS]TCPIP_SHR_DECC.OPT /OPTIONS"
1374 $!
1375 $!    Tell the user
1376 $!
1377 $     WRITE SYS$OUTPUT "Using TCPIP (post UCX) for TCP/IP"
1378 $!
1379 $!    Done with TCPIP
1380 $!
1381 $   ENDIF
1382 $!
1383 $!  Check to see if NONE was chosen
1384 $!
1385 $   IF P5.EQS."NONE"
1386 $   THEN
1387 $!
1388 $!    Do not use a TCPIP library.
1389 $!
1390 $     TCPIP_LIB = ""
1391 $!
1392 $!    Tell the user
1393 $!
1394 $     WRITE SYS$OUTPUT "A specific TCPIP library will not be used."
1395 $!
1396 $!    Done with NONE.
1397 $!
1398 $   ENDIF
1399 $!
1400 $!  Set the TCPIP_TYPE symbol
1401 $!
1402 $   TCPIP_TYPE = P5
1403 $!
1404 $!  Print info
1405 $!
1406 $   WRITE SYS$OUTPUT "TCP/IP library spec: ", TCPIP_LIB
1407 $!
1408 $!  Else The User Entered An Invalid Argument.
1409 $!
1410 $ ELSE
1411 $   IF P5 .NES. ""
1412 $   THEN
1413 $!
1414 $!    Tell The User We Don't Know What They Want.
1415 $!
1416 $     WRITE SYS$OUTPUT ""
1417 $     WRITE SYS$OUTPUT "The Option ",P5," Is Invalid.  The Valid Options Are:"
1418 $     WRITE SYS$OUTPUT ""
1419 $     WRITE SYS$OUTPUT "    SOCKETSHR  :  To link with SOCKETSHR TCP/IP library."
1420 $     WRITE SYS$OUTPUT "    UCX        :  To link with UCX TCP/IP library."
1421 $     WRITE SYS$OUTPUT "    TCPIP      :  To link with TCPIP TCP/IP (post UCX) library."
1422 $     WRITE SYS$OUTPUT "    NONE       :  To not link with a specific TCP/IP library."
1423 $     WRITE SYS$OUTPUT ""
1424 $!
1425 $!    Time To EXIT.
1426 $!
1427 $     GOTO TIDY
1428 $   ELSE
1429 $!
1430 $! If TCPIP is not defined, then hardcode it to make
1431 $! it clear that no TCPIP is desired.
1432 $!
1433 $     IF P5 .EQS. ""
1434 $     THEN
1435 $       TCPIP_LIB = ""
1436 $       TCPIP_TYPE = "NONE"
1437 $     ELSE
1438 $!
1439 $!    Set the TCPIP_TYPE symbol
1440 $!
1441 $       TCPIP_TYPE = P5
1442 $     ENDIF
1443 $   ENDIF
1444 $!
1445 $!  Done with TCP/IP libraries
1446 $!
1447 $ ENDIF
1448 $!
1449 $! Special Threads For OpenVMS v7.1 Or Later
1450 $!
1451 $! Written By:  Richard Levitte
1452 $!              richard@levitte.org
1453 $!
1454 $!
1455 $! Check To See If We Have A Option For P6.
1456 $!
1457 $ IF (P6.EQS."")
1458 $ THEN
1459 $!
1460 $!  Get The Version Of VMS We Are Using.
1461 $!
1462 $   ISSEVEN :=
1463 $   TMP = F$ELEMENT(0,"-",F$EXTRACT(1,4,VMS_VERSION))
1464 $   TMP = F$INTEGER(F$ELEMENT(0,".",TMP)+F$ELEMENT(1,".",TMP))
1465 $!
1466 $!  Check To See If The VMS Version Is v7.1 Or Later.
1467 $!
1468 $   IF (TMP.GE.71)
1469 $   THEN
1470 $!
1471 $!    We Have OpenVMS v7.1 Or Later, So Use The Special Threads.
1472 $!
1473 $     ISSEVEN := ,PTHREAD_USE_D4
1474 $!
1475 $!  End The VMS Version Check.
1476 $!
1477 $   ENDIF
1478 $!
1479 $! End The P6 Check.
1480 $!
1481 $ ENDIF
1482 $!
1483 $!
1484 $! Check To See If We Have A ZLIB Option.
1485 $!
1486 $ ZLIB = P7
1487 $ IF (ZLIB .NES. "")
1488 $ THEN
1489 $!
1490 $!  Check for expected ZLIB files.
1491 $!
1492 $   err = 0
1493 $   file1 = f$parse( "zlib.h", ZLIB, , , "SYNTAX_ONLY")
1494 $   if (f$search( file1) .eqs. "")
1495 $   then
1496 $     WRITE SYS$OUTPUT ""
1497 $     WRITE SYS$OUTPUT "The Option ", ZLIB, " Is Invalid."
1498 $     WRITE SYS$OUTPUT "    Can't find header: ''file1'"
1499 $     err = 1
1500 $   endif
1501 $!
1502 $   file2 = f$parse( ZLIB, "libz.olb", , , "SYNTAX_ONLY")
1503 $   if (f$search( file2) .eqs. "")
1504 $   then
1505 $     if (err .eq. 0)
1506 $     then
1507 $       WRITE SYS$OUTPUT ""
1508 $       WRITE SYS$OUTPUT "The Option ", ZLIB, " Is Invalid."
1509 $     endif
1510 $     WRITE SYS$OUTPUT "    Can't find library: ''file2'"
1511 $     WRITE SYS$OUTPUT ""
1512 $     err = err+ 2
1513 $   endif
1514 $   if (err .eq. 1)
1515 $   then
1516 $     WRITE SYS$OUTPUT ""
1517 $   endif
1518 $!
1519 $   if (err .ne. 0)
1520 $   then
1521 $     GOTO TIDY
1522 $   endif
1523 $!
1524 $!  Print info
1525 $!
1526 $   WRITE SYS$OUTPUT "ZLIB library spec: ", file2
1527 $!
1528 $! End The ZLIB Check.
1529 $!
1530 $ ENDIF
1531 $!
1532 $!  Time To RETURN...
1533 $!
1534 $ RETURN
1535 $!
1536 $ TIDY:
1537 $!
1538 $! Close any open files.
1539 $!
1540 $ if (f$trnlnm( "h_file", "LNM$PROCESS", 0, "SUPERVISOR") .nes. "") then -
1541    close h_file
1542 $!
1543 $! Restore the original default device:[directory].
1544 $!
1545 $ SET DEFAULT 'DEF_ORIG'
1546 $!
1547 $ EXIT
1548 $!