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

452 Commits   2 Branches   1 Tag

COMPONENT_TARGETS  = $(HARDWARE_INTEL_PC32)
COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
COMPONENT_TARGETS += $(HARDWARE_CB1X)
COMPONENT_TARGETS += $(HARDWARE_CB2X)
COMPONENT_TARGETS += $(HARDWARE_CB3X)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5B)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5P)
COMPONENT_TARGETS += $(HARDWARE_ROCK_5B)
COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
COMPONENT_TARGETS += $(HARDWARE_REPKA_PI3)
COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
COMPONENT_TARGETS += $(HARDWARE_POIN2)
COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
COMPONENT_TARGETS += $(HARDWARE_M201)
COMPONENT_TARGETS += $(HARDWARE_MXV)
COMPONENT_TARGETS += $(HARDWARE_P201)
COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
COMPONENT_TARGETS += $(HARDWARE_P212)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
COMPONENT_TARGETS += $(HARDWARE_Q201)
COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
COMPONENT_TARGETS += $(HARDWARE_CI20)
COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
COMPONENT_TARGETS += $(HARDWARE_S824L)
COMPONENT_TARGETS += $(HARDWARE_VESNIN)
COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
COMPONENT_TARGETS += $(HARDWARE_VISIONFIVE2)
COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)


NEED_ABS_PATH      = true
COMPONENT_IS_3PP   = true


include ../../../build-system/constants.mk


SOURCE_REQUIRES    = sources/packages/n/nss-pam-ldapd

REQUIRES           = secure/pam/1.5.1
REQUIRES          += net/krb5/1.19.1
REQUIRES          += dev/python3/3.10.8

# ======= __END_OF_REQUIRES__ =======


version            = 0.9.11
tar_xz_archive     = $(SRC_PACKAGE_PATH)/packages/n/nss-pam-ldapd/nss-pam-ldapd-$(version).tar.xz
SRC_ARCHIVE        = $(tar_xz_archive)
SRC_DIR            = $(TARGET_BUILD_DIR)/nss-pam-ldapd-$(version)
src_dir_name       = nss-pam-ldapd-$(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.
#
NSS_PAM_PKG_NAME                = nss-pam-ldapd
NSS_PAM_PKG_VERSION             = 0.9.11
NSS_PAM_PKG_ARCH                = $(PKGARCH)
NSS_PAM_PKG_DISTRO_NAME         = $(DISTRO_NAME)
NSS_PAM_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
NSS_PAM_PKG_GROUP               = $(PKG_GROUP)
###                              |---handy-ruler-------------------------------|
NSS_PAM_PKG_SHORT_DESCRIPTION   = LDAP NSS/PAM module
NSS_PAM_PKG_URL                 = $(BUG_URL)
NSS_PAM_PKG_LICENSE             = LGPLv2.1
NSS_PAM_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(NSS_PAM_PKG_NAME)-pkg-description
NSS_PAM_PKG_DESCRIPTION_FILE_IN = $(NSS_PAM_PKG_NAME)-pkg-description.in
NSS_PAM_PKG_INSTALL_SCRIPT      = $(NSS_PAM_PKG_NAME)-pkg-install.sh

NSS_PAM_PKG      = $(CURDIR)/$(TARGET_BUILD_DIR)/$(NSS_PAM_PKG_NAME)-package

pkg_basename     = $(NSS_PAM_PKG_NAME)-$(NSS_PAM_PKG_VERSION)-$(NSS_PAM_PKG_ARCH)-$(NSS_PAM_PKG_DISTRO_NAME)-$(NSS_PAM_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=$(NSS_PAM_PKG)


extra_configure_switches  = --libdir=/usr/lib$(LIBSUFFIX)
extra_configure_switches += --with-pam-seclib-dir=/lib$(LIBSUFFIX)/security
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 += --sysconfdir=/etc
extra_configure_switches += --localstatedir=/var

env_build  = PYTHON=$(PYTHON3)

CFLAGS  += -Wstringop-overflow=0


####### Dependencies

$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
	$(UNPACK_SRC_ARCHIVE)
	$(APPLY_PATCHES)
	@( cd $(SRC_DIR) ; \
	   autoreconf -vif ; autoupdate ; \
	 )
	@touch $@

$(build_target): $(src_done)
	@mkdir -p $(build_dir)
	@cd $(build_dir) && \
	  $(BUILD_ENVIRONMENT) $(env_build) ../$(src_dir_name)/configure \
	  --prefix=/usr            \
	  --build=$(BUILD)         \
	  --host=$(TARGET)         \
	  $(extra_configure_switches)
	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(env_build) $(MAKE)
	@touch $@

$(install_target): $(build_target)
	@mkdir -p $(NSS_PAM_PKG)
	@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
	@sed -i 's,$(BUILDSYSTEM)/usr/bin/,/usr/bin/env ,' $(NSS_PAM_PKG)/usr/share/nslcd-utils/chsh.py
	@sed -i 's,$(BUILDSYSTEM)/usr/bin/,/usr/bin/env ,' $(NSS_PAM_PKG)/usr/share/nslcd-utils/getent.py
	@( cd $(NSS_PAM_PKG)/usr/bin ; \
	   ln -sf ../share/nslcd-utils/chsh.py   chsh.ldap   ; \
	   ln -sf ../share/nslcd-utils/getent.py getent.ldap ; \
	 )
	# ======= Install config file as .new: =======
	@mv $(NSS_PAM_PKG)/etc/nslcd.conf $(NSS_PAM_PKG)/etc/nslcd.conf.new
	# ======= Restrict access since this file may include a secret credential: =======
	@chmod 600 $(NSS_PAM_PKG)/etc/nslcd.conf.new
	# ======= Install init script: =======
	@mkdir -p $(NSS_PAM_PKG)/etc/rc.d
	@cat $(CURDIR)/config/rc.nss-pam-ldapd > $(NSS_PAM_PKG)/etc/rc.d/rc.nss-pam-ldapd.new
	# ======= Install Documentation =======
	@if [ -d $(NSS_PAM_PKG)/usr/share/man ]; then \
	  ( cd $(NSS_PAM_PKG)/usr/share/man ; \
	    for manpagedir in `find . -type d -name "man*"` ; do \
	      ( cd $$manpagedir ; \
	        for eachpage in `find . -type l -maxdepth 1` ; do \
	          ln -s `readlink $$eachpage`.gz $$eachpage.gz ; \
	          rm $$eachpage ; \
	        done ; \
	        gzip -9 *.?  ; \
	      ) \
	    done \
	  ) \
	 fi
	@mkdir -p $(NSS_PAM_PKG)/usr/doc/$(src_dir_name)
	@cp -a $(SRC_DIR)/AUTHORS $(SRC_DIR)/COPYING \
	       $(NSS_PAM_PKG)/usr/doc/$(src_dir_name)
	@mkdir -p $(NSS_PAM_PKG)/usr/share/doc/$(src_dir_name)
	@( cd $(SRC_DIR) ; \
	   cp -a AUTHORS COPYING HACKING README TODO \
	         $(NSS_PAM_PKG)/usr/share/doc/$(src_dir_name) ; \
	 )
	@( cd $(SRC_DIR) ; \
	   if [ -r ChangeLog ]; then \
	     DOCSDIR=`echo $(NSS_PAM_PKG)/usr/share/doc/$(src_dir_name)` ; \
	     cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
	     touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
	   fi \
	 )
	@( cd $(SRC_DIR) ; \
	   if [ -r NEWS ]; then \
	     DOCSDIR=`echo $(NSS_PAM_PKG)/usr/share/doc/$(src_dir_name)` ; \
	     cat NEWS | head -n 1000 > $$DOCSDIR/NEWS ; \
	     touch -r NEWS $$DOCSDIR/NEWS ; \
	   fi \
	 )
	# ======= Install the same to $(TARGET_DEST_DIR) =======
	$(call install-into-devenv, $(NSS_PAM_PKG))
	# ======= Strip binaries =======
	@( cd $(NSS_PAM_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 ; \
	 )
	@touch $@

$(NSS_PAM_PKG_DESCRIPTION_FILE): $(NSS_PAM_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) $(NSS_PAM_PKG_DESCRIPTION_FILE) $(NSS_PAM_PKG_INSTALL_SCRIPT)
	@cp $(NSS_PAM_PKG_DESCRIPTION_FILE) $(NSS_PAM_PKG)/.DESCRIPTION
	@cp $(NSS_PAM_PKG_INSTALL_SCRIPT) $(NSS_PAM_PKG)/.INSTALL
	@$(BUILD_PKG_REQUIRES) $(NSS_PAM_PKG)/.REQUIRES
	@echo "pkgname=$(NSS_PAM_PKG_NAME)"                            >  $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "pkgver=$(NSS_PAM_PKG_VERSION)"                          >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "arch=$(NSS_PAM_PKG_ARCH)"                               >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "distroname=$(NSS_PAM_PKG_DISTRO_NAME)"                  >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "distrover=$(NSS_PAM_PKG_DISTRO_VERSION)"                >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "group=$(NSS_PAM_PKG_GROUP)"                             >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "short_description=\"$(NSS_PAM_PKG_SHORT_DESCRIPTION)\"" >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "url=$(NSS_PAM_PKG_URL)"                                 >> $(NSS_PAM_PKG)/.PKGINFO ; \
	 echo "license=$(NSS_PAM_PKG_LICENSE)"                         >> $(NSS_PAM_PKG)/.PKGINFO
	@$(PSEUDO) sh -c "cd $(NSS_PAM_PKG) && \
	                  chown -R root:root . && \
	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."