1
1
mirror of https://github.com/theoludwig/libcproject.git synced 2024-11-14 16:03:13 +01:00
libcproject/lib/filesystem.h

76 lines
1.6 KiB
C
Raw Permalink Normal View History

#ifndef __LIBCPROJECT_FILESYSTEM__
#define __LIBCPROJECT_FILESYSTEM__
2023-01-05 19:28:05 +01:00
2023-01-07 19:38:01 +01:00
#include <dirent.h>
#include <errno.h>
2023-01-05 19:28:05 +01:00
#include <fcntl.h>
2023-01-07 19:38:01 +01:00
#include <pwd.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include "string.h"
2023-06-25 15:07:34 +02:00
#include "types.h"
2023-06-25 14:34:33 +02:00
2023-01-05 19:28:05 +01:00
/**
* @brief Read the content of a file.
*
* @param path
* @param file_content
2023-08-09 21:08:15 +02:00
* @param file_size The size of the file that was read (mutated by the function).
* @retval -1 if the file does not exist or if there is an error.
* @retval 0 for success.
2023-08-09 21:08:15 +02:00
* @return int
* @since v1.0.0
2023-01-05 19:28:05 +01:00
*/
int filesystem_read(string_t path, byte_t **file_content, off_t *file_size);
2023-01-05 19:28:05 +01:00
/**
* @brief Write the content to a file.
*
* @param path
* @param file_content
* @param file_size
* @retval -1 if there is an error.
* @retval 0 for success.
2023-08-09 21:08:15 +02:00
* @return int
* @since v1.0.0
2023-01-05 19:28:05 +01:00
*/
int filesystem_write(string_t path, byte_t *file_content, off_t file_size);
2023-01-05 19:28:05 +01:00
2023-08-06 12:06:43 +02:00
/**
* @brief Check if a path exists.
*
* @param path
2023-08-09 21:08:15 +02:00
* @return true
* @return false
2023-08-06 12:06:43 +02:00
* @since v3.1.0
*/
bool filesystem_exists(string_t path);
2023-08-06 12:14:13 +02:00
/**
* @brief Removes a path.
*
* @param path
* @return int
* @retval -1 if there is an error.
* @retval 0 for success.
2023-08-09 21:08:15 +02:00
* @return int
2023-08-06 12:14:13 +02:00
* @since v3.1.0
*/
int filesystem_remove(string_t path);
2023-01-05 19:28:05 +01:00
/**
* @brief Get the mimetype of a file based on its extension.
2023-01-05 19:28:05 +01:00
*
* @param path
* @see https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types
* @see https://www.iana.org/assignments/media-types/media-types.xhtml
2023-08-09 21:08:15 +02:00
* @return string_t
* @since v1.0.0
2023-01-05 19:28:05 +01:00
*/
string_t filesystem_get_mimetype(string_t path);
2023-01-05 19:28:05 +01:00
#endif