mirror of
https://github.com/Ladebeze66/libft.git
synced 2025-12-13 04:36:55 +01:00
Add files via upload
This commit is contained in:
parent
ff10aaaf6b
commit
dc63981955
522
libft.fr.subject.pdf
Normal file
522
libft.fr.subject.pdf
Normal file
@ -0,0 +1,522 @@
|
|||||||
|
Libft
|
||||||
|
|
||||||
|
Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Résumé:
|
||||||
|
Ce projet a pour objectif de vous faire coder en C une bibliothèque de fonctions usuelles
|
||||||
|
|
||||||
|
que vous pourrez utiliser pour vos prochains projets.
|
||||||
|
Version: 16.1
|
||||||
|
Table des matières
|
||||||
|
|
||||||
|
I Introduction 2
|
||||||
|
|
||||||
|
II Règles communes 3
|
||||||
|
|
||||||
|
III Partie obligatoire 4
|
||||||
|
|
||||||
|
III.1 Considérations techniques . . . . . . . . . . . . . . . . . . . . . . . . . 4
|
||||||
|
|
||||||
|
III.2 Partie 1 - Fonctions de la libc . . . . . . . . . . . . . . . . . . . . . . 5
|
||||||
|
|
||||||
|
III.3 Partie 2 - Fonctions supplémentaires . . . . . . . . . . . . . . . . . . . 6
|
||||||
|
|
||||||
|
IV Partie bonus 11
|
||||||
|
|
||||||
|
V Rendu et peer-evaluation 16
|
||||||
|
|
||||||
|
1
|
||||||
|
Chapitre I
|
||||||
|
Introduction
|
||||||
|
|
||||||
|
La programmation en C est une activité très laborieuse dès lors que l’on n’a pas accès
|
||||||
|
à toutes ces petites fonctions usuelles très pratiques. C’est pourquoi nous vous proposons
|
||||||
|
à travers ce projet de prendre le temps de récrire ces fonctions, de les comprendre et
|
||||||
|
de vous les approprier. Vous pourrez alors réutiliser votre bibliothèque pour travailler
|
||||||
|
efficacement sur vos projets suivants en C.
|
||||||
|
|
||||||
|
Prenez le temps d’enrichir votre libft tout au long de l’année. Cependant, pour
|
||||||
|
chacun de vos projets futurs, veillez toujours à vérifier quelles sont les fonctions autorisées !
|
||||||
|
|
||||||
|
2
|
||||||
|
Chapitre II
|
||||||
|
|
||||||
|
Règles communes
|
||||||
|
|
||||||
|
• Votre projet doit être écrit en C.
|
||||||
|
|
||||||
|
• Votre projet doit être codé à la Norme. Si vous avez des fichiers ou fonctions bonus,
|
||||||
|
celles-ci seront inclues dans la vérification de la norme et vous aurez 0 au projet
|
||||||
|
en cas de faute de norme.
|
||||||
|
|
||||||
|
• Vos fonctions ne doivent pas s’arrêter de manière inattendue (segmentation fault,
|
||||||
|
bus error, double free, etc) mis à part dans le cas d’un comportement indéfini. Si
|
||||||
|
cela arrive, votre projet sera considéré non fonctionnel et vous aurez 0 au projet.
|
||||||
|
|
||||||
|
• Toute mémoire allouée sur la heap doit être libéré lorsque c’est nécessaire. Aucun
|
||||||
|
leak ne sera toléré.
|
||||||
|
|
||||||
|
• Si le projet le demande, vous devez rendre un Makefile qui compilera vos sources
|
||||||
|
pour créer la sortie demandée, en utilisant les flags -Wall, -Wextra et -Werror.
|
||||||
|
Votre Makefile ne doit pas relink.
|
||||||
|
|
||||||
|
• Si le projet demande un Makefile, votre Makefile doit au minimum contenir les
|
||||||
|
règles $(NAME), all, clean, fclean et re.
|
||||||
|
|
||||||
|
• Pour rendre des bonus, vous devez inclure une règle bonus à votre Makefile qui
|
||||||
|
ajoutera les divers headers, librairies ou fonctions qui ne sont pas autorisées dans
|
||||||
|
la partie principale du projet. Les bonus doivent être dans un fichier différent :
|
||||||
|
_bonus.{c/h}. L’évaluation de la partie obligatoire et de la partie bonus sont
|
||||||
|
faites séparément.
|
||||||
|
|
||||||
|
• Si le projet autorise votre libft, vous devez copier ses sources et son Makefile
|
||||||
|
associé dans un dossier libft contenu à la racine. Le Makefile de votre projet doit
|
||||||
|
compiler la librairie à l’aide de son Makefile, puis compiler le projet.
|
||||||
|
|
||||||
|
• Nous vous recommandons de créer des programmes de test pour votre projet, bien
|
||||||
|
que ce travail ne sera pas rendu ni noté. Cela vous donnera une chance de
|
||||||
|
tester facilement votre travail ainsi que celui de vos pairs.
|
||||||
|
|
||||||
|
• Vous devez rendre votre travail sur le git qui vous est assigné. Seul le travail déposé
|
||||||
|
sur git sera évalué. Si Deepthought doit corriger votre travail, cela sera fait à la fin
|
||||||
|
des peer-evaluations. Si une erreur se produit pendant l’évaluation Deepthought,
|
||||||
|
celle-ci s’arrête.
|
||||||
|
|
||||||
|
3
|
||||||
|
Chapitre III
|
||||||
|
Partie obligatoire
|
||||||
|
|
||||||
|
Nom du libft.a
|
||||||
|
|
||||||
|
programme Makefile, libft.h, ft_*.c
|
||||||
|
NAME, all, clean, fclean, re
|
||||||
|
Fichiers de rendu Détails ci-dessous
|
||||||
|
|
||||||
|
Makefile n/a
|
||||||
|
Créez votre propre bibliothèque contenant des
|
||||||
|
Fonctions fonctions utiles pour la suite de votre cursus.
|
||||||
|
|
||||||
|
externes
|
||||||
|
|
||||||
|
autorisées
|
||||||
|
|
||||||
|
Libft autorisée
|
||||||
|
|
||||||
|
Description
|
||||||
|
|
||||||
|
III.1 Considérations techniques
|
||||||
|
|
||||||
|
• Interdiction d’utiliser des variables globales.
|
||||||
|
|
||||||
|
• Si vous avez besoin de fonctions auxiliaires pour réaliser une fonction complexe,
|
||||||
|
vous devez définir ces dernières en static dans le respect de la Norme. Ainsi, leur
|
||||||
|
portée sera limitée au fichier concerné.
|
||||||
|
|
||||||
|
• Vous devez rendre tous vos fichiers à la racine de votre dépôt.
|
||||||
|
|
||||||
|
• Il est interdit de rendre des fichiers non utilisés.
|
||||||
|
|
||||||
|
• Chaque fichier .c doit être compilé avec les flags -Wall -Wextra -Werror.
|
||||||
|
• Vous devez utiliser la commande ar pour créer votre bibliothèque. L’utilisation de
|
||||||
|
|
||||||
|
la commande libtool est interdite.
|
||||||
|
• Votre libft.a doit être créé à la racine de votre dépôt.
|
||||||
|
|
||||||
|
4
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
III.2 Partie 1 - Fonctions de la libc
|
||||||
|
|
||||||
|
Dans cette première partie, vous devez recoder un ensemble de fonctions de la libc
|
||||||
|
telles que décrites dans leur man respectif sur votre système. Vos fonctions devront
|
||||||
|
avoir exactement le même prototype et le même comportement que les originales. Seule
|
||||||
|
différence, leur nom devra être préfixé par ’ft_’. Ainsi, strlen devient ft_strlen.
|
||||||
|
|
||||||
|
Certains prototypes des fonctions que vous devez recoder utilisent le
|
||||||
|
qualifieur de type ’restrict’. Ce mot-clé fait parti du standard c99.
|
||||||
|
Par conséquent, vous ne devez pas l’utiliser pour vos prototypes et
|
||||||
|
ne pas compiler votre code avec le flag -std=c99.
|
||||||
|
|
||||||
|
Vous devez recoder les fonctions suivantes. Elles ne nécessitent aucune fonction externe :
|
||||||
|
|
||||||
|
• isalpha • toupper
|
||||||
|
• isdigit • tolower
|
||||||
|
• isalnum • strchr
|
||||||
|
• isascii • strrchr
|
||||||
|
• isprint • strncmp
|
||||||
|
• strlen • memchr
|
||||||
|
• memset • memcmp
|
||||||
|
• bzero • strnstr
|
||||||
|
• memcpy • atoi
|
||||||
|
• memmove
|
||||||
|
• strlcpy
|
||||||
|
• strlcat
|
||||||
|
|
||||||
|
Pour les deux fonctions suivantes, vous pourrez faire appel à la fonction malloc() :
|
||||||
|
|
||||||
|
• calloc
|
||||||
|
• strdup
|
||||||
|
|
||||||
|
5
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
III.3 Partie 2 - Fonctions supplémentaires
|
||||||
|
|
||||||
|
Dans cette seconde partie, vous devrez implémenter un certain nombre de fonctions
|
||||||
|
absentes de la libc, ou qui y sont mais sous une forme différente.
|
||||||
|
|
||||||
|
Certaines de ces fonctions peuvent faciliter l’écriture des fonctions
|
||||||
|
demandées dans la Partie 1.
|
||||||
|
|
||||||
|
Function name ft_substr
|
||||||
|
Prototype char *ft_substr(char const *s, unsigned int start,
|
||||||
|
Fichiers de rendu size_t len);
|
||||||
|
Paramètres -
|
||||||
|
s: La chaîne de laquelle extraire la nouvelle
|
||||||
|
Valeur de retour chaîne.
|
||||||
|
Fonctions start: L’index de début de la nouvelle chaîne dans
|
||||||
|
externes la chaîne ’s’.
|
||||||
|
autorisées len: La taille maximale de la nouvelle chaîne.
|
||||||
|
Description La nouvelle chaîne de caractères.
|
||||||
|
NULL si l’allocation échoue.
|
||||||
|
malloc
|
||||||
|
|
||||||
|
Alloue (avec malloc(3)) et retourne une chaîne de
|
||||||
|
caractères issue de la chaîne ’s’.
|
||||||
|
Cette nouvelle chaîne commence à l’index ’start’ et
|
||||||
|
a pour taille maximale ’len’.
|
||||||
|
|
||||||
|
Function name ft_strjoin
|
||||||
|
Prototype char *ft_strjoin(char const *s1, char const *s2);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s1: La chaîne de caractères préfixe.
|
||||||
|
s2: La chaîne de caractères suffixe.
|
||||||
|
Valeur de retour La nouvelle chaîne de caractères.
|
||||||
|
NULL si l’allocation échoue.
|
||||||
|
Fonctions malloc
|
||||||
|
externes
|
||||||
|
autorisées Alloue (avec malloc(3)) et retourne une nouvelle
|
||||||
|
Description chaîne, résultat de la concaténation de s1 et s2.
|
||||||
|
|
||||||
|
6
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_strtrim
|
||||||
|
Prototype char *ft_strtrim(char const *s1, char const *set);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s1: La chaîne de caractères à trimmer.
|
||||||
|
set: Le set de référence de caractères à trimmer.
|
||||||
|
Valeur de retour La chaîne de caractères trimmée.
|
||||||
|
NULL si l’allocation échoue.
|
||||||
|
Fonctions malloc
|
||||||
|
externes
|
||||||
|
autorisées Alloue (avec malloc(3)) et retourne une copie de
|
||||||
|
Description la chaîne ’s1’, sans les caractères spécifiés
|
||||||
|
dans ’set’ au début et à la fin de la chaîne de
|
||||||
|
caractères.
|
||||||
|
|
||||||
|
Function name ft_split
|
||||||
|
Prototype char **ft_split(char const *s, char c);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s: La chaîne de caractères à découper.
|
||||||
|
c: Le caractère délimiteur.
|
||||||
|
Valeur de retour Le tableau de nouvelles chaînes de caractères
|
||||||
|
résultant du découpage.
|
||||||
|
Fonctions NULL si l’allocation échoue.
|
||||||
|
externes malloc, free
|
||||||
|
autorisées
|
||||||
|
Description Alloue (avec malloc(3)) et retourne un tableau
|
||||||
|
de chaînes de caractères obtenu en séparant ’s’ à
|
||||||
|
l’aide du caractère ’c’, utilisé comme délimiteur.
|
||||||
|
Le tableau doit être terminé par NULL.
|
||||||
|
|
||||||
|
Function name ft_itoa
|
||||||
|
Prototype char *ft_itoa(int n);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres n: L’entier à convertir.
|
||||||
|
Valeur de retour La chaîne de caractères représentant l’entier.
|
||||||
|
NULL si l’allocation échoue.
|
||||||
|
Fonctions malloc
|
||||||
|
externes
|
||||||
|
autorisées Alloue (avec malloc(3)) et retourne une chaîne
|
||||||
|
Description de caractères représentant l’entier ’n’ reçu en
|
||||||
|
argument. Les nombres négatifs doivent être gérés.
|
||||||
|
|
||||||
|
7
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_strmapi
|
||||||
|
Prototype char *ft_strmapi(char const *s, char (*f)(unsigned
|
||||||
|
int, char));
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s: La chaîne de caractères sur laquelle itérer.
|
||||||
|
f: La fonction à appliquer à chaque caractère.
|
||||||
|
Valeur de retour La chaîne de caractères résultant des applications
|
||||||
|
successives de ’f’.
|
||||||
|
Fonctions Retourne NULL si l’allocation échoue.
|
||||||
|
externes malloc
|
||||||
|
autorisées
|
||||||
|
Description Applique la fonction ’f’ à chaque caractère de
|
||||||
|
la chaîne de caractères ’s’, passant son index
|
||||||
|
comme premier argument et le caractère lui-même
|
||||||
|
comme second argument. Une nouvelle chaîne de
|
||||||
|
caractères est créée (avec malloc(3)), résultant
|
||||||
|
des applications successives de ’f’.
|
||||||
|
|
||||||
|
Function name ft_striteri
|
||||||
|
Prototype void ft_striteri(char *s, void (*f)(unsigned int,
|
||||||
|
char*));
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s: La chaîne de caractères sur laquelle itérer.
|
||||||
|
f: La fonction à appliquer à chaque caractère.
|
||||||
|
Valeur de retour Aucune
|
||||||
|
Fonctions Aucune
|
||||||
|
externes
|
||||||
|
autorisées Applique la fonction ’f’ à chaque caractère de la
|
||||||
|
Description chaîne de caractères transmise comme argument,
|
||||||
|
et en passant son index comme premier argument.
|
||||||
|
Chaque caractère est transmis par adresse à ’f’
|
||||||
|
afin d’être modifié si nécessaire.
|
||||||
|
|
||||||
|
8
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_putchar_fd
|
||||||
|
Prototype void ft_putchar_fd(char c, int fd);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres c: Le caractère à écrire.
|
||||||
|
fd: Le descripteur de fichier sur lequel écrire.
|
||||||
|
Valeur de retour Aucune
|
||||||
|
Fonctions write
|
||||||
|
externes
|
||||||
|
autorisées Écrit le caractère ’c’ sur le descripteur de
|
||||||
|
Description fichier donné.
|
||||||
|
|
||||||
|
Function name ft_putstr_fd
|
||||||
|
Prototype void ft_putstr_fd(char *s, int fd);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s: La chaîne de caractères à écrire.
|
||||||
|
fd: Le descripteur de fichier sur lequel écrire.
|
||||||
|
Valeur de retour Aucune
|
||||||
|
Fonctions write
|
||||||
|
externes
|
||||||
|
autorisées Écrit la chaîne de caractères ’s’ sur le
|
||||||
|
Description descripteur de fichier donné.
|
||||||
|
|
||||||
|
Function name ft_putendl_fd
|
||||||
|
Prototype void ft_putendl_fd(char *s, int fd);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres s: La chaîne de caractères à écrire.
|
||||||
|
fd: Le descripteur de fichier sur lequel écrire.
|
||||||
|
Valeur de retour Aucune
|
||||||
|
Fonctions write
|
||||||
|
externes
|
||||||
|
autorisées Écrit La chaîne de caractères ’s’ sur le
|
||||||
|
Description descripteur de fichier donné suivie d’un retour à
|
||||||
|
la ligne.
|
||||||
|
|
||||||
|
9
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_putnbr_fd
|
||||||
|
Prototype void ft_putnbr_fd(int n, int fd);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres n: L’entier à écrire.
|
||||||
|
fd: Le descripteur de fichier sur lequel écrire.
|
||||||
|
Valeur de retour Aucune
|
||||||
|
Fonctions write
|
||||||
|
externes
|
||||||
|
autorisées Écrit l’entier ’n’ sur le descripteur de fichier
|
||||||
|
Description donné.
|
||||||
|
|
||||||
|
10
|
||||||
|
Chapitre IV
|
||||||
|
Partie bonus
|
||||||
|
|
||||||
|
Si vous avez réussi parfaitement la partie obligatoire, cette section propose quelques
|
||||||
|
pistes pour aller plus loin. Un peu comme quand vous achetez un DLC pour un jeu vidéo.
|
||||||
|
|
||||||
|
Avoir des fonctions de manipulation de mémoire brute et de chaînes de caractères
|
||||||
|
est très pratique. Toutefois, vous vous rendrez vite compte qu’avoir des fonctions de
|
||||||
|
manipulation de listes est encore plus pratique.
|
||||||
|
|
||||||
|
Vous utiliserez la structure suivante pour représenter les maillons de votre liste. Sa
|
||||||
|
déclaration est à ajouter à votre fichier libft.h :
|
||||||
|
|
||||||
|
typedef struct s_list
|
||||||
|
{
|
||||||
|
*content;
|
||||||
|
void *next;
|
||||||
|
struct s_list t_list;
|
||||||
|
}
|
||||||
|
|
||||||
|
Les membres de la structure t_list sont les suivants :
|
||||||
|
|
||||||
|
• content : La donnée contenue dans le maillon.
|
||||||
|
void * permet de stocker une donnée de n’importe quel type.
|
||||||
|
|
||||||
|
• next : L’adresse du maillon suivant de la liste, ou NULL si le maillon suivant est le
|
||||||
|
dernier.
|
||||||
|
|
||||||
|
Dans votre Makefile, une règle make bonus vous permettra d’ajouter les fonctions
|
||||||
|
demandées à votre libft.a.
|
||||||
|
|
||||||
|
Vous ne devez pas suffixer vos fichiers .c et vos fichiers d’en-tête avec _bonus. En effet,
|
||||||
|
ajoutez le suffixe _bonus seulement aux fichiers supplémentaires réalisés exclusivement
|
||||||
|
pour la partie bonus.
|
||||||
|
|
||||||
|
Les bonus ne seront évalués que si la partie obligatoire est
|
||||||
|
PARFAITE. Par parfaite, nous entendons complète et sans aucun
|
||||||
|
dysfonctionnement. Si vous n’avez pas réussi TOUS les points de la
|
||||||
|
partie obligatoire, votre partie bonus ne sera pas prise en compte.
|
||||||
|
|
||||||
|
11
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Implémentez les fonctions suivantes afin de manipuler vos listes aisément.
|
||||||
|
|
||||||
|
Function name ft_lstnew
|
||||||
|
Prototype t_list *ft_lstnew(void *content);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres content: Le contenu du nouvel élément.
|
||||||
|
Valeur de retour Le nouvel élément
|
||||||
|
Fonctions malloc
|
||||||
|
externes
|
||||||
|
autorisées Alloue (avec malloc(3)) et renvoie un nouvel
|
||||||
|
Description élément. La variable membre ’content’ est
|
||||||
|
initialisée à l’aide de la valeur du paramètre
|
||||||
|
’content’. La variable ’next’ est initialisée à
|
||||||
|
NULL.
|
||||||
|
|
||||||
|
Function name ft_lstadd_front
|
||||||
|
Prototype void ft_lstadd_front(t_list **lst, t_list *new);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: L’adresse du pointeur vers le premier élément
|
||||||
|
de la liste.
|
||||||
|
Valeur de retour new: L’adresse du pointeur vers l’élément à
|
||||||
|
Fonctions rajouter à la liste.
|
||||||
|
externes Aucune
|
||||||
|
autorisées Aucune
|
||||||
|
Description
|
||||||
|
Ajoute l’élément ’new’ au début de la liste.
|
||||||
|
|
||||||
|
Function name ft_lstsize
|
||||||
|
Prototype int ft_lstsize(t_list *lst);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: Le début de la liste.
|
||||||
|
Valeur de retour Taille de la liste
|
||||||
|
Fonctions Aucune
|
||||||
|
externes
|
||||||
|
autorisées Compte le nombre d’éléments de la liste.
|
||||||
|
Description
|
||||||
|
|
||||||
|
12
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_lstlast
|
||||||
|
Prototype t_list *ft_lstlast(t_list *lst);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: Le début de la liste.
|
||||||
|
Valeur de retour Dernier élément de la liste
|
||||||
|
Fonctions Aucune
|
||||||
|
externes
|
||||||
|
autorisées Renvoie le dernier élément de la liste.
|
||||||
|
Description
|
||||||
|
|
||||||
|
Function name ft_lstadd_back
|
||||||
|
Prototype void ft_lstadd_back(t_list **lst, t_list *new);
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: L’adresse du pointeur vers le premier élément
|
||||||
|
de la liste.
|
||||||
|
Valeur de retour new: L’adresse du pointeur vers l’élément à
|
||||||
|
Fonctions rajouter à la liste.
|
||||||
|
externes Aucune
|
||||||
|
autorisées Aucune
|
||||||
|
Description
|
||||||
|
Ajoute l’élément ’new’ à la fin de la liste.
|
||||||
|
|
||||||
|
Function name ft_lstdelone
|
||||||
|
Prototype void ft_lstdelone(t_list *lst, void (*del)(void
|
||||||
|
*));
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: L’élément à free
|
||||||
|
del: L’adresse de la fonction permettant de
|
||||||
|
Valeur de retour supprimer le contenu de l’élément.
|
||||||
|
Fonctions Aucune
|
||||||
|
externes free
|
||||||
|
autorisées
|
||||||
|
Description Libère la mémoire de l’élément passé en argument en
|
||||||
|
utilisant la fonction ’del’ puis avec free(3). La
|
||||||
|
mémoire de ’next’ ne doit pas être free.
|
||||||
|
|
||||||
|
13
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_lstclear
|
||||||
|
Prototype void ft_lstclear(t_list **lst, void (*del)(void
|
||||||
|
*));
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: L’adresse du pointeur vers un élément.
|
||||||
|
del: L’adresse de la fonction permettant de
|
||||||
|
Valeur de retour supprimer le contenu d’un élément.
|
||||||
|
Fonctions Aucune
|
||||||
|
externes free
|
||||||
|
autorisées
|
||||||
|
Description Supprime et libère la mémoire de l’élément passé en
|
||||||
|
paramètre, et de tous les éléments qui suivent, à
|
||||||
|
l’aide de ’del’ et de free(3)
|
||||||
|
Enfin, le pointeur initial doit être mis à NULL.
|
||||||
|
|
||||||
|
Function name ft_lstiter
|
||||||
|
Prototype void ft_lstiter(t_list *lst, void (*f)(void *));
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: L’adresse du pointeur vers un élément.
|
||||||
|
f: L’adresse de la fonction à appliquer.
|
||||||
|
Valeur de retour Aucune
|
||||||
|
Fonctions Aucune
|
||||||
|
externes
|
||||||
|
autorisées Itère sur la liste ’lst’ et applique la fonction
|
||||||
|
Description ’f’ au contenu chaque élément.
|
||||||
|
|
||||||
|
14
|
||||||
|
Libft Ta propre bibliothèque rien que pour toi
|
||||||
|
|
||||||
|
Function name ft_lstmap
|
||||||
|
Prototype t_list *ft_lstmap(t_list *lst, void *(*f)(void *),
|
||||||
|
void (*del)(void *));
|
||||||
|
Fichiers de rendu -
|
||||||
|
Paramètres lst: L’adresse du pointeur vers un élément.
|
||||||
|
f: L’adresse de la fonction à appliquer.
|
||||||
|
Valeur de retour del: L’adresse de la fonction permettant de
|
||||||
|
supprimer le contenu d’un élément.
|
||||||
|
Fonctions La nouvelle liste.
|
||||||
|
externes NULL si l’allocation échoue
|
||||||
|
autorisées malloc, free
|
||||||
|
Description
|
||||||
|
Itère sur la liste ’lst’ et applique la fonction
|
||||||
|
’f ’au contenu de chaque élément. Crée une nouvelle
|
||||||
|
liste résultant des applications successives de
|
||||||
|
’f’. La fonction ’del’ est là pour détruire le
|
||||||
|
contenu d’un élément si nécessaire.
|
||||||
|
|
||||||
|
15
|
||||||
|
Chapitre V
|
||||||
|
Rendu et peer-evaluation
|
||||||
|
|
||||||
|
Rendez votre travail sur votre dépot Git comme d’habitude. Seul le travail présent
|
||||||
|
sur votre dépot sera évalué en soutenance. Vérifiez bien les noms de vos dossiers et de
|
||||||
|
vos fichiers afin que ces derniers soient conformes aux demandes du sujet.
|
||||||
|
|
||||||
|
Vous devez rendre tous vos fichiers à la racine de votre dépôt.
|
||||||
|
|
||||||
|
Rnpu cebwrpg bs gur 97 Pbzzba Pber pbagnvaf na rapbqrq uvag. Sbe rnpu
|
||||||
|
pvepyr, bayl bar cebwrpg cebivqrf gur pbeerpg uvag arrqrq sbe gur
|
||||||
|
arkg pvepyr. Guvf punyyratr vf vaqvivqhny, gurer vf bayl n cevmr sbe
|
||||||
|
bar fghqrag jvaare cebivqvat nyy qrpbqrq zrffntrf. Nal nqinagntrq
|
||||||
|
crbcyr pna cynl, yvxr pheerag be sbezre fgnss, ohg gur cevmr jvyy
|
||||||
|
erznva flzobyvp. Gur uvag sbe guvf svefg cebwrpg vf:
|
||||||
|
Ynetr pbjf trarebfvgl pbzrf jvgu punegf naq sbhe oybaqr ungf gb qrsl
|
||||||
|
hccre tenivgl ureb
|
||||||
|
|
||||||
|
16
|
||||||
|
|
||||||
BIN
libft.webp
Normal file
BIN
libft.webp
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 370 KiB |
Loading…
x
Reference in New Issue
Block a user