VMS: Updates for 0740-0D1220
lib/setup-vms.h : VAX HP OpenSSL port is ancient, needs help. More defines to set symbols to uppercase. src/tool_main.c : Fix parameter to vms_special_exit() call. packages/vms/ : backup_gnv_curl_src.com : Fix the error message to have the correct package. build_curl-config_script.com : Rewrite to be more accurate. build_libcurl_pc.com : Use tool_version.h now. build_vms.com : Fix to handle lib/vtls directory. curl_gnv_build_steps.txt : Updated build procedure documentation. generate_config_vms_h_curl.com : * VAX does not support 64 bit ints, so no NTLM support for now. * VAX HP SSL port is ancient, needs some help. * Disable NGHTTP2 for now, not ported to VMS. * Disable UNIX_SOCKETS, not available on VMS yet. * HP GSSAPI port does not have gss_nt_service_name. gnv_link_curl.com : Update for new curl structure. pcsi_product_gnv_curl.com : Set up to optionally do a complete build.
This commit is contained in:

committed by
Daniel Stenberg

parent
6f1f5a7506
commit
f9cf3de70b
@@ -1,10 +1,8 @@
|
||||
$! File: build_libcurl_pc.com
|
||||
$! build_curl-config_script.com
|
||||
$!
|
||||
$! $Id:$
|
||||
$! This generates the curl-config. script from the curl-config.in file.
|
||||
$!
|
||||
$! Build the curl-config file from the config_curl.in file
|
||||
$!
|
||||
$! Copyright 2013, John Malmberg
|
||||
$! Copyright 2014, John Malmberg
|
||||
$!
|
||||
$! Permission to use, copy, modify, and/or distribute this software for any
|
||||
$! purpose with or without fee is hereby granted, provided that the above
|
||||
@@ -19,44 +17,13 @@ $! ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
|
||||
$! OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
$!
|
||||
$!
|
||||
$! 15-Jun-2013 J. Malmberg
|
||||
$! 16-Dec-2014 J. Malmberg
|
||||
$!
|
||||
$!===========================================================================
|
||||
$!
|
||||
$! Skip this if the curl-config. already exists.
|
||||
$ if f$search("[--]curl-config.") .nes. "" then goto all_exit
|
||||
$!
|
||||
$! Need to know the kit type.
|
||||
$ kit_name = f$trnlnm("GNV_PCSI_KITNAME")
|
||||
$ if kit_name .eqs. ""
|
||||
$ then
|
||||
$ write sys$output "@MAKE_PCSI_CURL_KIT_NAME.COM has not been run."
|
||||
$ goto all_exit
|
||||
$ endif
|
||||
$!
|
||||
$!
|
||||
$! Parse the kit name into components.
|
||||
$!---------------------------------------
|
||||
$ producer = f$element(0, "-", kit_name)
|
||||
$ base = f$element(1, "-", kit_name)
|
||||
$ product = f$element(2, "-", kit_name)
|
||||
$ mmversion = f$element(3, "-", kit_name)
|
||||
$ majorver = f$extract(0, 3, mmversion)
|
||||
$ minorver = f$extract(3, 2, mmversion)
|
||||
$ updatepatch = f$element(4, "-", kit_name)
|
||||
$ if updatepatch .eqs. "-" then updatepatch = ""
|
||||
$!
|
||||
$! kit type of "D" means a daily build
|
||||
$ kit_type = f$edit(f$extract(0, 1, majorver), "upcase")
|
||||
$!
|
||||
$ cfg_file_in = "[--]curl-config.in"
|
||||
$!
|
||||
$ if f$search(cfg_file_in) .eqs. ""
|
||||
$ then
|
||||
$ write sys$output "Can not find curl-config.in."
|
||||
$ goto all_exit
|
||||
$ endif
|
||||
$!
|
||||
$ if (f$getsyi("HW_MODEL") .lt. 1024)
|
||||
$ then
|
||||
$ arch_name = "VAX"
|
||||
@@ -66,223 +33,122 @@ $ arch_name = arch_name + f$edit(f$getsyi("ARCH_NAME"), "UPCASE")
|
||||
$ if (arch_name .eqs. "") then arch_name = "UNK"
|
||||
$ endif
|
||||
$!
|
||||
$ x_prefix = "/usr"
|
||||
$ x_exec_prefix = "/usr"
|
||||
$ x_includedir = "${prefix}/include"
|
||||
$ x_cppflag_curl_staticlib = "-DCURL_STATICLIB"
|
||||
$ x_enabled_shared = "no"
|
||||
$ x_curl_ca_bundle = ""
|
||||
$ x_cc = "cc"
|
||||
$ x_support_features = "SSL IPv6 libz NTLM"
|
||||
$ x_support_protocols1 = "DICT FILE FTP FTPS GOPHER HTTP HTTPS IMAP IMAPS LDAP"
|
||||
$ x_support_protocols2 = " LDAPS POP3 POP3S RTSP SMTP SMTPS TELNET TFTP"
|
||||
$ x_support_protocols = x_support_protocols1 + x_support_protocols2
|
||||
$ x_curlversion = "0.0.0.0"
|
||||
$ x_versionnum = ""
|
||||
$ x_libdir = "${prefix}/lib"
|
||||
$ x_require_lib_deps = ""
|
||||
$ x_enable_static = ""
|
||||
$ x_ldflags = ""
|
||||
$ part1 = "-L/usr/lib -L/SSL_LIB -lssl -lcrypto -lz"
|
||||
$ if arch_name .eqs. "VAX"
|
||||
$ then
|
||||
$ x_libcurl_libs = part1
|
||||
$ else
|
||||
$ x_libcurl_libs = part1 + " -lgssapi"
|
||||
$ endif
|
||||
$ x_libext = "a"
|
||||
$!
|
||||
$ curl_version = "0.0.0"
|
||||
$ open/read vf [--.include.curl]curlver.h
|
||||
$version_loop:
|
||||
$ read vf/end=version_loop_end line_in
|
||||
$! Get the version number
|
||||
$!-----------------------
|
||||
$ i = 0
|
||||
$ open/read/error=version_loop_end vhf [--.include.curl]curlver.h
|
||||
$ version_loop:
|
||||
$ read/end=version_loop_end vhf line_in
|
||||
$ if line_in .eqs. "" then goto version_loop
|
||||
$ key = f$element(0, " ", line_in)
|
||||
$ if key .nes. "#define" then goto version_loop
|
||||
$ name = f$element(1, " ", line_in)
|
||||
$ if name .eqs. "LIBCURL_VERSION"
|
||||
$ if f$locate("#define LIBCURL_VERSION ", line_in) .eq. 0
|
||||
$ then
|
||||
$ curl_version = f$element(2, " ", line_in) - """" - """"
|
||||
$ goto version_loop
|
||||
$ x_curlversion = f$element(2," ", line_in) - """" - """"
|
||||
$ i = i + 1
|
||||
$ endif
|
||||
$ if name .eqs. "LIBCURL_VERSION_NUM"
|
||||
$ if f$locate("#define LIBCURL_VERSION_NUM ", line_in) .eq. 0
|
||||
$ then
|
||||
$ version_num_hex = f$element(2, " ", line_in)
|
||||
$ version_num = version_num_hex - "0x"
|
||||
$ goto version_loop
|
||||
$ x_versionnum = f$element(2," ", line_in) - """" - """"
|
||||
$ i = i + 1
|
||||
$ endif
|
||||
$version_loop_end:
|
||||
$ close vf
|
||||
$ if i .lt 2 then goto version_loop
|
||||
$ version_loop_end:
|
||||
$ close vhf
|
||||
$!
|
||||
$!
|
||||
$ create [--]curl-config.
|
||||
$ open/append pco [--]curl-config.
|
||||
$ open/read pci 'cfg_file_in'
|
||||
$cfg_file_loop:
|
||||
$ read pci/end=cfg_file_loop_end line_in
|
||||
$!
|
||||
$! blank lines
|
||||
$ if line_in .eqs. ""
|
||||
$ kit_type = "V"
|
||||
$ if f$locate("-", x_curlversion) .lt. f$length(x_curlversion)
|
||||
$ then
|
||||
$ write pco ""
|
||||
$ goto cfg_file_loop
|
||||
$ kit_type = "D"
|
||||
$ x_prefix = "/beta"
|
||||
$ x_exec_prefix = "/beta"
|
||||
$ endif
|
||||
$!
|
||||
$! comment lines
|
||||
$ key = f$extract(0, 1, line_in)
|
||||
$ if key .eqs. "#"
|
||||
$ if kit_type .nes. "D"
|
||||
$ then
|
||||
$ write pco line_in
|
||||
$ goto cfg_file_loop
|
||||
$ part1 = " echo "" '--prefix=/usr' '--exec-prefix=/usr' "
|
||||
$ else
|
||||
$ part1 = " echo "" '--prefix=/beta' '--exec_prefix=/beta' "
|
||||
$ endif
|
||||
$ if arch_name .eqs. "VAX"
|
||||
$ then
|
||||
$ part3 = ""
|
||||
$ else
|
||||
$ part3 = "'--with-gssapi' "
|
||||
$ endif
|
||||
$ part2 = "'--disable-dependency-tracking' '--disable-libtool-lock' "
|
||||
$ part4 = "'--disable-ntlm-wb' '--with-ca-path=gnv$curl_ca_path'"""
|
||||
$!
|
||||
$! No substitution line
|
||||
$ line_in_len = f$length(line_in)
|
||||
$ if f$locate("@", line_in) .ge. line_in_len
|
||||
$ then
|
||||
$ write pco line_in
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ x_configure_options = part1 + part2 + part3 + part4
|
||||
$!
|
||||
$ if f$locate("@prefix@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ if kit_type .nes. "D"
|
||||
$ then
|
||||
$ write pco "prefix=/usr"
|
||||
$ else
|
||||
$ write pco "prefix=/beta"
|
||||
$ endif
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@exec_prefix@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ if kit_type .nes. "D"
|
||||
$ then
|
||||
$ write pco "exec_prefix=/usr"
|
||||
$ else
|
||||
$ write pco "exec_prefix=/beta"
|
||||
$ endif
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("=@includedir@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco "includedir=$(prefix}/include"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("X@includedir@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " if test ""X$(prefix}/include""; then"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("I@includedir@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " echo "${CPPFLAG_CURL_STATICLIB}-I$(prefix}/include"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@CPPFLAG_CURL_STATICLIB@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco "cppflag_curl_staticlib=-DCURL_STATICLIB"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@ENABLE_SHARED@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " echo no"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@CURL_CA_BUNDLE@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " echo """""
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@CC@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " echo ""cc"""
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@SUPPORT_FEATURES@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ if arch_name .eqs. "VAX"
|
||||
$ then
|
||||
$ write pco " for feature in SSL libz NTLM ""; do"
|
||||
$ else
|
||||
$ write pco " for feature in SSL IPv6 libz NTLM ""; do"
|
||||
$ endif
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@SUPPORT_PROTOCOLS@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ proto1 = "DICT FILE FTP FTPS GOPHER HTTP HTTPS IMAP IMAPS"
|
||||
$ proto2 = " LDAP LDAPS POP3 POP3S RTSP SMTP SMTPS TELNET TFTP"
|
||||
$ proto = proto1 + proto2
|
||||
$ write pco " for protocol in " + proto + "; do"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("libcurl @CURLVERSION@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " echo libcurl ''curl_version'"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("existing @CURLVERSION@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ line_start = -
|
||||
" echo ""requested version $checkfor is newer than existing"
|
||||
$ write pco "''line_start' ''curl_version'"""
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("`echo @versionnum@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " numuppercase=`echo ''version_num' | tr 'a-f' 'A-F'`"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate(" echo @versionnum@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " echo ''version_num'"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("X@libdir@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ part1 = " if test ""$(exec_prefix}/lib"" != ""X/usr/lib"""
|
||||
$ part2 = "-a ""X$(exec_prefix}/lib"" != ""X/usr/lib64""; then"
|
||||
$ write pco part1,part2
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("L@libdir@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " CURLLIBDIR=""$(exec_prefix}/lib """
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@REQUIRE_LIB_DEPS@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " if test "Xyes" = "Xyes"; then"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@LIBCURL_LIBS@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ if arch_name .eqs. "VAX"
|
||||
$ then
|
||||
$ write pco " echo ${CURLLIBDIR}-lssl -lcrypto -lz"
|
||||
$ else
|
||||
$ write pco " echo ${CURLLIBDIR}-lssl -lcrypto -lgssapi -lz"
|
||||
$ endif
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@ENABLE_STATIC@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ write pco " if test "Xyes" != "Xno" ; then"
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@LIBCURL_LIBS@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ part1 = " echo ${exec_prefix}/lib/libcurl.a"
|
||||
$ part2 = "-L/usr/lib -L/SSL_LIB"
|
||||
$ if arch_name .eqs. "VAX"
|
||||
$ then
|
||||
$ write pco "''part1' ''part2' -lssl -lcrypto -lz"
|
||||
$ else
|
||||
$ write pco "''part1' ''part2' -lssl -lcrypto -lgssapi -lz"
|
||||
$ endif
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$ if f$locate("@CONFIGURE_OPTIONS@", line_in) .lt line_in_len
|
||||
$ then
|
||||
$ if kit_type .nes. "D"
|
||||
$ then
|
||||
$ part1 = " echo "" '--prefix=/usr' '--exec-prefix=/usr' "
|
||||
$ else
|
||||
$ part1 = " echo "" '--prefix=/beta' '--exec_prefix=/beta' "
|
||||
$ endif
|
||||
$ if arch_name .eqs. "VAX"
|
||||
$ then
|
||||
$ part3 = ""
|
||||
$ else
|
||||
$ part3 = "'--with-gssapi' "
|
||||
$ endif
|
||||
$ part2 = "'--disable-dependency-tracking' '--disable-libtool-lock' "
|
||||
$ part4 = "'--disable-ntlm-wb' '--with-ca-path=gnv$curl_ca_path'"""
|
||||
$!
|
||||
$ write pco part1,part2,part3,part4
|
||||
$!
|
||||
$ goto cfg_file_loop
|
||||
$ endif
|
||||
$!
|
||||
$pc_file_loop_end:
|
||||
$ close pco
|
||||
$ close pci
|
||||
$!
|
||||
$all_exit:
|
||||
$ exit
|
||||
$ open/read/error=read_loop_end c_c_in sys$disk:[--]curl-config.in
|
||||
$ create sys$disk:[--]curl-config.
|
||||
$ open/append c_c_out sys$disk:[--]curl-config.
|
||||
$read_loop:
|
||||
$ read/end=read_loop_end c_c_in line_in
|
||||
$ line_in_len = f$length(line_in)
|
||||
$ if f$locate("@", line_in) .ge. line_in_len
|
||||
$ then
|
||||
$ write c_c_out line_in
|
||||
$ goto read_loop
|
||||
$ endif
|
||||
$ i = 0
|
||||
$ line_out = ""
|
||||
$sub_loop:
|
||||
$ ! Replace between pairs of @ by alternating the elements.
|
||||
$ ! If mis-matched pairs, do not substitute anything.
|
||||
$ section1 = f$element(i, "@", line_in)
|
||||
$ if section1 .eqs. "@"
|
||||
$ then
|
||||
$ goto sub_loop_end
|
||||
$ endif
|
||||
$ i = i + 1
|
||||
$ section2 = f$element(i, "@", line_in)
|
||||
$ if section2 .eqs. "@"
|
||||
$ then
|
||||
$ goto sub_loop_end
|
||||
$ endif
|
||||
$ i = i + 1
|
||||
$ section3 = f$element(i, "@", line_in)
|
||||
$ if section3 .eqs. "@"
|
||||
$ then
|
||||
$ if line_out .eqs. "" then line_out = line_in
|
||||
$ goto sub_loop_end
|
||||
$ endif
|
||||
$ line_out = line_out + section1
|
||||
$ if f$type(x_'section2') .eqs. "STRING"
|
||||
$ then
|
||||
$ line_out = line_out + x_'section2'
|
||||
$ endif
|
||||
$ goto sub_loop
|
||||
$sub_loop_end:
|
||||
$ write c_c_out line_out
|
||||
$ goto read_loop
|
||||
$read_loop_end:
|
||||
$ close c_c_in
|
||||
$ close c_c_out
|
||||
|
Reference in New Issue
Block a user