[Buildroot] [PATCH 1/1] haproxy: new package

Fabrice Fontaine fontaine.fabrice at gmail.com
Fri Sep 21 20:56:19 UTC 2018


HAProxy is a free, very fast and reliable solution offering
high availability, load balancing, and proxying for TCP and
HTTP-based applications.

http://www.haproxy.org

Signed-off-by: Fabrice Fontaine <fontaine.fabrice at gmail.com>
---
 DEVELOPERS                   |  1 +
 package/Config.in            |  1 +
 package/haproxy/Config.in    | 10 +++++
 package/haproxy/haproxy.hash |  5 +++
 package/haproxy/haproxy.mk   | 85 ++++++++++++++++++++++++++++++++++++
 5 files changed, 102 insertions(+)
 create mode 100644 package/haproxy/Config.in
 create mode 100644 package/haproxy/haproxy.hash
 create mode 100644 package/haproxy/haproxy.mk

diff --git a/DEVELOPERS b/DEVELOPERS
index 84129553c5..d71c7bd500 100644
--- a/DEVELOPERS
+++ b/DEVELOPERS
@@ -742,6 +742,7 @@ F:	package/gssdp/
 F:	package/gupnp/
 F:	package/gupnp-dlna/
 F:	package/gupnp-tools/
+F:	package/haproxy/
 F:	package/hiredis/
 F:	package/i2pd/
 F:	package/igd2-for-linux/
diff --git a/package/Config.in b/package/Config.in
index c04645a30b..0d8fd8149f 100644
--- a/package/Config.in
+++ b/package/Config.in
@@ -1789,6 +1789,7 @@ menu "Networking applications"
 	source "package/gupnp-tools/Config.in"
 	source "package/gutenprint/Config.in"
 	source "package/hans/Config.in"
+	source "package/haproxy/Config.in"
 	source "package/hiawatha/Config.in"
 	source "package/hostapd/Config.in"
 	source "package/hplip/Config.in"
diff --git a/package/haproxy/Config.in b/package/haproxy/Config.in
new file mode 100644
index 0000000000..cbcbc0c388
--- /dev/null
+++ b/package/haproxy/Config.in
@@ -0,0 +1,10 @@
+config BR2_PACKAGE_HAPROXY
+	bool "haproxy"
+	depends on BR2_USE_MMU # fork()
+	depends on BR2_TOOLCHAIN_HAS_SYNC_4 # __sync_*_4 intrisics
+	help
+	  HAProxy is a free, very fast and reliable solution offering
+	  high availability, load balancing, and proxying for TCP and
+	  HTTP-based applications.
+
+	  http://www.haproxy.org
diff --git a/package/haproxy/haproxy.hash b/package/haproxy/haproxy.hash
new file mode 100644
index 0000000000..e6fcb3b65c
--- /dev/null
+++ b/package/haproxy/haproxy.hash
@@ -0,0 +1,5 @@
+# Locally computed:
+sha256	2bf5dafbb5f1530c0e67ab63666565de948591f8e0ee2a1d3c84c45e738220f1	haproxy-1.8.13.tar.gz
+sha256	0717ca51fceaa25ac9e5ccc62e0c727dcf27796057201fb5fded56a25ff6ca28	LICENSE
+sha256	5df07007198989c622f5d41de8d703e7bef3d0e79d62e24332ee739a452af62a	doc/lgpl.txt
+sha256	ddb9db7630752f8fdc6898f7c99a99eaeeac5213627ecb093df9c82f56175dc7	doc/gpl.txt
diff --git a/package/haproxy/haproxy.mk b/package/haproxy/haproxy.mk
new file mode 100644
index 0000000000..ba0ebef1f3
--- /dev/null
+++ b/package/haproxy/haproxy.mk
@@ -0,0 +1,85 @@
+################################################################################
+#
+# haproxy
+#
+################################################################################
+
+HAPROXY_VERSION_MAJOR = 1.8
+HAPROXY_VERSION = $(HAPROXY_VERSION_MAJOR).13
+HAPROXY_SITE = http://www.haproxy.org/download/$(HAPROXY_VERSION_MAJOR)/src
+HAPROXY_LICENSE = GPL-2.0+ and LGPL-2.1+ with exceptions
+HAPROXY_LICENSE_FILES = LICENSE doc/lgpl.txt doc/gpl.txt
+
+HAPROXY_MAKE_OPTS = \
+	LD=$(TARGET_CC) \
+	PREFIX=/usr \
+	TARGET=custom
+
+ifeq ($(BR2_TOOLCHAIN_HAS_LIBATOMIC),y)
+HAPROXY_LIBS += -latomic
+endif
+
+ifeq ($(BR2_TOOLCHAIN_HAS_THREADS),y)
+HAPROXY_MAKE_OPTS += USE_THREAD=1
+endif
+
+ifeq ($(BR2_PACKAGE_LUA_5_3),y)
+HAPROXY_DEPENDENCIES += lua
+HAPROXY_MAKE_OPTS += USE_LUA=1
+endif
+
+ifeq ($(BR2_PACKAGE_OPENSSL),y)
+HAPROXY_DEPENDENCIES += openssl
+HAPROXY_MAKE_OPTS += USE_OPENSSL=1
+ifeq ($(BR2_STATIC_LIBS),y)
+HAPROXY_LIBS += -lz
+endif
+endif
+
+# pcre and pcre2 can't be enabled at the same time so prefer pcre2
+# Set PCRE2_DIR as by haproxy will try to use pcre2-config and will default to
+# /usr/local
+ifeq ($(BR2_PACKAGE_PCRE2),y)
+HAPROXY_DEPENDENCIES += pcre2
+HAPROXY_MAKE_OPTS += \
+	PCRE2DIR=$(STAGING_DIR)/usr \
+	USE_PCRE2=1
+
+# Again, set manually PCRE2_LDFLAGS or default will contain -L/usr/local
+ifeq ($(BR2_PACKAGE_PCRE2_32),y)
+HAPROXY_MAKE_OPTS += PCRE2_LDFLAGS=-lpcre2-32
+else ifeq ($(BR2_PACKAGE_PCRE2_16),y)
+HAPROXY_MAKE_OPTS += PCRE2_LDFLAGS=-lpcre2-16
+else
+HAPROXY_MAKE_OPTS += PCRE2_LDFLAGS=-lpcre2-8
+endif
+else ifeq ($(BR2_PACKAGE_PCRE),y)
+HAPROXY_DEPENDENCIES += pcre
+HAPROXY_MAKE_OPTS += \
+	PCREDIR=$(STAGING_DIR)/usr \
+	USE_PCRE=1
+endif
+
+ifeq ($(BR2_PACKAGE_SYSTEMD),y)
+HAPROXY_DEPENDENCIES += systemd
+HAPROXY_MAKE_OPTS += USE_SYSTEMD=1
+endif
+
+ifeq ($(BR2_PACKAGE_ZLIB),y)
+HAPROXY_DEPENDENCIES += zlib
+HAPROXY_MAKE_OPTS += USE_ZLIB=1
+endif
+
+HAPROXY_MAKE_OPTS += ADDLIB="$(HAPROXY_LIBS)"
+
+define HAPROXY_BUILD_CMDS
+	$(TARGET_MAKE_ENV) $(MAKE) $(TARGET_CONFIGURE_OPTS) \
+		$(HAPROXY_MAKE_OPTS) -C $(@D)
+endef
+
+define HAPROXY_INSTALL_TARGET_CMDS
+	$(TARGET_MAKE_ENV) $(MAKE) $(TARGET_CONFIGURE_OPTS) \
+		$(HAPROXY_MAKE_OPTS) -C $(@D) DESTDIR=$(TARGET_DIR) install
+endef
+
+$(eval $(generic-package))
-- 
2.17.1



More information about the buildroot mailing list