Radix cross Linux

The main Radix cross Linux repository contains the build scripts of packages, which have the most complete and common functionality for desktop machines

383 Commits   1 Branch   1 Tag
Index: Makefile
===================================================================
--- Makefile	(nonexistent)
+++ Makefile	(revision 5)
@@ -0,0 +1,237 @@
+
+COMPONENT_TARGETS  = $(HARDWARE_INTEL_PC64)
+
+NEED_ABS_PATH      = true
+COMPONENT_IS_3PP   = true
+
+CREATE_X86_32_PACKAGE = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES    = sources/packages/n/curl
+
+REQUIRES           = net/curl/7.75.0
+REQUIRES          += net/gnutls/3.7.1-x86_32
+REQUIRES          += net/krb5/1.19.1-x86_32
+REQUIRES          += libs/libssh2/1.9.0-x86_32
+REQUIRES          += libs/zstd/1.5.2-x86_32
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version            = 7.75.0
+tar_xz_archive     = $(SRC_PACKAGE_PATH)/packages/n/curl/curl-$(version).tar.xz
+SRC_ARCHIVE        = $(tar_xz_archive)
+SRC_DIR            = $(TARGET_BUILD_DIR)/curl-$(version)
+src_dir_name       = curl-$(version)
+src_done           = $(TARGET_BUILD_DIR)/.source_done
+
+PATCHES = PATCHES
+
+build_dir          = $(TARGET_BUILD_DIR)/build
+build_target       = $(TARGET_BUILD_DIR)/.build_done
+install_target     = $(TARGET_BUILD_DIR)/.install_done
+
+
+####### Targets
+
+PKG_GROUP = net
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+CURL_32_PKG_NAME                = curl-x32
+CURL_32_PKG_VERSION             = 7.75.0
+CURL_32_PKG_ARCH                = $(PKGARCH)
+CURL_32_PKG_DISTRO_NAME         = $(DISTRO_NAME)
+CURL_32_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
+CURL_32_PKG_GROUP               = $(PKG_GROUP)
+###                              |---handy-ruler-------------------------------|
+CURL_32_PKG_SHORT_DESCRIPTION   = command line URL data transfer tool
+CURL_32_PKG_URL                 = $(BUG_URL)
+CURL_32_PKG_LICENSE             = custom
+CURL_32_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(CURL_32_PKG_NAME)-pkg-description
+CURL_32_PKG_DESCRIPTION_FILE_IN = $(CURL_32_PKG_NAME)-pkg-description.in
+CURL_32_PKG_INSTALL_SCRIPT      = $(CURL_32_PKG_NAME)-pkg-install.sh
+
+CURL_32_PKG      = $(CURDIR)/$(TARGET_BUILD_DIR)/$(CURL_32_PKG_NAME)-package
+
+pkg_basename     = $(CURL_32_PKG_NAME)-$(CURL_32_PKG_VERSION)-$(CURL_32_PKG_ARCH)-$(CURL_32_PKG_DISTRO_NAME)-$(CURL_32_PKG_DISTRO_VERSION)
+
+pkg_archive      = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
+pkg_certificate  = $(call cert-name,$(pkg_archive))
+pkg_signature    = $(call sign-name,$(pkg_archive))
+pkg_description  = $(call desc-name,$(pkg_archive))
+products         = $(call pkg-files,$(pkg_archive))
+
+BUILD_TARGETS    = $(build_target)
+BUILD_TARGETS   += $(install_target)
+
+PRODUCT_TARGETS  = $(products)
+
+ROOTFS_TARGETS   = $(pkg_archive)
+
+
+include ../../../build-system/core.mk
+
+
+env_sysroot  = DESTDIR=$(CURL_32_PKG)
+
+
+extra_configure_switches  = --libdir=/usr/lib$(MULTILIB_X86_32_SUFFIX)
+extra_configure_switches += --docdir=/usr/share/doc/$(src_dir_name)
+extra_configure_switches += --infodir=/usr/share/info
+extra_configure_switches += --mandir=/usr/share/man
+
+extra_configure_switches += --bindir=/usr/bin/32
+
+extra_configure_switches += --with-ca-bundle=/usr/share/curl/ca-bundle.crt
+extra_configure_switches += --with-ca-path=/etc/ssl/certs
+
+extra_configure_switches += --enable-ipv6
+extra_configure_switches += --with-libidn2=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-ssl=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-libssh2
+extra_configure_switches += --with-libssh=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-gssapi=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-gnutls=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --enable-ldap
+extra_configure_switches += --with-ldap-lib=$(TARGET_DEST_DIR)/usr/lib$(MULTILIB_X86_32_SUFFIX)/libldap.so
+extra_configure_switches += --with-lber-lib=$(TARGET_DEST_DIR)/usr/lib$(MULTILIB_X86_32_SUFFIX)/liblber.so
+extra_configure_switches += --with-zstd=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-zlib=$(TARGET_DEST_DIR)/usr
+
+extra_environment  = KRB5CONFIG=$(TARGET_DEST_DIR)/usr/bin/32/krb5-config
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --enable-static=yes
+else
+extra_configure_switches += --enable-static=no
+endif
+extra_configure_switches += --enable-shared=yes
+
+
+TARGET_LIB_RPATH = /lib$(MULTILIB_X86_32_SUFFIX):/usr/lib$(MULTILIB_X86_32_SUFFIX):/usr/lib/../lib$(MULTILIB_X86_32_SUFFIX)
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+	$(UNPACK_SRC_ARCHIVE)
+	$(APPLY_PATCHES)
+	@touch $@
+
+$(build_target): $(src_done)
+	@mkdir -p $(build_dir)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(extra_environment) ../$(src_dir_name)/configure \
+	  --prefix=/usr               \
+	  --build=$(BUILD)            \
+	  --host=$(TARGET32)          \
+	  $(extra_configure_switches)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE)
+	@touch $@
+
+$(install_target): $(build_target)
+	@mkdir -p $(CURL_32_PKG)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
+	@rm -rf $(CURL_32_PKG)/usr/include
+	@rm -rf $(CURL_32_PKG)/usr/share
+	# ======= remove unexpected libdir suffixes =======
+	@( cd $(CURL_32_PKG)/usr/bin/32 ; \
+	   sed -i "s,\-L[^ \t]*/lib ,,g" curl-config ; \
+	 )
+	@( cd $(CURL_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX) ; \
+	   sed -i "s,\-L[^ \t]*/lib ,,g" libcurl.la ; \
+	 )
+	@( cd $(CURL_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX)/pkgconfig ; \
+	   sed -i "s,\-L[^ \t]*/lib ,,g" libcurl.pc ; \
+	 )
+	# ======= remove toolchain path from target libtool *.la files =======
+	@( cd $(CURL_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX) ; \
+	   sed -i "s,$(TARGET_DEST_DIR),,g" libcurl.la ; \
+	 )
+	# ======= remove toolchain path from target pkg-config *.pc files =======
+	@( cd $(CURL_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX)/pkgconfig ; \
+	   sed -i "s,$(TARGET_DEST_DIR),,g" libcurl.pc ; \
+	 )
+	# ======= Tune development '/usr/bin/32/curl-config' sctipt =======
+	@( cd $(CURL_32_PKG)/usr/bin/32 ; \
+	   sed -i "s,^prefix=/usr,prefix=$(TARGET_DEST_DIR)/usr,"            curl-config ; \
+	   sed -i "s,\"/usr/share/curl,\"$(TARGET_DEST_DIR)/usr/share/curl," curl-config ; \
+	   sed -i "s,test \"X/usr/lib,test \"X\$${prefix}/lib,"              curl-config ; \
+	   sed -i "s,a \"X/usr/lib,a \"X\$${prefix}/lib,"                    curl-config ; \
+	   sed -i "s,L/usr/lib,L\$${prefix}/lib,g"                           curl-config ; \
+	   sed -i "s,/usr/lib$(MULTILIB_X86_32_SUFFIX)/libcurl.a,$(TARGET_DEST_DIR)/usr/lib$(MULTILIB_X86_32_SUFFIX)/libcurl.a," curl-config ; \
+	 )
+	# ======= Install the same to $(TARGET_DEST_DIR) =======
+	$(call install-into-devenv, $(CURL_32_PKG))
+	# ======= Tune target '/usr/bin/32/curl-config' sctipt =======
+	@( cd $(CURL_32_PKG)/usr/bin/32 ; \
+	   sed -i "s,$(TARGET_DEST_DIR),,g"    curl-config ; \
+	   sed -i "s,$(TOOLCHAIN_PATH),/usr,g" curl-config ; \
+	   sed -i "s,$(TARGET)-,,g"            curl-config ; \
+	   sed -i "s, '--build=[^\']*',,g"     curl-config ; \
+	   sed -i "s, '--host=[^\']*',,g"      curl-config ; \
+	   sed -i "s, 'build_alias=[^\']*',,g" curl-config ; \
+	   sed -i "s, 'host_alias=[^\']*',,g"  curl-config ; \
+	   sed -i "s, --sysroot=[^\']*',',g"   curl-config ; \
+	   sed -i 's, --sysroot=[^\"]*",",g'   curl-config ; \
+	 )
+	# ======= tune libtool *.la search path to the target destination for development =======
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(MULTILIB_X86_32_SUFFIX) ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g"   libcurl.la ; \
+	   sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" libcurl.la ; \
+	 )
+	# ======= tune pkg-config *.pc search path to the target destination for development =======
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(MULTILIB_X86_32_SUFFIX)/pkgconfig ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g"   libcurl.pc ; \
+	   sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" libcurl.pc ; \
+	 )
+	# ======= Strip binaries =======
+	@( cd $(CURL_32_PKG) ; \
+	   find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+	   find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+	 )
+ifeq ($(__ENABLE_STATIC__),yes)
+	@( cd $(CURL_32_PKG) ; \
+	   find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+	 )
+endif
+ifneq ($(PATCHELF),)
+	# ======= Set RPATH/RUNPATH for target shared objects =======
+	@( cd $(CURL_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX) ; \
+	   for file in `find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
+	     rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
+	     if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
+	       $(PATCHELF) --set-rpath $(TARGET_LIB_RPATH) $$file 1> /dev/null 2> /dev/null ; \
+	     fi ; \
+	   done ; \
+	 )
+endif
+	@touch $@
+
+$(CURL_32_PKG_DESCRIPTION_FILE): $(CURL_32_PKG_DESCRIPTION_FILE_IN)
+	@cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
+
+$(pkg_certificate) : $(pkg_archive) ;
+$(pkg_signature)   : $(pkg_archive) ;
+$(pkg_description) : $(pkg_archive) ;
+
+$(pkg_archive): $(install_target) $(CURL_32_PKG_DESCRIPTION_FILE) $(CURL_32_PKG_INSTALL_SCRIPT)
+	@cp $(CURL_32_PKG_DESCRIPTION_FILE) $(CURL_32_PKG)/.DESCRIPTION
+	@cp $(CURL_32_PKG_INSTALL_SCRIPT) $(CURL_32_PKG)/.INSTALL
+	@$(BUILD_PKG_REQUIRES) $(CURL_32_PKG)/.REQUIRES
+	@echo "pkgname=$(CURL_32_PKG_NAME)"                            >  $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "pkgver=$(CURL_32_PKG_VERSION)"                          >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "arch=$(CURL_32_PKG_ARCH)"                               >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "distroname=$(CURL_32_PKG_DISTRO_NAME)"                  >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "distrover=$(CURL_32_PKG_DISTRO_VERSION)"                >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "group=$(CURL_32_PKG_GROUP)"                             >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "short_description=\"$(CURL_32_PKG_SHORT_DESCRIPTION)\"" >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "url=$(CURL_32_PKG_URL)"                                 >> $(CURL_32_PKG)/.PKGINFO ; \
+	 echo "license=$(CURL_32_PKG_LICENSE)"                         >> $(CURL_32_PKG)/.PKGINFO
+	@$(PSEUDO) sh -c "cd $(CURL_32_PKG) && \
+	                  chown -R root:root . && \
+	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: PATCHES
===================================================================
Index: curl-x32-pkg-description.in
===================================================================
--- curl-x32-pkg-description.in	(nonexistent)
+++ curl-x32-pkg-description.in	(revision 5)
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description.  Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in.  You must
+# make exactly 11 lines for the formatting to be correct.  It's also
+# customary to leave one space after the ':'.
+
+        |-----handy-ruler------------------------------------------------------|
+curl-x32: curl-x32 @VERSION@ (command line URL data transfer tool)
+curl-x32:
+curl-x32: Curl is a command line tool for transferring data specified with URL
+curl-x32: syntax. The command is designed to work without user interaction or
+curl-x32: any kind of interactivity. Curl offers a busload of useful tricks
+curl-x32: like proxy support, user authentication, ftp upload, HTTP post, SSL
+curl-x32: (https:) connections, cookies, file transfer resume and more.
+curl-x32:
+curl-x32: libcurl is a library that Curl uses to do its job. It is readily
+curl-x32: available to be used by your software, too.
+curl-x32:
Index: curl-x32-pkg-install.sh
===================================================================
--- curl-x32-pkg-install.sh	(nonexistent)
+++ curl-x32-pkg-install.sh	(revision 5)
@@ -0,0 +1,39 @@
+#!/bin/sh
+
+# arg 1:  the new package version
+pre_install() {
+  /bin/true
+}
+
+# arg 1:  the new package version
+post_install() {
+  /bin/true
+}
+
+# arg 1:  the new package version
+# arg 2:  the old package version
+pre_update() {
+  /bin/true
+}
+
+# arg 1:  the new package version
+# arg 2:  the old package version
+post_update() {
+  post_install
+}
+
+# arg 1:  the old package version
+pre_remove() {
+  /bin/true
+}
+
+# arg 1:  the old package version
+post_remove() {
+  /bin/true
+}
+
+
+operation=$1
+shift
+
+$operation $*

Property changes on: curl-x32-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: .
===================================================================
--- .	(nonexistent)
+++ .	(revision 5)

Property changes on: .
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~