2011-03-10 15:42:28 +01:00
|
|
|
############################################################################
|
|
|
|
# apps/Makefile
|
|
|
|
#
|
2012-01-29 15:15:20 +01:00
|
|
|
# Copyright (C) 2011-2012 Uros Platise. All rights reserved.
|
2011-07-16 17:52:15 +02:00
|
|
|
# Authors: Uros Platise <uros.platise@isotel.eu>
|
2012-01-29 15:15:20 +01:00
|
|
|
# Gregory Nutt <gnutt@nuttx.org>
|
2011-03-10 15:42:28 +01:00
|
|
|
#
|
|
|
|
# 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
|
2012-04-14 22:01:08 +02:00
|
|
|
-include $(TOPDIR)/.config
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2011-03-19 17:54:35 +01:00
|
|
|
APPDIR = ${shell pwd}
|
|
|
|
|
2011-03-10 15:42:28 +01:00
|
|
|
# Application Directories
|
|
|
|
|
2011-05-09 21:37:22 +02:00
|
|
|
# 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)
|
2011-03-19 16:02:01 +01:00
|
|
|
# SUBDIRS is the list of all directories containing Makefiles. It is used
|
2011-05-09 21:37:22 +02:00
|
|
|
# only for cleaning. namedapp must always be the first in the list. This
|
|
|
|
# list can be extended by the .config file as well
|
2011-03-19 16:02:01 +01:00
|
|
|
|
2011-05-09 21:37:22 +02:00
|
|
|
CONFIGURED_APPS =
|
2011-09-21 20:40:23 +02:00
|
|
|
SUBDIRS = examples graphics interpreters namedapp nshlib netutils system vsn
|
2011-03-19 16:02:01 +01:00
|
|
|
|
2012-04-14 22:01:08 +02:00
|
|
|
# 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)
|
|
|
|
|
|
|
|
include examples/Make.defs
|
|
|
|
include graphics/Make.defs
|
|
|
|
include interpreters/Make.defs
|
|
|
|
include namedapp/Make.defs
|
|
|
|
include netutils/Make.defs
|
|
|
|
include nshlib/Make.defs
|
|
|
|
include system/Make.defs
|
|
|
|
include vsn/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. namedapp is always in the list of applications to be
|
|
|
|
# built.
|
|
|
|
|
|
|
|
INSTALLED_APPS =
|
|
|
|
|
|
|
|
# The legacy case:
|
|
|
|
|
|
|
|
else
|
2011-03-18 19:31:26 +01:00
|
|
|
-include .config
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2011-05-10 17:50:23 +02:00
|
|
|
# INSTALLED_APPS is the list of currently available application directories. It
|
2011-10-05 16:37:39 +02:00
|
|
|
# is the same as CONFIGURED_APPS, but filtered to exclude any non-existent
|
|
|
|
# application directory. namedapp is always in the list of applications to be
|
|
|
|
# built.
|
2011-03-14 21:50:46 +01:00
|
|
|
|
2011-05-10 17:50:23 +02:00
|
|
|
INSTALLED_APPS = namedapp
|
2012-04-14 22:01:08 +02:00
|
|
|
endif
|
2011-03-14 21:50:46 +01:00
|
|
|
|
2011-05-10 17:50:23 +02:00
|
|
|
# Create the list of available applications (INSTALLED_APPS)
|
2011-03-14 21:50:46 +01:00
|
|
|
|
2011-04-01 16:30:43 +02:00
|
|
|
define ADD_BUILTIN
|
2011-10-05 16:37:39 +02:00
|
|
|
INSTALLED_APPS += ${shell if [ -r $1/Makefile ]; then echo "$1"; fi}
|
2011-03-14 21:50:46 +01:00
|
|
|
endef
|
|
|
|
|
2011-04-01 16:30:43 +02:00
|
|
|
$(foreach BUILTIN, $(CONFIGURED_APPS), $(eval $(call ADD_BUILTIN,$(BUILTIN))))
|
2011-03-14 21:50:46 +01:00
|
|
|
|
2011-10-05 16:37:39 +02:00
|
|
|
# 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.
|
|
|
|
|
|
|
|
INSTALLED_APPS += ${shell if [ -r external/Makefile ]; then echo "external"; fi}
|
|
|
|
SUBDIRS += ${shell if [ -r external/Makefile ]; then echo "external"; fi}
|
|
|
|
|
2011-03-20 23:07:56 +01:00
|
|
|
# The final build target
|
2011-03-20 19:18:19 +01:00
|
|
|
|
2011-04-01 16:30:43 +02:00
|
|
|
BIN = libapps$(LIBEXT)
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2011-03-20 23:07:56 +01:00
|
|
|
# Build targets
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2011-03-20 23:07:56 +01:00
|
|
|
all: $(BIN)
|
2011-05-10 17:50:23 +02:00
|
|
|
.PHONY: $(INSTALLED_APPS) context depend clean distclean
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2011-05-10 17:50:23 +02:00
|
|
|
$(INSTALLED_APPS):
|
2011-04-10 18:08:08 +02:00
|
|
|
@$(MAKE) -C $@ TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)";
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2011-05-10 17:50:23 +02:00
|
|
|
$(BIN): $(INSTALLED_APPS)
|
2011-03-10 15:42:28 +01:00
|
|
|
@( for obj in $(OBJS) ; do \
|
|
|
|
$(call ARCHIVE, $@, $${obj}); \
|
|
|
|
done ; )
|
|
|
|
|
2011-03-24 01:28:50 +01:00
|
|
|
.context:
|
2011-05-10 17:50:23 +02:00
|
|
|
@for dir in $(INSTALLED_APPS) ; do \
|
2011-03-24 01:28:50 +01:00
|
|
|
rm -f $$dir/.context ; \
|
2011-04-10 18:08:08 +02:00
|
|
|
$(MAKE) -C $$dir TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" context ; \
|
2011-03-24 01:28:50 +01:00
|
|
|
done
|
|
|
|
@touch $@
|
|
|
|
|
|
|
|
context: .context
|
|
|
|
|
|
|
|
.depend: context Makefile $(SRCS)
|
2011-05-10 17:50:23 +02:00
|
|
|
@for dir in $(INSTALLED_APPS) ; do \
|
2011-03-12 23:09:14 +01:00
|
|
|
rm -f $$dir/.depend ; \
|
2011-04-10 18:08:08 +02:00
|
|
|
$(MAKE) -C $$dir TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" depend ; \
|
2011-03-10 15:42:28 +01:00
|
|
|
done
|
2011-03-20 23:07:56 +01:00
|
|
|
@touch $@
|
2011-03-10 15:42:28 +01:00
|
|
|
|
|
|
|
depend: .depend
|
|
|
|
|
|
|
|
clean:
|
2011-03-20 19:18:19 +01:00
|
|
|
@for dir in $(SUBDIRS) ; do \
|
2011-04-10 18:08:08 +02:00
|
|
|
$(MAKE) -C $$dir clean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"; \
|
2011-03-20 19:18:19 +01:00
|
|
|
done
|
2011-03-20 23:07:56 +01:00
|
|
|
@rm -f $(BIN) *~ .*.swp *.o
|
|
|
|
$(call CLEAN)
|
2011-03-10 15:42:28 +01:00
|
|
|
|
2012-05-29 03:43:51 +02:00
|
|
|
distclean: # clean
|
2011-03-20 19:18:19 +01:00
|
|
|
@for dir in $(SUBDIRS) ; do \
|
2011-04-10 18:08:08 +02:00
|
|
|
$(MAKE) -C $$dir distclean TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"; \
|
2011-03-20 19:18:19 +01:00
|
|
|
done
|
2011-03-24 01:28:50 +01:00
|
|
|
@rm -f .config .context .depend
|
2011-10-07 19:21:16 +02:00
|
|
|
@( if [ -e external ]; then \
|
|
|
|
echo "********************************************************"; \
|
|
|
|
echo "* The external directory/link must be removed manually *"; \
|
|
|
|
echo "********************************************************"; \
|
|
|
|
fi; \
|
|
|
|
)
|
2011-10-06 18:31:13 +02:00
|
|
|
|
2011-03-14 21:50:46 +01:00
|
|
|
|