X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3d845df082d79ab89649c1a8829eea201ae01085..d0db566319780080d97b6b0e66717959b42ff228:/src/xbt/xbt_os_file.c diff --git a/src/xbt/xbt_os_file.c b/src/xbt/xbt_os_file.c index 232ad066ea..4cc64d28df 100644 --- a/src/xbt/xbt_os_file.c +++ b/src/xbt/xbt_os_file.c @@ -9,7 +9,11 @@ #include "xbt/sysdep.h" #include "xbt/file.h" /* this module */ #include "xbt/log.h" -#include "portable.h" +#include "src/internal_config.h" + +#ifdef _WIN32 +#include +#endif #ifndef _MSC_VER #include "libgen.h" /* POSIX dirname */ @@ -67,13 +71,34 @@ ssize_t xbt_getline(char **buf, size_t *n, FILE *stream) * The argument is never modified, and the returned value must be freed after use. */ char *xbt_dirname(const char *path) { -#if _MSC_VER - char drive[_MAX_DRIVE]; - char dir[_MAX_DIR]; - errno_t err; - err = _splitpath_s(path, drive, _MAX_DRIVE, dir, _MAX_DIR, NULL,0, NULL,0); - return bprintf("%s%s",drive,dir); +#ifdef _MSC_VER + char drive[_MAX_DRIVE]; + char dir[_MAX_DIR]; + errno_t err; + err = _splitpath_s(path, drive, _MAX_DRIVE, dir, _MAX_DIR, NULL,0, NULL,0); + return bprintf("%s%s",drive,dir); +#else + char *tmp = xbt_strdup(path); + char *res = xbt_strdup(dirname(tmp)); + free(tmp); + return res; +#endif +} +/** @brief Returns the file component of a path (reimplementation of POSIX basename) + * + * The argument is never modified, and the returned value must be freed after use. + */ +char *xbt_basename(const char *path) { +#ifdef _MSC_VER + char file[1024]; + char ext[1024]; + errno_t err; + err = _splitpath_s(path, NULL,0, NULL,0, file,1024, ext,1024); + return bprintf("%s.%s",file,ext); #else - return dirname(xbt_strdup(path)); + char *tmp = xbt_strdup(path); + char *res = xbt_strdup(basename(tmp)); + free(tmp); + return res; #endif }