Home | History | Annotate | Download | only in zlib
      1 $! make libz under VMS written by
      2 $! Martin P.J. Zinser
      3 $! <zinser@zinser.no-ip.info or zinser@sysdev.deutsche-boerse.com>
      4 $!
      5 $ on error then goto err_exit
      6 $!
      7 $!
      8 $! Just some general constants...
      9 $!
     10 $ true  = 1
     11 $ false = 0
     12 $ tmpnam = "temp_" + f$getjpi("","pid")
     13 $ SAY = "WRITE SYS$OUTPUT"
     14 $!
     15 $! Setup variables holding "config" information
     16 $!
     17 $ Make     = ""
     18 $ name     = "Zlib"
     19 $ version  = "?.?.?"
     20 $ v_string = "ZLIB_VERSION"
     21 $ v_file   = "zlib.h"
     22 $ ccopt    = ""
     23 $ lopts    = ""
     24 $ linkonly = false
     25 $ optfile  = name + ".opt"
     26 $ its_decc = false
     27 $ its_vaxc = false
     28 $ its_gnuc = false
     29 $ axp      = f$getsyi("HW_MODEL").ge.1024
     30 $ s_case   = false
     31 $! Check for MMK/MMS
     32 $!
     33 $ If F$Search ("Sys$System:MMS.EXE") .nes. "" Then Make = "MMS"
     34 $ If F$Type (MMK) .eqs. "STRING" Then Make = "MMK"
     35 $!
     36 $!
     37 $ gosub find_version
     38 $!
     39 $ gosub check_opts
     40 $!
     41 $! Look for the compiler used
     42 $!
     43 $ gosub check_compiler
     44 $ if its_decc
     45 $ then
     46 $   ccopt = "/prefix=all" + ccopt
     47 $   if f$trnlnm("SYS") .eqs. ""
     48 $   then
     49 $     if axp
     50 $     then
     51 $       define sys sys$library:
     52 $     else
     53 $       ccopt = "/decc" + ccopt
     54 $       define sys decc$library_include:
     55 $     endif
     56 $   endif
     57 $ endif
     58 $ if its_vaxc .or. its_gnuc
     59 $ then
     60 $    if f$trnlnm("SYS").eqs."" then define sys sys$library:
     61 $ endif
     62 $!
     63 $! Build the thing plain or with mms
     64 $!
     65 $ write sys$output "Compiling Zlib sources ..."
     66 $ if make.eqs.""
     67 $  then
     68 $   dele example.obj;*,minigzip.obj;*
     69 $   CALL MAKE adler32.OBJ "CC ''CCOPT' adler32" -
     70                 adler32.c zlib.h zconf.h
     71 $   CALL MAKE compress.OBJ "CC ''CCOPT' compress" -
     72                 compress.c zlib.h zconf.h
     73 $   CALL MAKE crc32.OBJ "CC ''CCOPT' crc32" -
     74                 crc32.c zlib.h zconf.h
     75 $   CALL MAKE deflate.OBJ "CC ''CCOPT' deflate" -
     76                 deflate.c deflate.h zutil.h zlib.h zconf.h
     77 $   CALL MAKE gzio.OBJ "CC ''CCOPT' gzio" -
     78                 gzio.c zutil.h zlib.h zconf.h
     79 $   CALL MAKE infback.OBJ "CC ''CCOPT' infback" -
     80                 infback.c zutil.h inftrees.h inflate.h inffast.h inffixed.h
     81 $   CALL MAKE inffast.OBJ "CC ''CCOPT' inffast" -
     82                 inffast.c zutil.h zlib.h zconf.h inffast.h
     83 $   CALL MAKE inflate.OBJ "CC ''CCOPT' inflate" -
     84                 inflate.c zutil.h zlib.h zconf.h infblock.h
     85 $   CALL MAKE inftrees.OBJ "CC ''CCOPT' inftrees" -
     86                 inftrees.c zutil.h zlib.h zconf.h inftrees.h
     87 $   CALL MAKE trees.OBJ "CC ''CCOPT' trees" -
     88                 trees.c deflate.h zutil.h zlib.h zconf.h
     89 $   CALL MAKE uncompr.OBJ "CC ''CCOPT' uncompr" -
     90                 uncompr.c zlib.h zconf.h
     91 $   CALL MAKE zutil.OBJ "CC ''CCOPT' zutil" -
     92                 zutil.c zutil.h zlib.h zconf.h
     93 $   write sys$output "Building Zlib ..."
     94 $   CALL MAKE libz.OLB "lib/crea libz.olb *.obj" *.OBJ
     95 $   write sys$output "Building example..."
     96 $   CALL MAKE example.OBJ "CC ''CCOPT' example" -
     97                 example.c zlib.h zconf.h
     98 $   call make example.exe "LINK example,libz.olb/lib" example.obj libz.olb
     99 $   if f$search("x11vms:xvmsutils.olb") .nes. ""
    100 $   then
    101 $     write sys$output "Building minigzip..."
    102 $     CALL MAKE minigzip.OBJ "CC ''CCOPT' minigzip" -
    103                 minigzip.c zlib.h zconf.h
    104 $     call make minigzip.exe -
    105                 "LINK minigzip,libz.olb/lib,x11vms:xvmsutils.olb/lib" -
    106                 minigzip.obj libz.olb
    107 $   endif
    108 $  else
    109 $   gosub crea_mms
    110 $   SAY "Make ''name' ''version' with ''Make' "
    111 $   'make'
    112 $  endif
    113 $!
    114 $! Alpha gets a shareable image
    115 $!
    116 $ If axp
    117 $ Then
    118 $   gosub crea_olist
    119 $   write sys$output "Creating libzshr.exe"
    120 $   call anal_obj_axp modules.opt _link.opt
    121 $   if s_case
    122 $   then
    123 $      open/append optf modules.opt
    124 $      write optf "case_sensitive=YES"
    125 $      close optf
    126 $   endif
    127 $   LINK_'lopts'/SHARE=libzshr.exe modules.opt/opt,_link.opt/opt
    128 $ endif
    129 $ write sys$output "Zlib build completed"
    130 $ exit
    131 $CC_ERR:
    132 $ write sys$output "C compiler required to build ''name'"
    133 $ goto err_exit
    134 $ERR_EXIT:
    135 $ set message/facil/ident/sever/text
    136 $ write sys$output "Exiting..."
    137 $ exit 2
    138 $!
    139 $!
    140 $MAKE: SUBROUTINE   !SUBROUTINE TO CHECK DEPENDENCIES
    141 $ V = 'F$Verify(0)
    142 $! P1 = What we are trying to make
    143 $! P2 = Command to make it
    144 $! P3 - P8  What it depends on
    145 $
    146 $ If F$Search(P1) .Eqs. "" Then Goto Makeit
    147 $ Time = F$CvTime(F$File(P1,"RDT"))
    148 $arg=3
    149 $Loop:
    150 $       Argument = P'arg
    151 $       If Argument .Eqs. "" Then Goto Exit
    152 $       El=0
    153 $Loop2:
    154 $       File = F$Element(El," ",Argument)
    155 $       If File .Eqs. " " Then Goto Endl
    156 $       AFile = ""
    157 $Loop3:
    158 $       OFile = AFile
    159 $       AFile = F$Search(File)
    160 $       If AFile .Eqs. "" .Or. AFile .Eqs. OFile Then Goto NextEl
    161 $       If F$CvTime(F$File(AFile,"RDT")) .Ges. Time Then Goto Makeit
    162 $       Goto Loop3
    163 $NextEL:
    164 $       El = El + 1
    165 $       Goto Loop2
    166 $EndL:
    167 $ arg=arg+1
    168 $ If arg .Le. 8 Then Goto Loop
    169 $ Goto Exit
    170 $
    171 $Makeit:
    172 $ VV=F$VERIFY(0)
    173 $ write sys$output P2
    174 $ 'P2
    175 $ VV='F$Verify(VV)
    176 $Exit:
    177 $ If V Then Set Verify
    178 $ENDSUBROUTINE
    179 $!------------------------------------------------------------------------------
    180 $!
    181 $! Check command line options and set symbols accordingly
    182 $!
    183 $ CHECK_OPTS:
    184 $ i = 1
    185 $ OPT_LOOP:
    186 $ if i .lt. 9
    187 $ then
    188 $   cparm = f$edit(p'i',"upcase")
    189 $   if cparm .eqs. "DEBUG"
    190 $   then
    191 $     ccopt = ccopt + "/noopt/deb"
    192 $     lopts = lopts + "/deb"
    193 $   endif
    194 $   if f$locate("CCOPT=",cparm) .lt. f$length(cparm)
    195 $   then
    196 $     start = f$locate("=",cparm) + 1
    197 $     len   = f$length(cparm) - start
    198 $     ccopt = ccopt + f$extract(start,len,cparm)
    199 $     if f$locate("AS_IS",f$edit(ccopt,"UPCASE")) .lt. f$length(ccopt) -
    200          then s_case = true
    201 $   endif
    202 $   if cparm .eqs. "LINK" then linkonly = true
    203 $   if f$locate("LOPTS=",cparm) .lt. f$length(cparm)
    204 $   then
    205 $     start = f$locate("=",cparm) + 1
    206 $     len   = f$length(cparm) - start
    207 $     lopts = lopts + f$extract(start,len,cparm)
    208 $   endif
    209 $   if f$locate("CC=",cparm) .lt. f$length(cparm)
    210 $   then
    211 $     start  = f$locate("=",cparm) + 1
    212 $     len    = f$length(cparm) - start
    213 $     cc_com = f$extract(start,len,cparm)
    214       if (cc_com .nes. "DECC") .and. -
    215          (cc_com .nes. "VAXC") .and. -
    216 	 (cc_com .nes. "GNUC")
    217 $     then
    218 $       write sys$output "Unsupported compiler choice ''cc_com' ignored"
    219 $       write sys$output "Use DECC, VAXC, or GNUC instead"
    220 $     else
    221 $     	if cc_com .eqs. "DECC" then its_decc = true
    222 $     	if cc_com .eqs. "VAXC" then its_vaxc = true
    223 $     	if cc_com .eqs. "GNUC" then its_gnuc = true
    224 $     endif
    225 $   endif
    226 $   if f$locate("MAKE=",cparm) .lt. f$length(cparm)
    227 $   then
    228 $     start  = f$locate("=",cparm) + 1
    229 $     len    = f$length(cparm) - start
    230 $     mmks = f$extract(start,len,cparm)
    231 $     if (mmks .eqs. "MMK") .or. (mmks .eqs. "MMS")
    232 $     then
    233 $       make = mmks
    234 $     else
    235 $       write sys$output "Unsupported make choice ''mmks' ignored"
    236 $       write sys$output "Use MMK or MMS instead"
    237 $     endif
    238 $   endif
    239 $   i = i + 1
    240 $   goto opt_loop
    241 $ endif
    242 $ return
    243 $!------------------------------------------------------------------------------
    244 $!
    245 $! Look for the compiler used
    246 $!
    247 $CHECK_COMPILER:
    248 $ if (.not. (its_decc .or. its_vaxc .or. its_gnuc))
    249 $ then
    250 $   its_decc = (f$search("SYS$SYSTEM:DECC$COMPILER.EXE") .nes. "")
    251 $   its_vaxc = .not. its_decc .and. (F$Search("SYS$System:VAXC.Exe") .nes. "")
    252 $   its_gnuc = .not. (its_decc .or. its_vaxc) .and. (f$trnlnm("gnu_cc") .nes. "")
    253 $ endif
    254 $!
    255 $! Exit if no compiler available
    256 $!
    257 $ if (.not. (its_decc .or. its_vaxc .or. its_gnuc))
    258 $ then goto CC_ERR
    259 $ else
    260 $   if its_decc then write sys$output "CC compiler check ... Compaq C"
    261 $   if its_vaxc then write sys$output "CC compiler check ... VAX C"
    262 $   if its_gnuc then write sys$output "CC compiler check ... GNU C"
    263 $ endif
    264 $ return
    265 $!------------------------------------------------------------------------------
    266 $!
    267 $! If MMS/MMK are available dump out the descrip.mms if required
    268 $!
    269 $CREA_MMS:
    270 $ write sys$output "Creating descrip.mms..."
    271 $ create descrip.mms
    272 $ open/append out descrip.mms
    273 $ copy sys$input: out
    274 $ deck
    275 # descrip.mms: MMS description file for building zlib on VMS
    276 # written by Martin P.J. Zinser
    277 # <zinser (at] zinser.no-ip.info or zinser (at] sysdev.deutsche-boerse.com>
    278 
    279 OBJS = adler32.obj, compress.obj, crc32.obj, gzio.obj, uncompr.obj, infback.obj\
    280        deflate.obj, trees.obj, zutil.obj, inflate.obj, \
    281        inftrees.obj, inffast.obj
    282 
    283 $ eod
    284 $ write out "CFLAGS=", ccopt
    285 $ write out "LOPTS=", lopts
    286 $ copy sys$input: out
    287 $ deck
    288 
    289 all : example.exe minigzip.exe libz.olb
    290         @ write sys$output " Example applications available"
    291 
    292 libz.olb : libz.olb($(OBJS))
    293 	@ write sys$output " libz available"
    294 
    295 example.exe : example.obj libz.olb
    296               link $(LOPTS) example,libz.olb/lib
    297 
    298 minigzip.exe : minigzip.obj libz.olb
    299               link $(LOPTS) minigzip,libz.olb/lib,x11vms:xvmsutils.olb/lib
    300 
    301 clean :
    302 	delete *.obj;*,libz.olb;*,*.opt;*,*.exe;*
    303 
    304 
    305 # Other dependencies.
    306 adler32.obj  : adler32.c zutil.h zlib.h zconf.h
    307 compress.obj : compress.c zlib.h zconf.h
    308 crc32.obj    : crc32.c zutil.h zlib.h zconf.h
    309 deflate.obj  : deflate.c deflate.h zutil.h zlib.h zconf.h
    310 example.obj  : example.c zlib.h zconf.h
    311 gzio.obj     : gzio.c zutil.h zlib.h zconf.h
    312 inffast.obj  : inffast.c zutil.h zlib.h zconf.h inftrees.h inffast.h
    313 inflate.obj  : inflate.c zutil.h zlib.h zconf.h
    314 inftrees.obj : inftrees.c zutil.h zlib.h zconf.h inftrees.h
    315 minigzip.obj : minigzip.c zlib.h zconf.h
    316 trees.obj    : trees.c deflate.h zutil.h zlib.h zconf.h
    317 uncompr.obj  : uncompr.c zlib.h zconf.h
    318 zutil.obj    : zutil.c zutil.h zlib.h zconf.h
    319 infback.obj  : infback.c zutil.h inftrees.h inflate.h inffast.h inffixed.h
    320 $ eod
    321 $ close out
    322 $ return
    323 $!------------------------------------------------------------------------------
    324 $!
    325 $! Read list of core library sources from makefile.in and create options
    326 $! needed to build shareable image
    327 $!
    328 $CREA_OLIST:
    329 $ open/read min makefile.in
    330 $ open/write mod modules.opt
    331 $ src_check = "OBJS ="
    332 $MRLOOP:
    333 $ read/end=mrdone min rec
    334 $ if (f$extract(0,6,rec) .nes. src_check) then goto mrloop
    335 $ rec = rec - src_check
    336 $ gosub extra_filnam
    337 $ if (f$element(1,"\",rec) .eqs. "\") then goto mrdone
    338 $MRSLOOP:
    339 $ read/end=mrdone min rec
    340 $ gosub extra_filnam
    341 $ if (f$element(1,"\",rec) .nes. "\") then goto mrsloop
    342 $MRDONE:
    343 $ close min
    344 $ close mod
    345 $ return
    346 $!------------------------------------------------------------------------------
    347 $!
    348 $! Take record extracted in crea_olist and split it into single filenames
    349 $!
    350 $EXTRA_FILNAM:
    351 $ myrec = f$edit(rec - "\", "trim,compress")
    352 $ i = 0
    353 $FELOOP:
    354 $ srcfil = f$element(i," ", myrec)
    355 $ if (srcfil .nes. " ")
    356 $ then
    357 $   write mod f$parse(srcfil,,,"NAME"), ".obj"
    358 $   i = i + 1
    359 $   goto feloop
    360 $ endif
    361 $ return
    362 $!------------------------------------------------------------------------------
    363 $!
    364 $! Find current Zlib version number
    365 $!
    366 $FIND_VERSION:
    367 $ open/read h_in 'v_file'
    368 $hloop:
    369 $ read/end=hdone h_in rec
    370 $ rec = f$edit(rec,"TRIM")
    371 $ if (f$extract(0,1,rec) .nes. "#") then goto hloop
    372 $ rec = f$edit(rec - "#", "TRIM")
    373 $ if f$element(0," ",rec) .nes. "define" then goto hloop
    374 $ if f$element(1," ",rec) .eqs. v_string
    375 $ then
    376 $   version = 'f$element(2," ",rec)'
    377 $   goto hdone
    378 $ endif
    379 $ goto hloop
    380 $hdone:
    381 $ close h_in
    382 $ return
    383 $!------------------------------------------------------------------------------
    384 $!
    385 $! Analyze Object files for OpenVMS AXP to extract Procedure and Data
    386 $! information to build a symbol vector for a shareable image
    387 $! All the "brains" of this logic was suggested by Hartmut Becker
    388 $! (Hartmut.Becker@compaq.com). All the bugs were introduced by me
    389 $! (zinser@decus.de), so if you do have problem reports please do not
    390 $! bother Hartmut/HP, but get in touch with me
    391 $!
    392 $ ANAL_OBJ_AXP: Subroutine
    393 $ V = 'F$Verify(0)
    394 $ SAY := "WRITE_ SYS$OUTPUT"
    395 $
    396 $ IF F$SEARCH("''P1'") .EQS. ""
    397 $ THEN
    398 $    SAY "ANAL_OBJ_AXP-E-NOSUCHFILE:  Error, inputfile ''p1' not available"
    399 $    goto exit_aa
    400 $ ENDIF
    401 $ IF "''P2'" .EQS. ""
    402 $ THEN
    403 $    SAY "ANAL_OBJ_AXP:  Error, no output file provided"
    404 $    goto exit_aa
    405 $ ENDIF
    406 $
    407 $ open/read in 'p1
    408 $ create a.tmp
    409 $ open/append atmp a.tmp
    410 $ loop:
    411 $ read/end=end_loop in line
    412 $ f= f$search(line)
    413 $ if f .eqs. ""
    414 $ then
    415 $	write sys$output "ANAL_OBJ_AXP-w-nosuchfile, ''line'"
    416 $	goto loop
    417 $ endif
    418 $ define/user sys$output nl:
    419 $ define/user sys$error nl:
    420 $ anal/obj/gsd 'f /out=x.tmp
    421 $ open/read xtmp x.tmp
    422 $ XLOOP:
    423 $ read/end=end_xloop xtmp xline
    424 $ xline = f$edit(xline,"compress")
    425 $ write atmp xline
    426 $ goto xloop
    427 $ END_XLOOP:
    428 $ close xtmp
    429 $ goto loop
    430 $ end_loop:
    431 $ close in
    432 $ close atmp
    433 $ if f$search("a.tmp") .eqs. "" -
    434 	then $ exit
    435 $ ! all global definitions
    436 $ search a.tmp "symbol:","EGSY$V_DEF 1","EGSY$V_NORM 1"/out=b.tmp
    437 $ ! all procedures
    438 $ search b.tmp "EGSY$V_NORM 1"/wind=(0,1) /out=c.tmp
    439 $ search c.tmp "symbol:"/out=d.tmp
    440 $ define/user sys$output nl:
    441 $ edito/edt/command=sys$input d.tmp
    442 sub/symbol: "/symbol_vector=(/whole
    443 sub/"/=PROCEDURE)/whole
    444 exit
    445 $ ! all data
    446 $ search b.tmp "EGSY$V_DEF 1"/wind=(0,1) /out=e.tmp
    447 $ search e.tmp "symbol:"/out=f.tmp
    448 $ define/user sys$output nl:
    449 $ edito/edt/command=sys$input f.tmp
    450 sub/symbol: "/symbol_vector=(/whole
    451 sub/"/=DATA)/whole
    452 exit
    453 $ sort/nodupl d.tmp,f.tmp 'p2'
    454 $ delete a.tmp;*,b.tmp;*,c.tmp;*,d.tmp;*,e.tmp;*,f.tmp;*
    455 $ if f$search("x.tmp") .nes. "" -
    456 	then $ delete x.tmp;*
    457 $!
    458 $ EXIT_AA:
    459 $ if V then set verify
    460 $ endsubroutine
    461 $!------------------------------------------------------------------------------
    462