mirror of
https://github.com/motioneye-project/motioneyeos.git
synced 2025-07-27 05:06:39 +00:00
package/skeleton: split out into skeleton-common
Move all the handling of the default skeleton into a new package, skeleton-common. We don't name it skeleton-default, because it will be further split later, into a skeleton for sysv and another for systemd, with some parts still common between the two. So just name it skeleton-common right now; this will save us a rename later. While we're at it, also assign to SKELETON_COMMON_TARGET_FINALIZE_HOOKS instead of directly to the global FINALIZE_HOOKS. Therefore, we don't need to do all of that in a condition BR2_PACKAGE_SKELETON_COMMON==y. Note: it would be technically sound to move the skeleton files together within a sub-directory of the skeleton-common package. However, we refer the user to those files, from various locations (manual, packages). It will indeed be easier for the user to find those files in system/skeleton/ rather than in package/skeleton-common/skeleton/ Signed-off-by: "Yann E. MORIN" <yann.morin.1998@free.fr> Reviewed-by: Arnout Vandecappelle (Essensium/Mind) <arnout@mind.be> [Arnout: remove the mkdir $(STAGING_DIR)/usr/include which was removed in skeleton.mk in master.] Signed-off-by: Arnout Vandecappelle (Essensium/Mind) <arnout@mind.be> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
This commit is contained in:
parent
049d56e949
commit
120307520f
@ -2,6 +2,7 @@ menu "Target packages"
|
|||||||
|
|
||||||
source "package/busybox/Config.in"
|
source "package/busybox/Config.in"
|
||||||
source "package/skeleton/Config.in"
|
source "package/skeleton/Config.in"
|
||||||
|
source "package/skeleton-common/Config.in"
|
||||||
source "package/skeleton-custom/Config.in"
|
source "package/skeleton-custom/Config.in"
|
||||||
|
|
||||||
menu "Audio and video applications"
|
menu "Audio and video applications"
|
||||||
|
3
package/skeleton-common/Config.in
Normal file
3
package/skeleton-common/Config.in
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
config BR2_PACKAGE_SKELETON_COMMON
|
||||||
|
bool
|
||||||
|
select BR2_PACKAGE_SKELETON
|
95
package/skeleton-common/skeleton-common.mk
Normal file
95
package/skeleton-common/skeleton-common.mk
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
################################################################################
|
||||||
|
#
|
||||||
|
# skeleton-common
|
||||||
|
#
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
# The skeleton can't depend on the toolchain, since all packages depends on the
|
||||||
|
# skeleton and the toolchain is a target package, as is skeleton.
|
||||||
|
# Hence, skeleton would depends on the toolchain and the toolchain would depend
|
||||||
|
# on skeleton.
|
||||||
|
SKELETON_COMMON_ADD_TOOLCHAIN_DEPENDENCY = NO
|
||||||
|
SKELETON_COMMON_ADD_SKELETON_DEPENDENCY = NO
|
||||||
|
|
||||||
|
# The skeleton also handles the merged /usr case in the sysroot
|
||||||
|
SKELETON_COMMON_INSTALL_STAGING = YES
|
||||||
|
|
||||||
|
SKELETON_COMMON_PATH = system/skeleton
|
||||||
|
|
||||||
|
define SKELETON_COMMON_INSTALL_TARGET_CMDS
|
||||||
|
$(call SYSTEM_RSYNC,$(SKELETON_COMMON_PATH),$(TARGET_DIR))
|
||||||
|
$(call SYSTEM_USR_SYMLINKS_OR_DIRS,$(TARGET_DIR))
|
||||||
|
$(call SYSTEM_LIB_SYMLINK,$(TARGET_DIR))
|
||||||
|
$(INSTALL) -m 0644 support/misc/target-dir-warning.txt \
|
||||||
|
$(TARGET_DIR_WARNING_FILE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
# For the staging dir, we don't really care about /bin and /sbin.
|
||||||
|
# But for consistency with the target dir, and to simplify the code,
|
||||||
|
# we still handle them for the merged or non-merged /usr cases.
|
||||||
|
# Since the toolchain is not yet available, the staging is not yet
|
||||||
|
# populated, so we need to create the directories in /usr
|
||||||
|
define SKELETON_COMMON_INSTALL_STAGING_CMDS
|
||||||
|
$(INSTALL) -d -m 0755 $(STAGING_DIR)/usr/lib
|
||||||
|
$(INSTALL) -d -m 0755 $(STAGING_DIR)/usr/bin
|
||||||
|
$(INSTALL) -d -m 0755 $(STAGING_DIR)/usr/sbin
|
||||||
|
$(call SYSTEM_USR_SYMLINKS_OR_DIRS,$(STAGING_DIR))
|
||||||
|
$(call SYSTEM_LIB_SYMLINK,$(STAGING_DIR))
|
||||||
|
endef
|
||||||
|
|
||||||
|
SKELETON_COMMON_HOSTNAME = $(call qstrip,$(BR2_TARGET_GENERIC_HOSTNAME))
|
||||||
|
SKELETON_COMMON_ISSUE = $(call qstrip,$(BR2_TARGET_GENERIC_ISSUE))
|
||||||
|
SKELETON_COMMON_ROOT_PASSWD = $(call qstrip,$(BR2_TARGET_GENERIC_ROOT_PASSWD))
|
||||||
|
SKELETON_COMMON_PASSWD_METHOD = $(call qstrip,$(BR2_TARGET_GENERIC_PASSWD_METHOD))
|
||||||
|
SKELETON_COMMON_BIN_SH = $(call qstrip,$(BR2_SYSTEM_BIN_SH))
|
||||||
|
|
||||||
|
ifneq ($(SKELETON_COMMON_HOSTNAME),)
|
||||||
|
define SKELETON_COMMON_SET_HOSTNAME
|
||||||
|
mkdir -p $(TARGET_DIR)/etc
|
||||||
|
echo "$(SKELETON_COMMON_HOSTNAME)" > $(TARGET_DIR)/etc/hostname
|
||||||
|
$(SED) '$$a \127.0.1.1\t$(SKELETON_COMMON_HOSTNAME)' \
|
||||||
|
-e '/^127.0.1.1/d' $(TARGET_DIR)/etc/hosts
|
||||||
|
endef
|
||||||
|
SKELETON_COMMON_TARGET_FINALIZE_HOOKS += SKELETON_COMMON_SET_HOSTNAME
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(SKELETON_COMMON_ISSUE),)
|
||||||
|
define SKELETON_COMMON_SET_ISSUE
|
||||||
|
mkdir -p $(TARGET_DIR)/etc
|
||||||
|
echo "$(SKELETON_COMMON_ISSUE)" > $(TARGET_DIR)/etc/issue
|
||||||
|
endef
|
||||||
|
SKELETON_COMMON_TARGET_FINALIZE_HOOKS += SKELETON_COMMON_SET_ISSUE
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(BR2_TARGET_ENABLE_ROOT_LOGIN),y)
|
||||||
|
ifeq ($(SKELETON_COMMON_ROOT_PASSWD),)
|
||||||
|
SKELETON_ROOT_PASSWORD =
|
||||||
|
else ifneq ($(filter $$1$$% $$5$$% $$6$$%,$(SKELETON_COMMON_ROOT_PASSWD)),)
|
||||||
|
SKELETON_ROOT_PASSWORD = '$(SKELETON_COMMON_ROOT_PASSWD)'
|
||||||
|
else
|
||||||
|
# This variable will only be evaluated in the finalize stage, so we can
|
||||||
|
# be sure that host-mkpasswd will have already been built by that time.
|
||||||
|
SKELETON_ROOT_PASSWORD = "`$(MKPASSWD) -m "$(SKELETON_COMMON_PASSWD_METHOD)" "$(SKELETON_COMMON_ROOT_PASSWD)"`"
|
||||||
|
endif
|
||||||
|
else # !BR2_TARGET_ENABLE_ROOT_LOGIN
|
||||||
|
SKELETON_ROOT_PASSWORD = "*"
|
||||||
|
endif
|
||||||
|
define SKELETON_COMMON_SET_ROOT_PASSWD
|
||||||
|
$(SED) s,^root:[^:]*:,root:$(SKELETON_ROOT_PASSWORD):, $(TARGET_DIR)/etc/shadow
|
||||||
|
endef
|
||||||
|
SKELETON_COMMON_TARGET_FINALIZE_HOOKS += SKELETON_COMMON_SET_ROOT_PASSWD
|
||||||
|
|
||||||
|
ifeq ($(BR2_SYSTEM_BIN_SH_NONE),y)
|
||||||
|
define SKELETON_COMMON_BIN_SH
|
||||||
|
rm -f $(TARGET_DIR)/bin/sh
|
||||||
|
endef
|
||||||
|
else
|
||||||
|
ifneq ($(SKELETON_COMMON_BIN_SH),)
|
||||||
|
define SKELETON_COMMON_BIN_SH
|
||||||
|
ln -sf $(SKELETON_COMMON_BIN_SH) $(TARGET_DIR)/bin/sh
|
||||||
|
endef
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
SKELETON_COMMON_TARGET_FINALIZE_HOOKS += SKELETON_COMMON_BIN_SH
|
||||||
|
|
||||||
|
$(eval $(generic-package))
|
@ -11,94 +11,10 @@
|
|||||||
SKELETON_ADD_TOOLCHAIN_DEPENDENCY = NO
|
SKELETON_ADD_TOOLCHAIN_DEPENDENCY = NO
|
||||||
SKELETON_ADD_SKELETON_DEPENDENCY = NO
|
SKELETON_ADD_SKELETON_DEPENDENCY = NO
|
||||||
|
|
||||||
# The skeleton also handles the merged /usr case in the sysroot
|
|
||||||
SKELETON_INSTALL_STAGING = YES
|
|
||||||
|
|
||||||
ifeq ($(BR2_PACKAGE_SKELETON_CUSTOM),y)
|
ifeq ($(BR2_PACKAGE_SKELETON_CUSTOM),y)
|
||||||
|
|
||||||
SKELETON_DEPENDENCIES = skeleton-custom
|
SKELETON_DEPENDENCIES = skeleton-custom
|
||||||
|
|
||||||
else # ! custom skeleton
|
|
||||||
|
|
||||||
SKELETON_PATH = system/skeleton
|
|
||||||
|
|
||||||
define SKELETON_INSTALL_TARGET_CMDS
|
|
||||||
$(call SYSTEM_RSYNC,$(SKELETON_PATH),$(TARGET_DIR))
|
|
||||||
$(call SYSTEM_USR_SYMLINKS_OR_DIRS,$(TARGET_DIR))
|
|
||||||
$(call SYSTEM_LIB_SYMLINK,$(TARGET_DIR))
|
|
||||||
$(INSTALL) -m 0644 support/misc/target-dir-warning.txt \
|
|
||||||
$(TARGET_DIR_WARNING_FILE)
|
|
||||||
endef
|
|
||||||
|
|
||||||
# For the staging dir, we don't really care about /bin and /sbin.
|
|
||||||
# But for consistency with the target dir, and to simplify the code,
|
|
||||||
# we still handle them for the merged or non-merged /usr cases.
|
|
||||||
# Since the toolchain is not yet available, the staging is not yet
|
|
||||||
# populated, so we need to create the directories in /usr
|
|
||||||
define SKELETON_INSTALL_STAGING_CMDS
|
|
||||||
$(INSTALL) -d -m 0755 $(STAGING_DIR)/usr/lib
|
|
||||||
$(INSTALL) -d -m 0755 $(STAGING_DIR)/usr/bin
|
|
||||||
$(INSTALL) -d -m 0755 $(STAGING_DIR)/usr/sbin
|
|
||||||
$(call SYSTEM_USR_SYMLINKS_OR_DIRS,$(STAGING_DIR))
|
|
||||||
$(call SYSTEM_LIB_SYMLINK,$(STAGING_DIR))
|
|
||||||
endef
|
|
||||||
|
|
||||||
SKELETON_TARGET_GENERIC_HOSTNAME = $(call qstrip,$(BR2_TARGET_GENERIC_HOSTNAME))
|
|
||||||
SKELETON_TARGET_GENERIC_ISSUE = $(call qstrip,$(BR2_TARGET_GENERIC_ISSUE))
|
|
||||||
SKELETON_TARGET_GENERIC_ROOT_PASSWD = $(call qstrip,$(BR2_TARGET_GENERIC_ROOT_PASSWD))
|
|
||||||
SKELETON_TARGET_GENERIC_PASSWD_METHOD = $(call qstrip,$(BR2_TARGET_GENERIC_PASSWD_METHOD))
|
|
||||||
SKELETON_TARGET_GENERIC_BIN_SH = $(call qstrip,$(BR2_SYSTEM_BIN_SH))
|
|
||||||
|
|
||||||
ifneq ($(SKELETON_TARGET_GENERIC_HOSTNAME),)
|
|
||||||
define SKELETON_SET_HOSTNAME
|
|
||||||
mkdir -p $(TARGET_DIR)/etc
|
|
||||||
echo "$(SKELETON_TARGET_GENERIC_HOSTNAME)" > $(TARGET_DIR)/etc/hostname
|
|
||||||
$(SED) '$$a \127.0.1.1\t$(SKELETON_TARGET_GENERIC_HOSTNAME)' \
|
|
||||||
-e '/^127.0.1.1/d' $(TARGET_DIR)/etc/hosts
|
|
||||||
endef
|
|
||||||
TARGET_FINALIZE_HOOKS += SKELETON_SET_HOSTNAME
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifneq ($(SKELETON_TARGET_GENERIC_ISSUE),)
|
|
||||||
define SKELETON_SET_ISSUE
|
|
||||||
mkdir -p $(TARGET_DIR)/etc
|
|
||||||
echo "$(SKELETON_TARGET_GENERIC_ISSUE)" > $(TARGET_DIR)/etc/issue
|
|
||||||
endef
|
|
||||||
TARGET_FINALIZE_HOOKS += SKELETON_SET_ISSUE
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(BR2_TARGET_ENABLE_ROOT_LOGIN),y)
|
|
||||||
ifeq ($(SKELETON_TARGET_GENERIC_ROOT_PASSWD),)
|
|
||||||
SKELETON_ROOT_PASSWORD =
|
|
||||||
else ifneq ($(filter $$1$$% $$5$$% $$6$$%,$(SKELETON_TARGET_GENERIC_ROOT_PASSWD)),)
|
|
||||||
SKELETON_ROOT_PASSWORD = '$(SKELETON_TARGET_GENERIC_ROOT_PASSWD)'
|
|
||||||
else
|
else
|
||||||
# This variable will only be evaluated in the finalize stage, so we can
|
SKELETON_DEPENDENCIES = skeleton-common
|
||||||
# be sure that host-mkpasswd will have already been built by that time.
|
|
||||||
SKELETON_ROOT_PASSWORD = "`$(MKPASSWD) -m "$(SKELETON_TARGET_GENERIC_PASSWD_METHOD)" "$(SKELETON_TARGET_GENERIC_ROOT_PASSWD)"`"
|
|
||||||
endif
|
endif
|
||||||
else # !BR2_TARGET_ENABLE_ROOT_LOGIN
|
|
||||||
SKELETON_ROOT_PASSWORD = "*"
|
|
||||||
endif
|
|
||||||
|
|
||||||
define SKELETON_SET_ROOT_PASSWD
|
|
||||||
$(SED) s,^root:[^:]*:,root:$(SKELETON_ROOT_PASSWORD):, $(TARGET_DIR)/etc/shadow
|
|
||||||
endef
|
|
||||||
TARGET_FINALIZE_HOOKS += SKELETON_SET_ROOT_PASSWD
|
|
||||||
|
|
||||||
ifeq ($(BR2_SYSTEM_BIN_SH_NONE),y)
|
|
||||||
define SKELETON_BIN_SH
|
|
||||||
rm -f $(TARGET_DIR)/bin/sh
|
|
||||||
endef
|
|
||||||
else
|
|
||||||
ifneq ($(SKELETON_TARGET_GENERIC_BIN_SH),)
|
|
||||||
define SKELETON_BIN_SH
|
|
||||||
ln -sf $(SKELETON_TARGET_GENERIC_BIN_SH) $(TARGET_DIR)/bin/sh
|
|
||||||
endef
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
TARGET_FINALIZE_HOOKS += SKELETON_BIN_SH
|
|
||||||
|
|
||||||
endif # BR2_ROOTFS_SKELETON_DEFAULT
|
|
||||||
|
|
||||||
$(eval $(generic-package))
|
$(eval $(generic-package))
|
||||||
|
@ -5,7 +5,7 @@ choice
|
|||||||
|
|
||||||
config BR2_ROOTFS_SKELETON_DEFAULT
|
config BR2_ROOTFS_SKELETON_DEFAULT
|
||||||
bool "default target skeleton"
|
bool "default target skeleton"
|
||||||
select BR2_PACKAGE_SKELETON
|
select BR2_PACKAGE_SKELETON_COMMON
|
||||||
help
|
help
|
||||||
Use default target skeleton
|
Use default target skeleton
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user