-include/syscalls.h: Kernel/Makefile Kernel/syscalls.lst
- @make -C Kernel/ include/syscalls.h
-
-# Compile Only
-$(ALL_DYNMODS): all-%:
- +@echo === Dynamic Module: $* && BUILDTYPE=dynamic $(SUBMAKE) all -C Modules/$*
-$(ALL_MODULES): all-%:
- +@echo === Module: $* && BUILDTYPE=static $(SUBMAKE) all -C Modules/$*
-all-Kernel:
- +@echo === Kernel && $(SUBMAKE) all -C Kernel
-$(ALL_USRLIBS): all-%:
- +@echo === User Library: $* && $(SUBMAKE) all -C Usermode/Libraries/$*_src
-$(ALL_USRAPPS): all-%:
- +@echo === User Application: $* && $(SUBMAKE) all -C Usermode/Applications/$*_src
-
-# Compile & Install
-$(AI_DYNMODS): allinstall-%:
- +@echo === Dynamic Module: $* && BUILDTYPE=dynamic $(SUBMAKE) all install -C Modules/$*
-$(AI_MODULES): allinstall-%:
- +@echo === Module: $* && BUILDTYPE=static $(SUBMAKE) all install -C Modules/$*
-allinstall-Kernel:
- +@echo === Kernel && $(SUBMAKE) all install -C Kernel
-$(AI_USRLIBS): allinstall-%:
- +@echo === User Library: $* && $(SUBMAKE) all install -C Usermode/Libraries/$*_src
-$(AI_USRAPPS): allinstall-%:
- +@echo === User Application: $* && $(SUBMAKE) all install -C Usermode/Applications/$*_src
-
-# Clean up compilation
-$(CLEAN_DYNMODS): clean-%:
- +@BUILDTYPE=dynamic $(SUBMAKE) clean -C Modules/$*
-$(CLEAN_MODULES): clean-%:
- +@BUILDTYPE=static $(SUBMAKE) clean -C Modules/$*
-clean-Kernel:
- +@$(SUBMAKE) clean -C Kernel
-$(CLEAN_USRLIBS): clean-%:
- +@$(SUBMAKE) clean -C Usermode/Libraries/$*_src
-$(CLEAN_USRAPPS): clean-%:
- +@$(SUBMAKE) clean -C Usermode/Applications/$*_src
-
-# Install
-$(INSTALL_DYNMODS): install-%:
- @BUILDTYPE=dynamic $(SUBMAKE) install -C Modules/$*
-$(INSTALL_MODULES): install-%:
- @BUILDTYPE=static $(SUBMAKE) install -C Modules/$*
-install-Filesystem:
+include/syscalls.h: KernelLand/Kernel/Makefile KernelLand/Kernel/syscalls.lst
+ @make -C KernelLand/Kernel/ include/syscalls.h
+
+_build_dynmod := BUILDTYPE=dynamic $(SUBMAKE) -C KernelLand/Modules/
+_build_stmod := BUILDTYPE=static $(SUBMAKE) -C KernelLand/Modules/
+_build_kernel := $(SUBMAKE) -C KernelLand/Kernel
+
+define rules
+$$(ALL_$1): all-%: $(CC)
+ +@echo === $2 && $3 all
+$$(AI_$1): allinstall-%: $(CC)
+ +@echo === $2 && $3 all install
+$$(CLEAN_$1): clean-%: $(CC)
+ +@echo === $2 && $3 clean
+$$(INSTALL_$1): install-%: $(CC)
+ +@$3 install
+endef
+
+$(eval $(call rules,DYNMODS,Dynamic Module: $$*,$(_build_dynmod)$$*))
+$(eval $(call rules,MODULES,Module: $$*,$(_build_stmod)$$*))
+$(eval $(call rules,USRLIBS,User Library: $$*,$(SUBMAKE) -C Usermode/Libraries/$$*_src))
+$(eval $(call rules,EXTLIBS,External Library: $$*,$(SUBMAKE) -C Externals/$$*))
+$(eval $(call rules,USRAPPS,User Application: $$*,$(SUBMAKE) -C Usermode/Applications/$$*_src))
+all-Kernel: $(CC)
+ +@echo === Kernel && $(_build_kernel) all
+allinstall-Kernel: $(CC)
+ +@echo === Kernel && $(_build_kernel) all install
+clean-Kernel: $(CC)
+ +@$(_build_kernel) clean
+install-Kernel: $(CC)
+ @$(_build_kernel) install
+install-Filesystem: $(CC)