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
Index: 246.10/Makefile
===================================================================
--- 246.10/Makefile	(nonexistent)
+++ 246.10/Makefile	(revision 5)
@@ -0,0 +1,370 @@
+
+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_WECHIP_TX6)
+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_SIFIVE_U740)
+
+
+NEED_ABS_PATH      = true
+COMPONENT_IS_3PP   = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES    = sources/packages/a/elogind
+
+REQUIRES           = secure/libcap/2.48
+REQUIRES          += libs/eudev/3.2.10
+REQUIRES          += app/acl/2.2.53
+REQUIRES          += dev/gperf/3.1
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version            = 246.10
+tar_xz_archive     = $(SRC_PACKAGE_PATH)/packages/a/elogind/elogind-$(version).tar.xz
+SRC_ARCHIVE        = $(tar_xz_archive)
+SRC_DIR            = $(TARGET_BUILD_DIR)/elogind-$(version)
+src_dir_name       = elogind-$(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
+
+cross_file         = $(TARGET_BUILD_DIR)/$(TARGET)-cross
+
+
+####### Targets
+
+PKG_GROUP = app
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+ELOGIND_PKG_NAME                = elogind
+ELOGIND_PKG_VERSION             = 246.10
+ELOGIND_PKG_ARCH                = $(PKGARCH)
+ELOGIND_PKG_DISTRO_NAME         = $(DISTRO_NAME)
+ELOGIND_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
+ELOGIND_PKG_GROUP               = $(PKG_GROUP)
+###                              |---handy-ruler-------------------------------|
+ELOGIND_PKG_SHORT_DESCRIPTION   = login daemon from systemd
+ELOGIND_PKG_URL                 = $(BUG_URL)
+ELOGIND_PKG_LICENSE             = GPLv2
+ELOGIND_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(ELOGIND_PKG_NAME)-pkg-description
+ELOGIND_PKG_DESCRIPTION_FILE_IN = $(ELOGIND_PKG_NAME)-pkg-description.in
+ELOGIND_PKG_INSTALL_SCRIPT      = $(ELOGIND_PKG_NAME)-pkg-install.sh
+
+ELOGIND_PKG      = $(CURDIR)/$(TARGET_BUILD_DIR)/$(ELOGIND_PKG_NAME)-package
+
+pkg_basename     = $(ELOGIND_PKG_NAME)-$(ELOGIND_PKG_VERSION)-$(ELOGIND_PKG_ARCH)-$(ELOGIND_PKG_DISTRO_NAME)-$(ELOGIND_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=$(ELOGIND_PKG)
+
+#
+# https://mesonbuild.com/Reference-tables.html :
+# =============================================
+#
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_A1X_GLIBC)    $(TOOLCHAIN_A2X_GLIBC)    \
+                             $(TOOLCHAIN_H3_GLIBC)     $(TOOLCHAIN_RK328X_GLIBC) \
+                             $(TOOLCHAIN_S8XX_GLIBC)   $(TOOLCHAIN_IMX6_GLIBC)   \
+                             $(TOOLCHAIN_AM335X_GLIBC) $(TOOLCHAIN_OMAP543X_GLIBC)),)
+cpu_name = arm
+endian   = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_H5_GLIBC)     $(TOOLCHAIN_RK33XX_GLIBC) \
+                             $(TOOLCHAIN_RK339X_GLIBC) $(TOOLCHAIN_S9XX_GLIBC)   \
+                             $(TOOLCHAIN_A311X_GLIBC)  $(TOOLCHAIN_M1000_GLIBC)),)
+cpu_name = aarch64
+endian   = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_JZ47XX_GLIBC) $(TOOLCHAIN_P5600_GLIBC)),)
+cpu_name = mips
+endian   = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_POWER8_GLIBC) $(TOOLCHAIN_POWER9_GLIBC)),)
+cpu_name = ppc64
+endian   = big
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_POWER8LE_GLIBC) $(TOOLCHAIN_POWER9LE_GLIBC)),)
+cpu_name = ppc64
+endian   = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_RISCV64_GLIBC)),)
+cpu_name = riscv64
+endian   = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_I586_GLIBC) $(TOOLCHAIN_I686_GLIBC)),)
+cpu_name = x86
+endian   = little
+endif
+ifneq ($(filter $(TOOLCHAIN),$(TOOLCHAIN_X86_64_GLIBC)),)
+cpu_name = x86_64
+endian   = little
+endif
+
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --default-library=both
+else
+extra_configure_switches += --default-library=shared
+endif
+
+
+TARGET_BIN_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX)
+TARGET_LIB_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX):/usr/lib/../lib$(LIBSUFFIX)
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+	$(UNPACK_SRC_ARCHIVE)
+	$(APPLY_PATCHES)
+	# ======= Change nobody user UID number to 99: =======
+	@( cd $(SRC_DIR) ; sed -e 's/65534/99/g' -i `grep -lr 65534 .` )
+	@touch $@
+
+$(build_target): $(src_done)
+	@mkdir -p $(build_dir)
+	@echo ""                                            >  $(cross_file)
+	@echo "[build_machine]"                             >> $(cross_file)
+	@echo "system = '$(shell uname -s | tr 'L' 'l')'"   >> $(cross_file)
+	@echo "cpu_family = '$(shell uname -m)'"            >> $(cross_file)
+	@echo "cpu = '$(shell uname -m)'"                   >> $(cross_file)
+	@echo "endian = '$(shell lscpu | grep Endian | tr -s ' ' | cut -f3 -d' ' | tr 'L' 'l')'" >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[host_machine]"                              >> $(cross_file)
+	@echo "system = 'linux'"                            >> $(cross_file)
+	@echo "cpu_family = '$(cpu_name)'"                  >> $(cross_file)
+	@echo "cpu = '$(cpu_name)'"                         >> $(cross_file)
+	@echo "endian = '$(endian)'"                        >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[target_machine]"                            >> $(cross_file)
+	@echo "system = 'linux'"                            >> $(cross_file)
+	@echo "cpu_family = '$(cpu_name)'"                  >> $(cross_file)
+	@echo "cpu = '$(cpu_name)'"                         >> $(cross_file)
+	@echo "endian = '$(endian)'"                        >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[properties]"                                >> $(cross_file)
+	@echo "sys_root = '$(TARGET_DEST_DIR)'"             >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[binaries]"                                  >> $(cross_file)
+	@echo "c = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-gcc'"   >> $(cross_file)
+	@echo "cpp = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-g++'" >> $(cross_file)
+	@echo "ar = '$(AR)'"                                >> $(cross_file)
+	@echo "strip = '$(STRIP)'"                          >> $(cross_file)
+	@echo "pkgconfig = 'pkg-config'"                    >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@PKG_CONFIG_PATH= \
+	   meson setup \
+	    --prefix=/usr \
+	    --libdir=/usr/lib$(LIBSUFFIX) \
+	    --buildtype=release  \
+	    -Dc_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`"         \
+	    -Dc_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(LDFLAGS)" | tr -s ' '`"   \
+	    -Dcpp_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`"       \
+	    -Dcpp_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(LDFLAGS)" | tr -s ' '`" \
+	    -Drootlibdir="/lib$(LIBSUFFIX)" \
+	    -Drootlibexecdir="/lib$(LIBSUFFIX)/elogind" \
+	    -Dudevrulesdir="/lib/udev/rules.d" \
+	    -Ddocdir="/usr/share/doc/$(src_dir_name)" \
+	    -Dhtmldir="/usr/share/doc/$(src_dir_name)/html" \
+	    -Dmandir="/usr/share/man" \
+	    -Dman=true \
+	    -Dhtml=false \
+	    -Dbashcompletiondir="/usr/share/bash-completion/completions" \
+	    -Dnobody-group=nogroup \
+	    -Dpam=true \
+	    -Dpamlibdir="/lib$(LIBSUFFIX)/security" \
+	    -Dpamconfdir="/etc/pam.d" \
+	    -Dacl=true \
+	    -Dsmack=false \
+	    -Dutmp=true \
+	    -Ddefault-hierarchy=legacy \
+	    -Dcgroup-controller=elogind \
+	    -Dhalt-path=/sbin/halt \
+	    -Dpoweroff-path=/sbin/poweroff \
+	    -Dreboot-path=/sbin/reboot \
+	    -Ddefault-kill-user-processes=false \
+	    -Dselinux=false \
+	    $(extra_configure_switches) \
+	    --cross-file=$(cross_file) $(SRC_DIR) $(build_dir)
+	@cd $(build_dir) && ninja -v
+	@touch $@
+
+$(install_target): $(build_target)
+	@cd $(build_dir) && $(env_sysroot) ninja install
+	# ======= Create symlinks for elogind library to /usr/lib$(LIBSUFFIX): =======
+	@mkdir -p $(ELOGIND_PKG)/usr/lib$(LIBSUFFIX)
+	@( cd $(ELOGIND_PKG)/usr/lib$(LIBSUFFIX) ; \
+	   cp  -a ../../lib$(LIBSUFFIX)/lib*.so     . ; \
+	   cp  -a ../../lib$(LIBSUFFIX)/lib*.so.?   . ; \
+	   ln -sf ../../lib$(LIBSUFFIX)/lib*.so.?.* . ; \
+	 )
+	# ======= Create symlinks for elogind binaries to /usr/bin: =======
+	@mkdir -p $(ELOGIND_PKG)/usr/bin
+	@( cd $(ELOGIND_PKG)/usr/bin ; \
+	   ln -sf ../../bin/elogind-inhibit . ; \
+	   ln -sf ../../bin/loginctl . ; \
+	 )
+	# ======= Make sure we do not overwrite the user's customizations: =======
+	@mv -i $(ELOGIND_PKG)/etc/elogind/logind.conf{,.new}
+	# ======= Create supported dirs in /etc/elogind/ (local config): =======
+	@mkdir -p $(ELOGIND_PKG)/etc/elogind/logind.conf.d $(ELOGIND_PKG)/etc/elogind/sleep.conf.d
+	# ======= Add login1 policy file that allows users in the =======
+	# ======= 'power' group to shutdown/reboot the computer:  =======
+	@mkdir -p $(ELOGIND_PKG)/usr/share/polkit-1/rules.d
+	@cat $(CURDIR)/scripts/10-enable-elogind-power.rules > \
+	     $(ELOGIND_PKG)/usr/share/polkit-1/rules.d/10-enable-session-power.rules
+	# ======= Add an rc script: =======
+	@mkdir -p $(ELOGIND_PKG)/etc/rc.d
+	@cat $(CURDIR)/scripts/rc.elogind \
+	     | sed -e "s/@LIBDIRSUFFIX@/$(LIBSUFFIX)/g" \
+	     > $(ELOGIND_PKG)/etc/rc.d/rc.elogind.new
+	@chmod 755 $(ELOGIND_PKG)/etc/rc.d/rc.elogind.new
+	# ======= We don't need the hidden files to make inferior package managers keep dirs: =======
+	@( cd $(ELOGIND_PKG) ; \
+	   find . -type f -name ".keep_dir" -exec rm -f {} \; ; \
+	 )
+	# ======= Install Documentation =======
+	@( cd $(ELOGIND_PKG)/usr/share/man/man3 ; \
+	   for file in *.3 ; do                                \
+	     ln=`head -n 1 $$file` ;                           \
+	     if [ "`echo $$ln | grep '^\.so '`" != "" ] ; then \
+	       origin=`echo $$ln | cut -f 2 -d ' '` ;          \
+	       origin=`basename $$origin` ;                    \
+	       rm -f $$file ;                                  \
+	       ln -sf $$origin $$file ;                        \
+	     fi ;                                              \
+	   done ;                                              \
+	 )
+	@if [ -d $(ELOGIND_PKG)/usr/share/man ]; then \
+	  ( cd $(ELOGIND_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 $(ELOGIND_PKG)/usr/doc/$(src_dir_name)
+	@cp -a $(SRC_DIR)/LICENSE* \
+	       $(ELOGIND_PKG)/usr/doc/$(src_dir_name)
+	@mkdir -p $(ELOGIND_PKG)/usr/share/doc/$(src_dir_name)
+	@( cd $(SRC_DIR) ; \
+	   cp -a LICENSE* README* \
+	         $(ELOGIND_PKG)/usr/share/doc/$(src_dir_name) \
+	 )
+	@( cd $(SRC_DIR) ; \
+	   if [ -r ChangeLog ]; then \
+	     DOCSDIR=`echo $(ELOGIND_PKG)/usr/share/doc/$(src_dir_name)` ; \
+	     cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
+	     touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
+	   fi \
+	 )
+	# ======= Install the same to $(TARGET_DEST_DIR) =======
+	$(call install-into-devenv, $(ELOGIND_PKG))
+	# ======= tune pkg-config *.pc search path to the target destination for development =======
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/pkgconfig ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libelogind.pc ; \
+	 )
+	@( cd $(ELOGIND_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 $(ELOGIND_PKG) ; \
+	   find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+	 )
+endif
+	@touch $@
+
+$(ELOGIND_PKG_DESCRIPTION_FILE): $(ELOGIND_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) $(ELOGIND_PKG_DESCRIPTION_FILE) $(ELOGIND_PKG_INSTALL_SCRIPT)
+	@cp $(ELOGIND_PKG_DESCRIPTION_FILE) $(ELOGIND_PKG)/.DESCRIPTION
+	@cp $(ELOGIND_PKG_INSTALL_SCRIPT) $(ELOGIND_PKG)/.INSTALL
+	@chmod a+x $(ELOGIND_PKG)/.INSTALL
+	@$(BUILD_PKG_REQUIRES) $(ELOGIND_PKG)/.REQUIRES
+	@echo "pkgname=$(ELOGIND_PKG_NAME)"                            >  $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "pkgver=$(ELOGIND_PKG_VERSION)"                          >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "arch=$(ELOGIND_PKG_ARCH)"                               >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "distroname=$(ELOGIND_PKG_DISTRO_NAME)"                  >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "distrover=$(ELOGIND_PKG_DISTRO_VERSION)"                >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "group=$(ELOGIND_PKG_GROUP)"                             >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "short_description=\"$(ELOGIND_PKG_SHORT_DESCRIPTION)\"" >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "url=$(ELOGIND_PKG_URL)"                                 >> $(ELOGIND_PKG)/.PKGINFO ; \
+	 echo "license=$(ELOGIND_PKG_LICENSE)"                         >> $(ELOGIND_PKG)/.PKGINFO
+	@$(PSEUDO) sh -c "cd $(ELOGIND_PKG) && \
+	                  chown -R root:root . && \
+	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: 246.10/PATCHES
===================================================================
Index: 246.10/elogind-pkg-description.in
===================================================================
--- 246.10/elogind-pkg-description.in	(nonexistent)
+++ 246.10/elogind-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------------------------------------------------------|
+elogind: elogind @VERSION@ (login daemon from systemd)
+elogind:
+elogind: elogind is the systemd project's logind, extracted to a standalone
+elogind: package.
+elogind:
+elogind:
+elogind:
+elogind: Homepage: https://github.com/elogind/elogind
+elogind:
+elogind:
+elogind:
Index: 246.10/elogind-pkg-install.sh
===================================================================
--- 246.10/elogind-pkg-install.sh	(nonexistent)
+++ 246.10/elogind-pkg-install.sh	(revision 5)
@@ -0,0 +1,75 @@
+#!/bin/sh
+
+# Preserve new files
+install_file() {
+  NEW="$1"
+  OLD="`dirname $NEW`/`basename $NEW .new`"
+  # If there's no file by that name, mv it over:
+  if [ ! -r $OLD ]; then
+    mv $NEW $OLD
+  elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy
+    rm $NEW
+  fi
+  # Otherwise, we leave the .new copy for the admin to consider...
+}
+
+preserve_perms() {
+  NEW="$1"
+  OLD="$(dirname ${NEW})/$(basename ${NEW} .new)"
+  if [ -e ${OLD} ]; then
+    cp -a ${OLD} ${NEW}.incoming
+    cat ${NEW} > ${NEW}.incoming
+    mv ${NEW}.incoming ${NEW}
+  fi
+  install_file ${NEW}
+}
+
+
+# arg 1:  the new package version
+pre_install() {
+  /bin/true
+}
+
+# arg 1:  the new package version
+post_install() {
+  preserve_perms etc/rc.d/rc.elogind.new
+  install_file etc/elogind/logind.conf.new
+
+  # We have to check that we are not in the installer mode on the target system
+  # ("/etc/system-installer"), and we have to be sure that we are on the working system
+  # on the target hardware ("proc/sys/kernel/osrelease" - relative path).
+  if [ -r proc/sys/kernel/osrelease -a ! -r /etc/system-installer ]; then
+    if pgrep -f elogind-daemon | grep -q 'elogind-daemon'; then
+      echo "Reloading elogind-daemon..."
+      pkill -HUP -f elogind-daemon
+    fi
+  fi
+}
+
+# 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: 246.10/elogind-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: 246.10/scripts/10-enable-elogind-power.rules
===================================================================
--- 246.10/scripts/10-enable-elogind-power.rules	(nonexistent)
+++ 246.10/scripts/10-enable-elogind-power.rules	(revision 5)
@@ -0,0 +1,12 @@
+polkit.addRule(
+  function(action, subject) {
+    if ( (action.id == "org.freedesktop.login1.reboot" ||
+          action.id == "org.freedesktop.login1.reboot-multiple-sessions" ||
+          action.id == "org.freedesktop.login1.power-off" ||
+          action.id == "org.freedesktop.login1.power-off-multiple-sessions")
+           && subject.isInGroup("power") ) {
+      return polkit.Result.YES;
+    }
+  }
+);
+
Index: 246.10/scripts/rc.elogind
===================================================================
--- 246.10/scripts/rc.elogind	(nonexistent)
+++ 246.10/scripts/rc.elogind	(revision 5)
@@ -0,0 +1,65 @@
+#!/bin/bash
+#
+# /etc/rc.d/rc.elogind
+#     Initializes the elogind service on Slackware.
+#     There is no need to explicitly start a daemon; this will be taken
+#     care of automatically by dbus when that starts.
+#
+# Author:
+#     Eric Hameleers <alien@slackware.com> 2016
+#     Widya Walesa 2020
+#
+# Description:
+#     We use elogind (standalone subset extracted from systemd) instead of
+#     systemd itself; so we need to initialize a systemd-like state.
+#
+# Note:
+#     Slackware has a tmpfs mounted on /run (see rc.S).
+#
+
+start_elogind() {
+  if [ -x /lib@LIBDIRSUFFIX@/elogind/elogind ]; then
+    if [ ! -d /run/user ]; then
+      mkdir -p /run/user
+    fi
+    if [ ! -d /run/systemd ]; then
+      mkdir -p /run/elogind /sys/fs/cgroup/elogind
+      ( cd /run; rm -rf systemd; ln -sf elogind systemd; )
+      ( cd /sys/fs/cgroup; rm -rf systemd; ln -sf elogind systemd; )
+    fi
+    if pgrep -l -F /run/elogind.pid 2>/dev/null | grep -q elogind; then
+      echo "Elogind is already running"
+    else
+      echo -n "Starting elogind:  "
+      rm -f /run/elogind.pid
+      /lib@LIBDIRSUFFIX@/elogind/elogind --daemon
+      echo "/lib@LIBDIRSUFFIX@/elogind/elogind --daemon"
+    fi
+  fi
+}
+
+stop_elogind() {
+  if pgrep -l -F /run/elogind.pid 2>/dev/null | grep -q elogind; then
+    echo -n "Stopping elogind:  "
+    pkill -F /run/elogind.pid 2>/dev/null
+    echo "DONE"
+  else
+    echo "Elogind is not running"
+  fi
+}
+
+case "$1" in
+  start)
+    start_elogind
+    ;;
+  stop)
+    stop_elogind
+    ;;
+  restart)
+    stop_elogind
+    sleep 1
+    start_elogind
+    ;;
+  *)
+    echo "Usage: $0 start|stop|restart"
+esac
Index: 246.10/scripts
===================================================================
--- 246.10/scripts	(nonexistent)
+++ 246.10/scripts	(revision 5)

Property changes on: 246.10/scripts
___________________________________________________________________
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
+*~
Index: 246.10
===================================================================
--- 246.10	(nonexistent)
+++ 246.10	(revision 5)

Property changes on: 246.10
___________________________________________________________________
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
+*~
Index: 246.10-ppc32/Makefile
===================================================================
--- 246.10-ppc32/Makefile	(nonexistent)
+++ 246.10-ppc32/Makefile	(revision 5)
@@ -0,0 +1,233 @@
+
+COMPONENT_TARGETS  = $(HARDWARE_S824L)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
+
+NEED_ABS_PATH      = true
+COMPONENT_IS_3PP   = true
+
+CREATE_PPC32_PACKAGE = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES    = sources/packages/a/elogind
+
+REQUIRES           = app/elogind/246.10
+REQUIRES          += secure/libcap/2.48-ppc32
+REQUIRES          += libs/eudev/3.2.10-ppc32
+REQUIRES          += app/acl/2.2.53-ppc32
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version            = 246.10
+tar_xz_archive     = $(SRC_PACKAGE_PATH)/packages/a/elogind/elogind-$(version).tar.xz
+SRC_ARCHIVE        = $(tar_xz_archive)
+SRC_DIR            = $(TARGET_BUILD_DIR)/elogind-$(version)
+src_dir_name       = elogind-$(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
+
+cross_file         = $(TARGET_BUILD_DIR)/$(TARGET32)-cross
+
+
+####### Targets
+
+PKG_GROUP = app
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+ELOGIND_32_PKG_NAME                = elogind-x32
+ELOGIND_32_PKG_VERSION             = 246.10
+ELOGIND_32_PKG_ARCH                = $(PKGARCH)
+ELOGIND_32_PKG_DISTRO_NAME         = $(DISTRO_NAME)
+ELOGIND_32_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
+ELOGIND_32_PKG_GROUP               = $(PKG_GROUP)
+###                                 |---handy-ruler-------------------------------|
+ELOGIND_32_PKG_SHORT_DESCRIPTION   = login daemon from systemd
+ELOGIND_32_PKG_URL                 = $(BUG_URL)
+ELOGIND_32_PKG_LICENSE             = GPLv2
+ELOGIND_32_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(ELOGIND_32_PKG_NAME)-pkg-description
+ELOGIND_32_PKG_DESCRIPTION_FILE_IN = $(ELOGIND_32_PKG_NAME)-pkg-description.in
+ELOGIND_32_PKG_INSTALL_SCRIPT      = $(ELOGIND_32_PKG_NAME)-pkg-install.sh
+
+ELOGIND_32_PKG   = $(CURDIR)/$(TARGET_BUILD_DIR)/$(ELOGIND_32_PKG_NAME)-package
+
+pkg_basename     = $(ELOGIND_32_PKG_NAME)-$(ELOGIND_32_PKG_VERSION)-$(ELOGIND_32_PKG_ARCH)-$(ELOGIND_32_PKG_DISTRO_NAME)-$(ELOGIND_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=$(ELOGIND_32_PKG)
+
+
+cpu_name = ppc
+endian   = big
+
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --default-library=both
+else
+extra_configure_switches += --default-library=shared
+endif
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+	$(UNPACK_SRC_ARCHIVE)
+	$(APPLY_PATCHES)
+	# ======= Change nobody user UID number to 99: =======
+	@( cd $(SRC_DIR) ; sed -e 's/65534/99/g' -i `grep -lr 65534 .` )
+	@touch $@
+
+$(build_target): $(src_done)
+	@mkdir -p $(build_dir)
+	@echo ""                                            >  $(cross_file)
+	@echo "[build_machine]"                             >> $(cross_file)
+	@echo "system = '$(shell uname -s | tr 'L' 'l')'"   >> $(cross_file)
+	@echo "cpu_family = '$(shell uname -m)'"            >> $(cross_file)
+	@echo "cpu = '$(shell uname -m)'"                   >> $(cross_file)
+	@echo "endian = '$(shell lscpu | grep Endian | tr -s ' ' | cut -f3 -d' ' | tr 'L' 'l')'" >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[host_machine]"                              >> $(cross_file)
+	@echo "system = 'linux'"                            >> $(cross_file)
+	@echo "cpu_family = '$(cpu_name)'"                  >> $(cross_file)
+	@echo "cpu = '$(cpu_name)'"                         >> $(cross_file)
+	@echo "endian = '$(endian)'"                        >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[target_machine]"                            >> $(cross_file)
+	@echo "system = 'linux'"                            >> $(cross_file)
+	@echo "cpu_family = '$(cpu_name)'"                  >> $(cross_file)
+	@echo "cpu = '$(cpu_name)'"                         >> $(cross_file)
+	@echo "endian = '$(endian)'"                        >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[properties]"                                >> $(cross_file)
+	@echo "sys_root = '$(TARGET_DEST_DIR)'"             >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[binaries]"                                  >> $(cross_file)
+	@echo "c = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-gcc'"   >> $(cross_file)
+	@echo "cpp = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-g++'" >> $(cross_file)
+	@echo "ar = '$(AR)'"                                >> $(cross_file)
+	@echo "strip = '$(STRIP)'"                          >> $(cross_file)
+	@echo "pkgconfig = 'pkg-config'"                    >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@PKG_CONFIG_PATH=/usr/lib$(MULTILIB_PPC32_SUFFIX)/pkgconfig \
+	   meson setup \
+	    --prefix=/usr \
+	    --libdir=/usr/lib$(MULTILIB_PPC32_SUFFIX) \
+	    --buildtype=release    \
+	    -Dc_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`"              \
+	    -Dc_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) -m32 $(LDFLAGS)" | tr -s ' '`"   \
+	    -Dcpp_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`"            \
+	    -Dcpp_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) -m32 $(LDFLAGS)" | tr -s ' '`" \
+	    -Drootlibdir="/lib$(MULTILIB_PPC32_SUFFIX)" \
+	    -Drootlibexecdir="/lib$(MULTILIB_PPC32_SUFFIX)/elogind" \
+	    -Dudevrulesdir="/lib/udev/rules.d" \
+	    -Ddocdir="/usr/share/doc/$(src_dir_name)" \
+	    -Dhtmldir="/usr/share/doc/$(src_dir_name)/html" \
+	    -Dmandir="/usr/share/man" \
+	    -Dman=true \
+	    -Dhtml=false \
+	    -Dbashcompletiondir="/usr/share/bash-completion/completions" \
+	    -Dnobody-group=nogroup \
+	    -Dpam=true \
+	    -Dpamlibdir="/lib$(MULTILIB_PPC32_SUFFIX)/security" \
+	    -Dpamconfdir="/etc/pam.d" \
+	    -Dacl=true \
+	    -Dsmack=false \
+	    -Dutmp=true \
+	    -Ddefault-hierarchy=legacy \
+	    -Dcgroup-controller=elogind \
+	    -Dhalt-path=/sbin/halt \
+	    -Dpoweroff-path=/sbin/poweroff \
+	    -Dreboot-path=/sbin/reboot \
+	    -Ddefault-kill-user-processes=false \
+	    -Dselinux=false \
+	    $(extra_configure_switches) \
+	    --cross-file=$(cross_file) $(SRC_DIR) $(build_dir)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) ninja -v
+	@touch $@
+
+$(install_target): $(build_target)
+	@cd $(build_dir) && $(env_sysroot) ninja install
+	# ======= Create symlinks for elogind library to /usr/lib$(MULTILIB_PPC32_SUFFIX): =======
+	@mkdir -p $(ELOGIND_32_PKG)/usr/lib$(MULTILIB_PPC32_SUFFIX)
+	@( cd $(ELOGIND_32_PKG)/usr/lib$(MULTILIB_PPC32_SUFFIX) ; \
+	   cp  -a ../../lib$(MULTILIB_PPC32_SUFFIX)/lib*.so     . ; \
+	   cp  -a ../../lib$(MULTILIB_PPC32_SUFFIX)/lib*.so.?   . ; \
+	   ln -sf ../../lib$(MULTILIB_PPC32_SUFFIX)/lib*.so.?.* . ; \
+	 )
+	@rm -rf $(ELOGIND_32_PKG)/{bin,etc}
+	@rm -rf $(ELOGIND_32_PKG)/lib/udev
+	@if [ -n "$(MULTILIB_PPC32_SUFFIX)" ] ; then \
+	   rm -rf $(ELOGIND_32_PKG)/lib ; \
+	 fi
+	@rm -rf $(ELOGIND_32_PKG)/lib$(MULTILIB_PPC32_SUFFIX)/elogind
+	@rm -rf $(ELOGIND_32_PKG)/usr/bin
+	@rm -rf $(ELOGIND_32_PKG)/usr/include
+	@rm -rf $(ELOGIND_32_PKG)/usr/share
+	# ======= Install the same to $(TARGET_DEST_DIR) =======
+	$(call install-into-devenv, $(ELOGIND_32_PKG))
+	# ======= tune pkg-config *.pc search path to the target destination for development =======
+	@( cd $(TARGET_DEST_DIR)/usr/lib$(MULTILIB_PPC32_SUFFIX)/pkgconfig ; \
+	   sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libelogind.pc ; \
+	 )
+	# ======= Strip binaries =======
+	@( cd $(ELOGIND_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 $(ELOGIND_32_PKG) ; \
+	   find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+	 )
+endif
+	@touch $@
+
+$(ELOGIND_32_PKG_DESCRIPTION_FILE): $(ELOGIND_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) $(ELOGIND_32_PKG_DESCRIPTION_FILE) $(ELOGIND_32_PKG_INSTALL_SCRIPT)
+	@cp $(ELOGIND_32_PKG_DESCRIPTION_FILE) $(ELOGIND_32_PKG)/.DESCRIPTION
+	@cp $(ELOGIND_32_PKG_INSTALL_SCRIPT) $(ELOGIND_32_PKG)/.INSTALL
+	@chmod a+x $(ELOGIND_32_PKG)/.INSTALL
+	@$(BUILD_PKG_REQUIRES) $(ELOGIND_32_PKG)/.REQUIRES
+	@echo "pkgname=$(ELOGIND_32_PKG_NAME)"                            >  $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "pkgver=$(ELOGIND_32_PKG_VERSION)"                          >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "arch=$(ELOGIND_32_PKG_ARCH)"                               >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "distroname=$(ELOGIND_32_PKG_DISTRO_NAME)"                  >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "distrover=$(ELOGIND_32_PKG_DISTRO_VERSION)"                >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "group=$(ELOGIND_32_PKG_GROUP)"                             >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "short_description=\"$(ELOGIND_32_PKG_SHORT_DESCRIPTION)\"" >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "url=$(ELOGIND_32_PKG_URL)"                                 >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "license=$(ELOGIND_32_PKG_LICENSE)"                         >> $(ELOGIND_32_PKG)/.PKGINFO
+	@$(PSEUDO) sh -c "cd $(ELOGIND_32_PKG) && \
+	                  chown -R root:root . && \
+	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: 246.10-ppc32/PATCHES
===================================================================
Index: 246.10-ppc32/elogind-x32-pkg-description.in
===================================================================
--- 246.10-ppc32/elogind-x32-pkg-description.in	(nonexistent)
+++ 246.10-ppc32/elogind-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------------------------------------------------------|
+elogind-x32: elogind-x32 @VERSION@ (login daemon from systemd)
+elogind-x32:
+elogind-x32: elogind is the systemd project's logind, extracted to a standalone
+elogind-x32: package.
+elogind-x32:
+elogind-x32:
+elogind-x32:
+elogind-x32: Homepage: https://github.com/elogind/elogind
+elogind-x32:
+elogind-x32:
+elogind-x32:
Index: 246.10-ppc32/elogind-x32-pkg-install.sh
===================================================================
--- 246.10-ppc32/elogind-x32-pkg-install.sh	(nonexistent)
+++ 246.10-ppc32/elogind-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: 246.10-ppc32/elogind-x32-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: 246.10-ppc32
===================================================================
--- 246.10-ppc32	(nonexistent)
+++ 246.10-ppc32	(revision 5)

Property changes on: 246.10-ppc32
___________________________________________________________________
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
+*~
Index: 246.10-x86_32/Makefile
===================================================================
--- 246.10-x86_32/Makefile	(nonexistent)
+++ 246.10-x86_32/Makefile	(revision 5)
@@ -0,0 +1,230 @@
+
+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/a/elogind
+
+REQUIRES           = app/elogind/246.10
+REQUIRES          += secure/libcap/2.48-x86_32
+REQUIRES          += libs/eudev/3.2.10-x86_32
+REQUIRES          += app/acl/2.2.53-x86_32
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version            = 246.10
+tar_xz_archive     = $(SRC_PACKAGE_PATH)/packages/a/elogind/elogind-$(version).tar.xz
+SRC_ARCHIVE        = $(tar_xz_archive)
+SRC_DIR            = $(TARGET_BUILD_DIR)/elogind-$(version)
+src_dir_name       = elogind-$(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
+
+cross_file         = $(TARGET_BUILD_DIR)/$(TARGET32)-cross
+
+
+####### Targets
+
+PKG_GROUP = app
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+ELOGIND_32_PKG_NAME                = elogind-x32
+ELOGIND_32_PKG_VERSION             = 246.10
+ELOGIND_32_PKG_ARCH                = $(PKGARCH)
+ELOGIND_32_PKG_DISTRO_NAME         = $(DISTRO_NAME)
+ELOGIND_32_PKG_DISTRO_VERSION      = $(DISTRO_VERSION)
+ELOGIND_32_PKG_GROUP               = $(PKG_GROUP)
+###                                 |---handy-ruler-------------------------------|
+ELOGIND_32_PKG_SHORT_DESCRIPTION   = login daemon from systemd
+ELOGIND_32_PKG_URL                 = $(BUG_URL)
+ELOGIND_32_PKG_LICENSE             = GPLv2
+ELOGIND_32_PKG_DESCRIPTION_FILE    = $(TARGET_BUILD_DIR)/$(ELOGIND_32_PKG_NAME)-pkg-description
+ELOGIND_32_PKG_DESCRIPTION_FILE_IN = $(ELOGIND_32_PKG_NAME)-pkg-description.in
+ELOGIND_32_PKG_INSTALL_SCRIPT      = $(ELOGIND_32_PKG_NAME)-pkg-install.sh
+
+ELOGIND_32_PKG   = $(CURDIR)/$(TARGET_BUILD_DIR)/$(ELOGIND_32_PKG_NAME)-package
+
+pkg_basename     = $(ELOGIND_32_PKG_NAME)-$(ELOGIND_32_PKG_VERSION)-$(ELOGIND_32_PKG_ARCH)-$(ELOGIND_32_PKG_DISTRO_NAME)-$(ELOGIND_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=$(ELOGIND_32_PKG)
+
+
+cpu_name = x86
+endian   = little
+
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --default-library=both
+else
+extra_configure_switches += --default-library=shared
+endif
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+	$(UNPACK_SRC_ARCHIVE)
+	$(APPLY_PATCHES)
+	# ======= Change nobody user UID number to 99: =======
+	@( cd $(SRC_DIR) ; sed -e 's/65534/99/g' -i `grep -lr 65534 .` )
+	@touch $@
+
+$(build_target): $(src_done)
+	@mkdir -p $(build_dir)
+	@echo ""                                            >  $(cross_file)
+	@echo "[build_machine]"                             >> $(cross_file)
+	@echo "system = '$(shell uname -s | tr 'L' 'l')'"   >> $(cross_file)
+	@echo "cpu_family = '$(shell uname -m)'"            >> $(cross_file)
+	@echo "cpu = '$(shell uname -m)'"                   >> $(cross_file)
+	@echo "endian = '$(shell lscpu | grep Endian | tr -s ' ' | cut -f3 -d' ' | tr 'L' 'l')'" >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[host_machine]"                              >> $(cross_file)
+	@echo "system = 'linux'"                            >> $(cross_file)
+	@echo "cpu_family = '$(cpu_name)'"                  >> $(cross_file)
+	@echo "cpu = '$(cpu_name)'"                         >> $(cross_file)
+	@echo "endian = '$(endian)'"                        >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[target_machine]"                            >> $(cross_file)
+	@echo "system = 'linux'"                            >> $(cross_file)
+	@echo "cpu_family = '$(cpu_name)'"                  >> $(cross_file)
+	@echo "cpu = '$(cpu_name)'"                         >> $(cross_file)
+	@echo "endian = '$(endian)'"                        >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[properties]"                                >> $(cross_file)
+	@echo "sys_root = '$(TARGET_DEST_DIR)'"             >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@echo "[binaries]"                                  >> $(cross_file)
+	@echo "c = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-gcc'"   >> $(cross_file)
+	@echo "cpp = '$(TOOLCHAIN_PATH)/bin/$(TARGET)-g++'" >> $(cross_file)
+	@echo "ar = '$(AR)'"                                >> $(cross_file)
+	@echo "strip = '$(STRIP)'"                          >> $(cross_file)
+	@echo "pkgconfig = 'pkg-config'"                    >> $(cross_file)
+	@echo ""                                            >> $(cross_file)
+	@PKG_CONFIG_PATH=/usr/lib$(MULTILIB_X86_32_SUFFIX)/pkgconfig \
+	   meson setup \
+	    --prefix=/usr \
+	    --libdir=/usr/lib$(MULTILIB_X86_32_SUFFIX) \
+	    --buildtype=release    \
+	    -Dc_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`"              \
+	    -Dc_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) -m32 $(LDFLAGS)" | tr -s ' '`"   \
+	    -Dcpp_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) $(CFLAGS)" | tr -s ' '`"            \
+	    -Dcpp_link_args="`echo -n "--sysroot=$(TARGET_DEST_DIR) -m32 $(LDFLAGS)" | tr -s ' '`" \
+	    -Drootlibdir="/lib$(MULTILIB_X86_32_SUFFIX)" \
+	    -Drootlibexecdir="/lib$(MULTILIB_X86_32_SUFFIX)/elogind" \
+	    -Dudevrulesdir="/lib/udev/rules.d" \
+	    -Ddocdir="/usr/share/doc/$(src_dir_name)" \
+	    -Dhtmldir="/usr/share/doc/$(src_dir_name)/html" \
+	    -Dmandir="/usr/share/man" \
+	    -Dman=true \
+	    -Dhtml=false \
+	    -Dbashcompletiondir="/usr/share/bash-completion/completions" \
+	    -Dnobody-group=nogroup \
+	    -Dpam=true \
+	    -Dpamlibdir="/lib$(MULTILIB_X86_32_SUFFIX)/security" \
+	    -Dpamconfdir="/etc/pam.d" \
+	    -Dacl=true \
+	    -Dsmack=false \
+	    -Dutmp=true \
+	    -Ddefault-hierarchy=legacy \
+	    -Dcgroup-controller=elogind \
+	    -Dhalt-path=/sbin/halt \
+	    -Dpoweroff-path=/sbin/poweroff \
+	    -Dreboot-path=/sbin/reboot \
+	    -Ddefault-kill-user-processes=false \
+	    -Dselinux=false \
+	    $(extra_configure_switches) \
+	    --cross-file=$(cross_file) $(SRC_DIR) $(build_dir)
+	@cd $(build_dir) && $(BUILD_ENVIRONMENT) ninja -v
+	@touch $@
+
+$(install_target): $(build_target)
+	@cd $(build_dir) && $(env_sysroot) ninja install
+	# ======= Create symlinks for elogind library to /usr/lib$(MULTILIB_X86_32_SUFFIX): =======
+	@mkdir -p $(ELOGIND_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX)
+	@( cd $(ELOGIND_32_PKG)/usr/lib$(MULTILIB_X86_32_SUFFIX) ; \
+	   cp  -a ../../lib$(MULTILIB_X86_32_SUFFIX)/lib*.so     . ; \
+	   cp  -a ../../lib$(MULTILIB_X86_32_SUFFIX)/lib*.so.?   . ; \
+	   ln -sf ../../lib$(MULTILIB_X86_32_SUFFIX)/lib*.so.?.* . ; \
+	 )
+	@rm -rf $(ELOGIND_32_PKG)/{bin,etc}
+	@rm -rf $(ELOGIND_32_PKG)/lib/udev
+	@if [ -n "$(MULTILIB_X86_32_SUFFIX)" ] ; then \
+	   rm -rf $(ELOGIND_32_PKG)/lib ; \
+	 fi
+	@rm -rf $(ELOGIND_32_PKG)/lib$(MULTILIB_X86_32_SUFFIX)/elogind
+	@rm -rf $(ELOGIND_32_PKG)/usr/bin
+	@rm -rf $(ELOGIND_32_PKG)/usr/include
+	@rm -rf $(ELOGIND_32_PKG)/usr/share
+	# ======= Install the same to $(TARGET_DEST_DIR) =======
+	$(call install-into-devenv, $(ELOGIND_32_PKG))
+	# ======= 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" libelogind.pc ; \
+	 )
+	# ======= Strip binaries =======
+	@( cd $(ELOGIND_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 $(ELOGIND_32_PKG) ; \
+	   find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+	 )
+endif
+	@touch $@
+
+$(ELOGIND_32_PKG_DESCRIPTION_FILE): $(ELOGIND_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) $(ELOGIND_32_PKG_DESCRIPTION_FILE) $(ELOGIND_32_PKG_INSTALL_SCRIPT)
+	@cp $(ELOGIND_32_PKG_DESCRIPTION_FILE) $(ELOGIND_32_PKG)/.DESCRIPTION
+	@cp $(ELOGIND_32_PKG_INSTALL_SCRIPT) $(ELOGIND_32_PKG)/.INSTALL
+	@chmod a+x $(ELOGIND_32_PKG)/.INSTALL
+	@$(BUILD_PKG_REQUIRES) $(ELOGIND_32_PKG)/.REQUIRES
+	@echo "pkgname=$(ELOGIND_32_PKG_NAME)"                            >  $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "pkgver=$(ELOGIND_32_PKG_VERSION)"                          >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "arch=$(ELOGIND_32_PKG_ARCH)"                               >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "distroname=$(ELOGIND_32_PKG_DISTRO_NAME)"                  >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "distrover=$(ELOGIND_32_PKG_DISTRO_VERSION)"                >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "group=$(ELOGIND_32_PKG_GROUP)"                             >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "short_description=\"$(ELOGIND_32_PKG_SHORT_DESCRIPTION)\"" >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "url=$(ELOGIND_32_PKG_URL)"                                 >> $(ELOGIND_32_PKG)/.PKGINFO ; \
+	 echo "license=$(ELOGIND_32_PKG_LICENSE)"                         >> $(ELOGIND_32_PKG)/.PKGINFO
+	@$(PSEUDO) sh -c "cd $(ELOGIND_32_PKG) && \
+	                  chown -R root:root . && \
+	                  $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: 246.10-x86_32/PATCHES
===================================================================
Index: 246.10-x86_32/elogind-x32-pkg-description.in
===================================================================
--- 246.10-x86_32/elogind-x32-pkg-description.in	(nonexistent)
+++ 246.10-x86_32/elogind-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------------------------------------------------------|
+elogind-x32: elogind-x32 @VERSION@ (login daemon from systemd)
+elogind-x32:
+elogind-x32: elogind is the systemd project's logind, extracted to a standalone
+elogind-x32: package.
+elogind-x32:
+elogind-x32:
+elogind-x32:
+elogind-x32: Homepage: https://github.com/elogind/elogind
+elogind-x32:
+elogind-x32:
+elogind-x32:
Index: 246.10-x86_32/elogind-x32-pkg-install.sh
===================================================================
--- 246.10-x86_32/elogind-x32-pkg-install.sh	(nonexistent)
+++ 246.10-x86_32/elogind-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: 246.10-x86_32/elogind-x32-pkg-install.sh
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: 246.10-x86_32
===================================================================
--- 246.10-x86_32	(nonexistent)
+++ 246.10-x86_32	(revision 5)

Property changes on: 246.10-x86_32
___________________________________________________________________
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
+*~
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
+*~