]> git.tdb.fi Git - libs/core.git/blobdiff - source/core/application.cpp
terminate instead of rethrowing an uncaught exception
[libs/core.git] / source / core / application.cpp
index 0ef3443e8eac4fab7173b15df42c9cd1360b4e88..0e0b69f28af4aa9686ff4e30fb593f8ea58ea635 100644 (file)
@@ -40,16 +40,16 @@ int Application::run(int argc, char **argv)
 
        try
        {
-               app_=reg_app_->create_app(argc, argv);
-       }
-       catch(const UsageError &e)
-       {
-               reg_app_->usage(e.what(), argv[0], e.get_brief());
-               return 1;
-       }
+               try
+               {
+                       app_=reg_app_->create_app(argc, argv);
+               }
+               catch(const UsageError &e)
+               {
+                       reg_app_->usage(e.what(), argv[0], e.get_brief());
+                       return 1;
+               }
 
-       try
-       {
                int result=app_->main();
                delete app_;
                return result;
@@ -60,7 +60,7 @@ int Application::run(int argc, char **argv)
                cerr<<"  type:   "<<typeid(e).name()<<'\n';
                cerr<<"  what(): "<<e.what()<<'\n';
                delete app_;
-               throw;
+               terminate();
        }
 }