#include <stdexcept>
void writeFile( const std::string& name, const std::string& content ) {
- std::ofstream file;
-
- file.open( name );
+ std::ofstream file( name );
file << content;
- file.close();
//! \FIXME: Error checking
}
std::string readFile( const std::string& name ) {
std::ifstream t( name );
std::string res = std::string( std::istreambuf_iterator<char>( t ), std::istreambuf_iterator<char>() );
- t.close();
return res;
}
std::string checkS( check, siz );
if( checkS != date ) {
- return std::pair<bool, time_t>( false, 0 );
+ return { false, 0 };
}
return std::pair<bool, time_t>( true, res );
}
}
-std::shared_ptr<std::ofstream> openLogfile( const std::string name ) {
+std::unique_ptr<std::ofstream> openLogfile( const std::string &name ) {
struct stat buffer;
std::string tname = name;
int ctr = 2;
tname = name + "_" + std::to_string( ctr++ );
}
- auto res = std::shared_ptr<std::ofstream>( new std::ofstream( tname ),
- []( std::ofstream * p ) {
- p->close();
- delete p;
- } );
+ auto res = std::make_unique<std::ofstream>( tname );
if( ! res->good() ) {
- throw std::string( "Failed to open file for logging: " ) + name;
+ throw std::runtime_error( std::string("Failed to open file for logging: " ) + name );
}
return res;
}
+
+std::string timestamp(){
+ time_t c_time;
+ if( time( &c_time ) == -1 ) {
+ throw std::runtime_error( "Error while fetching time?" );
+ }
+ return std::to_string( c_time );
+}