X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/172a73b13fe909117c7fbf3d69d4ce5e87efdbc6..e2f4c322102dab25d663a761157720cbbb11702d:/src/xbt/xbt_os_file.cpp diff --git a/src/xbt/xbt_os_file.cpp b/src/xbt/xbt_os_file.cpp index d3e87dfd16..ce487f4ebd 100644 --- a/src/xbt/xbt_os_file.cpp +++ b/src/xbt/xbt_os_file.cpp @@ -1,49 +1,46 @@ -/* xbt_os_file.cpp -- portable interface to file-related functions */ +/* xbt_os_file.cpp -- portable interface to file-related functions */ -/* Copyright (c) 2017. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2017-2019. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ +#include "src/internal_config.h" +#include "xbt/asserts.h" #include "xbt/file.hpp" /* this module */ -#include "xbt/file.h" -#include "xbt/sysdep.h" - #ifdef _WIN32 #include #endif +#if HAVE_UNISTD_H +#include +#endif + #include +#include #include /* POSIX dirname */ -/** @brief Returns the directory component of a path (reimplementation of POSIX dirname) - * - * The argument is never modified, and the returned value must be freed after use. - */ -char *xbt_dirname(const char *path) +simgrid::xbt::Path::Path() { - return xbt_strdup(simgrid::xbt::Path(path).getDirname().c_str()); -} - -/** @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) -{ - return xbt_strdup(simgrid::xbt::Path(path).getBasename().c_str()); +#if HAVE_UNISTD_H + char buffer[2048]; + char* ret = getcwd(buffer, 2048); + xbt_assert(ret == buffer, "Error during getcwd: %s", strerror(errno)); + path_ = std::string(buffer); +#else + path_ = std::string("."); +#endif } -std::string simgrid::xbt::Path::getDirname() +std::string simgrid::xbt::Path::get_dir_name() { std::string p(path_); char *res = dirname(&p[0]); return std::string(res, strlen(res)); } -std::string simgrid::xbt::Path::getBasename() +std::string simgrid::xbt::Path::get_base_name() { std::string p(path_); char *res = basename(&p[0]);