forked from altcloud/mkimage-profiles
Compare commits
34 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
f5178dee01 | ||
|
08b935545a | ||
|
5d37a0c54d | ||
|
75fd795210 | ||
|
c5bf0529bc | ||
|
f32b8d4f6e | ||
|
4801579cf5 | ||
|
3373a7bc89 | ||
|
0c98733338 | ||
|
ef0d5e1581 | ||
|
5dbf407c0f | ||
|
74e81984f0 | ||
|
a3c0d2bbc3 | ||
|
eeccd5dfb1 | ||
|
f32ae716e8 | ||
|
774169c6cd | ||
|
fba30e0675 | ||
|
69d5133a3b | ||
|
7f555ed7a1 | ||
|
b56df31624 | ||
|
4dfd689810 | ||
|
cf81cc6785 | ||
|
3d10c59d2b | ||
|
3a5b47e712 | ||
|
2b90dffa6f | ||
|
5c54341044 | ||
|
9475d199a0 | ||
|
2b47da9852 | ||
|
f5a8b89381 | ||
|
0e57149de9 | ||
|
5569b4fce1 | ||
|
878abab5ce | ||
|
20844de700 | ||
|
e78c62b4e7 |
6
Makefile
6
Makefile
@@ -18,6 +18,8 @@ include distro.mk
|
|||||||
include log.mk
|
include log.mk
|
||||||
include iso.mk
|
include iso.mk
|
||||||
|
|
||||||
|
.PHONY: $(IMAGES)
|
||||||
|
|
||||||
# we can't use implicit rules for top-level targets, only for prereqs
|
# we can't use implicit rules for top-level targets, only for prereqs
|
||||||
# NB: what about static pattern rules?
|
# NB: what about static pattern rules?
|
||||||
# TODO: move into libdistro?
|
# TODO: move into libdistro?
|
||||||
@@ -30,10 +32,14 @@ IMAGEDIR ?= $(shell [ -d "$$HOME/out" -a -w "$$HOME/out" ] \
|
|||||||
|| echo "$(BUILDDIR)/out" )
|
|| echo "$(BUILDDIR)/out" )
|
||||||
IMAGENAME ?= mkimage-profiles-$(ARCH).iso
|
IMAGENAME ?= mkimage-profiles-$(ARCH).iso
|
||||||
|
|
||||||
|
everything:
|
||||||
|
@for i in $(IMAGES); do $(MAKE) BUILDDIR=$(BUILDDIR) $$i; done
|
||||||
|
|
||||||
$(IMAGES): %.iso: | profile/init distro/% boot/isolinux profile/populate iso
|
$(IMAGES): %.iso: | profile/init distro/% boot/isolinux profile/populate iso
|
||||||
@# TODO: run automated tests (e.g. iso size)
|
@# TODO: run automated tests (e.g. iso size)
|
||||||
@OUTNAME="$(@:.iso=)-$(DATE)-$(ARCH).iso"; \
|
@OUTNAME="$(@:.iso=)-$(DATE)-$(ARCH).iso"; \
|
||||||
OUTPATH="$(IMAGEDIR)/$$OUTNAME"; \
|
OUTPATH="$(IMAGEDIR)/$$OUTNAME"; \
|
||||||
|
mkdir -p "$(IMAGEDIR)" && \
|
||||||
test -s "$(IMAGEDIR)/$(IMAGENAME)" && \
|
test -s "$(IMAGEDIR)/$(IMAGENAME)" && \
|
||||||
mv "$(IMAGEDIR)/$(IMAGENAME)" "$$OUTPATH" && \
|
mv "$(IMAGEDIR)/$(IMAGENAME)" "$$OUTPATH" && \
|
||||||
echo "** image: $$OUTPATH" && \
|
echo "** image: $$OUTPATH" && \
|
||||||
|
15
README
15
README
@@ -38,7 +38,11 @@ license: GPLv2+, see COPYING
|
|||||||
+ базовые комплекты помещены в подкаталогах под sub.in/;
|
+ базовые комплекты помещены в подкаталогах под sub.in/;
|
||||||
их наборы скриптов могут расширяться фичами
|
их наборы скриптов могут расширяться фичами
|
||||||
- stage1: propagator, ядро инсталятора и initrd в т.ч. с firmware
|
- stage1: propagator, ядро инсталятора и initrd в т.ч. с firmware
|
||||||
- install2: сам инсталятор (и модули ядра)
|
- stage2: базовый live-образ (и модули ядра, соответствующие stage1);
|
||||||
|
используется только с модификаторами (см. соответствующие фичи):
|
||||||
|
+ stage2/install2: инсталятор
|
||||||
|
+ stage2/live: LiveCD
|
||||||
|
+ stage2/rescue: спасательная система
|
||||||
- main: пакетная база к инсталяции (обязательная и дополнительная)
|
- main: пакетная база к инсталяции (обязательная и дополнительная)
|
||||||
- фичи:
|
- фичи:
|
||||||
+ список собирается в $(FEATURES)
|
+ список собирается в $(FEATURES)
|
||||||
@@ -46,14 +50,17 @@ license: GPLv2+, see COPYING
|
|||||||
+ описываются в индивидуальных features.in/*/config.mk
|
+ описываются в индивидуальных features.in/*/config.mk
|
||||||
+ могут зависеть друг от друга и требовать субпрофили
|
+ могут зависеть друг от друга и требовать субпрофили
|
||||||
+ при сборке $(BUILDDIR) содержимое указанных в $(FEATURES) фич
|
+ при сборке $(BUILDDIR) содержимое указанных в $(FEATURES) фич
|
||||||
(подкаталоги, соответствующие входящим в дистрибутив субпрофилям)
|
(подкаталоги, соответствующие входящим в дистрибутив субпрофилям
|
||||||
|
под их итоговыми названиями -- например, live, а не stage2/live)
|
||||||
добавляется в профиль; затем выполняются generate.sh, generate.mk
|
добавляется в профиль; затем выполняются generate.sh, generate.mk
|
||||||
- списки пакетов (*_LISTS): просьба по возможности избегать дублирования
|
- списки пакетов (*_LISTS): просьба по возможности избегать дублирования
|
||||||
|
NB: перечисленные в этих переменных файлы автоматически копируются
|
||||||
|
в порождаемый профиль => не следует указывать пакаджлисты напрямую
|
||||||
- индивидуальные пакеты (*_PACKAGES): следует крайне осторожно пользоваться
|
- индивидуальные пакеты (*_PACKAGES): следует крайне осторожно пользоваться
|
||||||
COMMON_PACKAGES -- эти пакеты попадут во все стадии, в том числе в образ
|
SYSTEM_PACKAGES -- эти пакеты попадут во все стадии, в том числе в образ
|
||||||
чувствительной к объёму install2 (в stage1 -- только в инструментальный
|
чувствительной к объёму install2 (в stage1 -- только в инструментальный
|
||||||
чрут); применяйте для того, что обязано быть и в инсталяторе, и в готовой
|
чрут); применяйте для того, что обязано быть и в инсталяторе, и в готовой
|
||||||
системе
|
системе -- и не путайте с COMMON_PACKAGES (main, live, rescue)
|
||||||
|
|
||||||
Результат:
|
Результат:
|
||||||
- при успешном завершении сборки образ называется сообразно
|
- при успешном завершении сборки образ называется сообразно
|
||||||
|
12
clean.mk
12
clean.mk
@@ -3,8 +3,18 @@
|
|||||||
# drop stock predefined rules
|
# drop stock predefined rules
|
||||||
.DEFAULT:
|
.DEFAULT:
|
||||||
|
|
||||||
|
# tmpfs-sparing extra rule: cleanup workdir after completing each stage
|
||||||
|
# (as packed results are saved this only lowers RAM pressure)
|
||||||
|
ifdef CLEAN
|
||||||
|
export GLOBAL_CLEAN_WORKDIR = clean-current
|
||||||
|
ifdef DEBUG
|
||||||
|
WARNING = (both CLEAN and DEBUG defined, debug options will be limited)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
# ordinary clean: destroys workdirs but not the corresponding results
|
||||||
clean:
|
clean:
|
||||||
@echo '** cleaning up'
|
@echo '** cleaning up $(WARNING)'
|
||||||
@find -name '*~' -delete >&/dev/null
|
@find -name '*~' -delete >&/dev/null
|
||||||
@if [ -L build -a -d build/ ]; then \
|
@if [ -L build -a -d build/ ]; then \
|
||||||
$(MAKE) -C build $@ GLOBAL_BUILDDIR=$(shell readlink build) $(LOG); \
|
$(MAKE) -C build $@ GLOBAL_BUILDDIR=$(shell readlink build) $(LOG); \
|
||||||
|
61
distro.mk
61
distro.mk
@@ -26,36 +26,61 @@ distro/syslinux: distro/.init distro/.branding sub/stage1 \
|
|||||||
use/syslinux/ui-vesamenu use/hdt use/memtest use/dos
|
use/syslinux/ui-vesamenu use/hdt use/memtest use/dos
|
||||||
|
|
||||||
# $(VAR) will be substituted before writing them to $(CONFIG);
|
# $(VAR) will be substituted before writing them to $(CONFIG);
|
||||||
# $$(VAR) will remain unsubstituted util $(CONFIG) is included
|
# $$(VAR) will remain unsubstituted until $(CONFIG) is included
|
||||||
# and their value requested (so the variable referenced
|
# and their value requested (so the variable referenced
|
||||||
# can change its value during configuration _before_
|
# can change its value during configuration _before_
|
||||||
# it's actually used); just peek inside $(CONFIG) ;-)
|
# it's actually used); just peek inside $(CONFIG) ;-)
|
||||||
|
|
||||||
# something actually useful (as a network-only installer)
|
|
||||||
distro/installer: distro/.base use/installer
|
|
||||||
@$(call set,INSTALLER,altlinux-generic)
|
|
||||||
@$(call set,INSTALLER_KMODULES_REGEXP,drm.*) # for KMS
|
|
||||||
|
|
||||||
# BASE_PACKAGES, BASE_LISTS, MAIN_PACKAGES, MAIN_LISTS: see sub.in/main/
|
# BASE_PACKAGES, BASE_LISTS, MAIN_PACKAGES, MAIN_LISTS: see sub.in/main/
|
||||||
|
|
||||||
distro/server-base: distro/installer sub/main use/syslinux/ui-menu use/memtest
|
# live images
|
||||||
|
|
||||||
|
distro/live: distro/.base use/live use/syslinux/ui-menu
|
||||||
|
distro/rescue: distro/.base use/rescue use/syslinux/ui-menu
|
||||||
|
distro/dos: sub/stage1 use/dos use/syslinux/ui-menu
|
||||||
|
|
||||||
|
# something actually useful (as a network-only installer)
|
||||||
|
# NB: doesn't carry stage3 thus cannot use/bootloader
|
||||||
|
distro/installer: distro/.base use/install2
|
||||||
|
@$(call set,INSTALLER,altlinux-generic)
|
||||||
|
@$(call set,STAGE1_KMODULES_REGEXP,drm.*) # for KMS
|
||||||
|
|
||||||
|
# server distributions
|
||||||
|
|
||||||
|
distro/server-base: distro/installer sub/main \
|
||||||
|
use/syslinux/ui-menu use/memtest use/bootloader/grub
|
||||||
@$(call add,BASE_LISTS,server-base)
|
@$(call add,BASE_LISTS,server-base)
|
||||||
|
|
||||||
distro/server-ovz: distro/server-base use/hdt use/firmware/server
|
distro/server-mini: distro/server-base use/cleanup/x11-alterator
|
||||||
@$(call set,INSTALLER_KFLAVOUR,std-def)
|
@$(call set,KFLAVOURS,el-smp)
|
||||||
|
@$(call add,KMODULES,e1000e igb)
|
||||||
|
@$(call add,BASE_LISTS,\
|
||||||
|
$(call tags,base && (server || network || security || pkg)))
|
||||||
|
@$(call add,BASE_LISTS,$(call tags,extra network))
|
||||||
|
|
||||||
|
distro/server-ovz: distro/server-base \
|
||||||
|
use/hdt use/rescue use/firmware/server use/powerbutton/acpi \
|
||||||
|
use/cleanup/x11-alterator
|
||||||
|
@$(call set,STAGE1_KFLAVOUR,std-def)
|
||||||
@$(call set,KFLAVOURS,std-def ovz-el)
|
@$(call set,KFLAVOURS,std-def ovz-el)
|
||||||
@$(call add,KMODULES,bcmwl e1000e igb ndiswrapper rtl8168 rtl8192)
|
@$(call add,KMODULES,bcmwl e1000e igb ndiswrapper rtl8168 rtl8192)
|
||||||
@$(call add,KMODULES,ipset ipt-netflow opendpi pf_ring xtables-addons)
|
@$(call add,KMODULES,ipset ipt-netflow opendpi pf_ring xtables-addons)
|
||||||
@$(call add,KMODULES,drbd83 kvm)
|
@$(call add,KMODULES,drbd83 kvm)
|
||||||
@$(call add,MAIN_LISTS,kernel-wifi)
|
|
||||||
@$(call add,BASE_LISTS,ovz-server)
|
@$(call add,BASE_LISTS,ovz-server)
|
||||||
@$(call add,BASE_LISTS,$(call tags,base server))
|
@$(call add,BASE_LISTS,$(call tags,base server))
|
||||||
@$(call add,GROUPS,dns-server http-server ftp-server kvm-server)
|
@$(call add,MAIN_LISTS,kernel-wifi)
|
||||||
@$(call add,GROUPS,ipmi mysql-server dhcp-server mail-server)
|
@$(call add,MAIN_GROUPS,dns-server http-server ftp-server kvm-server)
|
||||||
@$(call add,GROUPS,monitoring diag-tools)
|
@$(call add,MAIN_GROUPS,ipmi mysql-server dhcp-server mail-server)
|
||||||
|
@$(call add,MAIN_GROUPS,monitoring diag-tools)
|
||||||
|
|
||||||
distro/minicd: distro/server-base
|
# desktop distributions
|
||||||
@$(call set,KFLAVOURS,pure-emerald) # we might need the most recent drivers
|
|
||||||
@$(call add,MAIN_PACKAGES,etcnet-full)
|
|
||||||
|
|
||||||
# if there are too many screens above, it might make sense to distro.d/
|
distro/desktop-base: distro/installer sub/main \
|
||||||
|
use/syslinux/ui-vesamenu use/x11/xorg use/bootloader/grub
|
||||||
|
|
||||||
|
distro/icewm: distro/desktop-base \
|
||||||
|
use/lowmem use/x11/xdm use/x11/runlevel5 \
|
||||||
|
use/bootloader/lilo use/powerbutton/acpi \
|
||||||
|
use/cleanup/alterator
|
||||||
|
@$(call add,BASE_LISTS,$(call tags,icewm desktop))
|
||||||
|
|
||||||
|
# NB: if there are too many screens above, it might make sense to distro.d/
|
||||||
|
@@ -1,9 +1,8 @@
|
|||||||
требования по оформлению кода
|
требования по оформлению кода
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
* постарайтесь не вносить без обсуждения разнобой стилей,
|
* постарайтесь не вносить без обсуждения разнобой стилей,
|
||||||
если есть предметные пожелания по коррекции текущего --
|
если есть предметные пожелания по коррекции текущего --
|
||||||
пишите, обсудим;
|
пишите в devel-distro@, обсудим;
|
||||||
|
|
||||||
* перед тем, как делать существенные переработки уже имеющегося
|
* перед тем, как делать существенные переработки уже имеющегося
|
||||||
кода -- опять же опишите проблему, идею и предполагаемый результат,
|
кода -- опять же опишите проблему, идею и предполагаемый результат,
|
||||||
@@ -14,7 +13,6 @@
|
|||||||
|
|
||||||
рекомендации
|
рекомендации
|
||||||
~~~~~~~~~~~~
|
~~~~~~~~~~~~
|
||||||
|
|
||||||
* трезво относитесь ко входным данным и не пренебрегайте кавычками:
|
* трезво относитесь ко входным данным и не пренебрегайте кавычками:
|
||||||
название дистрибутива с пробелом или получение текста ошибки вместо
|
название дистрибутива с пробелом или получение текста ошибки вместо
|
||||||
ожидаемого вывода команды могут привести к сложнодиагностируемым
|
ожидаемого вывода команды могут привести к сложнодиагностируемым
|
||||||
@@ -31,3 +29,8 @@
|
|||||||
* предпочтительно применение $() вместо `` (особенно при вложенности);
|
* предпочтительно применение $() вместо `` (особенно при вложенности);
|
||||||
|
|
||||||
* постарайтесь не вылазить за 80 колонок.
|
* постарайтесь не вылазить за 80 колонок.
|
||||||
|
|
||||||
|
ссылки
|
||||||
|
~~~~~~
|
||||||
|
* https://lists.altlinux.org/mailman/listinfo/devel-distro
|
||||||
|
(подписка по приглашению)
|
||||||
|
29
doc/assumptions.txt
Normal file
29
doc/assumptions.txt
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
предположения фрагментов кода об окружении
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
- pkg.in/lists/Makefile
|
||||||
|
+ ожидает, что названия пакаджлистов указываются в переменных
|
||||||
|
вида *_LISTS, и копирует в генерируемый профиль только их
|
||||||
|
+ если задать имя файла пакаджлиста непосредственно в Makefile
|
||||||
|
субпрофиля, он не будет скопирован
|
||||||
|
+ характерное сообщение об ошибке:
|
||||||
|
E: Couldn't find package
|
||||||
|
|
||||||
|
- features.in/stage2/stage1/scripts.d/02-kdefault
|
||||||
|
- features.in/stage2/stage1/scripts.d/03-test-kernel
|
||||||
|
- sub.in/stage1/Makefile
|
||||||
|
+ ожидают, что в stage1 попадёт строго одно ядро сообразно
|
||||||
|
явному указанию в STAGE1_KFLAVOUR (либо последнее указанное
|
||||||
|
в KFLAVOURS)
|
||||||
|
+ если добавить какой-либо kernel-image в STAGE1_PACKAGES*,
|
||||||
|
результат может быть неожиданным
|
||||||
|
+ вероятная ошибка: незагрузка полученного squashfs
|
||||||
|
|
||||||
|
- features.in/install2/install2/stage2cfg.mk
|
||||||
|
- features.in/live/live/stage2cfg.mk
|
||||||
|
- features.in/rescue/rescue/stage2cfg.mk
|
||||||
|
- features.in/syslinux/cfg.in/15live.cfg
|
||||||
|
- features.in/syslinux/cfg.in/20install2.cfg
|
||||||
|
- features.in/syslinux/cfg.in/80rescue.cfg
|
||||||
|
- features.in/syslinux/scripts.d/20-propagator-ramdisk
|
||||||
|
+ ожидают, что названия squashfs-образов второй стадии инсталятора,
|
||||||
|
livecd и спасательной системы соответственно altinst, live и rescue
|
21
doc/debug.txt
Normal file
21
doc/debug.txt
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
ловля плюх
|
||||||
|
~~~~~~~~~~
|
||||||
|
При отладке сборки конфигурации или самого дистрибутива
|
||||||
|
могут оказаться полезными следующие средства:
|
||||||
|
|
||||||
|
- build/distcfg.mk
|
||||||
|
+ формируется автоматически в процессе построения конфигурации;
|
||||||
|
+ содержит трассировочную информацию (откуда что взялось);
|
||||||
|
+ этот файл применяется как авторитетный конфигурационный
|
||||||
|
|
||||||
|
- build/build.log
|
||||||
|
+ подробность зависит от значения переменной DEBUG,
|
||||||
|
которую можно передать при запуске make (см. variables.txt);
|
||||||
|
+ содержит коммит, из которого происходит сборка, и признак
|
||||||
|
"грязности" рабочего каталога при наличии модификаций после
|
||||||
|
этого коммита;
|
||||||
|
+ содержит список конфигурационных переменных и их конечных значений,
|
||||||
|
созданный на основании distcfg.mk (см. тж. build/vars.mk)
|
||||||
|
|
||||||
|
Общая информация по отладке сборки профилей mkimage:
|
||||||
|
http://www.altlinux.org/Mkimage/debug
|
@@ -1,3 +1,5 @@
|
|||||||
|
фичи
|
||||||
|
~~~~
|
||||||
Особенности дистрибутива, не учитываемые в пакетной базе
|
Особенности дистрибутива, не учитываемые в пакетной базе
|
||||||
или зависящие от переменных времени сборки/установки образа,
|
или зависящие от переменных времени сборки/установки образа,
|
||||||
могут быть оформлены несколькими образами:
|
могут быть оформлены несколькими образами:
|
||||||
@@ -18,4 +20,10 @@
|
|||||||
* необходимы пакетные зависимости;
|
* необходимы пакетные зависимости;
|
||||||
* требуется компилируемый платформозависимый код (для чего бы...);
|
* требуется компилируемый платформозависимый код (для чего бы...);
|
||||||
* код фичи достаточно специфичен, нетривиален и объёмен,
|
* код фичи достаточно специфичен, нетривиален и объёмен,
|
||||||
чтобы загромождать метапрофиль было не очень осмысленно.
|
чтобы загромождать метапрофиль было не очень осмысленно;
|
||||||
|
* фича представляет из себя отдельный мини-продукт, над которым
|
||||||
|
ведётся активная работа (возможно, несколькими людьми).
|
||||||
|
|
||||||
|
Стоит избегать изменения пакетных умолчаний в случае, когда их
|
||||||
|
представляется осмысленным и возможным скорректировать в пакете:
|
||||||
|
таким образом они станут более дистрибутивными.
|
||||||
|
@@ -1,7 +1,10 @@
|
|||||||
### sample ~/.mkimage/profiles.mk
|
### sample ~/.mkimage/profiles.mk
|
||||||
|
|
||||||
# ARCH is defined in/for metaprofile's toplevel Makefile, not here
|
### where to look for apt.conf; system one used by default
|
||||||
APTCONF = ~/apt/apt.conf.$(ARCH)
|
#APTCONF = ~/apt/apt.conf.$(ARCH)
|
||||||
|
|
||||||
# can be defined here but passing DEBUG=1 is preferred
|
### turns on GLOBAL_VERBOSE and prettier output
|
||||||
#GLOBAL_VERBOSE = 1
|
#DEBUG = 1
|
||||||
|
|
||||||
|
# spares tmpfs, quite recommended unless you need raw workdir chroots
|
||||||
|
#CLEAN = 1
|
||||||
|
35
doc/variables.txt
Normal file
35
doc/variables.txt
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
переменные make
|
||||||
|
~~~~~~~~~~~~~~~
|
||||||
|
При запуске на сборку принимается ряд переменных
|
||||||
|
(см. тж. profiles.mk.sample):
|
||||||
|
|
||||||
|
- APTCONF
|
||||||
|
+ задаёт путь к требуемому apt.conf
|
||||||
|
+ значение: пусто (по умолчанию системный) либо строка
|
||||||
|
+ см. image.in/Makefile
|
||||||
|
|
||||||
|
- ARCH
|
||||||
|
+ определяет целевую архитектуру образа
|
||||||
|
+ значение: пусто (по умолчанию авто), i586 или x86_64
|
||||||
|
+ см. iso.mk
|
||||||
|
|
||||||
|
- BUILDDIR
|
||||||
|
+ определяет каталог генерируемого профиля и сборки
|
||||||
|
+ значение: пусто (по умолчанию авто) либо строка
|
||||||
|
+ см. profile.mk
|
||||||
|
|
||||||
|
- CLEAN
|
||||||
|
+ экономия RAM при сборке в tmpfs, иначе места на диске
|
||||||
|
+ очистка рабочего каталога после успешной сборки очередной стадии
|
||||||
|
+ может помешать использовать некоторые варианты отладки
|
||||||
|
+ значение: любая строка, по умолчанию пусто
|
||||||
|
+ см. clean.mk
|
||||||
|
|
||||||
|
- DEBUG
|
||||||
|
+ включение средств отладки
|
||||||
|
+ значение: пусто (по умолчанию), 1 или 2
|
||||||
|
+ см. log.mk
|
||||||
|
|
||||||
|
пример
|
||||||
|
~~~~~~
|
||||||
|
make DEBUG=1 CLEAN=1 syslinux.iso
|
@@ -14,7 +14,8 @@
|
|||||||
её в переменную FEATURES -- к сожалению, реализовать добавление
|
её в переменную FEATURES -- к сожалению, реализовать добавление
|
||||||
автоматом не представляется возможным). Если название фичи не
|
автоматом не представляется возможным). Если название фичи не
|
||||||
упоминается в списке, содержащемся в этой переменной, то она
|
упоминается в списке, содержащемся в этой переменной, то она
|
||||||
и не задействуется при построении профиля.
|
не задействуется при построении профиля, а только при сборке
|
||||||
|
конфигурации дистрибутива.
|
||||||
|
|
||||||
Остальное содержимое является дополнительным и используется
|
Остальное содержимое является дополнительным и используется
|
||||||
в таком порядке (см. features.in/Makefile):
|
в таком порядке (см. features.in/Makefile):
|
||||||
@@ -31,11 +32,11 @@
|
|||||||
|
|
||||||
- затем используется generate.mk, если существует и непустой.
|
- затем используется generate.mk, если существует и непустой.
|
||||||
|
|
||||||
Например, если дистрибутив требует субпрофили stage1, install2
|
Например, если используются субпрофили stage1, stage2/install2
|
||||||
и main, вы можете решить собрать специфические для фичи скрипты
|
и main, вы можете решить собрать специфические для фичи скрипты
|
||||||
инсталятора в install2/image-scripts.d/ (или необходимые для
|
инсталятора в install2/image-scripts.d/ (или необходимые для
|
||||||
операций с пакетной базой -- в main/scripts.d/, смотря чего надо
|
операций с пакетной базой -- в main/scripts.d/, смотря чего
|
||||||
добиться; загляните также в документацию mkimage).
|
надо добиться; загляните также в документацию mkimage).
|
||||||
|
|
||||||
А если требуются нетривиальные действия по конфигурированию
|
А если требуются нетривиальные действия по конфигурированию
|
||||||
(как при сборке syslinux.cfg из кусочков, в зависимости от того,
|
(как при сборке syslinux.cfg из кусочков, в зависимости от того,
|
||||||
|
@@ -5,38 +5,72 @@ ifndef BUILDDIR
|
|||||||
$(error BUILDDIR not defined)
|
$(error BUILDDIR not defined)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
-include $(BUILDDIR)/distcfg.mk
|
include $(BUILDDIR)/distcfg.mk
|
||||||
|
|
||||||
# first rsync what's static, and make backups --
|
# first rsync what's static, and make backups (*~) --
|
||||||
# these might signal of file clashes (or plain dirt);
|
# these might signal of file clashes (or plain dirt);
|
||||||
|
# second, care for toplevel and tagged script dirs;
|
||||||
# then handle two more ways of implementing a feature
|
# then handle two more ways of implementing a feature
|
||||||
|
#
|
||||||
|
# NB: some subprofiles will be specified as "src/dst"
|
||||||
|
# -- then both src/ and dst/ can hold the addons;
|
||||||
|
# still both pieces go into a single destination
|
||||||
|
|
||||||
|
### {image-,}scripts.d/ get rsynced twice :-/
|
||||||
|
### still we don't want the trimmed-down case
|
||||||
|
|
||||||
all:
|
all:
|
||||||
@echo "** starting feature configuration"
|
@echo "** starting feature configuration"
|
||||||
@if test -n "$(GLOBAL_DEBUG)"; then echo "** requested: $(FEATURES)"; fi
|
@if [ -n "$(GLOBAL_DEBUG)" ]; then \
|
||||||
@for dir in $(FEATURES); do \
|
echo "** target subprofiles: $(SUBPROFILES)"; \
|
||||||
for sub in $(SUBPROFILES); do \
|
echo "** requested features: $(FEATURES)"; \
|
||||||
if test -d $$dir/$$sub/; then \
|
fi
|
||||||
if rsync -ab $$dir/$$sub/ $(BUILDDIR)/$$sub/; \
|
@for feat in $(FEATURES); do \
|
||||||
then \
|
pushd "$$feat" && \
|
||||||
type -t git >&/dev/null && \
|
for sub in / $(SUBPROFILES); do \
|
||||||
pushd $(BUILDDIR)/$$sub/ && \
|
src="$${sub%/*}"; \
|
||||||
git add . && \
|
dst="$${sub#*/}"; \
|
||||||
git commit -qam "$@/$$dir/$$sub" ||:; \
|
if [ -d "$$src" ]; then rsync -qab "$$src/" "$(BUILDDIR)/$$dst/"; fi; \
|
||||||
popd; \
|
if [ -d "$$dst" ]; then rsync -qab "$$dst/" "$(BUILDDIR)/$$dst/"; fi; \
|
||||||
|
for scr in {image-,}scripts.d; do \
|
||||||
|
scriptdir="$(BUILDDIR)/$$dst/$$scr/"; \
|
||||||
|
if [ -d "$$scriptdir" ]; then \
|
||||||
|
if [ -d "$$scr" ]; then \
|
||||||
|
rsync -qab "$$scr/" "$$scriptdir/"; \
|
||||||
|
fi; \
|
||||||
|
if [ -d "tagged/$$scr" ]; then \
|
||||||
|
pushd "tagged/$$scr" && \
|
||||||
|
echo "$$feat && ($$src || $$dst)" \
|
||||||
|
| tags2lists . \
|
||||||
|
| xargs -r cp -v -pLt "$$scriptdir" --; \
|
||||||
|
popd; \
|
||||||
|
fi; \
|
||||||
fi; \
|
fi; \
|
||||||
|
done; \
|
||||||
|
type -t git >&/dev/null && \
|
||||||
|
pushd "$(BUILDDIR)/$$dst/" && \
|
||||||
|
git add . && \
|
||||||
|
if [ -n "$$dst" ]; then \
|
||||||
|
the="$$sub subprofile"; \
|
||||||
|
else \
|
||||||
|
the="toplevel"; \
|
||||||
fi; \
|
fi; \
|
||||||
done; \
|
git commit -qam "$$feat feature ($$the part)" ||:; \
|
||||||
if test -x $$dir/generate.sh; then \
|
|
||||||
pushd $$dir && \
|
|
||||||
sh generate.sh; \
|
|
||||||
popd; \
|
popd; \
|
||||||
fi; \
|
done; \
|
||||||
if test -s $$dir/generate.mk; then \
|
if [ -x "generate.sh" ]; then sh generate.sh; fi; \
|
||||||
$(MAKE) -C $$dir -f generate.mk; \
|
if [ -s "generate.mk" ]; then $(MAKE) -f generate.mk; fi; \
|
||||||
fi; \
|
type -t git >&/dev/null && \
|
||||||
|
pushd "$(BUILDDIR)/" && \
|
||||||
|
git add . && \
|
||||||
|
git commit -qam "$$feat feature generation complete" ||:; \
|
||||||
|
popd; \
|
||||||
|
popd; \
|
||||||
done
|
done
|
||||||
|
@find "$(BUILDDIR)/" -name '*~' \
|
||||||
|
| sed "s,$(BUILDDIR)/,** warning: file clash: ," >&2
|
||||||
|
|
||||||
help:
|
# FIXME: drop or fix regarding undefined BUILDDIR being ok
|
||||||
@echo "** available features:"
|
#help:
|
||||||
@grep -h '^use/' */config.mk
|
# @echo "** available features:"
|
||||||
|
# @grep -h '^use/' */config.mk | fmt -sw"$$((COLUMNS>>1))" | column -t
|
||||||
|
@@ -13,8 +13,16 @@
|
|||||||
после инициализации профиля (см. ../image.in/) и копирования
|
после инициализации профиля (см. ../image.in/) и копирования
|
||||||
субпрофилей (см. ../sub.in/). Для каждой фичи, указанной
|
субпрофилей (см. ../sub.in/). Для каждой фичи, указанной
|
||||||
в $(FEATURES), копируются подкаталоги сообразно субпрофилям,
|
в $(FEATURES), копируются подкаталоги сообразно субпрофилям,
|
||||||
а также выполняется скрипт generate.sh и задействуется generate.mk
|
а также производится обработка {tagged/,}{image-},scripts.d/
|
||||||
(при их наличии).
|
(см. cleanup/ в качестве примера); затем выполняется скрипт
|
||||||
|
generate.sh и задействуется generate.mk (при их наличии).
|
||||||
|
|
||||||
|
NB: тегированные скрипты являются экспериментальными,
|
||||||
|
возможны недоработки и существенные изменения!
|
||||||
|
|
||||||
|
Если фича дополняет хуками семейство целевых субпрофилей,
|
||||||
|
построенных на одном базовом, можно воспользоваться подкаталогом
|
||||||
|
с именем исходного базового субпрофиля (см. $src, $dst в Makefile).
|
||||||
|
|
||||||
Несложный пример содержится в 00example/, более близкий к жизни
|
Несложный пример содержится в 00example/, более близкий к жизни
|
||||||
и нынешним пределам возможностей метапрофиля -- в syslinux/.
|
и нынешним пределам возможностей метапрофиля -- в syslinux/.
|
||||||
|
9
features.in/bootloader/README
Normal file
9
features.in/bootloader/README
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
Добавление установки загрузчика основной системы, затребованного
|
||||||
|
посредством указания "grub" или "lilo" в BASE_BOOTLOADER.
|
||||||
|
|
||||||
|
Соответствующий модуль alterator добавляется в устанавливаемую
|
||||||
|
систему (он НЕ должен требоваться пакету installer-distro-*)
|
||||||
|
и требует пакет выбранного загрузчика.
|
||||||
|
|
||||||
|
Реализация экспериментальная (нужно модуляризовать installer-steps),
|
||||||
|
пока завязана на installer-distro-altlinux-generic.
|
9
features.in/bootloader/config.mk
Normal file
9
features.in/bootloader/config.mk
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
# TODO: invent something prettier (think "lilo+grub" -- or error out?)
|
||||||
|
# - add,BASE_PACKAGES,alterator-$* is overly additive
|
||||||
|
# - remember .base if adding yet another *_PACKAGES
|
||||||
|
|
||||||
|
use/bootloader: use/install2 sub/main
|
||||||
|
@$(call add,BASE_PACKAGES,alterator-$$(BASE_BOOTLOADER))
|
||||||
|
|
||||||
|
use/bootloader/grub use/bootloader/lilo: use/bootloader/%: use/bootloader
|
||||||
|
@$(call set,BASE_BOOTLOADER,$*)
|
6
features.in/cleanup/README
Normal file
6
features.in/cleanup/README
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
Эта фича вместо созидания занимается выкидыванием лишнего
|
||||||
|
(например, части модулей инсталятора из установленной системы).
|
||||||
|
|
||||||
|
По возможности стоит работать над дизайном инфраструктуры
|
||||||
|
и пакетной базой так, чтобы ставить-удалять приходилось как
|
||||||
|
можно меньше. В идеале такой антифичи не должно быть вовсе :)
|
19
features.in/cleanup/config.mk
Normal file
19
features.in/cleanup/config.mk
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
use/cleanup:
|
||||||
|
@$(call add,FEATURES,cleanup)
|
||||||
|
|
||||||
|
use/cleanup/installer: use/cleanup
|
||||||
|
@$(call add,CLEANUP_PACKAGES,'installer-*')
|
||||||
|
|
||||||
|
use/cleanup/x11: use/cleanup
|
||||||
|
@$(call add,CLEANUP_PACKAGES,libSM libXext libXmu libXi)
|
||||||
|
|
||||||
|
# as some alterator modules are installed into stage3 (the destination
|
||||||
|
# root filesystem) to perform actions like bootloader setup, we might
|
||||||
|
# have to remove them (contrary to the usual build-up)...
|
||||||
|
use/cleanup/alterator: use/cleanup
|
||||||
|
@$(call add,CLEANUP_PACKAGES,'alterator*' rpm-macros-alterator)
|
||||||
|
@$(call add,CLEANUP_PACKAGES,'guile*' libvhttpd)
|
||||||
|
|
||||||
|
# for lightweight server distros
|
||||||
|
use/cleanup/x11-alterator: use/cleanup/x11 use/cleanup/alterator
|
||||||
|
@$(call add,CLEANUP_PACKAGES,libmng qt4-common)
|
20
features.in/cleanup/tagged/image-scripts.d/01+install2+cleanup
Executable file
20
features.in/cleanup/tagged/image-scripts.d/01+install2+cleanup
Executable file
@@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/sh -efu
|
||||||
|
|
||||||
|
if [ -n "$GLOBAL_VERBOSE" ]; then
|
||||||
|
echo "** GLOBAL_CLEANUP_PACKAGES: $GLOBAL_CLEANUP_PACKAGES"
|
||||||
|
fi >&2
|
||||||
|
|
||||||
|
SCRIPT="/usr/share/install2/postinstall.d/01+install2+cleanup"
|
||||||
|
cat > "$SCRIPT" << EOF
|
||||||
|
#!/bin/sh -efu
|
||||||
|
|
||||||
|
. install2-init-functions
|
||||||
|
|
||||||
|
# don't override the script start message on the same line
|
||||||
|
echo "removing $GLOBAL_CLEANUP_PACKAGES"
|
||||||
|
|
||||||
|
# remove extra packages from installed system
|
||||||
|
list="\$(exec_chroot rpmquery -a --qf='%{NAME}\\n' $GLOBAL_CLEANUP_PACKAGES)"
|
||||||
|
[ -z "\$list" ] || exec_chroot apt-get remove -f -y -- \$list
|
||||||
|
EOF
|
||||||
|
chmod +x "$SCRIPT"
|
6
features.in/dos/README
Normal file
6
features.in/dos/README
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
Фича добавляет создание FreeDOS "live floppy" в stage1.
|
||||||
|
|
||||||
|
Текущее состояние -- загружается минимальная система.
|
||||||
|
Для практического применения (в первую очередь это
|
||||||
|
перешивка firmware) требуется сделать подключение
|
||||||
|
CD и/или USB Flash с тем, чтобы класть туда прошивки.
|
5
features.in/dos/config.mk
Normal file
5
features.in/dos/config.mk
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
use/dos: use/syslinux
|
||||||
|
@$(call add,FEATURES,dos)
|
||||||
|
@$(call add,SYSLINUX_CFG,dos)
|
||||||
|
@$(call add,SYSLINUX_FILES,/usr/lib/syslinux/memdisk)
|
||||||
|
@$(call add,STAGE1_PACKAGES,make-freedos-floppy glibc-gconv-modules)
|
6
features.in/dos/stage1/scripts.d/50-make-dos-floppy
Executable file
6
features.in/dos/stage1/scripts.d/50-make-dos-floppy
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/sh -x
|
||||||
|
# create a barebone bootable freedos floppy
|
||||||
|
# TODO: some sub-framework to populate it as well
|
||||||
|
|
||||||
|
mkdir -p "$WORKDIR/syslinux"
|
||||||
|
make-freedos-floppy "$WORKDIR/syslinux/freedos.img"
|
7
features.in/firmware/README
Normal file
7
features.in/firmware/README
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
Эта фича добавляет комплекты различного firmware в инсталятор,
|
||||||
|
устанавливаемую систему и т.п.
|
||||||
|
|
||||||
|
Следует учитывать, что объём добавленного может быть довольно
|
||||||
|
существенным -- в десктопе вряд ли нужен микрокод для FC HBA
|
||||||
|
или SCSI RAID, который может быть критичен для полезного
|
||||||
|
серверного или спасательного дистрибутива (см. #18047).
|
@@ -3,14 +3,14 @@
|
|||||||
# for mkmodpack to use
|
# for mkmodpack to use
|
||||||
|
|
||||||
use/firmware:
|
use/firmware:
|
||||||
@$(call add,COMMON_PACKAGES,firmware-linux)
|
@$(call add,SYSTEM_PACKAGES,firmware-linux)
|
||||||
|
|
||||||
use/firmware/server: use/firmware
|
use/firmware/server: use/firmware
|
||||||
@$(call add,COMMON_PACKAGES,firmware-aic94xx-seq)
|
@$(call add,SYSTEM_PACKAGES,firmware-aic94xx-seq)
|
||||||
@$(call add,MAIN_PACKAGES_REGEXP,firmware-ql.*)
|
@$(call add,MAIN_PACKAGES_REGEXP,firmware-ql.*)
|
||||||
|
|
||||||
use/firmware/desktop: use/firmware
|
use/firmware/desktop: use/firmware
|
||||||
@$(call add,COMMON_PACKAGES,firmware-psb)
|
@$(call add,SYSTEM_PACKAGES,firmware-psb)
|
||||||
|
|
||||||
use/firmware/wireless: use/firmware
|
use/firmware/wireless: use/firmware
|
||||||
@$(call add,MAIN_PACKAGES,firmware-acx100)
|
@$(call add,MAIN_PACKAGES,firmware-acx100)
|
||||||
|
@@ -1,11 +1,9 @@
|
|||||||
Этот каталог содержит субпрофиль второй стадии инсталятора,
|
Эта фича дополняет базовый "живой" образ второй стадии
|
||||||
требующийся для сборки инсталяционных образов.
|
специфическими для инсталяционного образа настройками
|
||||||
|
и скриптовыми хуками.
|
||||||
|
|
||||||
При добавлении скриптов в image-scripts.d/ следует позаботиться,
|
При добавлении скриптов в image-scripts.d/ следует позаботиться,
|
||||||
чтобы в компактном livecd, которым является инсталятор, оказались
|
чтобы в компактном livecd, которым является инсталятор, оказались
|
||||||
нужные им утилиты (INSTALL2_PACKAGES). Перегружать его не следует,
|
нужные им утилиты (INSTALL2_PACKAGES). Перегружать его не следует,
|
||||||
поскольку это прямо влияет на требования по минимальному размеру
|
поскольку это прямо влияет на требования по минимальному размеру
|
||||||
оперативной памяти для установки.
|
оперативной памяти для установки.
|
||||||
|
|
||||||
Результат -- squashfs в файле altinst, подлежащем копированию
|
|
||||||
в образ.
|
|
@@ -1,7 +1,6 @@
|
|||||||
use/installer: sub/install2 use/syslinux/install2.cfg
|
use/install2: use/stage2 sub/stage2/install2 use/cleanup/installer
|
||||||
@$(call add,FEATURES,installer)
|
@$(call add,FEATURES,install2)
|
||||||
@$(call set,INSTALL2_PACKAGES,installer-distro-$$(INSTALLER)-stage2)
|
@$(call set,INSTALL2_PACKAGES,installer-distro-$$(INSTALLER)-stage2)
|
||||||
@$(call add,INSTALL2_PACKAGES,branding-$$(BRANDING)-alterator)
|
@$(call add,INSTALL2_PACKAGES,branding-$$(BRANDING)-alterator)
|
||||||
@$(call add,MAIN_PACKAGES,branding-$$(BRANDING)-release)
|
@$(call add,MAIN_PACKAGES,branding-$$(BRANDING)-release)
|
||||||
# @$(call set,BASE_LISTS,base)
|
|
||||||
@$(call add,BASE_LISTS,$(call tags,basesystem))
|
@$(call add,BASE_LISTS,$(call tags,basesystem))
|
5
features.in/install2/install2/image-scripts.d/10bootloader
Executable file
5
features.in/install2/install2/image-scripts.d/10bootloader
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# FIXME: test run for installer-distro-altlinux-generic 6.0-alt2
|
||||||
|
# NB: grub is currently the default in ALT Linux
|
||||||
|
|
||||||
|
sed -i "s/^grub$/$GLOBAL_BASE_BOOTLOADER/" /usr/share/install2/installer-steps
|
17
features.in/install2/install2/stage2cfg.mk
Normal file
17
features.in/install2/install2/stage2cfg.mk
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
# stage2 mod: build install2 subprofile (installer "live" part)
|
||||||
|
|
||||||
|
IMAGE_PACKAGES = $(INSTALL2_PACKAGES) \
|
||||||
|
udev e2fsprogs glibc-nss
|
||||||
|
|
||||||
|
MKI_PACK_RESULTS = squash:altinst
|
||||||
|
|
||||||
|
# also removed in a cleanup hook but to spare a few cycles...
|
||||||
|
HSH_EXCLUDE_DOCS = 1
|
||||||
|
|
||||||
|
# pass downstream
|
||||||
|
GLOBAL_BASE_BOOTLOADER := $(BASE_BOOTLOADER)
|
||||||
|
|
||||||
|
debug:
|
||||||
|
@echo "** install2: IMAGE_PACKAGES: $(IMAGE_PACKAGES)"
|
||||||
|
@echo "** install2: IMAGE_PACKAGES_REGEXP: $(IMAGE_PACKAGES_REGEXP)"
|
||||||
|
@echo "** install2: CLEANUP_PACKAGES: $(CLEANUP_PACKAGES)"
|
@@ -1,25 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
# symlink default kernel iff requested but not yet done
|
|
||||||
|
|
||||||
INSTALLER_KFLAVOUR="$INFO_INSTALLER_KFLAVOUR"
|
|
||||||
if [ -n "$GLOBAL_VERBOSE" ]; then
|
|
||||||
echo "** INSTALLER_KFLAVOUR: $INSTALLER_KFLAVOUR"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# kernel-image in instrumental chroot
|
|
||||||
VMLINK=/boot/vmlinuz
|
|
||||||
|
|
||||||
# better bail out early rather than make a silly symlink
|
|
||||||
shopt -s failglob
|
|
||||||
|
|
||||||
if [ -L "$VMLINK" ]; then
|
|
||||||
echo "** $VMLINK -> $(readlink "$VMLINK")"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$INSTALLER_KFLAVOUR" ]; then
|
|
||||||
VMLINUZ="$(cd /boot; echo vmlinuz-*-$INSTALLER_KFLAVOUR-*)"
|
|
||||||
if [ -n "$VMLINUZ" ]; then
|
|
||||||
ln -sf "$VMLINUZ" "$VMLINK"
|
|
||||||
echo "** overriding $VMLINK with $VMLINUZ"
|
|
||||||
fi
|
|
||||||
fi
|
|
3
features.in/live/README
Normal file
3
features.in/live/README
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Эта фича дополняет базовый "живой" образ второй стадии
|
||||||
|
специфическими для полноценного LiveCD настройками
|
||||||
|
и скриптовыми хуками.
|
3
features.in/live/config.mk
Normal file
3
features.in/live/config.mk
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
use/live: use/stage2 sub/stage2/live
|
||||||
|
@$(call add,FEATURES,live)
|
||||||
|
@$(call add,LIVE_LISTS,$(call tags,(base || desktop) && (live || network || icewm)))
|
52
features.in/live/live/image-scripts.d/30-users
Executable file
52
features.in/live/live/image-scripts.d/30-users
Executable file
@@ -0,0 +1,52 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# * reset password for root
|
||||||
|
# * add user `altlinux' (without password)
|
||||||
|
|
||||||
|
verbose()
|
||||||
|
{
|
||||||
|
if [ -n "$GLOBAL_VERBOSE" ]; then
|
||||||
|
echo "HOOK: 30-users: $@"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
add_user()
|
||||||
|
{
|
||||||
|
verbose "Add $1 user"
|
||||||
|
local groups=
|
||||||
|
for g in users scanner audio radio proc cdrom cdwriter wheel fuse; do
|
||||||
|
if groupmod $g 2>/dev/null; then
|
||||||
|
if [ -n "$groups" ]; then
|
||||||
|
groups="$groups,$g"
|
||||||
|
else
|
||||||
|
groups="$g"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
/usr/sbin/useradd -p "" -G "$groups" "$1" ||:
|
||||||
|
chown -R "$1:auth" "/etc/tcb/$1"
|
||||||
|
chown -R "$1:$1" /home/$1
|
||||||
|
|
||||||
|
if [ -n "$GLOBAL_CRYPT_HOMES" ]; then
|
||||||
|
verbose "Set password for user $1"
|
||||||
|
echo "$1" | passwd --stdin $1
|
||||||
|
fi
|
||||||
|
|
||||||
|
sudoers="/etc/sudoers"
|
||||||
|
if [ -w "$sudoers" ]; then
|
||||||
|
verbose "Add $1 to sudoers."
|
||||||
|
echo "$1 ALL=(root) NOPASSWD:ALL" >> "$sudoers"
|
||||||
|
else
|
||||||
|
verbose "Can't find writable $sudoers file."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
verbose "has started"
|
||||||
|
|
||||||
|
verbose "Clear password for root account"
|
||||||
|
/usr/sbin/usermod -p "" root
|
||||||
|
chown -R root.auth /etc/tcb/root
|
||||||
|
|
||||||
|
add_user altlinux
|
||||||
|
|
||||||
|
verbose "finished"
|
8
features.in/live/live/stage2cfg.mk
Normal file
8
features.in/live/live/stage2cfg.mk
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# stage2 mod: livecd
|
||||||
|
|
||||||
|
IMAGE_PACKAGES = $(COMMON_PACKAGES) \
|
||||||
|
$(LIVE_PACKAGES) \
|
||||||
|
$(call map,list,$(LIVE_LISTS) $(LIVE_MAIN_GROUPS)) \
|
||||||
|
interactivesystem
|
||||||
|
|
||||||
|
MKI_PACK_RESULTS = squash:live
|
2
features.in/lowmem/README
Normal file
2
features.in/lowmem/README
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Эта фича дополняет зачистку "живой" стадии инсталятора
|
||||||
|
с тем, чтобы уменьшить её размер и требования к памяти.
|
@@ -1,4 +1,4 @@
|
|||||||
use/lowmem: use/installer
|
use/lowmem: use/install2
|
||||||
@$(call add,FEATURES,lowmem)
|
@$(call add,FEATURES,lowmem)
|
||||||
# TODO: http://www.altlinux.org/Branding/slideshow => disable?
|
# TODO: http://www.altlinux.org/Branding/slideshow => disable?
|
||||||
# also installer-feature-rm-slideshow
|
# also installer-feature-rm-slideshow
|
||||||
|
@@ -1,5 +1,2 @@
|
|||||||
Добавление memtest86+ в загрузку с образа и в устанавливаемую пакетную базу;
|
Добавление memtest86+ в загрузку с образа и в устанавливаемую пакетную базу;
|
||||||
востребовано для для инсталяторов, live/rescue.
|
востребовано для для инсталяторов, live/rescue. Интегрируется с syslinux.
|
||||||
|
|
||||||
NB: интегрируется с syslinux (проверено/работает), но _не_ требует
|
|
||||||
use/syslinux на случай, если прикрутим поддержку других загрузчиков.
|
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
use/memtest:
|
use/memtest: use/syslinux
|
||||||
@$(call add,FEATURES,memtest)
|
@$(call add,FEATURES,memtest)
|
||||||
@$(call add,COMMON_PACKAGES,memtest86+)
|
@$(call add,SYSTEM_PACKAGES,memtest86+)
|
||||||
@$(call add,SYSLINUX_CFG,memtest)
|
@$(call add,SYSLINUX_CFG,memtest)
|
||||||
|
2
features.in/powerbutton/README
Normal file
2
features.in/powerbutton/README
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
Эта фича конфигурирует поддержку управления кнопкой питания
|
||||||
|
-- выключение для ACPI, засыпание для APM (не проверялось).
|
14
features.in/powerbutton/config.mk
Normal file
14
features.in/powerbutton/config.mk
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# common
|
||||||
|
use/powerbutton:
|
||||||
|
@$(call add,COMMON_PACKAGES,installer-feature-powerbutton-stage3)
|
||||||
|
|
||||||
|
# modern power management
|
||||||
|
use/powerbutton/acpi: use/powerbutton
|
||||||
|
@$(call add,COMMON_PACKAGES,acpid acpid-events-power)
|
||||||
|
|
||||||
|
use/powerbutton/powersave: use/powerbutton/acpi
|
||||||
|
@$(call add,COMMON_PACKAGES,powersave)
|
||||||
|
|
||||||
|
# legacy power management
|
||||||
|
use/powerbutton/apm: use/powerbutton
|
||||||
|
@$(call add,COMMON_PACKAGES,apmd)
|
3
features.in/rescue/README
Normal file
3
features.in/rescue/README
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
Эта фича дополняет базовый "живой" образ второй стадии
|
||||||
|
специфическими для спасательного образа настройками
|
||||||
|
и скриптовыми хуками.
|
4
features.in/rescue/config.mk
Normal file
4
features.in/rescue/config.mk
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
use/rescue: use/stage2 sub/stage2/rescue
|
||||||
|
@$(call add,FEATURES,rescue)
|
||||||
|
@$(call add,RESCUE_LISTS,$(call tags,base && (rescue || network)))
|
||||||
|
@$(call add,RESCUE_LISTS,$(call tags,extra network))
|
21
features.in/rescue/rescue/image-scripts.d/98init-rescue
Executable file
21
features.in/rescue/rescue/image-scripts.d/98init-rescue
Executable file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# stage1 needs this <-- FIXME: duplicated in sub.in/stage2/image-scripts.d/00propagator
|
||||||
|
#mkdir -p /image
|
||||||
|
|
||||||
|
# m-p-d::profiles/rescue/image-scripts.d/999system
|
||||||
|
mv -f -- /etc/inittab.rescue /etc/inittab
|
||||||
|
|
||||||
|
# enable NFS mounts
|
||||||
|
chkconfig rpcbind on
|
||||||
|
sed -i 's,#\(RPCBIND_ARGS="-l".*\),\1,' /etc/sysconfig/rpcbind
|
||||||
|
|
||||||
|
# remove unwanted startup scripts
|
||||||
|
find /etc/rc.d/rc{2,3,4,5}.d/ -type l -name 'S*' \
|
||||||
|
-not -name '*logd' \
|
||||||
|
-not -name '*network' \
|
||||||
|
-not -name '*rpcbind' \
|
||||||
|
-not -name '*random' \
|
||||||
|
-not -name '*sysreport' \
|
||||||
|
-not -name '*udev*' \
|
||||||
|
-delete -print
|
12
features.in/rescue/rescue/stage2cfg.mk
Normal file
12
features.in/rescue/rescue/stage2cfg.mk
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
# stage2 mod: rescue "live" image
|
||||||
|
|
||||||
|
IMAGE_PACKAGES = $(COMMON_PACKAGES) \
|
||||||
|
$(RESCUE_PACKAGES) \
|
||||||
|
$(call list,$(RESCUE_LISTS)) \
|
||||||
|
interactivesystem startup-rescue
|
||||||
|
|
||||||
|
MKI_PACK_RESULTS = squash:rescue
|
||||||
|
|
||||||
|
debug:
|
||||||
|
@echo "** rescue: IMAGE_PACKAGES: $(IMAGE_PACKAGES)"
|
||||||
|
@echo "** rescue: IMAGE_PACKAGES_REGEXP: $(IMAGE_PACKAGES_REGEXP)"
|
5
features.in/stage2/README
Normal file
5
features.in/stage2/README
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
Эта фича служит для добавления в первую стадию хуков, необходимых
|
||||||
|
при наличии в stage1 ядра (что типично, но не обязательно).
|
||||||
|
|
||||||
|
Передача информации о конфигурации ядра между stage1 и stage2 также
|
||||||
|
требуется для оптимального сжатия squashfs-образа второй стадии.
|
8
features.in/stage2/config.mk
Normal file
8
features.in/stage2/config.mk
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# "1" is not a typo
|
||||||
|
use/stage2: sub/stage1
|
||||||
|
@$(call add,FEATURES,stage2)
|
||||||
|
@$(call add,STAGE1_PACKAGES,file make-initrd make-initrd-propagator)
|
||||||
|
|
||||||
|
# NB: sub/stage2 isn't used standalone but rather
|
||||||
|
# as a base for various livecd modifications
|
||||||
|
# (currently install2, live, rescue)
|
6
features.in/stage2/stage1/scripts.d/10-initrd-base
Executable file
6
features.in/stage2/stage1/scripts.d/10-initrd-base
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# prepare base make-initrd configuration for stage1
|
||||||
|
# see also http://www.altlinux.org/Make-initrd-propagator
|
||||||
|
|
||||||
|
subst 's/AUTODETECT/#AUTODETECT/' /etc/initrd.mk
|
||||||
|
echo 'FEATURES += propagator' >> /etc/initrd.mk
|
11
features.in/stage2/stage1/scripts.d/11-initrd-misc
Executable file
11
features.in/stage2/stage1/scripts.d/11-initrd-misc
Executable file
@@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# FIXME: move somewhere else
|
||||||
|
#echo 'FEATURES += nfs' >> /etc/initrd.mk
|
||||||
|
|
||||||
|
# FIXME: move to plymouth feature
|
||||||
|
#if [ -f /etc/plymouth/plymouthd.conf ];then
|
||||||
|
# subst 's/#\([T\[]\)/\1/' /etc/plymouth/plymouthd.conf
|
||||||
|
# echo 'FEATURES += plymouth' >> /etc/initrd.mk
|
||||||
|
#fi
|
||||||
|
|
15
features.in/stage2/stage1/scripts.d/80-make-initfs
Executable file
15
features.in/stage2/stage1/scripts.d/80-make-initfs
Executable file
@@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/sh -efu
|
||||||
|
# NB: /etc/initrd.mk carefully prepared by earlier scripts
|
||||||
|
|
||||||
|
kver="$(rpm -qa 'kernel-image*' --qf '%{installtime} %{version}-%{name}-%{release}\n' \
|
||||||
|
| sort -n \
|
||||||
|
| tail -n 1 \
|
||||||
|
| cut -f 2 -d ' ' \
|
||||||
|
| sed 's/kernel-image-//')"
|
||||||
|
|
||||||
|
make-initrd --no-checks -k $kver \
|
||||||
|
&& gzip < /boot/initrd-$kver.img > $(getconf LIBDIR)/propagator/initfs \
|
||||||
|
|| exit 1
|
||||||
|
|
||||||
|
[ -h /boot/vmlinuz ] || ln -s vmlinuz-$kver /boot/vmlinuz
|
||||||
|
[ -h /boot/initrd.img ] || ln -s initrd-$kver.img /boot/initrd.img
|
4
features.in/syslinux/cfg.in/15live.cfg
Normal file
4
features.in/syslinux/cfg.in/15live.cfg
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
label live
|
||||||
|
menu label ^LiveCD (no hard disk needed)
|
||||||
|
kernel alt0/vmlinuz
|
||||||
|
append initrd=alt0/full.cz live ramdisk_size=@live_size@ fastboot stagename=live showopts automatic=method:cdrom
|
@@ -1,8 +1,8 @@
|
|||||||
label linux
|
label linux
|
||||||
menu label ^Install ALT Linux
|
menu label ^Install ALT Linux
|
||||||
kernel alt0/vmlinuz
|
kernel alt0/vmlinuz
|
||||||
append initrd=alt0/full.cz changedisk vga=0x314 quiet=1 showopts automatic=method:cdrom
|
append initrd=alt0/full.cz ramdisk_size=@altinst_size@ changedisk vga=0x314 quiet=1 showopts automatic=method:cdrom
|
||||||
label noapic
|
label noapic
|
||||||
menu label ^Failsafe install
|
menu label ^Failsafe install
|
||||||
kernel alt0/vmlinuz
|
kernel alt0/vmlinuz
|
||||||
append initrd=alt0/full.cz changedisk showopts nolapic noapic
|
append initrd=alt0/full.cz ramdisk_size=@altinst_size@ changedisk showopts nolapic noapic
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
label rescue
|
label rescue
|
||||||
menu label ^Rescue LiveCD
|
menu label ^Rescue LiveCD
|
||||||
kernel alt0/vmlinuz
|
kernel alt0/vmlinuz
|
||||||
append initrd=alt0/full.cz live fastboot stagename=rescue
|
append initrd=alt0/full.cz live ramdisk_size=@rescue_size@ fastboot stagename=rescue showopts automatic=method:cdrom
|
||||||
|
4
features.in/syslinux/cfg.in/85dos.cfg
Normal file
4
features.in/syslinux/cfg.in/85dos.cfg
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
label freedos
|
||||||
|
menu label Live ^FreeDOS
|
||||||
|
kernel memdisk
|
||||||
|
append initrd=freedos.img
|
@@ -18,9 +18,10 @@ $(warning no syslinux ui configured, default is plain text prompt)
|
|||||||
SYSLINUX_UI := prompt
|
SYSLINUX_UI := prompt
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# SUBPROFILES are considered SYSLINUX_CFG too;
|
# SUBPROFILES are considered SYSLINUX_CFG too
|
||||||
|
# (note these can appear like stage2/live);
|
||||||
# 01defaults.cfg is included indefinitely
|
# 01defaults.cfg is included indefinitely
|
||||||
SYSLINUX_CFG := $(SYSLINUX_CFG) $(SUBPROFILES) defaults
|
SYSLINUX_CFG := $(SYSLINUX_CFG) $(notdir $(SUBPROFILES)) defaults
|
||||||
|
|
||||||
### have to operate BUILDDIR, not pretty...
|
### have to operate BUILDDIR, not pretty...
|
||||||
DSTDIR := $(BUILDDIR)/stage1/files/syslinux/.in
|
DSTDIR := $(BUILDDIR)/stage1/files/syslinux/.in
|
||||||
|
13
features.in/syslinux/scripts.d/20-propagator-ramdisk
Executable file
13
features.in/syslinux/scripts.d/20-propagator-ramdisk
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/sh -x
|
||||||
|
# postprocess isolinux configuration
|
||||||
|
# when the image sizes are finally known
|
||||||
|
|
||||||
|
cd "$WORKDIR"
|
||||||
|
|
||||||
|
# apply size census while looking for potential squashfs images
|
||||||
|
find -maxdepth 1 -type f -size +1M \
|
||||||
|
| sed 's,^\./,,' \
|
||||||
|
| while read image; do
|
||||||
|
size="$[ $(stat -c%s "$image") / 1024 + 1 ]"
|
||||||
|
sed -i "s,@${image}_size@,$size," syslinux/*.cfg
|
||||||
|
done
|
@@ -34,3 +34,6 @@ grep -hv '^#' .in/[0-9][0-9]*.cfg > "$BOOTLOADER.cfg"
|
|||||||
|
|
||||||
# snippets are not going into the actual image
|
# snippets are not going into the actual image
|
||||||
if test "$DEBUG" != 2; then rm -r .in/; fi
|
if test "$DEBUG" != 2; then rm -r .in/; fi
|
||||||
|
|
||||||
|
# NB: there will be final macro expansion based on actual image sizes
|
||||||
|
# (done by ../../scripts.d/10-propagator-ramdisk)
|
||||||
|
1
features.in/x11/README
Normal file
1
features.in/x11/README
Normal file
@@ -0,0 +1 @@
|
|||||||
|
Эта фича добавляет базовую поддержку графической системы X11.
|
10
features.in/x11/config.mk
Normal file
10
features.in/x11/config.mk
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
use/x11/xorg:
|
||||||
|
@$(call add,BASE_LISTS,xorg)
|
||||||
|
|
||||||
|
### strictly speaking, runlevel5 should require a *dm, not vice versa
|
||||||
|
use/x11/runlevel5: use/x11/xorg
|
||||||
|
@$(call add,BASE_PACKAGES,installer-feature-runlevel5-stage3)
|
||||||
|
|
||||||
|
### xdm: see also #23108
|
||||||
|
use/x11/xdm: use/x11/runlevel5
|
||||||
|
@$(call add,BASE_PACKAGES,xdm installer-feature-no-xconsole)
|
@@ -15,6 +15,7 @@ endef
|
|||||||
# add() just appends an additive rule...
|
# add() just appends an additive rule...
|
||||||
add = $(and $(1),$(2),$(add_body))
|
add = $(and $(1),$(2),$(add_body))
|
||||||
define add_body
|
define add_body
|
||||||
|
$(if $(filter GLOBAL_% INFO_%,$(1)),$(warning add,$(1) might be a problem)) \
|
||||||
{ $(log_body); \
|
{ $(log_body); \
|
||||||
printf '%s += %s\n' '$(1)' '$(2)' >> "$(CONFIG)"; }
|
printf '%s += %s\n' '$(1)' '$(2)' >> "$(CONFIG)"; }
|
||||||
endef
|
endef
|
||||||
|
1
image.in/.gitignore
vendored
Normal file
1
image.in/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
build.log
|
@@ -11,7 +11,9 @@ include $(GLOBAL_BUILDDIR)/functions.mk
|
|||||||
include $(GLOBAL_BUILDDIR)/distcfg.mk
|
include $(GLOBAL_BUILDDIR)/distcfg.mk
|
||||||
include $(MKIMAGE_PREFIX)/config.mk
|
include $(MKIMAGE_PREFIX)/config.mk
|
||||||
|
|
||||||
SUBDIRS = $(SUBPROFILES)
|
# for complex-specified subprofiles like stage2/live,
|
||||||
|
# take the latter part
|
||||||
|
SUBDIRS = $(notdir $(SUBPROFILES))
|
||||||
|
|
||||||
# "main" subprofile needs genbasedir
|
# "main" subprofile needs genbasedir
|
||||||
CHROOT_PACKAGES = apt-utils
|
CHROOT_PACKAGES = apt-utils
|
||||||
@@ -30,33 +32,35 @@ else
|
|||||||
GLOBAL_HSH_APT_CONFIG = $(APTCONF)
|
GLOBAL_HSH_APT_CONFIG = $(APTCONF)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Metadata/ needed only for installers (and not for e.g. syslinux.iso)
|
||||||
|
ifneq "$(STAGE1_KFLAVOUR)$(KFLAVOURS)" ""
|
||||||
|
METADATA = metadata
|
||||||
|
endif
|
||||||
|
|
||||||
include $(MKIMAGE_PREFIX)/targets.mk
|
include $(MKIMAGE_PREFIX)/targets.mk
|
||||||
|
|
||||||
all: prep copy-subdirs copy-tree run-scripts pack-image
|
all: $(GLOBAL_DEBUG) prep copy-subdirs copy-tree run-scripts pack-image \
|
||||||
|
$(GLOBAL_CLEAN_WORKDIR)
|
||||||
|
|
||||||
|
prep: $(GLOBAL_DEBUG) dot-disk $(METADATA) $(IMAGEDIR)
|
||||||
|
|
||||||
# Metadata/ needed only for installer (and not for e.g. syslinux.iso)
|
|
||||||
ifeq "$(INSTALLER_KFLAVOUR)$(KFLAVOURS)" ""
|
|
||||||
metadata:
|
|
||||||
@echo "** skipping metadata target, no stage1 kernel installed"
|
|
||||||
else
|
|
||||||
metadata: dot-base
|
metadata: dot-base
|
||||||
@mkdir -p files/Metadata
|
@mkdir -p files/Metadata
|
||||||
@rm -f files/Metadata/pkg-groups.tar
|
@rm -f files/Metadata/pkg-groups.tar
|
||||||
# see also alterator-pkg (backend3/pkg-install); we only tar up what's up to it
|
# see also alterator-pkg (backend3/pkg-install); we only tar up what's up to it
|
||||||
@tar -cvf files/Metadata/pkg-groups.tar -C $(PKGDIR) \
|
@tar -cvf files/Metadata/pkg-groups.tar -C $(PKGDIR) \
|
||||||
$$(echo $(call list,$(GROUPS) .base) \
|
$$(echo $(call list,$(MAIN_GROUPS) .base) \
|
||||||
$(call group,$(GROUPS)) \
|
$(call group,$(MAIN_GROUPS)) \
|
||||||
| sed 's,$(PKGDIR)/*,,g')
|
| sed 's,$(PKGDIR)/*,,g')
|
||||||
endif
|
|
||||||
|
|
||||||
dot-base:
|
dot-base:
|
||||||
@echo -e "# auto-added in image.in/Makefile" >> $(call list,.base)
|
@{ \
|
||||||
@echo "$(call kpackages,$(KMODULES),$(KFLAVOURS))" >> $(call list,.base)
|
echo -e "\n## added by image.in/Makefile"; \
|
||||||
|
echo "$(call kpackages,$(KMODULES),$(KFLAVOURS))"; \
|
||||||
prep: $(GLOBAL_DEBUG) dot-disk metadata $(IMAGEDIR)
|
} >> $(call list,.base)
|
||||||
|
|
||||||
$(IMAGEDIR):
|
$(IMAGEDIR):
|
||||||
mkdir -p "$(IMAGEDIR)"
|
@mkdir -p "$(IMAGEDIR)"
|
||||||
|
|
||||||
# specified only for the final image, not for the subparts
|
# specified only for the final image, not for the subparts
|
||||||
pack-image: OUTDIR = $(IMAGEDIR)
|
pack-image: OUTDIR = $(IMAGEDIR)
|
||||||
@@ -71,7 +75,8 @@ dot-disk:
|
|||||||
@echo "ALT Linux based" >files/.disk/info
|
@echo "ALT Linux based" >files/.disk/info
|
||||||
@echo "$(ARCH)" >files/.disk/arch
|
@echo "$(ARCH)" >files/.disk/arch
|
||||||
@echo "$(DATE)" >files/.disk/date
|
@echo "$(DATE)" >files/.disk/date
|
||||||
@type -t git >&/dev/null && ( \
|
@if type -t git >&/dev/null; then \
|
||||||
cd $(TOPDIR) && \
|
( cd $(TOPDIR) && \
|
||||||
git show-ref --head -d -s -- HEAD 2>/dev/null; \
|
git show-ref --head -ds -- HEAD ) \
|
||||||
) >files/.disk/commit
|
>files/.disk/commit 2>/dev/null; \
|
||||||
|
fi
|
||||||
|
@@ -1,7 +1,6 @@
|
|||||||
Этот каталог копируется из метапрофиля в профиль "как есть"
|
Этот каталог копируется из метапрофиля в профиль "как есть"
|
||||||
и формирует "затравку", собирающую собственно образ из результатов
|
и формирует "затравку", собирающую собственно образ из результатов
|
||||||
работы индивидуальных субпрофилей (в т.ч. стадий инсталятора,
|
работы индивидуальных субпрофилей (см. ../sub.in/).
|
||||||
см. ../sub.in/).
|
|
||||||
|
|
||||||
Содержимое files/ копируется в корень образа.
|
Содержимое files/ копируется в корень образа.
|
||||||
|
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
# TODO: invent some way to remove this inter-subprofile thing
|
# TODO: invent some way to remove this inter-subprofile thing
|
||||||
|
|
||||||
rm -vf $WORKDIR/{squashcfg.mk,initfs}
|
rm -vf $WORKDIR/{squashcfg.mk,initfs,.gitignore}
|
||||||
|
@@ -1,4 +1,5 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
# FIXME: bring to common style
|
||||||
|
|
||||||
verbose()
|
verbose()
|
||||||
{
|
{
|
||||||
|
14
image.in/vars.mk
Normal file
14
image.in/vars.mk
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# dump interesting variables' effective values;
|
||||||
|
# based on http://stackoverflow.com/questions/7117978
|
||||||
|
|
||||||
|
SPAM := $(.VARIABLES) DISTCFG_MK
|
||||||
|
-include distcfg.mk
|
||||||
|
HAM := $(.VARIABLES)
|
||||||
|
|
||||||
|
.PHONY: dump-vars
|
||||||
|
|
||||||
|
dump-vars:
|
||||||
|
$(foreach v, \
|
||||||
|
$(filter-out $(SPAM) SPAM,$(sort $(HAM))), \
|
||||||
|
$(info $(v) = $($(v))))
|
||||||
|
@:
|
@@ -4,9 +4,8 @@
|
|||||||
sub/%:
|
sub/%:
|
||||||
@$(call add,SUBPROFILES,$(@:sub/%=%))
|
@$(call add,SUBPROFILES,$(@:sub/%=%))
|
||||||
|
|
||||||
sub/install2: sub/stage1
|
# FIXME: maybe syslinux feature belongs to distro/.init?
|
||||||
|
boot/%: distro/.init use/syslinux
|
||||||
boot/%: distro/.init
|
|
||||||
@$(call set,BOOTLOADER,$*)
|
@$(call set,BOOTLOADER,$*)
|
||||||
|
|
||||||
# initalize config from scratch, put some sane defaults in
|
# initalize config from scratch, put some sane defaults in
|
||||||
|
4
log.mk
4
log.mk
@@ -11,6 +11,8 @@ BUILDLOG ?= $(BUILDDIR)/build.log
|
|||||||
|
|
||||||
# LOG holds a postprocessor
|
# LOG holds a postprocessor
|
||||||
ifdef DEBUG
|
ifdef DEBUG
|
||||||
|
# 1) makefile target; 2) also passed to script hooks
|
||||||
|
GLOBAL_DEBUG := debug
|
||||||
GLOBAL_VERBOSE ?= $(DEBUG)
|
GLOBAL_VERBOSE ?= $(DEBUG)
|
||||||
ifeq (2,$(DEBUG))
|
ifeq (2,$(DEBUG))
|
||||||
SHELL += -x
|
SHELL += -x
|
||||||
@@ -19,8 +21,6 @@ LOG = >>$(BUILDLOG) 2>&1
|
|||||||
else
|
else
|
||||||
MAKE += -s
|
MAKE += -s
|
||||||
LOG = 2>>$(BUILDLOG) >/dev/null
|
LOG = 2>>$(BUILDLOG) >/dev/null
|
||||||
# 1) makefile target; 2) also passed to script hooks
|
|
||||||
GLOBAL_DEBUG := debug
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
DATE = $(shell date +%Y%m%d)
|
DATE = $(shell date +%Y%m%d)
|
||||||
|
@@ -5,6 +5,7 @@ ifndef BUILDDIR
|
|||||||
$(error BUILDDIR not defined)
|
$(error BUILDDIR not defined)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# sequential execution, no reason to haste
|
||||||
all:
|
all:
|
||||||
@for dir in lists groups; do \
|
@for dir in lists groups; do \
|
||||||
$(MAKE) -C $$dir; \
|
$(MAKE) -C $$dir; \
|
||||||
|
@@ -10,15 +10,15 @@ SUFFIX := pkg/groups
|
|||||||
TARGET := $(BUILDDIR)/$(SUFFIX)
|
TARGET := $(BUILDDIR)/$(SUFFIX)
|
||||||
|
|
||||||
all: $(GLOBAL_DEBUG)
|
all: $(GLOBAL_DEBUG)
|
||||||
@if [ -n "$(GROUPS)" ]; then \
|
@if [ -n "$(MAIN_GROUPS)" ]; then \
|
||||||
mkdir -p $(TARGET) && \
|
mkdir -p $(TARGET) && \
|
||||||
cp -at $(TARGET) -- $(addsuffix .directory,$(GROUPS)); \
|
cp -at $(TARGET) -- $(addsuffix .directory,$(MAIN_GROUPS)); \
|
||||||
type -t git >&/dev/null && \
|
type -t git >&/dev/null && \
|
||||||
cd $(TARGET) && \
|
cd $(TARGET) && \
|
||||||
git add . && \
|
git add . && \
|
||||||
git commit -qam "$(SUFFIX)"; \
|
git commit -qam "requested $(SUFFIX) copied over"; \
|
||||||
cd - >&/dev/null; \
|
cd - >&/dev/null; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
debug:
|
debug:
|
||||||
@echo "** GROUPS: $(GROUPS)"
|
@echo "** MAIN_GROUPS: $(MAIN_GROUPS)"
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
Этот каталог содержит описания групп, копируемые из метапрофиля
|
Этот каталог содержит описания групп, копируемые из метапрофиля
|
||||||
в создаваемый профиль по необходимости (только фигурирующие в
|
в создаваемый профиль по необходимости (только фигурирующие в
|
||||||
списке, которым является значение переменной GROUPS).
|
списке, которым является значение переменной MAIN_GROUPS).
|
||||||
|
|
||||||
В данный момент перенесено почти 1:1 из mkimage-profiles-desktop,
|
В данный момент перенесено почти 1:1 из mkimage-profiles-desktop,
|
||||||
требует увязки с ../lists/tagged/.
|
требует увязки с ../lists/tagged/.
|
||||||
|
@@ -10,38 +10,47 @@ SUFFIX := pkg/lists
|
|||||||
TARGET := $(BUILDDIR)/$(SUFFIX)
|
TARGET := $(BUILDDIR)/$(SUFFIX)
|
||||||
|
|
||||||
all: $(TARGET) $(GLOBAL_DEBUG)
|
all: $(TARGET) $(GLOBAL_DEBUG)
|
||||||
# env | sort -u | grep _LISTS | xargs cp
|
@# env | sort -u | grep _LISTS | xargs cp
|
||||||
@$(foreach V, \
|
@$(foreach V, \
|
||||||
$(filter %_LISTS,$(sort $(.VARIABLES))), \
|
$(filter %_LISTS,$(sort $(.VARIABLES))), \
|
||||||
$(if $(filter environment% file,$(origin $V)),\
|
$(if $(filter environment% file,$(origin $V)),\
|
||||||
$(shell cp --parents -at $(TARGET) \
|
$(shell cp --parents -at $(TARGET) \
|
||||||
-- $(value $V))))
|
-- $(value $V))))
|
||||||
# construct .base packagelist for alterator-pkg
|
@# construct .base packagelist for alterator-pkg
|
||||||
@( \
|
@{ \
|
||||||
echo "### generated via pkg.in/lists/Makefile" && \
|
echo "## generated by pkg.in/lists/Makefile"; \
|
||||||
echo "### BASE_LISTS" && \
|
if [ -n "$(BRANDING)" ]; then \
|
||||||
cat $(BASE_LISTS) /dev/null && \
|
echo "branding-$(BRANDING)-release"; \
|
||||||
echo "### branding" && \
|
fi; \
|
||||||
echo "branding-$(BRANDING)-release" && \
|
if [ -n "$(SYSTEM_PACKAGES)" ]; then \
|
||||||
echo "### COMMON_PACKAGES" && \
|
echo -e "\n## SYSTEM_PACKAGES\n$(SYSTEM_PACKAGES)"; \
|
||||||
echo "$(COMMON_PACKAGES)" && \
|
fi; \
|
||||||
echo "### BASE_PACKAGES" && \
|
if [ -n "$(COMMON_PACKAGES)" ]; then \
|
||||||
echo "$(BASE_PACKAGES)" \
|
echo -e "\n## COMMON_PACKAGES\n$(COMMON_PACKAGES)"; \
|
||||||
) | sed -re '/^[^[:space:]#]/ s/[[:space:]]+/\n/g' >$(TARGET)/.base
|
fi; \
|
||||||
@[ -z $(GROUPS) ] || cp -at $(TARGET) $(GROUPS)
|
if [ -n "$(BASE_PACKAGES)" ]; then \
|
||||||
@type -t git >&/dev/null && \
|
echo -e "\n## BASE_PACKAGES\n$(BASE_PACKAGES)"; \
|
||||||
cd $(TARGET) && \
|
fi; \
|
||||||
git add . && \
|
if [ -n "$(BASE_LISTS)" ]; then \
|
||||||
git commit -qam "$(SUFFIX)";
|
echo -e "\n## BASE_LISTS"; cat $(BASE_LISTS); \
|
||||||
|
fi; \
|
||||||
|
} | sed -re '/^[^[:space:]#]/ s/[[:space:]]+/\n/g' >$(TARGET)/.base
|
||||||
|
@if [ -n "$(MAIN_GROUPS)" ]; then \
|
||||||
|
cp -at $(TARGET) -- $(MAIN_GROUPS); \
|
||||||
|
fi
|
||||||
|
@if type -t git >&/dev/null; then \
|
||||||
|
cd $(TARGET) && \
|
||||||
|
git add . && \
|
||||||
|
git commit -qam "requested $(SUFFIX) copied over"; \
|
||||||
|
fi
|
||||||
|
|
||||||
# do beforehand as foreach gets expanded before recipe execution
|
# do beforehand as foreach gets expanded before recipe execution
|
||||||
$(TARGET):
|
$(TARGET):
|
||||||
@mkdir -p $(TARGET)
|
@mkdir -p $(TARGET)
|
||||||
|
|
||||||
|
# figure out *_LISTS variables and print them out nicely
|
||||||
debug:
|
debug:
|
||||||
@$(foreach V, \
|
@echo -e $(foreach V, \
|
||||||
$(filter %_LISTS,$(sort $(.VARIABLES))), \
|
$(filter %_LISTS,$(sort $(.VARIABLES))), \
|
||||||
$(if $(filter environment% file,$(origin $V)),\
|
$(if $(filter environment% file,$(origin $V)),\
|
||||||
$(warning $V=$(value $V))))
|
$(shell echo '\\n"**"' $V: $(value $V)))) '\n'
|
||||||
@echo "** LISTS: -- see above"
|
|
||||||
@echo "** GROUPS: $(GROUPS)"
|
|
||||||
|
@@ -3,10 +3,8 @@
|
|||||||
имён списков в переменных *_LISTS, см. реализацию в Makefile).
|
имён списков в переменных *_LISTS, см. реализацию в Makefile).
|
||||||
|
|
||||||
Список .base является особенным (формирует базовую систему,
|
Список .base является особенным (формирует базовую систему,
|
||||||
см. http://www.altlinux.org/Alterator-pkg) и копируется безусловно.
|
см. http://www.altlinux.org/Alterator-pkg); он создаётся из
|
||||||
Это предполагается изменить в будущем -- возможно, генерацией .base
|
содержимого ряда переменных (см. Makefile).
|
||||||
по тегам.
|
|
||||||
|
|
||||||
Подкаталог tagged/ стоит рассматривать как экспериментальный,
|
Подкаталог tagged/ стоит рассматривать как экспериментальный,
|
||||||
хотя весь необходимый код уже на месте -- см. bin/tags2lists
|
но находящий всё более широкое практическое использование.
|
||||||
и distro.mk (в корневом каталоге).
|
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
Этот каталог содержит тегированные списки; на данный момент
|
Этот каталог содержит тегированные списки; на данный момент
|
||||||
реализация (bin/tags2lists) требует, чтобы каждый тег был
|
реализация (tags2lists) требует, чтобы каждый из тегов был
|
||||||
отдельным словом, состоящим из символов из набора a-zA-Z0-9_
|
отдельным словом, состоящим из символов из набора a-zA-Z0-9_
|
||||||
(внимание: не используйте в слове "-"); рекомендуется
|
(внимание: не используйте в слове "-"); рекомендуется
|
||||||
разделять слова "+" или ",".
|
разделять слова "+" или "," (стандарт ещё не устоялся).
|
||||||
|
|
||||||
Предположительное применение: дополнение функциональности,
|
Предположительное применение: дополнение функциональности,
|
||||||
заданной статически (наследственно или явно), факультативным
|
заданной статически (наследственно или явно), факультативным
|
||||||
|
4
pkg.in/lists/tagged/base+live
Normal file
4
pkg.in/lists/tagged/base+live
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
wget
|
||||||
|
apt
|
||||||
|
vim-console
|
||||||
|
mc
|
2
pkg.in/lists/tagged/base+network
Normal file
2
pkg.in/lists/tagged/base+network
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
etcnet
|
||||||
|
dhcpcd
|
1
pkg.in/lists/tagged/base+pkg
Normal file
1
pkg.in/lists/tagged/base+pkg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
apt
|
126
pkg.in/lists/tagged/base+rescue
Normal file
126
pkg.in/lists/tagged/base+rescue
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
### Startup
|
||||||
|
rootfiles
|
||||||
|
sysvinit
|
||||||
|
interactivesystem
|
||||||
|
startup
|
||||||
|
startup-rescue
|
||||||
|
|
||||||
|
udev
|
||||||
|
|
||||||
|
### Common
|
||||||
|
coreutils
|
||||||
|
glibc-locales
|
||||||
|
glibc-nss
|
||||||
|
glibc-utils
|
||||||
|
lilo
|
||||||
|
man
|
||||||
|
man-pages
|
||||||
|
sysfsutils
|
||||||
|
sysklogd
|
||||||
|
util-linux
|
||||||
|
|
||||||
|
### CPU utils
|
||||||
|
cpuburn
|
||||||
|
x86info
|
||||||
|
|
||||||
|
### Disk utils
|
||||||
|
bonnie++
|
||||||
|
cfdisk
|
||||||
|
ddrescue
|
||||||
|
disktype
|
||||||
|
evms
|
||||||
|
evms-ncurses
|
||||||
|
gpart
|
||||||
|
hdparm
|
||||||
|
lvm2
|
||||||
|
mdadm
|
||||||
|
ms-sys
|
||||||
|
parted
|
||||||
|
sdparm
|
||||||
|
sfdisk
|
||||||
|
smartmontools
|
||||||
|
testdisk
|
||||||
|
mtools
|
||||||
|
partimage
|
||||||
|
|
||||||
|
### Applications
|
||||||
|
binutils
|
||||||
|
dmidecode
|
||||||
|
hexedit
|
||||||
|
pciutils
|
||||||
|
procps
|
||||||
|
quota
|
||||||
|
shadow-suite
|
||||||
|
sharutils
|
||||||
|
time
|
||||||
|
openssl
|
||||||
|
|
||||||
|
### Applications/Archiving
|
||||||
|
arj
|
||||||
|
bzip2
|
||||||
|
gzip
|
||||||
|
unrar
|
||||||
|
unzip
|
||||||
|
zip
|
||||||
|
|
||||||
|
### Applications/Editors
|
||||||
|
vim-console
|
||||||
|
|
||||||
|
### Applications/File
|
||||||
|
findutils
|
||||||
|
file
|
||||||
|
less
|
||||||
|
mtools
|
||||||
|
|
||||||
|
### Filesystem utils
|
||||||
|
dosfstools
|
||||||
|
e2fsprogs
|
||||||
|
jfsprogs
|
||||||
|
ntfs-3g
|
||||||
|
recover
|
||||||
|
recoverdm
|
||||||
|
reiserfsprogs
|
||||||
|
xfsprogs
|
||||||
|
btrfs-progs
|
||||||
|
ext3grep
|
||||||
|
|
||||||
|
### Applications/Networking
|
||||||
|
arpwatch
|
||||||
|
elinks
|
||||||
|
hostinfo
|
||||||
|
iftop
|
||||||
|
iproute2
|
||||||
|
iptables
|
||||||
|
iputils
|
||||||
|
lftp
|
||||||
|
mailx
|
||||||
|
netcat
|
||||||
|
netlist
|
||||||
|
nfs-utils
|
||||||
|
ngrep
|
||||||
|
nmap
|
||||||
|
openssh-clients
|
||||||
|
openssh-server
|
||||||
|
p0f
|
||||||
|
postfix
|
||||||
|
rsync
|
||||||
|
scanssh
|
||||||
|
#stunnel
|
||||||
|
tcpdump
|
||||||
|
tcptraceroute
|
||||||
|
telnet
|
||||||
|
traceroute
|
||||||
|
wget
|
||||||
|
whois
|
||||||
|
|
||||||
|
### Applications/Shells
|
||||||
|
zsh
|
||||||
|
ash
|
||||||
|
bash
|
||||||
|
bc
|
||||||
|
gpm
|
||||||
|
mc
|
||||||
|
|
||||||
|
### Development/Debuggers
|
||||||
|
strace
|
||||||
|
sysstat
|
3
pkg.in/lists/tagged/base+security
Normal file
3
pkg.in/lists/tagged/base+security
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
sudo
|
||||||
|
su
|
||||||
|
passwd
|
@@ -1,4 +1,3 @@
|
|||||||
alterator-grub
|
|
||||||
alterator-root
|
alterator-root
|
||||||
alterator-users
|
alterator-users
|
||||||
alterator-net-eth
|
alterator-net-eth
|
||||||
|
4
pkg.in/lists/tagged/desktop+live
Normal file
4
pkg.in/lists/tagged/desktop+live
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
xdm
|
||||||
|
xinit
|
||||||
|
xinitrc
|
||||||
|
installer-feature-runlevel5-stage3
|
1
pkg.in/lists/tagged/desktop,icewm
Normal file
1
pkg.in/lists/tagged/desktop,icewm
Normal file
@@ -0,0 +1 @@
|
|||||||
|
icewm
|
2
pkg.in/lists/tagged/extra+network
Normal file
2
pkg.in/lists/tagged/extra+network
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
etcnet-full
|
||||||
|
net-tools
|
5
pkg.in/lists/tagged/rescue+live
Normal file
5
pkg.in/lists/tagged/rescue+live
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
fdisk
|
||||||
|
parted
|
||||||
|
mdadm
|
||||||
|
rsync
|
||||||
|
etcnet-full
|
@@ -1,7 +1,6 @@
|
|||||||
# network tools
|
# network tools
|
||||||
curl
|
curl
|
||||||
elinks
|
elinks
|
||||||
etcnet
|
|
||||||
hostinfo
|
hostinfo
|
||||||
iptables
|
iptables
|
||||||
iputils
|
iputils
|
46
pkg.in/lists/xorg
Normal file
46
pkg.in/lists/xorg
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
xorg-server
|
||||||
|
xorg-drv-ati
|
||||||
|
xorg-drv-cirrus
|
||||||
|
xorg-drv-evdev
|
||||||
|
xorg-drv-fbdev
|
||||||
|
xorg-drv-intel
|
||||||
|
xorg-drv-joystick
|
||||||
|
xorg-drv-mga
|
||||||
|
xorg-drv-multimedia
|
||||||
|
xorg-drv-nouveau
|
||||||
|
xorg-drv-nv
|
||||||
|
#I586_ONLY@xorg-drv-s3
|
||||||
|
#I586_ONLY@xorg-drv-s3virge
|
||||||
|
#I586_ONLY@xorg-drv-savage
|
||||||
|
xorg-drv-sis
|
||||||
|
xorg-drv-synaptics
|
||||||
|
xorg-drv-vesa
|
||||||
|
xorg-drv-video
|
||||||
|
xorg-drv-void
|
||||||
|
xorg-drv-wacom
|
||||||
|
xorg-drv-qxl
|
||||||
|
|
||||||
|
# for those who need these
|
||||||
|
xorg-drv-keyboard
|
||||||
|
xorg-drv-mouse
|
||||||
|
|
||||||
|
#xorg-dri-*
|
||||||
|
|
||||||
|
xauth
|
||||||
|
xorg-utils
|
||||||
|
#xorg-extensions*
|
||||||
|
xinit
|
||||||
|
|
||||||
|
# TODO: split these into a separate packagelist or no sense?
|
||||||
|
#wm-select
|
||||||
|
|
||||||
|
fonts-ttf-dejavu
|
||||||
|
fonts-bitmap-terminus
|
||||||
|
fonts-otf-stix
|
||||||
|
fonts-ttf-droid
|
||||||
|
x-cursor-theme-jimmac
|
||||||
|
|
||||||
|
menu-icons-default
|
||||||
|
|
||||||
|
# :-/
|
||||||
|
#*-debuginfo-
|
50
profile.mk
50
profile.mk
@@ -1,50 +1,68 @@
|
|||||||
# this makefile is designed to be included in toplevel one
|
# this makefile is designed to be included in toplevel one
|
||||||
|
|
||||||
|
SYMLINK = build
|
||||||
|
|
||||||
# this could have come from environment;
|
# this could have come from environment;
|
||||||
# if not, can be symlinked if r/w, or made anew
|
# if not, can be symlinked if r/w, or made anew
|
||||||
# NB: immediate assignment
|
# NB: immediate assignment matters
|
||||||
|
# NB: PATH has no effect here
|
||||||
ifndef BUILDDIR
|
ifndef BUILDDIR
|
||||||
BUILDDIR := $(shell [ -s build ] \
|
BUILDDIR := $(shell [ -s "$(SYMLINK)" ] \
|
||||||
&& realpath build \
|
&& realpath "$(SYMLINK)" \
|
||||||
|| bin/mktmpdir mkimage-profiles.build)
|
|| bin/mktmpdir mkimage-profiles.build)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# holds a postprocessor; shell test executes in particular situation
|
|
||||||
# NB: not exported, for toplevel use only
|
|
||||||
SHORTEN = $(shell [ "$(DEBUG)" != 2 -a -s build ] \
|
|
||||||
&& echo "| sed 's,$(BUILDDIR),build,'")
|
|
||||||
|
|
||||||
# even smart caching only hurts when every build goes from scratch
|
# even smart caching only hurts when every build goes from scratch
|
||||||
NO_CACHE ?= 1
|
NO_CACHE ?= 1
|
||||||
|
|
||||||
export BUILDDIR NO_CACHE
|
PATH := $(CURDIR)/bin:$(PATH)
|
||||||
|
|
||||||
|
export BUILDDIR NO_CACHE PATH
|
||||||
|
|
||||||
|
# holds a postprocessor; shell test executes in particular situation
|
||||||
|
# NB: not exported, for toplevel use only
|
||||||
|
SHORTEN = $(shell [ "$(DEBUG)" != 2 -a -s "$(SYMLINK)" ] \
|
||||||
|
&& echo "| sed 's,$(BUILDDIR),$(SYMLINK),'")
|
||||||
|
|
||||||
# step 1: initialize the off-tree mkimage profile (BUILDDIR)
|
# step 1: initialize the off-tree mkimage profile (BUILDDIR)
|
||||||
profile/init: distclean
|
profile/init: distclean
|
||||||
@echo -n "** initializing BUILDDIR: "
|
@echo -n "** initializing BUILDDIR: "
|
||||||
@rsync -qaH --delete image.in/ "$(BUILDDIR)"/
|
@rsync -qaH --delete image.in/ "$(BUILDDIR)"/
|
||||||
@:> "$(BUILDDIR)"/distcfg.mk
|
@{ \
|
||||||
|
echo "ifndef DISTCFG_MK"; \
|
||||||
|
echo "DISTCFG_MK = 1"; \
|
||||||
|
} > "$(BUILDDIR)"/distcfg.mk
|
||||||
@{ \
|
@{ \
|
||||||
git show-ref --head -d -s -- HEAD && \
|
git show-ref --head -d -s -- HEAD && \
|
||||||
git status -s && \
|
git status -s && \
|
||||||
echo; \
|
echo; \
|
||||||
} 2>/dev/null >> "$(BUILDLOG)"
|
} $(LOG)
|
||||||
@mkdir "$(BUILDDIR)"/.mki # mkimage toplevel marker
|
@mkdir "$(BUILDDIR)"/.mki # mkimage toplevel marker
|
||||||
@type -t git >&/dev/null && \
|
@type -t git >&/dev/null && \
|
||||||
cd $(BUILDDIR) && \
|
cd $(BUILDDIR) && \
|
||||||
git init -q && \
|
git init -q && \
|
||||||
git add . && \
|
git add . && \
|
||||||
git commit -qam 'init'
|
git commit -qam 'distribution profile initialized'
|
||||||
@rm -f build && \
|
@rm -f "$(SYMLINK)" && \
|
||||||
if [ -w . ]; then \
|
if [ -w . ]; then \
|
||||||
ln -sf "$(BUILDDIR)" build && \
|
ln -sf "$(BUILDDIR)" "$(SYMLINK)" && \
|
||||||
echo "build/"; \
|
echo "$(SYMLINK)/"; \
|
||||||
else \
|
else \
|
||||||
echo "$(BUILDDIR)/"; \
|
echo "$(BUILDDIR)/"; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
profile/finalize: distro/.rc
|
||||||
|
@echo "endif" >> "$(BUILDDIR)"/distcfg.mk
|
||||||
|
|
||||||
|
# requires already formed distcfg.mk for useful output
|
||||||
|
profile/dump-vars:
|
||||||
|
@if [ -s "$(SYMLINK)" ]; then \
|
||||||
|
$(MAKE) --no-print-directory -C "$(SYMLINK)/" -f vars.mk; \
|
||||||
|
echo; \
|
||||||
|
fi $(LOG)
|
||||||
|
|
||||||
# step 3 entry point: copy the needed parts into BUILDDIR
|
# step 3 entry point: copy the needed parts into BUILDDIR
|
||||||
profile/populate: profile/init distro/.rc
|
profile/populate: profile/init profile/finalize profile/dump-vars
|
||||||
@for dir in sub.in features.in pkg.in; do \
|
@for dir in sub.in features.in pkg.in; do \
|
||||||
$(MAKE) -C $$dir $(LOG); \
|
$(MAKE) -C $$dir $(LOG); \
|
||||||
done
|
done
|
||||||
|
@@ -6,20 +6,26 @@ endif
|
|||||||
|
|
||||||
include $(BUILDDIR)/distcfg.mk
|
include $(BUILDDIR)/distcfg.mk
|
||||||
|
|
||||||
|
# if the subprofile is specified in src/dst notation,
|
||||||
|
# take src/ and put it as dst/ (for stage2 variants)
|
||||||
all:
|
all:
|
||||||
@for dir in $(SUBPROFILES); do \
|
@for sub in $(SUBPROFILES); do \
|
||||||
rsync -a $$dir/ $(BUILDDIR)/$$dir/ && \
|
src="$${sub%/*}" && \
|
||||||
|
dst="$${sub#*/}" && \
|
||||||
|
neq="$${src#$$dst}" && \
|
||||||
|
rsync -a "$$src/" "$(BUILDDIR)/$$dst/" && \
|
||||||
type -t git >&/dev/null && \
|
type -t git >&/dev/null && \
|
||||||
cd $(BUILDDIR)/$$dir/ && \
|
cd "$(BUILDDIR)/$$dst/" && \
|
||||||
git add . && \
|
git add . && \
|
||||||
git commit -qam "$@/$$dir"; \
|
git commit -qam "$$dst subprofile initialized$${neq:+ (using $$src)}"; \
|
||||||
cd - >&/dev/null; \
|
cd - >&/dev/null; \
|
||||||
done ||:
|
done
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
@for dir in $(SUBPROFILES); do \
|
@for sub in $(SUBPROFILES); do \
|
||||||
if [ -n "$$dir" ]; then \
|
dst="${sub#*/}" && \
|
||||||
rm -rf $(BUILDDIR)/$$dir && \
|
if [ -n "$$dst" -a -n "$(BUILDDIR)" ]; then \
|
||||||
mkdir -p $(BUILDDIR)/$$dir; \
|
rm -r "$(BUILDDIR)/$$dst" && \
|
||||||
|
mkdir -p "$(BUILDDIR)/$$dst"; \
|
||||||
fi; \
|
fi; \
|
||||||
done
|
done
|
||||||
|
@@ -1,20 +1,31 @@
|
|||||||
Этот каталог содержит субпрофили; содержимое заказанных
|
Этот каталог содержит субпрофили; содержимое затребованных
|
||||||
в формируемый профиль (названия которых содержатся в значении
|
(названия которых содержатся в значении переменной SUBPROFILES,
|
||||||
переменной SUBPROFILES, которую обычно заполняют цели sub/* --
|
которую заполняют цели sub/* -- см. ../distro.mk) будет
|
||||||
см. ditro.mk в корневом каталоге) будет скопировано в каталог
|
скопировано в каталог $(BUILDDIR)/image/ формируемого профиля.
|
||||||
$(BUILDDIR)/image/.
|
|
||||||
|
|
||||||
Просьба ответственно относиться к модификации существующих
|
Просьба ответственно относиться к модификации существующих
|
||||||
и вдумчиво -- к созданию новых; возможно, достаточно всего лишь
|
и вдумчиво -- к созданию новых; возможно, достаточно всего лишь
|
||||||
оформить нужное новой фичей (см. ../features.in/).
|
оформить нужное новой фичей (см. ../features.in/).
|
||||||
|
|
||||||
Краткое описание существующих:
|
Обратите внимание: поскольку сборка частей образа и происходит
|
||||||
|
в каталогах субпрофилей, то повторное использование одного простого
|
||||||
|
субпрофиля в рамках сгенерированного профиля штатным образом невозможно.
|
||||||
|
Если требуется создать несколько близких по реализации субпрофилей,
|
||||||
|
изучите stage2 и задействующие его фичи.
|
||||||
|
|
||||||
|
Краткое описание существующих вариантов:
|
||||||
|
|
||||||
- stage1: propagator и загрузчик (при подключении фичи syslinux);
|
- stage1: propagator и загрузчик (при подключении фичи syslinux);
|
||||||
типично требуется для инсталяторов, live- и rescue-образов
|
типично требуется для инсталяторов, live- и rescue-образов,
|
||||||
|
но может использоваться без добавления таковых в образ,
|
||||||
|
обеспечивая сетевую загрузку второй стадии
|
||||||
|
|
||||||
- install2: installer, installer-feature-*-stage2 и прочее обычно
|
- stage2: наиболее сложный технологически субпрофиль, поскольку
|
||||||
востребованное в инсталяционных образах
|
он является только базовым для получения ряда итоговых частей
|
||||||
|
дистрибутива (install2, live, rescue); задействуется для этого
|
||||||
|
только опосредованно через use/stage2/* и модифицирует stage1
|
||||||
|
в силу наличия связи между ними (в stage1 попадает образ ядра
|
||||||
|
и firmware, в stage2 -- соответствующие модули)
|
||||||
|
|
||||||
- main: пакетная база, укладываемая на образ (NB: поскольку рабочий
|
- main: пакетная база, укладываемая на образ (NB: поскольку рабочий
|
||||||
чрут в этом случае не содержит ничего, кроме пакетов, добавлять
|
чрут в этом случае не содержит ничего, кроме пакетов, добавлять
|
||||||
|
@@ -1,35 +0,0 @@
|
|||||||
# step 4: build install2 subprofile (installer "live" part)
|
|
||||||
|
|
||||||
ifndef GLOBAL_BUILDDIR
|
|
||||||
$(error GLOBAL_BUILDDIR not defined)
|
|
||||||
endif
|
|
||||||
|
|
||||||
default: all
|
|
||||||
|
|
||||||
include $(GLOBAL_BUILDDIR)/distcfg.mk
|
|
||||||
include $(GLOBAL_BUILDDIR)/functions.mk
|
|
||||||
include $(MKIMAGE_PREFIX)/config.mk
|
|
||||||
|
|
||||||
# this might have been prepared by ../stage1/scripts.d/03-test-kernel
|
|
||||||
-include $(GLOBAL_BUILDDIR)/squashcfg.mk
|
|
||||||
|
|
||||||
# here we also try and come up with the installer kernel/modules, if any;
|
|
||||||
# no kernel flavour specified will result in no modules for stage1 vmlinuz
|
|
||||||
INSTALLER_KFLAVOUR ?= $(lastword $(KFLAVOURS))
|
|
||||||
|
|
||||||
ifeq "$(INSTALLER_KFLAVOUR)" ""
|
|
||||||
$(error INSTALLER_KFLAVOUR is utterly empty; cannot guess either)
|
|
||||||
endif
|
|
||||||
|
|
||||||
# need kernel modules only (which require corresponding kernel-image);
|
|
||||||
# these go into work chroot; NB: no vmlinuz there
|
|
||||||
IMAGE_PACKAGES_REGEXP = $(call kpackages,$(INSTALLER_KMODULES),$(INSTALLER_KFLAVOUR))
|
|
||||||
IMAGE_PACKAGES = $(COMMON_PACKAGES) \
|
|
||||||
$(INSTALL2_PACKAGES) \
|
|
||||||
./packages
|
|
||||||
|
|
||||||
MKI_PACK_RESULTS = squash:altinst
|
|
||||||
|
|
||||||
include $(MKIMAGE_PREFIX)/targets.mk
|
|
||||||
|
|
||||||
all: | build-image run-image-scripts pack-image
|
|
@@ -1,3 +0,0 @@
|
|||||||
udev
|
|
||||||
e2fsprogs
|
|
||||||
glibc-nss
|
|
@@ -15,7 +15,8 @@ CHROOT_PACKAGES = apt-utils rsync
|
|||||||
IMAGE_PACKAGES_REGEXP = $(call kpackages,$(KMODULES),$(KFLAVOURS)) \
|
IMAGE_PACKAGES_REGEXP = $(call kpackages,$(KMODULES),$(KFLAVOURS)) \
|
||||||
$(MAIN_PACKAGES_REGEXP)
|
$(MAIN_PACKAGES_REGEXP)
|
||||||
|
|
||||||
IMAGE_PACKAGES = $(call map,list,$(BASE_LISTS) $(MAIN_LISTS) $(GROUPS)) \
|
IMAGE_PACKAGES = $(call map,list,$(BASE_LISTS) $(MAIN_LISTS) $(MAIN_GROUPS)) \
|
||||||
|
$(SYSTEM_PACKAGES) \
|
||||||
$(COMMON_PACKAGES) \
|
$(COMMON_PACKAGES) \
|
||||||
$(BASE_PACKAGES) \
|
$(BASE_PACKAGES) \
|
||||||
$(MAIN_PACKAGES)
|
$(MAIN_PACKAGES)
|
||||||
@@ -25,7 +26,7 @@ MKI_PACK_RESULTS = data
|
|||||||
|
|
||||||
include $(MKIMAGE_PREFIX)/targets.mk
|
include $(MKIMAGE_PREFIX)/targets.mk
|
||||||
|
|
||||||
all: $(GLOBAL_DEBUG) copy-packages pack-image
|
all: $(GLOBAL_DEBUG) copy-packages pack-image $(GLOBAL_CLEAN_WORKDIR)
|
||||||
|
|
||||||
debug:
|
debug:
|
||||||
@echo "** main: IMAGE_PACKAGES: $(IMAGE_PACKAGES)"
|
@echo "** main: IMAGE_PACKAGES: $(IMAGE_PACKAGES)"
|
||||||
|
@@ -1,12 +1,12 @@
|
|||||||
Этот каталог содержит субпрофиль main, собирающий пакетную базу,
|
Этот каталог содержит субпрофиль main, собирающий пакетную базу
|
||||||
которая затем укладывается в образ.
|
для локальной инсталяции системы и возможности установки дополнений.
|
||||||
|
|
||||||
Подбирает:
|
Подбирает:
|
||||||
- COMMON_PACKAGES, BASE_PACKAGES, BASE_LISTS: в установку по умолчанию;
|
- SYSTEM_PACKAGES, COMMON_PACKAGES, BASE_PACKAGES, BASE_LISTS:
|
||||||
|
в установку по умолчанию;
|
||||||
- MAIN_PACKAGES, MAIN_LISTS: дополнительные пакеты.
|
- MAIN_PACKAGES, MAIN_LISTS: дополнительные пакеты.
|
||||||
|
|
||||||
В image-scripts.d/* смысла нет, только scripts.d/* --
|
В image-scripts.d/* смысла нет, только scripts.d/* --
|
||||||
рабочий чрут не содержит исполняемых файлов.
|
рабочий чрут не содержит исполняемых файлов.
|
||||||
|
|
||||||
Результат -- каталог ALTLinux/RPMS.main, подлежащий копированию
|
Результат -- каталог ALTLinux/RPMS.main для копирования в образ.
|
||||||
в образ.
|
|
||||||
|
@@ -21,31 +21,33 @@ COPY_TREE = ./files
|
|||||||
include $(MKIMAGE_PREFIX)/targets.mk
|
include $(MKIMAGE_PREFIX)/targets.mk
|
||||||
|
|
||||||
# here we try and come up with the installer kernel/modules, if any;
|
# here we try and come up with the installer kernel/modules, if any;
|
||||||
# only a single kernel might be needed (INSTALLER_KFLAVOUR sets explicitly);
|
# only a single kernel might be needed (STAGE1_KFLAVOUR sets explicitly);
|
||||||
# kernel image copied from instrumental chroot into .work/syslinux/alt0/
|
# kernel image copied from instrumental chroot into .work/syslinux/alt0/
|
||||||
|
|
||||||
INSTALLER_KFLAVOUR ?= $(lastword $(KFLAVOURS))
|
STAGE1_KFLAVOUR ?= $(lastword $(KFLAVOURS))
|
||||||
|
|
||||||
# propagator needed iff stage1 kernel installed (not for e.g. syslinux.iso)
|
# propagator needed iff stage1 kernel installed (not for e.g. syslinux.iso)
|
||||||
ifeq "$(INSTALLER_KFLAVOUR)" ""
|
ifneq "$(STAGE1_KFLAVOUR)" ""
|
||||||
build-propagator:
|
BUILD_PROPAGATOR = build-propagator
|
||||||
@echo "** skipping build-propagator target, no kernel installed"
|
CHROOT_PACKAGES_REGEXP := $(call kpackages,$(STAGE1_KMODULES_REGEXP),$(STAGE1_KFLAVOUR))
|
||||||
else
|
INFO_STAGE1_KFLAVOUR := $(STAGE1_KFLAVOUR)
|
||||||
CHROOT_PACKAGES_REGEXP := $(call kpackages,$(INSTALLER_KMODULES_REGEXP),$(INSTALLER_KFLAVOUR))
|
|
||||||
INFO_INSTALLER_KFLAVOUR := $(INSTALLER_KFLAVOUR)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CHROOT_PACKAGES_REGEXP += $(STAGE1_PACKAGES_REGEXP)
|
CHROOT_PACKAGES_REGEXP += $(STAGE1_PACKAGES_REGEXP)
|
||||||
CHROOT_PACKAGES = $(STAGE1_PACKAGES) $(COMMON_PACKAGES)
|
CHROOT_PACKAGES = $(STAGE1_PACKAGES) $(SYSTEM_PACKAGES)
|
||||||
|
|
||||||
# scripts prepare bootloader configuration, too
|
# scripts prepare bootloader configuration, too
|
||||||
# NB: we pass tested squashfs options for ../install2/Makefile
|
# NB: we pass tested squashfs options for ../install2/Makefile
|
||||||
all: | debug prepare-workdir copy-tree run-scripts build-propagator \
|
all: | debug prepare-workdir copy-tree run-scripts $(BUILD_PROPAGATOR) \
|
||||||
copy-$(BOOTLOADER) pack-image
|
copy-$(BOOTLOADER) $(COPY_SQUASHCFG) pack-image $(GLOBAL_CLEAN_WORKDIR)
|
||||||
@cp $(OUTDIR)/squashcfg.mk $(GLOBAL_BUILDDIR)/
|
@if test -s $(OUTDIR)/squashcfg.mk; then \
|
||||||
|
cp $(OUTDIR)/squashcfg.mk $(GLOBAL_BUILDDIR)/; \
|
||||||
|
fi
|
||||||
|
|
||||||
debug:
|
debug:
|
||||||
@if test -n "$(GLOBAL_VERBOSE)"; then \
|
@if test -n "$(GLOBAL_VERBOSE)"; then \
|
||||||
|
echo "** BRANDING: $(BRANDING)"; \
|
||||||
|
echo "** IMAGE_INIT_LIST: $(IMAGE_INIT_LIST)"; \
|
||||||
echo "** STAGE1_PACKAGES: $(STAGE1_PACKAGES)"; \
|
echo "** STAGE1_PACKAGES: $(STAGE1_PACKAGES)"; \
|
||||||
echo "** STAGE1_PACKAGES_REGEXP: $(STAGE1_PACKAGES_REGEXP)"; \
|
echo "** STAGE1_PACKAGES_REGEXP: $(STAGE1_PACKAGES_REGEXP)"; \
|
||||||
echo "** CHROOT_PACKAGES: $(CHROOT_PACKAGES)"; \
|
echo "** CHROOT_PACKAGES: $(CHROOT_PACKAGES)"; \
|
||||||
|
@@ -2,18 +2,17 @@
|
|||||||
здесь место syslinux (загрузчик) и propagator (ориентировка
|
здесь место syslinux (загрузчик) и propagator (ориентировка
|
||||||
на местности, вытягивание второй стадии с CD/FTP/...).
|
на местности, вытягивание второй стадии с CD/FTP/...).
|
||||||
|
|
||||||
Скрипты обычно запускаются извне формируемого образа,
|
Скрипты запускаются извне формируемого образа (scripts.d/);
|
||||||
т.е. это scripts.d/; следует крайне бережно относиться
|
следует крайне бережно относиться к составу STAGE1_PACKAGES
|
||||||
к составу STAGE1_PACKAGES и объёму этой стадии.
|
и объёму этой стадии.
|
||||||
|
|
||||||
Обратите внимание: если не указать явно требуемый вариант
|
Обратите внимание: если не указать явно требуемый вариант
|
||||||
ядра посредством INSTALLER_KFLAVOUR, будет взят последний
|
ядра посредством STAGE1_KFLAVOUR, будет взят последний
|
||||||
из перечисленных в KFLAVOURS; если не указать явно регэкс,
|
из перечисленных в KFLAVOURS; если не указать явно регэкс,
|
||||||
описывающий требуемые в инсталяторе модули, посредством
|
описывающий требуемые в инсталяторе модули, посредством
|
||||||
INSTALLER_KMODULES_REGEXP -- будет подмножество модулей
|
STAGE1_KMODULES_REGEXP -- будет подмножество модулей
|
||||||
из kernel-image (упаковываются в syslinux/alt0/full.cz).
|
из kernel-image (упаковываются в syslinux/alt0/full.cz).
|
||||||
|
|
||||||
Требуется для инсталяционных, live- и rescue-образов.
|
Требуется для инсталяционных, live- и rescue-образов.
|
||||||
|
|
||||||
Результат -- каталог syslinux/, подлежащий копированию
|
Результат -- каталог syslinux/ для копирования в образ.
|
||||||
в образ.
|
|
||||||
|
46
sub.in/stage2/Makefile
Normal file
46
sub.in/stage2/Makefile
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
# step 4: build a stage2 subprofile (custom livecd)
|
||||||
|
|
||||||
|
# NB: stage2 is not standalone but rather a common base
|
||||||
|
# for all livecd images (installer, live, rescue)
|
||||||
|
|
||||||
|
ifndef GLOBAL_BUILDDIR
|
||||||
|
$(error GLOBAL_BUILDDIR not defined)
|
||||||
|
endif
|
||||||
|
|
||||||
|
default: all
|
||||||
|
|
||||||
|
include $(GLOBAL_BUILDDIR)/distcfg.mk
|
||||||
|
include $(GLOBAL_BUILDDIR)/functions.mk
|
||||||
|
include $(MKIMAGE_PREFIX)/config.mk
|
||||||
|
|
||||||
|
# this might have been prepared by ../stage1/scripts.d/03-test-kernel
|
||||||
|
-include $(GLOBAL_BUILDDIR)/squashcfg.mk
|
||||||
|
|
||||||
|
# this should be brought in by corresponding specific stage2 feature
|
||||||
|
include stage2cfg.mk
|
||||||
|
|
||||||
|
# requisite stuff
|
||||||
|
IMAGE_PACKAGES += $(SYSTEM_PACKAGES)
|
||||||
|
|
||||||
|
# here we also try and come up with the stage1 kernel/modules, if any;
|
||||||
|
# no kernel flavour specified will result in no modules for stage1 vmlinuz
|
||||||
|
STAGE1_KFLAVOUR ?= $(lastword $(KFLAVOURS))
|
||||||
|
|
||||||
|
ifeq "$(STAGE1_KFLAVOUR)" ""
|
||||||
|
$(error STAGE1_KFLAVOUR is utterly empty; cannot guess either)
|
||||||
|
endif
|
||||||
|
|
||||||
|
# need kernel modules only (which require corresponding kernel-image);
|
||||||
|
# these go into work chroot; NB: no vmlinuz there
|
||||||
|
IMAGE_PACKAGES_REGEXP = $(call kpackages,$(STAGE1_KMODULES),$(STAGE1_KFLAVOUR))
|
||||||
|
|
||||||
|
include $(MKIMAGE_PREFIX)/targets.mk
|
||||||
|
|
||||||
|
# NB: it's a collector variable, add()ing to a GLOBAL_ results in lost hair
|
||||||
|
GLOBAL_CLEANUP_PACKAGES := $(CLEANUP_PACKAGES)
|
||||||
|
|
||||||
|
all: | $(GLOBAL_DEBUG) build-image run-image-scripts pack-image \
|
||||||
|
$(GLOBAL_CLEAN_WORKDIR)
|
||||||
|
|
||||||
|
# dummy
|
||||||
|
debug: ;
|
6
sub.in/stage2/README
Normal file
6
sub.in/stage2/README
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
Этот каталог содержит общий базовый субпрофиль "живой" второй стадии,
|
||||||
|
используемый для сборки образов install2, live, rescue (возможно,
|
||||||
|
нескольких одновременно в составе одного дистрибутива).
|
||||||
|
|
||||||
|
Результат -- соответственно названный файл со squashfs,
|
||||||
|
подлежащий копированию в итоговый образ.
|
5
sub.in/stage2/image-scripts.d/00stage1
Executable file
5
sub.in/stage2/image-scripts.d/00stage1
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# propagator needs this,
|
||||||
|
# "FATAL ERROR IN INIT: overmounting /image" otherwise
|
||||||
|
mkdir -p /image
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user