mirror of
https://github.com/matrix-construct/construct
synced 2025-01-27 06:50:01 +01:00
construct: Simplify various behavior based on runlevel.
This commit is contained in:
parent
97f38507e0
commit
b2b5d6abce
2 changed files with 19 additions and 23 deletions
construct
|
@ -105,7 +105,7 @@ try
|
||||||
ircd::runlevel == ircd::runlevel::HALT;
|
ircd::runlevel == ircd::runlevel::HALT;
|
||||||
});
|
});
|
||||||
|
|
||||||
if(ircd::runlevel == ircd::runlevel::HALT)
|
if(ircd::runlevel != ircd::runlevel::RUN)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const unwind atexit([]
|
const unwind atexit([]
|
||||||
|
|
|
@ -232,10 +232,10 @@ enable_coredumps()
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static bool handle_quit();
|
static void handle_quit();
|
||||||
static bool handle_interruption();
|
static void handle_interruption();
|
||||||
static bool handle_hangup();
|
static void handle_hangup();
|
||||||
static bool handle(const int &signum);
|
static void handle(const int &signum);
|
||||||
|
|
||||||
void
|
void
|
||||||
sigfd_handler(const boost::system::error_code &ec,
|
sigfd_handler(const boost::system::error_code &ec,
|
||||||
|
@ -258,13 +258,20 @@ noexcept
|
||||||
throw std::runtime_error(ec.message());
|
throw std::runtime_error(ec.message());
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!handle(signum))
|
handle(signum);
|
||||||
|
|
||||||
|
switch(ircd::runlevel)
|
||||||
|
{
|
||||||
|
case ircd::runlevel::QUIT:
|
||||||
|
case ircd::runlevel::FAULT:
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
default:
|
||||||
sigs.async_wait(sigfd_handler);
|
sigs.async_wait(sigfd_handler);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
void
|
||||||
handle(const int &signum)
|
handle(const int &signum)
|
||||||
{
|
{
|
||||||
switch(signum)
|
switch(signum)
|
||||||
|
@ -273,17 +280,15 @@ handle(const int &signum)
|
||||||
case SIGHUP: return handle_hangup();
|
case SIGHUP: return handle_hangup();
|
||||||
case SIGQUIT: return handle_quit();
|
case SIGQUIT: return handle_quit();
|
||||||
case SIGTERM: return handle_quit();
|
case SIGTERM: return handle_quit();
|
||||||
default: return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
void
|
||||||
handle_quit()
|
handle_quit()
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
console_cancel();
|
console_cancel();
|
||||||
ircd::quit();
|
ircd::quit();
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
catch(const std::exception &e)
|
catch(const std::exception &e)
|
||||||
{
|
{
|
||||||
|
@ -291,16 +296,13 @@ catch(const std::exception &e)
|
||||||
{
|
{
|
||||||
"SIGQUIT handler: %s", e.what()
|
"SIGQUIT handler: %s", e.what()
|
||||||
};
|
};
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
void
|
||||||
handle_hangup()
|
handle_hangup()
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
console_hangup();
|
console_hangup();
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
catch(const std::exception &e)
|
catch(const std::exception &e)
|
||||||
{
|
{
|
||||||
|
@ -308,11 +310,9 @@ catch(const std::exception &e)
|
||||||
{
|
{
|
||||||
"SIGHUP handler: %s", e.what()
|
"SIGHUP handler: %s", e.what()
|
||||||
};
|
};
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
void
|
||||||
handle_interruption()
|
handle_interruption()
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -320,8 +320,6 @@ try
|
||||||
console_cancel();
|
console_cancel();
|
||||||
else
|
else
|
||||||
console_spawn();
|
console_spawn();
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
catch(const std::exception &e)
|
catch(const std::exception &e)
|
||||||
{
|
{
|
||||||
|
@ -329,6 +327,4 @@ catch(const std::exception &e)
|
||||||
{
|
{
|
||||||
"SIGINT handler: %s", e.what()
|
"SIGINT handler: %s", e.what()
|
||||||
};
|
};
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue