+
#include <iostream>
#include <fstream>
#include <streambuf>
#include "io/bios.h"
#include "io/slipBio.h"
#include "io/recordHandler.h"
+#include "log/logger.hpp"
#include "util.h"
#include "config.h"
#endif
if( parseConfig( path ) != 0 ) {
+ logger::fatal( "Could not parse configuration file." );
return -1;
}
std::shared_ptr<int> ssl_lib = ssl_lib_ref;
if( serialPath == "" ) {
- std::cout << "Error: no serial device is given" << std::endl;
+ logger::fatal( "Error: No device for the serial connection was given." );
return -1;
}
std::shared_ptr<BIO> conn = openSerial( serialPath );
std::shared_ptr<BIO> slip1( BIO_new( toBio<SlipBIO>() ), BIO_free );
- static_cast<SlipBIO*>( slip1->ptr )->setTarget( std::shared_ptr<OpensslBIO>( new OpensslBIOWrapper( conn ) ) );
+ static_cast<SlipBIO*>( slip1->ptr )->setTarget( std::shared_ptr<OpensslBIO>( new OpensslBIOWrapper( conn ) ), true );
DefaultRecordHandler* dh = new DefaultRecordHandler( std::shared_ptr<Signer>( new SimpleOpensslSigner( ) ), slip1 );
+ logger::note( "Entering mainloop" );
while( true ) {
try {
dh->handle();
//} catch( const std::exception &ch ) {
//std::cout << "Real exception: " << typeid(ch).name() << ", " << ch.what() << std::endl;
- } catch( const std::string& ch ) {
- std::cout << "Exception: " << ch << std::endl;
- } catch( char const* ch ) {
- std::cout << "Exception: " << ch << std::endl;
+ } catch( const std::exception& e ) {
+ logger::error( "Exception: ", e.what() );
}
}
return -1;
-} catch(std::exception& e) {
- std::cerr << "Fatal Error: " << e.what() << "!\n";
+} catch( std::exception& e ) {
+ try {
+ logger::fatalf( "Fatal Error: %s!\n", e.what() );
+ }catch( std::exception &e){
+ printf( "Fatal Error (+logger failed): %s!\n", e.what() );
+ }
return -1;
-} catch(...) {
- std::cerr << "Fatal Error: Unknown Exception!\n";
+} catch( ... ) {
+ try{
+ logger::fatal( "Fatal Error: Unknown Exception!\n" );
+ }catch( std::exception &e){
+ printf( "Fatal Error (+ logger failed): %s!\n", e.what() );
+ }
return -1;
}