You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
6.9 KiB
208 lines
6.9 KiB
############################################################################ |
|
# apps/Makefile |
|
# |
|
# Copyright (C) 2011-2012 Uros Platise. All rights reserved. |
|
# Authors: Uros Platise <uros.platise@isotel.eu> |
|
# Gregory Nutt <gnutt@nuttx.org> |
|
# |
|
# Redistribution and use in source and binary forms, with or without |
|
# modification, are permitted provided that the following conditions |
|
# are met: |
|
# |
|
# 1. Redistributions of source code must retain the above copyright |
|
# notice, this list of conditions and the following disclaimer. |
|
# 2. Redistributions in binary form must reproduce the above copyright |
|
# notice, this list of conditions and the following disclaimer in |
|
# the documentation and/or other materials provided with the |
|
# distribution. |
|
# 3. Neither the name NuttX nor the names of its contributors may be |
|
# used to endorse or promote products derived from this software |
|
# without specific prior written permission. |
|
# |
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS |
|
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE |
|
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, |
|
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, |
|
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS |
|
# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED |
|
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN |
|
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
|
# POSSIBILITY OF SUCH DAMAGE. |
|
# |
|
############################################################################ |
|
|
|
-include $(TOPDIR)/Make.defs |
|
-include $(TOPDIR)/.config |
|
|
|
APPDIR = ${shell pwd} |
|
|
|
# Application Directories |
|
|
|
# CONFIGURED_APPS is the list of all configured built-in directories/built |
|
# action. It is created by the configured appconfig file (a copy of which |
|
# appears in this directory as .config) |
|
# SUBDIRS is the list of all directories containing Makefiles. It is used |
|
# only for cleaning. builtin must always be the first in the list. This |
|
# list can be extended by the .config file as well. |
|
|
|
CONFIGURED_APPS = |
|
|
|
SUBDIRS = examples interpreters builtin nshlib system |
|
|
|
#SUBDIRS = examples graphics interpreters modbus builtin nshlib netutils system |
|
|
|
# There are two different mechanisms for obtaining the list of configured |
|
# directories: |
|
# |
|
# (1) In the legacy method, these paths are all provided in the appconfig |
|
# file that is copied to the top-level apps/ directory as .config |
|
# (2) With the development of the NuttX configuration tool, however, the |
|
# selected applications are now enabled by the configuration tool. |
|
# The apps/.config file is no longer used. Instead, the set of |
|
# configured build directories can be found by including a Make.defs |
|
# file contained in each of the apps/subdirectories. |
|
# |
|
# When the NuttX configuration tools executes, it will always define the |
|
# configure CONFIG_NUTTX_NEWCONFIG to select between these two cases. Then |
|
# legacy appconfig files will still work but newly configuration files will |
|
# also work. Eventually the CONFIG_NUTTX_NEWCONFIG option will be phased |
|
# out. |
|
|
|
ifeq ($(CONFIG_NUTTX_NEWCONFIG),y) |
|
|
|
# builtin/Make.defs must be included first |
|
|
|
include builtin/Make.defs |
|
include examples/Make.defs |
|
include graphics/Make.defs |
|
include interpreters/Make.defs |
|
include modbus/Make.defs |
|
include netutils/Make.defs |
|
include nshlib/Make.defs |
|
include system/Make.defs |
|
|
|
# INSTALLED_APPS is the list of currently available application directories. It |
|
# is the same as CONFIGURED_APPS, but filtered to exclude any non-existent |
|
# application directory. builtin is always in the list of applications to be |
|
# built. |
|
|
|
INSTALLED_APPS = |
|
|
|
# The legacy case: |
|
|
|
else |
|
-include .config |
|
|
|
# INSTALLED_APPS is the list of currently available application directories. It |
|
# is the same as CONFIGURED_APPS, but filtered to exclude any non-existent |
|
# application directory. builtin is always in the list of applications to be |
|
# built. |
|
|
|
INSTALLED_APPS = builtin |
|
endif |
|
|
|
# Create the list of available applications (INSTALLED_APPS) |
|
|
|
define ADD_BUILTIN |
|
INSTALLED_APPS += $(if $(wildcard $1$(DELIM)Makefile),$1,) |
|
endef |
|
|
|
$(foreach BUILTIN, $(CONFIGURED_APPS), $(eval $(call ADD_BUILTIN,$(BUILTIN)))) |
|
|
|
# EXTERNAL_APPS is used to add out of tree apps to the build |
|
INSTALLED_APPS += $(EXTERNAL_APPS) |
|
|
|
# The external/ directory may also be added to the INSTALLED_APPS. But there |
|
# is no external/ directory in the repository. Rather, this directory may be |
|
# provided by the user (possibly as a symbolic link) to add libraries and |
|
# applications to the standard build from the repository. |
|
|
|
EXTERNAL_DIR := $(dir $(wildcard external$(DELIM)Makefile)) |
|
|
|
INSTALLED_APPS += $(EXTERNAL_DIR) |
|
SUBDIRS += $(EXTERNAL_DIR) |
|
|
|
# The final build target |
|
|
|
BIN = libapps$(LIBEXT) |
|
|
|
# Build targets |
|
|
|
all: $(BIN) |
|
.PHONY: $(INSTALLED_APPS) context depend clean distclean |
|
|
|
$(INSTALLED_APPS): |
|
$(Q) $(MAKE) -C $@ TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" |
|
|
|
$(BIN): $(INSTALLED_APPS) |
|
|
|
context: |
|
ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
|
$(Q) for %%G in ($(INSTALLED_APPS)) do ( \ |
|
$(MAKE) -C %%G TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" context \ |
|
) |
|
else |
|
$(Q) for dir in $(INSTALLED_APPS) ; do \ |
|
$(MAKE) -C $$dir TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" context ; \ |
|
done |
|
endif |
|
|
|
.depend: context Makefile $(SRCS) |
|
ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
|
$(Q) for %%G in ($(INSTALLED_APPS)) do ( \ |
|
if exist %%G\.depend del /f /q %%G\.depend \ |
|
$(MAKE) -C %%G TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" depend \ |
|
) |
|
else |
|
$(Q) for dir in $(INSTALLED_APPS) ; do \ |
|
rm -f $$dir/.depend ; \ |
|
$(MAKE) -C $$dir TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" depend ; \ |
|
done |
|
endif |
|
$(Q) touch $@ |
|
|
|
depend: .depend |
|
|
|
clean: |
|
ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
|
$(Q) for %%G in ($(SUBDIRS)) do ( \ |
|
$(MAKE) -C %%G clean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" \ |
|
) |
|
else |
|
$(Q) for dir in $(SUBDIRS) ; do \ |
|
$(MAKE) -C $$dir clean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"; \ |
|
done |
|
endif |
|
$(call DELFILE, $(BIN)) |
|
$(call CLEAN) |
|
|
|
distclean: |
|
ifeq ($(CONFIG_WINDOWS_NATIVE),y) |
|
$(Q) for %%G in ($(SUBDIRS)) do ( \ |
|
$(MAKE) -C %%G distclean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" \ |
|
) |
|
$(call DELFILE, .config) |
|
$(call DELFILE, .depend) |
|
$(Q) ( if exist external ( \ |
|
echo ********************************************************" \ |
|
echo * The external directory/link must be removed manually *" \ |
|
echo ********************************************************" \ |
|
) |
|
else |
|
$(Q) for dir in $(SUBDIRS) ; do \ |
|
$(MAKE) -C $$dir distclean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"; \ |
|
done |
|
$(call DELFILE, .config) |
|
$(call DELFILE, .depend) |
|
$(Q) ( if [ -e external ]; then \ |
|
echo "********************************************************"; \ |
|
echo "* The external directory/link must be removed manually *"; \ |
|
echo "********************************************************"; \ |
|
fi; \ |
|
) |
|
endif |
|
|
|
|
|
|