Saltar al contenido

función mkdir c++

Después de investigar con expertos en esta materia, programadores de deferentes áreas y profesores hemos dado con la solución a la cuestión y la compartimos en esta publicación.

Solución:

Si desea escribir código multiplataforma, puede usar boost::filesystem rutinas

#include 
boost::filesystem::create_directory("dirname");

Esto agrega una dependencia de la biblioteca, pero es probable que también use otras rutinas del sistema de archivos y boost::filesystem tiene algunas interfaces geniales para eso.

Si solo necesita crear un nuevo directorio y si solo va a usar VS 2008, puede usar _mkdir() como otros han señalado.

Está en desuso, pero cumple con ISO C ++ _mkdir() lo reemplazó, así que use esa versión. Todo lo que necesita para llamarlo es el nombre del directorio, su único argumento:

#include 

void foo()

  _mkdir("C:\hello"); // Notice the double backslash, since backslashes 
                       // need to be escaped

Aquí está el prototipo de MSDN:

int _mkdir( const char *dirname );

Mi solución multiplataforma (recursiva):

#include 
#include 

// for windows mkdir
#ifdef _WIN32
#include 
#endif

namespace utils

    /**
     * Checks if a folder exists
     * @param foldername path to the folder to check.
     * @return true if the folder exists, false otherwise.
     */
    bool folder_exists(std::string foldername)
    
        struct stat st;
        stat(foldername.c_str(), &st);
        return st.st_mode & S_IFDIR;
    

    /**
     * Portable wrapper for mkdir. Internally used by mkdir()
     * @param[in] path the full path of the directory to create.
     * @return zero on success, otherwise -1.
     */
    int _mkdir(const char *path)
    
    #ifdef _WIN32
        return ::_mkdir(path);
    #else
    #if _POSIX_C_SOURCE
        return ::mkdir(path);
    #else
        return ::mkdir(path, 0755); // not sure if this works on mac
    #endif
    #endif
    

    /**
     * Recursive, portable wrapper for mkdir.
     * @param[in] path the full path of the directory to create.
     * @return zero on success, otherwise -1.
     */
    int mkdir(const char *path)
    
        std::string current_level = "";
        std::string level;
        std::stringstream ss(path);

        // split path using slash as a separator
        while (std::getline(ss, level, '/'))
        
            current_level += level; // append folder to the current level

            // create current level
            if (!folder_exists(current_level) && _mkdir(current_level.c_str()) != 0)
                return -1;

            current_level += "/"; // don't forget to append a slash
        

        return 0;
    

Te mostramos las comentarios y valoraciones de los lectores

Acuérdate de que puedes valorar esta noticia si te ayudó.

¡Haz clic para puntuar esta entrada!
(Votos: 0 Promedio: 0)



Utiliza Nuestro Buscador

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *