Index: Makefile
===================================================================
--- Makefile (nonexistent)
+++ Makefile (revision 5)
@@ -0,0 +1,212 @@
+
+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/squashfs-tools
+
+REQUIRES = app/gzip/1.10
+REQUIRES += libs/lzo/2.10
+REQUIRES += libs/zstd/1.5.2
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version = 4.5.1
+tar_xz_archive = $(SRC_PACKAGE_PATH)/packages/a/squashfs-tools/squashfs-tools-$(version).tar.xz
+SRC_ARCHIVE = $(tar_xz_archive)
+SRC_DIR = $(TARGET_BUILD_DIR)/squashfs-tools-$(version)
+src_done = $(TARGET_BUILD_DIR)/.source_done
+
+PATCHES = PATCHES
+
+build_target = $(TARGET_BUILD_DIR)/.build_done
+install_target = $(TARGET_BUILD_DIR)/.install_done
+
+
+####### Targets
+
+PKG_GROUP = app
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+SQUASHFS_PKG_NAME = squashfs-tools
+SQUASHFS_PKG_VERSION = 4.5.1
+SQUASHFS_PKG_ARCH = $(PKGARCH)
+SQUASHFS_PKG_DISTRO_NAME = $(DISTRO_NAME)
+SQUASHFS_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
+SQUASHFS_PKG_GROUP = $(PKG_GROUP)
+### |---handy-ruler-------------------------------|
+SQUASHFS_PKG_SHORT_DESCRIPTION = squashed read-only filesystem for Linux
+SQUASHFS_PKG_URL = $(BUG_URL)
+SQUASHFS_PKG_LICENSE = GPLv2
+SQUASHFS_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(SQUASHFS_PKG_NAME)-pkg-description
+SQUASHFS_PKG_DESCRIPTION_FILE_IN = $(SQUASHFS_PKG_NAME)-pkg-description.in
+SQUASHFS_PKG_INSTALL_SCRIPT = $(SQUASHFS_PKG_NAME)-pkg-install.sh
+
+SQUASHFS_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(SQUASHFS_PKG_NAME)-package
+
+pkg_basename = $(SQUASHFS_PKG_NAME)-$(SQUASHFS_PKG_VERSION)-$(SQUASHFS_PKG_ARCH)-$(SQUASHFS_PKG_DISTRO_NAME)-$(SQUASHFS_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 = INSTALL_PREFIX=$(SQUASHFS_PKG)/usr
+
+#
+# NOTE:
+# squashfs doesn't want to have -I$(TARGET_DEST_DIR)/usr/include in CFLAGS
+# but we have to pass the architecture dependend CFLAGS. In this case we
+# overwrite CFLAGS with ARCH_FLAGS value to remove standatd -I flags added
+# by build-system.
+#
+# GCC CPP documentation:
+# All directories named by ‘-isystem’ are searched after all directories
+# named by ‘-I’, no matter what their order was on the command line. If the
+# same directory is named by both ‘-I’ and ‘-isystem’, the ‘-I’ option is
+# ignored. GCC provides an informative message when this occurs if ‘-v’ is
+# used. For example, we can make use following CFLAGS:
+#
+# CFLAGS = -v -isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS)
+#
+CFLAGS = -isystem $(TARGET_DEST_DIR)/usr/include $(ARCH_FLAGS)
+
+extra_configure_switches = GZIP_SUPPORT="1"
+extra_configure_switches += XZ_SUPPORT="1"
+extra_configure_switches += LZ4_SUPPORT="1"
+extra_configure_switches += LZO_SUPPORT="1"
+extra_configure_switches += LZMA_XZ_SUPPORT="1"
+extra_configure_switches += ZSTD_SUPPORT="1"
+extra_configure_switches += COMP_DEFAULT="xz"
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+ $(UNPACK_SRC_ARCHIVE)
+ $(APPLY_PATCHES)
+ @( cd $(SRC_DIR)/squashfs-tools ; \
+ sed -i '/..\/generate-manpages\/install-manpages.sh/d' Makefile ; \
+ chmod a-x Makefile ; \
+ )
+ @touch $@
+
+$(build_target): $(src_done)
+ @cd $(SRC_DIR)/squashfs-tools && $(BUILD_ENVIRONMENT) $(MAKE) $(extra_configure_switches)
+ @touch $@
+
+$(install_target): $(build_target)
+ @cd $(SRC_DIR)/squashfs-tools && $(BUILD_ENVIRONMENT) $(MAKE) install $(env_sysroot)
+ # ======= Install Manpages =======
+ @mkdir -p $(SQUASHFS_PKG)/usr/share/man/man1
+ @( cd $(SRC_DIR)/manpages ; \
+ for page in mksquashfs.1 sqfscat.1 sqfstar.1 unsquashfs.1 ; do \
+ cat $$page | gzip -9c > $(SQUASHFS_PKG)/usr/share/man/man1/$$page.gz ; \
+ done ; \
+ )
+ # ======= Install Documentation =======
+ @mkdir -p $(SQUASHFS_PKG)/usr/doc/squashfs-tools-$(version)
+ @mkdir -p $(SQUASHFS_PKG)/usr/share/doc/squashfs-tools-$(version)
+ @( cd $(SRC_DIR) ; \
+ cp -a COPYING \
+ $(SQUASHFS_PKG)/usr/doc/squashfs-tools-$(version) \
+ )
+ @( cd $(SRC_DIR) ; \
+ cp -a ACKNOWLEDGEMENTS ACTIONS-README CHANGES COPYING INSTALL README* USAGE \
+ $(SQUASHFS_PKG)/usr/share/doc/squashfs-tools-$(version) \
+ )
+ # ======= Install the same to $(TARGET_DEST_DIR) =======
+ $(call install-into-devenv, $(SQUASHFS_PKG))
+ # ======= Strip binaries =======
+ @( cd $(SQUASHFS_PKG) ; \
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ )
+ @touch $@
+
+$(SQUASHFS_PKG_DESCRIPTION_FILE): $(SQUASHFS_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) $(SQUASHFS_PKG_DESCRIPTION_FILE) $(SQUASHFS_PKG_INSTALL_SCRIPT)
+ @cp $(SQUASHFS_PKG_DESCRIPTION_FILE) $(SQUASHFS_PKG)/.DESCRIPTION
+ @cp $(SQUASHFS_PKG_INSTALL_SCRIPT) $(SQUASHFS_PKG)/.INSTALL
+ @$(BUILD_PKG_REQUIRES) $(SQUASHFS_PKG)/.REQUIRES
+ @echo "pkgname=$(SQUASHFS_PKG_NAME)" > $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "pkgver=$(SQUASHFS_PKG_VERSION)" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "arch=$(SQUASHFS_PKG_ARCH)" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "distroname=$(SQUASHFS_PKG_DISTRO_NAME)" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "distrover=$(SQUASHFS_PKG_DISTRO_VERSION)" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "group=$(SQUASHFS_PKG_GROUP)" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "short_description=\"$(SQUASHFS_PKG_SHORT_DESCRIPTION)\"" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "url=$(SQUASHFS_PKG_URL)" >> $(SQUASHFS_PKG)/.PKGINFO ; \
+ echo "license=$(SQUASHFS_PKG_LICENSE)" >> $(SQUASHFS_PKG)/.PKGINFO
+ @$(PSEUDO) sh -c "cd $(SQUASHFS_PKG) && \
+ chown -R root:root . && \
+ $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."