#
|
# CDDL HEADER START
|
#
|
# The contents of this file are subject to the terms of the
|
# Common Development and Distribution License (the "License").
|
# You may not use this file except in compliance with the License.
|
#
|
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
# or http://www.opensolaris.org/os/licensing.
|
# See the License for the specific language governing permissions
|
# and limitations under the License.
|
#
|
# When distributing Covered Code, include this CDDL HEADER in each
|
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
# If applicable, add the following below this CDDL HEADER, with the
|
# fields enclosed by brackets "[]" replaced with your own identifying
|
# information: Portions Copyright [yyyy] [name of copyright owner]
|
#
|
# CDDL HEADER END
|
#
|
# Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2018, Michal Nowak
|
# Copyright (c) 2022, Niklas Poslovski
|
#
|
|
BUILD_BITS= 64
|
OPENSSL_VERSION= 3.1
|
USE_DEFAULT_TEST_TRANSFORMS= yes
|
include ../../../make-rules/shared-macros.mk
|
|
COMPONENT_NAME= curl
|
COMPONENT_VERSION= 8.7.1
|
COMPONENT_SUMMARY= The CURL Network Utility and Library
|
COMPONENT_DESCRIPTION= A command-line tool and library for transforming data with URL syntax
|
COMPONENT_SRC= $(COMPONENT_NAME)-$(COMPONENT_VERSION)
|
COMPONENT_PROJECT_URL= https://curl.haxx.se
|
COMPONENT_ARCHIVE= $(COMPONENT_SRC).tar.xz
|
COMPONENT_ARCHIVE_HASH= sha256:6fea2aac6a4610fbd0400afb0bcddbe7258a64c63f1f68e5855ebc0c659710cd
|
COMPONENT_ARCHIVE_URL= $(COMPONENT_PROJECT_URL)/download/$(COMPONENT_ARCHIVE)
|
COMPONENT_SIG_URL= $(COMPONENT_ARCHIVE_URL).asc
|
COMPONENT_FMRI= web/$(COMPONENT_NAME)
|
COMPONENT_CLASSIFICATION=System/Libraries
|
COMPONENT_LICENSE= CURL
|
COMPONENT_LICENSE_FILE= COPYING
|
|
include $(WS_MAKE_RULES)/common.mk
|
|
# Community code uses different defs
|
#$(BUILD_DIR_32)/.configured: CPPFLAGS += -D__ILP32=32
|
$(BUILD_DIR_64)/.configured: CPPFLAGS += -D__LP64=64
|
|
CPPFLAGS += $(CPP_LARGEFILES)
|
CPPFLAGS += $(CC_PIC_ENABLE)
|
CPPFLAGS += -DNAME_MAX=256
|
|
CPPFLAGS += -I/usr/include/openldap
|
CPPFLAGS += $(shell pkg-config --cflags libidn2)
|
# GSS MECH's API is in /usr/include/kerberosv5/gssapi/
|
CPPFLAGS += $(shell krb5-config --cflags)
|
LIBS += $(shell krb5-config --libs gssapi)
|
|
#GSSAPI_LIBDIR_32= /usr/lib
|
GSSAPI_LIBDIR_64= /usr/lib/$(MACH64)
|
|
LDFLAGS += -m$(BITS)
|
LDFLAGS += $(LD_Z_DEFS)
|
|
CONFIGURE_ENV += CFLAGS="-I$(OPENSSL_INCDIR) $(CFLAGS)"
|
CONFIGURE_ENV += CPPFLAGS="-I$(OPENSSL_INCDIR) $(CPPFLAGS) -I/usr/include/openldap"
|
|
CONFIGURE_OPTIONS += LDFLAGS="-L$(OPENSSL_LIBDIR.$(BITS)) $(LDFLAGS)"
|
CONFIGURE_OPTIONS += --disable-dependency-tracking
|
CONFIGURE_OPTIONS += --localstatedir=$(VARDIR)
|
CONFIGURE_OPTIONS += --enable-shared
|
CONFIGURE_OPTIONS += --disable-static
|
CONFIGURE_OPTIONS += --enable-http --enable-ftp
|
CONFIGURE_OPTIONS += --enable-file --enable-dict
|
CONFIGURE_OPTIONS += --enable-manual --disable-libgcc
|
CONFIGURE_OPTIONS += --enable-rtsp --enable-proxy
|
CONFIGURE_OPTIONS += --enable-telnet --enable-tftp --enable-pop3
|
CONFIGURE_OPTIONS += --enable-imap --enable-smtp
|
CONFIGURE_OPTIONS += --enable-ipv6 --enable-nonblocking
|
CONFIGURE_OPTIONS += --enable-thread --enable-verbose
|
CONFIGURE_OPTIONS += --disable-sspi --enable-crypto-auth
|
CONFIGURE_OPTIONS += --enable-cookies --disable-hidden-symbols
|
CONFIGURE_OPTIONS += --disable-soname-bump
|
CONFIGURE_OPTIONS += --enable-ldap --with-random=/dev/urandom
|
CONFIGURE_OPTIONS += --enable-ares
|
CONFIGURE_OPTIONS += --enable-websockets
|
CONFIGURE_OPTIONS += --with-openssl=$(OPENSSL_PREFIX)
|
CONFIGURE_OPTIONS += --with-ldap-lib=ldap_r-2.4
|
CONFIGURE_OPTIONS += --with-lber-lib=lber-2.4
|
CONFIGURE_OPTIONS += --with-gssapi-includes=/usr/include/gssapi
|
CONFIGURE_OPTIONS += --with-gssapi-libs=$(GSSAPI_LIBDIR_$(BITS))
|
CONFIGURE_OPTIONS += --with-gssapi=/usr --without-ca-bundle
|
CONFIGURE_OPTIONS += --with-ca-path=/etc/openssl/certs
|
CONFIGURE_OPTIONS += --with-zlib=/usr --with-libidn=/usr
|
CONFIGURE_OPTIONS += --with-pic
|
CONFIGURE_OPTIONS += --with-libssh2
|
CONFIGURE_OPTIONS += --without-librtmp
|
CONFIGURE_OPTIONS += "curl_disallow_getifaddrs=yes"
|
|
# Generate configuration scripts form .am-files
|
COMPONENT_PREP_ACTION= (cd $(@D) ; PATH="$(PATH)" autoreconf -fi)
|
|
ENV = /usr/bin/env -i
|
COMPONENT_TEST_ENV += CC="$(CC)"
|
COMPONENT_TEST_ENV += USER=`id -un`
|
COMPONENT_TEST_ENV += PATH="$(GCC_ROOT)/bin:$(GNUBIN):$(PATH)"
|
COMPONENT_TEST_ENV += CFLAGS="$(CFLAGS)"
|
COMPONENT_TEST_ENV += LC_ALL=C
|
COMPONENT_TEST_ARGS += -k -i
|
|
# Only the #'s of passed/failed tests are verified for change
|
# Note that we have many broken tests if valgrind is installed.
|
COMPONENT_TEST_TRANSFORMS += \
|
'-e "s/ during [0-9]* seconds.//" ' \
|
'-e "/TESTDONE:/p" '
|
|
# Auto-generated dependencies
|
REQUIRED_PACKAGES += compress/zstd
|
REQUIRED_PACKAGES += library/brotli
|
REQUIRED_PACKAGES += library/libcares
|
REQUIRED_PACKAGES += library/libgsasl
|
REQUIRED_PACKAGES += library/libidn2
|
REQUIRED_PACKAGES += library/libpsl
|
REQUIRED_PACKAGES += library/libssh2
|
REQUIRED_PACKAGES += library/nghttp2
|
REQUIRED_PACKAGES += library/openldap
|
REQUIRED_PACKAGES += library/security/openssl-31
|
REQUIRED_PACKAGES += library/zlib
|
REQUIRED_PACKAGES += shell/ksh93
|
REQUIRED_PACKAGES += system/library
|
REQUIRED_PACKAGES += system/library/security/gss
|