mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 17:52:45 +01:00
d6b109f720
This tests passing CFLAGS with spaces to an application and also that even if the CFLAGS are defined after Makefile.include, they trigger a rebuild when modified. This includes an example how to pass macros with spaces to a docker build. The test as both an automated part for the CFLAGS with spaces, and a manual part for the two other features.
44 lines
1.2 KiB
Markdown
44 lines
1.2 KiB
Markdown
Build system cflags with space test
|
|
===================================
|
|
|
|
This tests that the build system now handles CFLAGS correctly.
|
|
|
|
There is an automated test for CFLAGS with spaces when defined in the Makefile.
|
|
|
|
|
|
Other manual tests
|
|
------------------
|
|
|
|
There are also 2 other manual tests that can be run
|
|
|
|
|
|
### Modifying CFLAGS defined after including Makefile.include
|
|
|
|
CFLAGS defined after `Makefile.include` trigger a rebuild when changed.
|
|
|
|
Running the test once should work and then when changing `CONFIGURATION_VALUE`
|
|
it should pass too.
|
|
|
|
make flash test
|
|
CONFIGURATION_VALUE=1 make flash test
|
|
|
|
|
|
### Setting CFLAGS with space for docker
|
|
|
|
This one is a trickier as CFLAGS are modified in the Makefile, so cannot be
|
|
detected automatically in the docker handling. The solution is to pass it with
|
|
`DOCKER_ENVIRONMENT_CMDLINE`.
|
|
|
|
When the CFLAGS is defined like this, I did not find another solution than
|
|
escaping the space.
|
|
|
|
```
|
|
DOCKER_ENVIRONMENT_CMDLINE=$'-e CFLAGS=-DSTRING_FROM_DOCKER=\'\\\"with\ space\\\"\'' \
|
|
BUILD_IN_DOCKER=1 make
|
|
grep '#define STRING_FROM_DOCKER "with space"' bin/native/riotbuild/riotbuild.h \
|
|
|| { echo 'ERROR CFLAGS not passed correctly' >&2; false; }
|
|
|
|
...
|
|
#define STRING_FROM_DOCKER "with space"
|
|
```
|