96 lines
2.6 KiB
Markdown
Raw Permalink Normal View History

2025-03-03 23:19:24 +01:00
# Test 16 - Gestion des variables sur plusieurs lignes
2025-03-03 23:19:24 +01:00
Ce test vérifie si `bake` et `make` gèrent correctement les variables définies sur plusieurs lignes
avec un caractère de continuation (`\`).
## Sommaire
- [Structure du test](#structure-du-test)
- [Contenu des fichiers de règles](#contenu-des-fichiers-de-règles)
- [Objectif du test](#objectif-du-test)
- [Comment exécuter le test](#comment-exécuter-le-test)
- [Test manuel](#test-manuel)
- [Résultats attendus](#résultats-attendus)
## Structure du test
```
test-16-variables-multi-lignes/
├── README.md # Ce fichier
├── bake/
│ ├── Bakefile # Fichier de règles pour bake
│ ├── bakefile.jar # Exécutable de bake (JAR)
│ ├── main.c # Fichier source principal
│ ├── module.c # Fichier source du module
2025-03-10 13:21:31 +01:00
└── make/
├── Makefile # Fichier de règles pour make
├── main.c # Fichier source principal
└── module.c # Fichier source du module
2025-03-03 23:19:24 +01:00
```
## Contenu des fichiers de règles
Les fichiers `Makefile` et `Bakefile` utilisent des variables définies sur plusieurs lignes :
```makefile
COMPILER = gcc
CFLAGS = -Wall \
-ansi \
-pedantic
OUTPUT = program
OBJS = main.o module.o
# Règle principale
$(OUTPUT): $(OBJS)
$(COMPILER) $(CFLAGS) -o $(OUTPUT) $(OBJS)
main.o: main.c
$(COMPILER) $(CFLAGS) -c main.c -o main.o
module.o: module.c
$(COMPILER) $(CFLAGS) -c module.c -o module.o
clean:
rm -f $(OUTPUT) $(OBJS)
```
## Objectif du test
Ce test vérifie que `bake` et `make` :
1. Interprètent correctement les variables définies sur plusieurs lignes avec `\`.
2. Utilisent les options de compilation définies par `CFLAGS` sans erreur.
3. Gèrent correctement la compilation et la création de l'exécutable `program`.
4. Comparent les messages de sortie pour s'assurer que `bake` et `make` gèrent les variables multi-lignes de manière similaire.
## Comment exécuter le test
### Test manuel
1. Compilez avec Make :
```bash
cd make
make
```
L'exécutable `program` doit être généré.
2. Exécutez le programme compilé :
```bash
./program
```
Le programme doit s'exécuter normalement.
3. Faites la même procédure avec Bake :
```bash
cd bake
java -cp bakefile.jar fr.monlouyan.bakefile.Main
```
4. Comparez les résultats et les messages affichés.
## Résultats attendus
- `bake` et `make` doivent interpréter correctement les variables multi-lignes.
- La compilation doit réussir et produire l'exécutable `program`.
- L'exécution de `program` ne doit pas rencontrer d'erreurs.