Namespaces
Variants

std::experimental::filesystem:: last_write_time

From cppreference.net
Definido en el encabezado <experimental/filesystem>
file_time_type last_write_time ( const path & p ) ;
file_time_type last_write_time ( const path & p, error_code & ec )
(1) (filesystem TS)
void last_write_time ( const path & p, file_time_type new_time ) ;
void last_write_time ( const path & p, file_time_type new_time, error_code & ec ) ;
(2) (filesystem TS)
1) Devuelve el tiempo de la última modificación de p , determinado como si se accediera al miembro st_mtime del stat de POSIX (los enlaces simbólicos son seguidos). La sobrecarga que no lanza excepciones devuelve file_time_type :: min ( ) en caso de errores.
2) Cambia la hora de la última modificación de p , como si fuera mediante POSIX futimens (los enlaces simbólicos son seguidos).

Contenidos

Parámetros

p - ruta a examinar o modificar
new_time - nuevo tiempo de modificación
ec - parámetro de salida para reporte de errores en la sobrecarga que no lanza excepciones

Valor de retorno

1) El tiempo de la última modificación de p .
2) (ninguno)

Excepciones

The overload that does not take an error_code & parameter throws filesystem_error on underlying OS API errors, constructed with p as the first argument and the OS error code as the error code argument. std:: bad_alloc may be thrown if memory allocation fails. The overload taking an error_code & parameter sets it to the OS API error code if an OS API call fails, and executes ec. clear ( ) if no errors occur. This overload has
noexcept especificación:
noexcept

Notas

No está garantizado que inmediatamente después de establecer la hora de escritura, el valor devuelto por (1) sea el mismo que lo que se pasó como argumento a (2) porque la hora del sistema de archivos puede ser más granular que file_time_type .

Ejemplo

#include <chrono>
#include <experimental/filesystem>
#include <fstream>
#include <iomanip>
#include <iostream>
namespace fs = std::experimental::filesystem;
using namespace std::chrono_literals;
int main()
{
    fs::path p = fs::current_path() / "example.bin";
    std::ofstream(p.c_str()).put('a'); // crear archivo
    auto ftime = fs::last_write_time(p);
    std::time_t cftime = decltype(ftime)::clock::to_time_t(ftime); // asumiendo system_clock
    std::cout << "File write time is " << std::asctime(std::localtime(&cftime)) << '\n';
    fs::last_write_time(p, ftime + 1h); // mover la hora de escritura del archivo 1 hora hacia el futuro
    ftime = fs::last_write_time(p); // leer nuevamente desde el sistema de archivos
    cftime = decltype(ftime)::clock::to_time_t(ftime);
    std::cout << "File write time is " << std::asctime(std::localtime(&cftime)) << '\n';
    fs::remove(p);
}

Salida posible:

File write time is Tue Mar 31 19:47:04 2015
File write time is Tue Mar 31 20:47:04 2015

Véase también

representa valores de tiempo de archivo
(typedef)