Boost :: filesystem, std :: sort: problema al retener información en los pases de clasificación

Estoy tratando de usarstd::sort en un tipo de datos que contiene información leída de unboost::filesystem::dictionary_iterator. Parece que como ha hecho el algoritmo de clasificaciónn comparacionesn siendo la cantidad de archivos en el directorio, esa información se pierde y termino segfaulting. Valgrind dice que estoy usando valores sin inicializar y haciendo lecturas inválidas.

Como puedo cambiar miFile tipo de datos o algoritmos para que la información se mantenga entre pases?

#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
#include <boost/filesystem.hpp>
namespace fs = boost::filesystem;

struct File {
    fs::path path;
    fs::file_status status;
};

bool comp(const File& a, const File& b) {
    static size_t count = 0;
    std::cout << "Compare function called " << ++count << " times" << std::endl;
    std::string a_filename = a.path.filename().native();
    std::string b_filename = b.path.filename().native();
    return a_filename.compare(b_filename);
}

int main() {
    std::vector<File> vec;

    // Read directory
    fs::directory_iterator it("/etc"), end;
    for (; it != end; it++) {
        File f = *(new File);
        f.path = it->path();
        f.status = it->status();
        vec.push_back(f);
    }

    std::sort(vec.begin(), vec.end(), comp);

    // Clean up
    for (std::vector<File>::iterator it = vec.begin(); it != vec.end(); it++)
        delete &(*it);

    return 0;
}

(Este no es mi programa real, pero muestra el mismo comportamiento.)

Respuestas a la pregunta(1)

Su respuesta a la pregunta