|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- /*
- * Carla process utils
- * Copyright (C) 2019-2020 Filipe Coelho <falktx@falktx.com>
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License as
- * published by the Free Software Foundation; either version 2 of
- * the License, or any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * For a full copy of the GNU General Public License see the doc/GPL.txt file.
- */
-
- #include "CarlaProcessUtils.hpp"
-
- // --------------------------------------------------------------------------------------------------------------------
- // process utility classes
-
- ScopedAbortCatcher::ScopedAbortCatcher()
- {
- s_triggered = false;
- #ifndef CARLA_OS_WIN
- s_oldsig = ::setjmp(s_env) == 0
- ? std::signal(SIGABRT, sig_handler)
- : nullptr;
- #endif
- }
-
- ScopedAbortCatcher::~ScopedAbortCatcher()
- {
- #ifndef CARLA_OS_WIN
- if (s_oldsig != nullptr && ! s_triggered)
- std::signal(SIGABRT, s_oldsig);
- #endif
- }
-
- bool ScopedAbortCatcher::s_triggered = false;
-
- #ifndef CARLA_OS_WIN
- jmp_buf ScopedAbortCatcher::s_env;
- sig_t ScopedAbortCatcher::s_oldsig;
-
- void ScopedAbortCatcher::sig_handler(const int signum)
- {
- CARLA_SAFE_ASSERT_INT2_RETURN(signum == SIGABRT, signum, SIGABRT,);
-
- s_triggered = true;
- std::signal(signum, s_oldsig);
- std::longjmp(s_env, 1);
- }
- #endif
-
- // --------------------------------------------------------------------------------------------------------------------
-
- CarlaSignalRestorer::CarlaSignalRestorer()
- {
- #ifndef CARLA_OS_WIN
- carla_zeroStructs(sigs, 16);
-
- for (int i=0; i < 16; ++i)
- ::sigaction(i+1, nullptr, &sigs[i]);
- #endif
- }
-
- CarlaSignalRestorer::~CarlaSignalRestorer()
- {
- #ifndef CARLA_OS_WIN
- for (int i=0; i < 16; ++i)
- ::sigaction(i+1, &sigs[i], nullptr);
- #endif
- }
-
- // --------------------------------------------------------------------------------------------------------------------
|