Skip to content

get_next_line is a 42 school project meant to teach us how to read from a file descriptor and use static variables.

Notifications You must be signed in to change notification settings

mcombeau/get_next_line

Repository files navigation

get_next_line

get_next_line 42 project badge

The 42 school's get_next_line project is where we learn to read from a file descriptor, as well as the use of static variables.

This function returns a single line from a given file descriptor. If called in a loop, get_next_line returns the entire contents of a file, line by line until it reaches the end of the file. It can be compiled specifying any buffer size.


🇺🇸 Read my articles in English about the concepts tackled in this project:

🇫🇷 Lire mes articles en français sur les concepts abordés dans ce projet :


Status

Finished: 2022-01-21. Grade: 125/100.

Usage

This function is not a stand-alone program, its files must be included and compiled within another project.

Example main.c:

#include <stdio.h>
#include <fcntl.h>
#include <unistd.h>
#include "get_next_line.h"

int	main(int argc, char **argv)
{
	int	fd;
	char	*line;

	(void)argc;
	fd = open(argv[1], O_RDONLY);
	line = "";
	while (line != NULL)
	{
		line = get_next_line(fd);
		printf("%s", line);
	}
	fd = close(fd);
	return (0);
}

Compilation:

gcc main.c get_next_line.c get_next_line_utils.c

BUFFER_SIZE can be specified at compilation to override the default BUFFER_SIZE:

gcc -D BUFFER_SIZE=42 main.c get_next_line.c get_next_line_utils.c

Execution:

./a.out [file]

Output should show the entire contents of the given file.

Execution with stdin:

./a.out /dev/tty

Program will wait for input, then once the enter key is pressed, print out the input as well as get_next_line's output. The process can be killed with ctrl-c.


Made by mcombeau: [email protected] | LinkedIn: mcombeau | Website: codequoi.com

About

get_next_line is a 42 school project meant to teach us how to read from a file descriptor and use static variables.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages