perl-path-tiny: bump to version 0.061
[buildroot-gz.git] / package / pkg-autotools.mk
blobb20e20ef418551ad094208b2594299e64ae02c32
1 ################################################################################
2 # Autotools package infrastructure
4 # This file implements an infrastructure that eases development of
5 # package .mk files for autotools packages. It should be used for all
6 # packages that use the autotools as their build system.
8 # See the Buildroot documentation for details on the usage of this
9 # infrastructure
11 # In terms of implementation, this autotools infrastructure requires
12 # the .mk file to only specify metadata information about the
13 # package: name, version, download URL, etc.
15 # We still allow the package .mk file to override what the different
16 # steps are doing, if needed. For example, if <PKG>_BUILD_CMDS is
17 # already defined, it is used as the list of commands to perform to
18 # build the package, instead of the default autotools behaviour. The
19 # package can also define some post operation hooks.
21 ################################################################################
25 # Utility function to upgrade config.sub and config.guess files
27 # argument 1 : directory into which config.guess and config.sub need
28 # to be updated. Note that config.sub and config.guess are searched
29 # recursively in this directory.
31 define CONFIG_UPDATE
32 for file in config.guess config.sub; do \
33 for i in $$(find $(1) -name $$file); do \
34 cp support/gnuconfig/$$file $$i; \
35 done; \
36 done
37 endef
39 # This function generates the ac_cv_file_<foo> value for a given
40 # filename. This is needed to convince configure script doing
41 # AC_CHECK_FILE() tests that the file actually exists, since such
42 # tests cannot be done in a cross-compilation context. This function
43 # takes as argument the path of the file. An example usage is:
45 # FOOBAR_CONF_ENV = \
46 # $(call AUTOCONF_AC_CHECK_FILE_VAL,/dev/random)=yes
47 AUTOCONF_AC_CHECK_FILE_VAL = ac_cv_file_$(subst -,_,$(subst /,_,$(subst .,_,$(1))))
50 # Hook to update config.sub and config.guess if needed
52 define UPDATE_CONFIG_HOOK
53 @$(call MESSAGE,"Updating config.sub and config.guess")
54 $(call CONFIG_UPDATE,$(@D))
55 endef
58 # Hook to patch libtool to make it work properly for cross-compilation
60 define LIBTOOL_PATCH_HOOK
61 @$(call MESSAGE,"Patching libtool")
62 $(Q)for i in `find $($(PKG)_SRCDIR) -name ltmain.sh`; do \
63 ltmain_version=`sed -n '/^[ ]*VERSION=/{s/^[ ]*VERSION=//;p;q;}' $$i | \
64 sed -e 's/\([0-9].[0-9]*\).*/\1/' -e 's/\"//'`; \
65 ltmain_patchlevel=`sed -n '/^[ ]*VERSION=/{s/^[ ]*VERSION=//;p;q;}' $$i | \
66 sed -e 's/\([0-9].[0-9].\)\([0-9]*\).*/\2/' -e 's/\"//'`; \
67 if test $${ltmain_version} = '1.5'; then \
68 $(APPLY_PATCHES) $${i%/*} support/libtool buildroot-libtool-v1.5.patch; \
69 elif test $${ltmain_version} = "2.2"; then\
70 $(APPLY_PATCHES) $${i%/*} support/libtool buildroot-libtool-v2.2.patch; \
71 elif test $${ltmain_version} = "2.4"; then\
72 if test $${ltmain_patchlevel} -gt 2; then\
73 $(APPLY_PATCHES) $${i%/*} support/libtool buildroot-libtool-v2.4.4.patch; \
74 else \
75 $(APPLY_PATCHES) $${i%/*} support/libtool buildroot-libtool-v2.4.patch; \
76 fi \
77 fi \
78 done
79 endef
82 # Hook to gettextize the package if needed
84 define GETTEXTIZE_HOOK
85 @$(call MESSAGE,"Gettextizing")
86 $(Q)cd $($(PKG)_SRCDIR) && $(GETTEXTIZE) $($(PKG)_GETTEXTIZE_OPTS)
87 endef
90 # Hook to autoreconf the package if needed
92 define AUTORECONF_HOOK
93 @$(call MESSAGE,"Autoreconfiguring")
94 $(Q)cd $($(PKG)_SRCDIR) && $($(PKG)_AUTORECONF_ENV) $(AUTORECONF) $($(PKG)_AUTORECONF_OPTS)
95 endef
97 ################################################################################
98 # inner-autotools-package -- defines how the configuration, compilation and
99 # installation of an autotools package should be done, implements a
100 # few hooks to tune the build process for autotools specifities and
101 # calls the generic package infrastructure to generate the necessary
102 # make targets
104 # argument 1 is the lowercase package name
105 # argument 2 is the uppercase package name, including a HOST_ prefix
106 # for host packages
107 # argument 3 is the uppercase package name, without the HOST_ prefix
108 # for host packages
109 # argument 4 is the type (target or host)
110 ################################################################################
112 define inner-autotools-package
114 ifndef $(2)_LIBTOOL_PATCH
115 ifdef $(3)_LIBTOOL_PATCH
116 $(2)_LIBTOOL_PATCH = $$($(3)_LIBTOOL_PATCH)
117 else
118 $(2)_LIBTOOL_PATCH ?= YES
119 endif
120 endif
122 ifndef $(2)_MAKE
123 ifdef $(3)_MAKE
124 $(2)_MAKE = $$($(3)_MAKE)
125 else
126 $(2)_MAKE ?= $$(MAKE)
127 endif
128 endif
130 ifndef $(2)_AUTORECONF
131 ifdef $(3)_AUTORECONF
132 $(2)_AUTORECONF = $$($(3)_AUTORECONF)
133 else
134 $(2)_AUTORECONF ?= NO
135 endif
136 endif
138 ifndef $(2)_GETTEXTIZE
139 ifdef $(3)_GETTEXTIZE
140 $(2)_GETTEXTIZE = $$($(3)_GETTEXTIZE)
141 else
142 $(2)_GETTEXTIZE ?= NO
143 endif
144 endif
146 ifeq ($(4),host)
147 $(2)_GETTEXTIZE_OPTS ?= $$($(3)_GETTEXTIZE_OPTS)
148 endif
150 ifeq ($(4),host)
151 $(2)_AUTORECONF_OPTS ?= $$($(3)_AUTORECONF_OPTS)
152 endif
154 $(2)_CONF_ENV ?=
155 $(2)_CONF_OPTS ?=
156 $(2)_MAKE_ENV ?=
157 $(2)_MAKE_OPTS ?=
158 $(2)_INSTALL_OPTS ?= install
159 $(2)_INSTALL_STAGING_OPTS ?= DESTDIR=$$(STAGING_DIR) install
160 $(2)_INSTALL_TARGET_OPTS ?= DESTDIR=$$(TARGET_DIR) install
162 # This must be repeated from inner-generic-package, otherwise we get an empty
163 # _DEPENDENCIES if _AUTORECONF is YES. Also filter the result of _AUTORECONF
164 # and _GETTEXTIZE away from the non-host rule
165 ifeq ($(4),host)
166 $(2)_DEPENDENCIES ?= $$(filter-out host-automake host-autoconf host-libtool \
167 host-gettext host-toolchain $(1),\
168 $$(patsubst host-host-%,host-%,$$(addprefix host-,$$($(3)_DEPENDENCIES))))
169 endif
172 # Configure step. Only define it if not already defined by the package
173 # .mk file. And take care of the differences between host and target
174 # packages.
176 ifndef $(2)_CONFIGURE_CMDS
177 ifeq ($(4),target)
179 # Configure package for target
180 define $(2)_CONFIGURE_CMDS
181 (cd $$($$(PKG)_SRCDIR) && rm -rf config.cache && \
182 $$(TARGET_CONFIGURE_OPTS) \
183 $$(TARGET_CONFIGURE_ARGS) \
184 $$($$(PKG)_CONF_ENV) \
185 CONFIG_SITE=/dev/null \
186 ./configure \
187 --target=$$(GNU_TARGET_NAME) \
188 --host=$$(GNU_TARGET_NAME) \
189 --build=$$(GNU_HOST_NAME) \
190 --prefix=/usr \
191 --exec-prefix=/usr \
192 --sysconfdir=/etc \
193 --localstatedir=/var \
194 --program-prefix="" \
195 --disable-gtk-doc \
196 --disable-doc \
197 --disable-docs \
198 --disable-documentation \
199 --with-xmlto=no \
200 --with-fop=no \
201 --disable-dependency-tracking \
202 $$(DISABLE_NLS) \
203 $$(DISABLE_LARGEFILE) \
204 $$(DISABLE_IPV6) \
205 $$(ENABLE_DEBUG) \
206 $$(SHARED_STATIC_LIBS_OPTS) \
207 $$(QUIET) $$($$(PKG)_CONF_OPTS) \
209 endef
210 else
212 # Configure package for host
213 # disable all kind of documentation generation in the process,
214 # because it often relies on host tools which may or may not be
215 # installed.
216 define $(2)_CONFIGURE_CMDS
217 (cd $$($$(PKG)_SRCDIR) && rm -rf config.cache; \
218 $$(HOST_CONFIGURE_OPTS) \
219 CFLAGS="$$(HOST_CFLAGS)" \
220 LDFLAGS="$$(HOST_LDFLAGS)" \
221 $$($$(PKG)_CONF_ENV) \
222 CONFIG_SITE=/dev/null \
223 ./configure \
224 --prefix="$$(HOST_DIR)/usr" \
225 --sysconfdir="$$(HOST_DIR)/etc" \
226 --localstatedir="$$(HOST_DIR)/var" \
227 --enable-shared --disable-static \
228 --disable-gtk-doc \
229 --disable-doc \
230 --disable-docs \
231 --disable-documentation \
232 --disable-debug \
233 --with-xmlto=no \
234 --with-fop=no \
235 --disable-dependency-tracking \
236 $$(QUIET) $$($$(PKG)_CONF_OPTS) \
238 endef
239 endif
240 endif
242 $(2)_POST_PATCH_HOOKS += UPDATE_CONFIG_HOOK
244 ifeq ($$($(2)_AUTORECONF),YES)
246 # This has to come before autoreconf
247 ifeq ($$($(2)_GETTEXTIZE),YES)
248 $(2)_PRE_CONFIGURE_HOOKS += GETTEXTIZE_HOOK
249 $(2)_DEPENDENCIES += host-gettext
250 endif
251 $(2)_PRE_CONFIGURE_HOOKS += AUTORECONF_HOOK
252 # default values are not evaluated yet, so don't rely on this defaulting to YES
253 ifneq ($$($(2)_LIBTOOL_PATCH),NO)
254 $(2)_PRE_CONFIGURE_HOOKS += LIBTOOL_PATCH_HOOK
255 endif
256 $(2)_DEPENDENCIES += host-automake host-autoconf host-libtool
258 else # ! AUTORECONF = YES
260 # default values are not evaluated yet, so don't rely on this defaulting to YES
261 ifneq ($$($(2)_LIBTOOL_PATCH),NO)
262 $(2)_POST_PATCH_HOOKS += LIBTOOL_PATCH_HOOK
263 endif
265 endif
268 # Build step. Only define it if not already defined by the package .mk
269 # file.
271 ifndef $(2)_BUILD_CMDS
272 ifeq ($(4),target)
273 define $(2)_BUILD_CMDS
274 $$(TARGET_MAKE_ENV) $$($$(PKG)_MAKE_ENV) $$($$(PKG)_MAKE) $$($$(PKG)_MAKE_OPTS) -C $$($$(PKG)_SRCDIR)
275 endef
276 else
277 define $(2)_BUILD_CMDS
278 $$(HOST_MAKE_ENV) $$($$(PKG)_MAKE_ENV) $$($$(PKG)_MAKE) $$($$(PKG)_MAKE_OPTS) -C $$($$(PKG)_SRCDIR)
279 endef
280 endif
281 endif
284 # Host installation step. Only define it if not already defined by the
285 # package .mk file.
287 ifndef $(2)_INSTALL_CMDS
288 define $(2)_INSTALL_CMDS
289 $$(HOST_MAKE_ENV) $$($$(PKG)_MAKE_ENV) $$($$(PKG)_MAKE) $$($$(PKG)_INSTALL_OPTS) -C $$($$(PKG)_SRCDIR)
290 endef
291 endif
294 # Staging installation step. Only define it if not already defined by
295 # the package .mk file.
297 # Most autotools packages install libtool .la files alongside any
298 # installed libraries. These .la files sometimes refer to paths
299 # relative to the sysroot, which libtool will interpret as absolute
300 # paths to host libraries instead of the target libraries. Since this
301 # is not what we want, these paths are fixed by prefixing them with
302 # $(STAGING_DIR). As we configure with --prefix=/usr, this fix
303 # needs to be applied to any path that starts with /usr.
305 # To protect against the case that the output or staging directories
306 # themselves are under /usr, we first substitute away any occurrences
307 # of these directories as @BASE_DIR@ and @STAGING_DIR@. Note that
308 # STAGING_DIR can be outside BASE_DIR when the user sets BR2_HOST_DIR
309 # to a custom value.
311 ifndef $(2)_INSTALL_STAGING_CMDS
312 define $(2)_INSTALL_STAGING_CMDS
313 $$(TARGET_MAKE_ENV) $$($$(PKG)_MAKE_ENV) $$($$(PKG)_MAKE) $$($$(PKG)_INSTALL_STAGING_OPTS) -C $$($$(PKG)_SRCDIR)
314 find $$(STAGING_DIR)/usr/lib* -name "*.la" | xargs --no-run-if-empty \
315 $$(SED) "s:$$(BASE_DIR):@BASE_DIR@:g" \
316 -e "s:$$(STAGING_DIR):@STAGING_DIR@:g" \
317 -e "s:\(['= ]\)/usr:\\1@STAGING_DIR@/usr:g" \
318 -e "s:@STAGING_DIR@:$$(STAGING_DIR):g" \
319 -e "s:@BASE_DIR@:$$(BASE_DIR):g"
320 endef
321 endif
324 # Target installation step. Only define it if not already defined by
325 # the package .mk file.
327 ifndef $(2)_INSTALL_TARGET_CMDS
328 define $(2)_INSTALL_TARGET_CMDS
329 $$(TARGET_MAKE_ENV) $$($$(PKG)_MAKE_ENV) $$($$(PKG)_MAKE) $$($$(PKG)_INSTALL_TARGET_OPTS) -C $$($$(PKG)_SRCDIR)
330 endef
331 endif
333 # Call the generic package infrastructure to generate the necessary
334 # make targets
335 $(call inner-generic-package,$(1),$(2),$(3),$(4))
337 endef
339 ################################################################################
340 # autotools-package -- the target generator macro for autotools packages
341 ################################################################################
343 autotools-package = $(call inner-autotools-package,$(pkgname),$(call UPPERCASE,$(pkgname)),$(call UPPERCASE,$(pkgname)),target)
344 host-autotools-package = $(call inner-autotools-package,host-$(pkgname),$(call UPPERCASE,host-$(pkgname)),$(call UPPERCASE,$(pkgname)),host)