summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
Diffstat (limited to 'src/common')
-rw-r--r--src/common/Makefile.am1
-rw-r--r--src/common/io.c177
-rw-r--r--src/common/io.h9
-rw-r--r--src/common/pathname.c179
-rw-r--r--src/common/pathname.h11
5 files changed, 191 insertions, 186 deletions
diff --git a/src/common/Makefile.am b/src/common/Makefile.am
index 8366376..7da1a13 100644
--- a/src/common/Makefile.am
+++ b/src/common/Makefile.am
@@ -58,6 +58,7 @@ libcommon4_la_SOURCES = \
compiler.h \
environment.h environment.c \
extstr.h extstr.c \
+ io.h io.c \
pathname.h pathname.c \
sort.h sort.c \
xdg.h xdg.c
diff --git a/src/common/io.c b/src/common/io.c
index a710721..3208a2a 100644
--- a/src/common/io.c
+++ b/src/common/io.c
@@ -25,21 +25,15 @@
#include <errno.h>
-#include <fcntl.h>
-#include <libgen.h>
#include <malloc.h>
#include <stdint.h>
-#include <stdio.h>
-#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
-#include <sys/stat.h>
#include <sys/un.h>
#include "../core/logs.h"
-#include "../core/params.h"
@@ -290,174 +284,3 @@ bool safe_send(int sockfd, const void *buf, size_t len, int flags)
return (remaining == 0);
}
-
-
-/******************************************************************************
-* *
-* Paramètres : path = chemin d'accès à valider. *
-* *
-* Description : S'assure qu'un chemin donné existe dans le système. *
-* *
-* Retour : 0 si le chemin est actuellement présent, -1 sinon. *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-int ensure_path_exists(const char *path)
-{
- int result; /* Bilan de l'assurance */
- char *copy; /* Chemin libérable */
- char *tmp; /* Chemin altérable */
-
- copy = strdup(path);
- tmp = dirname(copy);
-
- result = access(tmp, W_OK | X_OK);
-
- if (result != 0)
- {
- result = ensure_path_exists(tmp);
-
- if (result == 0)
- result = mkdir(tmp, 0700);
-
- }
-
- free(copy);
-
- return result;
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : prefix = préfixe du nom du fichier temporaire à créer. *
-* suffix = éventuel suffixe à coller au nom de fichier. *
-* filename = chemin d'accès complet au nouveau fichier. [OUT] *
-* *
-* Description : Met en place un fichier temporaire. *
-* *
-* Retour : Flux ouvert en lecture et écriture, ou -1 en cas d'erreur. *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-int make_tmp_file(const char *prefix, const char *suffix, char **filename)
-{
- int result; /* Flux ou code à retourner */
- const char *tmpdir; /* Répertoire d'accueil */
- bool status; /* Bilan d'un consultation */
- size_t slen; /* Taille du suffixe */
-
- status = g_generic_config_get_value(get_main_configuration(), MPK_TMPDIR, &tmpdir);
- if (!status) return -1;
-
- slen = strlen(suffix);
-
- if (slen > 0)
- asprintf(filename, "%s" G_DIR_SEPARATOR_S "%s-%d.XXXXXX.%s", tmpdir, prefix, getpid(), suffix);
- else
- asprintf(filename, "%s" G_DIR_SEPARATOR_S "%s-%d.XXXXXX", tmpdir, prefix, getpid());
-
- result = ensure_path_exists(*filename);
-
- if (result == 0)
- {
- if (slen > 0)
- result = mkstemps(*filename, slen + 1);
- else
- result = mkstemp(*filename);
-
- if (result == -1) perror("mkstemp");
-
- }
-
- if (result == -1)
- {
- free(*filename);
- *filename = NULL;
- }
-
- return result;
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : dest = fichier de destination de la copie. *
-* src = fichier source à copier. *
-* *
-* Description : Copie un fichier. *
-* *
-* Retour : Bilan de l'opération. *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-bool copy_file(const char *dest, const char *src)
-{
- bool result; /* Bilan à retourner */
- int fd; /* Descripteur du fichier */
- struct stat info; /* Informations sur le fichier */
- int ret; /* Bilan d'un appel */
- void *data; /* Quantité de données traitées*/
- bool status; /* Bilan de la lecture */
-
- result = false;
-
- /* Côté source */
-
- fd = open(src, O_RDONLY);
- if (fd == -1)
- {
- LOG_ERROR_N("open");
- goto exit;
- }
-
- ret = fstat(fd, &info);
- if (ret == -1)
- {
- LOG_ERROR_N("fstat");
- goto done;
- }
-
- data = malloc(info.st_size);
-
- status = safe_read(fd, data, info.st_size);
- if (!status) goto clean;
-
- close(fd);
-
- /* Côté destination */
-
- fd = open(dest, O_WRONLY | O_CREAT, S_IRUSR | S_IWUSR);
- if (fd == -1)
- {
- LOG_ERROR_N("open");
- free(data);
- goto exit;
- }
-
- status = safe_write(fd, data, info.st_size);
- if (!status) goto clean;
-
- result = true;
-
- clean:
-
- free(data);
-
- done:
-
- close(fd);
-
- exit:
-
- return result;
-
-}
diff --git a/src/common/io.h b/src/common/io.h
index b1d4035..82fb41e 100644
--- a/src/common/io.h
+++ b/src/common/io.h
@@ -45,15 +45,6 @@ bool safe_recv(int, void *, size_t, int);
/* Envoie des données au travers un flux réseau. */
bool safe_send(int, const void *, size_t, int);
-/* S'assure qu'un chemin donné existe dans le système. */
-int ensure_path_exists(const char *);
-
-/* Met en place un fichier temporaire. */
-int make_tmp_file(const char *, const char *, char **);
-
-/* Copie un fichier. */
-bool copy_file(const char *, const char *);
-
#endif /* _COMMON_IO_H */
diff --git a/src/common/pathname.c b/src/common/pathname.c
index d6355ed..dd3ec9e 100644
--- a/src/common/pathname.c
+++ b/src/common/pathname.c
@@ -25,13 +25,21 @@
#include <assert.h>
+#include <fcntl.h>
#include <glib.h>
+#include <libgen.h>
#include <malloc.h>
+#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
+#include <unistd.h>
#include <sys/stat.h>
#include "extstr.h"
+#include "io.h"
+#include "../core/logs.h"
+//#include "../core/params.h" // TODO : config
@@ -254,3 +262,174 @@ bool mkpath(const char *path)
return (ret == 0);
}
+
+
+/******************************************************************************
+* *
+* Paramètres : path = chemin d'accès à valider. *
+* *
+* Description : S'assure qu'un chemin donné existe dans le système. *
+* *
+* Retour : 0 si le chemin est actuellement présent, -1 sinon. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+int ensure_path_exists(const char *path)
+{
+ int result; /* Bilan de l'assurance */
+ char *copy; /* Chemin libérable */
+ char *tmp; /* Chemin altérable */
+
+ copy = strdup(path);
+ tmp = dirname(copy);
+
+ result = access(tmp, W_OK | X_OK);
+
+ if (result != 0)
+ {
+ result = ensure_path_exists(tmp);
+
+ if (result == 0)
+ result = mkdir(tmp, 0700);
+
+ }
+
+ free(copy);
+
+ return result;
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : prefix = préfixe du nom du fichier temporaire à créer. *
+* suffix = éventuel suffixe à coller au nom de fichier. *
+* filename = chemin d'accès complet au nouveau fichier. [OUT] *
+* *
+* Description : Met en place un fichier temporaire. *
+* *
+* Retour : Flux ouvert en lecture et écriture, ou -1 en cas d'erreur. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+#if 0 // TODO
+int make_tmp_file(const char *prefix, const char *suffix, char **filename)
+{
+ int result; /* Flux ou code à retourner */
+ const char *tmpdir; /* Répertoire d'accueil */
+ bool status; /* Bilan d'un consultation */
+ size_t slen; /* Taille du suffixe */
+
+ status = g_generic_config_get_value(get_main_configuration(), MPK_TMPDIR, &tmpdir);
+ if (!status) return -1;
+
+ slen = strlen(suffix);
+
+ if (slen > 0)
+ asprintf(filename, "%s" G_DIR_SEPARATOR_S "%s-%d.XXXXXX.%s", tmpdir, prefix, getpid(), suffix);
+ else
+ asprintf(filename, "%s" G_DIR_SEPARATOR_S "%s-%d.XXXXXX", tmpdir, prefix, getpid());
+
+ result = ensure_path_exists(*filename);
+
+ if (result == 0)
+ {
+ if (slen > 0)
+ result = mkstemps(*filename, slen + 1);
+ else
+ result = mkstemp(*filename);
+
+ if (result == -1) perror("mkstemp");
+
+ }
+
+ if (result == -1)
+ {
+ free(*filename);
+ *filename = NULL;
+ }
+
+ return result;
+
+}
+#endif
+
+/******************************************************************************
+* *
+* Paramètres : dest = fichier de destination de la copie. *
+* src = fichier source à copier. *
+* *
+* Description : Copie un fichier. *
+* *
+* Retour : Bilan de l'opération. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+bool copy_file(const char *dest, const char *src)
+{
+ bool result; /* Bilan à retourner */
+ int fd; /* Descripteur du fichier */
+ struct stat info; /* Informations sur le fichier */
+ int ret; /* Bilan d'un appel */
+ void *data; /* Quantité de données traitées*/
+ bool status; /* Bilan de la lecture */
+
+ result = false;
+
+ /* Côté source */
+
+ fd = open(src, O_RDONLY);
+ if (fd == -1)
+ {
+ LOG_ERROR_N("open");
+ goto exit;
+ }
+
+ ret = fstat(fd, &info);
+ if (ret == -1)
+ {
+ LOG_ERROR_N("fstat");
+ goto done;
+ }
+
+ data = malloc(info.st_size);
+
+ status = safe_read(fd, data, info.st_size);
+ if (!status) goto clean;
+
+ close(fd);
+
+ /* Côté destination */
+
+ fd = open(dest, O_WRONLY | O_CREAT, S_IRUSR | S_IWUSR);
+ if (fd == -1)
+ {
+ LOG_ERROR_N("open");
+ free(data);
+ goto exit;
+ }
+
+ status = safe_write(fd, data, info.st_size);
+ if (!status) goto clean;
+
+ result = true;
+
+ clean:
+
+ free(data);
+
+ done:
+
+ close(fd);
+
+ exit:
+
+ return result;
+
+}
diff --git a/src/common/pathname.h b/src/common/pathname.h
index f7b679e..1b6624c 100644
--- a/src/common/pathname.h
+++ b/src/common/pathname.h
@@ -38,6 +38,17 @@ char *build_absolute_filename(const char *, const char *);
/* S'assure que le chemin fourni est bien en place. */
bool mkpath(const char *);
+/* S'assure qu'un chemin donné existe dans le système. */
+int ensure_path_exists(const char *);
+
+/* Met en place un fichier temporaire. */
+#if 0 // TODO
+int make_tmp_file(const char *, const char *, char **);
+#endif
+
+/* Copie un fichier. */
+bool copy_file(const char *, const char *);
+
#endif /* _COMMON_PATHNAME_H */