2 # @copyright Copyright (c) 2016-2020 TOYOTA MOTOR CORPORATION.
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
8 # http://www.apache.org/licenses/LICENSE-2.0
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
18 # Standard Module Makefile version 2.0
21 # Name of the componet (team/domain prefix '_' component name)
22 COMPONENT_NAME = NS_XMLConfigParser
25 export PRJ_ROOT = $(CURDIR)/../
27 include $(PRJ_ROOT)cfg/depends.mk
29 # Name of the componet (team/domain prefix '_' component name)
30 # This must be the same as the RTC Component name and Eclipse Project Name
31 COMPONENT_NAME = NS_XMLConfigParser
34 # Additive Compile Flags (Flags from initiating make process will still apply)
37 # Set local includes and then the reference includes (priority order determines search path)
38 # Default pattern are any configuration includes (which would be things like PosixBasedOS001), local (Team) component directories,
39 # dependencies includes (other teams)
40 # Local (current component references should be in the form of
41 # $(CC_IFLAG)$(TEAM_ROOT)$(COMPONENT_NAME)/directory
42 # Example your public include directory would be
43 # $(CC_IFLAG)$(TEAM_ROOT)$(COMPONENT_NAME)/inc
44 # Team references should only be to other's public includes such as
45 # $(CC_IFLAG)$(TEAM_ROOT)NS_MessageCenter/inc
46 # Global (non-team) references should be only to other's public includes such
47 # these are found in the depends include file and captured in the (DEPENDS_INCLUDES) variable
52 $(CC_IFLAG)$(TEAM_ROOT)$(COMPONENT_NAME)/inc \
53 $(CC_IFLAG)$(TEAM_ROOT)NS_ConfigParser/inc
56 # Do the same if you need to include library paths as well
57 # Do an incremental in case additional library paths are defined
58 # at the top-level make. Use similar guidelines as for includes
59 # for example to include a team component library it would be
60 # $(TEAM_ROOT)NS_MessageCenter/lib/NS_MessageCenter/
62 $(DEPENDS_LIB_PATHS) \
66 # Define binary outputs. These can be libraries or executables.
67 # Name a variable for each deliverable. Suffixes should be
68 # EXEC - For Executables -> output to the bin directory
69 #TIME_EXEC = $(BIN_PATH)time
70 # LIB - For Static Libraries -> output to lib directory with specific naming
71 #MATH_LIB = $(LIB_PATH)$(LIB_PREFIX)math.$(LIB_EXT)
72 # SLIB - For Shared Objects
73 #FRMWRK_SLIB = $(SLIB_PATH)frmwrk.$(SO_EXT)
74 # LIB - Define the static library for Message Queue
78 COMPONENT_LIB = $(SLIB_PATH)$(LIB_PREFIX)$(COMPONENT_NAME)$(DEBUG_EXT).$(SO_EXT)
80 COMPONENT_LIB = $(LIB_PATH)$(LIB_PREFIX)$(COMPONENT_NAME)$(DEBUG_EXT).$(LIB_EXT)
86 # Define Library & Executable Sources (on a per deliverable basis)
87 # This includes sources located in subdirectories.
89 # Define generic line that pulls all c, cc, cpp files
90 # since your in the src folder is pull only files from there
95 # Define sources that my not be local to your component
96 # here, you can define indivial files or wildcard from
101 # List of all sources to be built. Can be assembled from the other defintitions.
102 # This only defines sources for the current directory, so if there are subdirectories
103 # those are not included. (Those are found in simple subdirectory makefiles that only
104 # direct the building of sources, but no linking into a binary)
112 # Convert the source files to object files with correct folder location.
115 C_LANG_OBJECTS = $(addprefix $(BLD_PATH),$(addsuffix .$(OBJ_EXT),$(basename $(filter %.c ,$(SOURCES) ) ) ) )
116 CPP_LANG_OBJECTS = $(addprefix $(BLD_PATH),$(addsuffix .$(OBJ_EXT),$(basename $(filter %.cpp %.cc %.cxx,$(SOURCES) ) ) ) )
119 # List of all sources to be generated. Can be assembled from the other defintitions.
126 # All headers that are dependencies. Wildcard is easy to pickup local headers.
127 # This is only to automate the rebuilding, all builds on the servers are cleans
128 # So this is not a huge deal when building on a component level.
131 $(wildcard $(TEAM_ROOT)$(COMPONENT_NAME)/inc/*.h) \
132 $(wildcard $(TEAM_ROOT)NativeServices/inc/*.h) \
133 $(wildcard $(TEAM_ROOT)NativeServices/inc/native/*.h) \
145 all: banner module_dirs subdirs local library binary
148 $(MAKE) TARGET=arm DEBUG=TRUE all
150 base: banner module_dirs subdirs local
152 # Standard Building of Source Files (Default builds for all objects defined above)
153 $(C_LANG_OBJECTS): $(SOURCES) $(HEADERS)
156 $(CPP_LANG_OBJECTS): $(SOURCES) $(HEADERS)
161 # Defines specific for each deliverable
163 # For a static library
164 $(COMPONENT_LIB): $(OBJECTS)
166 # For a dynamic library
168 $(HIDE_ECHO_FLAG)$(OBJCPY) --only-keep-debug $(@) $(@).debug
169 $(HIDE_ECHO_FLAG)$(OBJCPY) --strip-all $(@)
170 $(HIDE_ECHO_FLAG)$(OBJCPY) --add-gnu-debuglink=$(@).debug $(@)
172 # For a static library
176 # Standard set of derived targets
179 @echo "***** `date` Done building library: $(COMPONENT_NAME) ******"
184 # Subdirs should be to jump to subdirectories
185 # standard form is of
186 # $(MAKE) -C subdirectory_name $(MAKECMDGOALS)
193 -rm -f $(COMPONENT_LIB).map
194 -rm -f $(COMPONENT_LIB).debug
197 @echo "objs: --> $(OBJECTS)"
198 @echo "sources: --> $(SOURCES)"
199 @echo "headers: --> $(HEADERS)"
200 @echo "includes: --> $(INCLUDES)"
201 @echo "lib paths: --> $(LIB_PATHS)"
202 @echo "static libs: --> $(LD_STATIC_LIBS)"
203 @echo "dynamic libs: --> $(LD_DYNAMIC_LIBS)"
204 @echo "lib: --> $(LIBRARIES)"
205 @echo "bin: --> $(BINARIES)"
207 module_dirs: build_dirs