{"id":50976143,"url":"https://github.com/alessio-severi/libft","last_synced_at":"2026-06-19T08:04:19.213Z","repository":{"id":359986430,"uuid":"1248264933","full_name":"alessio-severi/libft","owner":"alessio-severi","description":"C library reimplementing standard libc functions — 42 Roma Elis","archived":false,"fork":false,"pushed_at":"2026-06-07T15:55:13.000Z","size":2735,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-06-07T17:23:59.245Z","etag":null,"topics":["42","42roma","c","libft","library"],"latest_commit_sha":null,"homepage":"","language":"C","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/alessio-severi.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-05-24T12:14:01.000Z","updated_at":"2026-06-07T15:55:16.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/alessio-severi/libft","commit_stats":null,"previous_names":["alessio-severi/libft"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/alessio-severi/libft","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alessio-severi%2Flibft","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alessio-severi%2Flibft/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alessio-severi%2Flibft/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alessio-severi%2Flibft/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/alessio-severi","download_url":"https://codeload.github.com/alessio-severi/libft/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/alessio-severi%2Flibft/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34522042,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-19T02:00:06.005Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["42","42roma","c","libft","library"],"created_at":"2026-06-19T08:04:16.058Z","updated_at":"2026-06-19T08:04:19.206Z","avatar_url":"https://github.com/alessio-severi.png","language":"C","funding_links":[],"categories":[],"sub_categories":[],"readme":"![Score](https://img.shields.io/badge/Score-100%2F100-brightgreen)\n\n*This project has been created as part of the 42 curriculum by aseveri.*\n\n## Description\n\nLibft è una libreria C che reimplementa funzioni standard della libc e aggiunge funzioni di utilità per la manipolazione di stringhe, memoria e liste concatenate. L'obiettivo è comprendere il funzionamento interno di queste funzioni implementandole da zero, senza dipendenze esterne. La libreria viene compilata come archivio statico `libft.a` e può essere riutilizzata nei progetti successivi del cursus 42.\n\n## Instructions\n\n```bash\nmake        # compila la libreria libft.a\nmake clean  # rimuove i file oggetto (.o)\nmake fclean # rimuove i file oggetto e libft.a\nmake re     # esegue fclean e ricompila da zero\n```\n\nPer usare la libreria in un progetto:\n```c\n#include \"libft.h\"\n```\n```bash\n# compilare con:\ncc -Wall -Wextra -Werror main.c -L. -lft\n```\n\n## Library\n\nLa libreria è divisa in tre parti:\n\n### Parte 1 — Reimplementazione funzioni libc\n\nFunzioni che replicano il comportamento delle originali della libc, prefissate con `ft_`:\n\n| Funzione | Descrizione |\n|---|---|\n| `ft_isalpha` | Controlla se il carattere è alfabetico. Restituisce 1 se lo è, 0 altrimenti. |\n| `ft_isdigit` | Controlla se il carattere è una cifra decimale. Restituisce 1 se lo è, 0 altrimenti. |\n| `ft_isalnum` | Controlla se il carattere è alfanumerico. Restituisce 1 se lo è, 0 altrimenti. |\n| `ft_isascii` | Controlla se il carattere rientra nel set ASCII (0-127). Restituisce 1 se lo è, 0 altrimenti. |\n| `ft_isprint` | Controlla se il carattere è stampabile. Restituisce 1 se lo è, 0 altrimenti. |\n| `ft_strlen` | Restituisce la lunghezza di una stringa. |\n| `ft_memset` | Riempie un'area di memoria con un byte specificato. |\n| `ft_bzero` | Azzera un'area di memoria. |\n| `ft_memcpy` | Copia n byte da una zona di memoria a un'altra (non gestisce overlap). |\n| `ft_memmove` | Copia n byte gestendo correttamente le sovrapposizioni di memoria. |\n| `ft_strlcpy` | Copia una stringa con garanzia di terminazione null, restituisce la lunghezza della sorgente. |\n| `ft_strlcat` | Concatena `src` a `dst` entro `dstsize` byte con garanzia di terminazione  `'\\0'`. Restituisce `dstsize + src_len` se `dst` non rientra in `dstsize` byte; altrimenti `dst_len + src_len`, utile per rilevare troncamenti su `src` in `dst`. |\n| `ft_toupper` | Converte un carattere minuscolo in maiuscolo. |\n| `ft_tolower` | Converte un carattere maiuscolo in minuscolo. |\n| `ft_strchr` | Cerca la prima occorrenza di un carattere in una stringa, restituisce un `char *` alla posizione trovata, `NULL` se non presente. |\n| `ft_strrchr` | Cerca l'ultima occorrenza di un carattere in una stringa, restituisce un `char *` alla posizione trovata, `NULL` se non presente. |\n| `ft_strncmp` | Confronta al massimo i primi n caratteri di due stringhe. |\n| `ft_memchr` | Cerca la prima occorrenza di un byte in un'area di memoria, restituisce un `void *` alla posizione trovata, `NULL` se non presente. |\n| `ft_memcmp` | Confronta due aree di memoria byte per byte. |\n| `ft_strnstr` | Cerca la sottostringa `needle` in `haystack` entro i primi `len` caratteri. Restituisce un `char *` alla prima occorrenza trovata, `haystack` stesso se `needle` è vuoto, `NULL` se non trovata o `len` è 0. |\n| `ft_atoi` | Converte una stringa in intero. |\n| `ft_calloc` | Alloca memoria inizializzata a zero. Gestisce il caso nmemb o size uguale a 0. |\n| `ft_strdup` | Duplica una stringa allocando la memoria necessaria. |\n\n### Parte 2 — Funzioni aggiuntive\n\nFunzioni non presenti nella libc o presenti in forma diversa:\n\n| Funzione | Descrizione |\n|---|---|\n| `ft_substr` | Alloca e restituisce una sottostringa di `s` a partire da `start` di lunghezza massima `len`. |\n| `ft_strjoin` | Alloca e restituisce la concatenazione di due stringhe `s1` e `s2`. |\n| `ft_strtrim` | Alloca e restituisce una copia di `s1` senza i caratteri del set `set` agli estremi. |\n| `ft_split` | Divide una stringa usando un carattere delimitatore e restituisce un array di stringhe allocate. |\n| `ft_itoa` | Converte un intero (inclusi negativi) in stringa allocata dinamicamente. |\n| `ft_strmapi` | Applica una funzione a ogni carattere di una stringa creando una nuova stringa dei risultati. |\n| `ft_striteri` | Applica una funzione a ogni carattere di una stringa passando l'indice e l'indirizzo del carattere. |\n| `ft_putchar_fd` | Scrive un carattere sul file descriptor specificato. |\n| `ft_putstr_fd` | Scrive una stringa sul file descriptor specificato. |\n| `ft_putendl_fd` | Scrive una stringa seguita da newline sul file descriptor specificato. |\n| `ft_putnbr_fd` | Scrive un intero sul file descriptor specificato. |\n\n### Parte 3 — Liste concatenate\n\nFunzioni per la manipolazione di liste concatenate tramite la `struct s_list`, accessibile tramite il typedef `t_list`:\n\n```c\ntypedef struct s_list\n{\n    void            *content;\n    struct s_list   *next;\n} t_list;\n```\n\n| Funzione | Descrizione |\n|---|---|\n| `ft_lstnew` | Alloca e restituisce un nuovo nodo con `content` inizializzato e `next` a `NULL`. |\n| `ft_lstadd_front` | Aggiunge un nodo all'inizio della lista. |\n| `ft_lstsize` | Conta e restituisce il numero di nodi nella lista. |\n| `ft_lstlast` | Restituisce l'ultimo nodo della lista. |\n| `ft_lstadd_back` | Aggiunge un nodo alla fine della lista. |\n| `ft_lstdelone` | Libera il contenuto di un nodo con la funzione `del` e libera il nodo stesso. |\n| `ft_lstclear` | Elimina e libera un nodo e tutti i suoi successori, imposta il puntatore a `NULL`. |\n| `ft_lstiter` | Itera sulla lista applicando la funzione `f` al contenuto di ogni nodo. |\n| `ft_lstmap` | Itera sulla lista applicando `f` a ogni nodo e crea una nuova lista con i risultati. La funzione `del` viene utilizzata per eliminare il contenuto di un nodo, se necessario.|\n\n## Resources\n\n- [Linux Man Pages](https://man7.org/linux/man-pages/) — riferimento principale per il comportamento atteso di ogni funzione\n- [42 Norm](https://github.com/42School/norminette) — norminette per il rispetto delle regole di stile\n\n## Copyright and licensing\n\nCopyright (C) 2026 Alessio Severi\n\nIl codice sorgente contenuto in questo repository è stato scritto da me. Il subject originale appartiene a 42 Roma Elis.\n\nQuesto codice sorgente è distribuito sotto la licenza GNU General Public License v3.0. Per maggiori dettagli, consultare il file LICENSE.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Falessio-severi%2Flibft","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Falessio-severi%2Flibft","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Falessio-severi%2Flibft/lists"}