mirror of
https://github.com/postgres/postgres.git
synced 2025-06-29 10:41:53 +03:00
Unify calling conventions for postgres/postmaster sub-main functions
There was a wild mix of calling conventions: Some were declared to return void and didn't return, some returned an int exit code, some claimed to return an exit code, which the callers checked, but actually never returned, and so on. Now all of these functions are declared to return void and decorated with attribute noreturn and don't return. That's easiest, and most code already worked that way.
This commit is contained in:
@ -3507,7 +3507,7 @@ process_postgres_switches(int argc, char *argv[], GucContext ctx)
|
||||
* for the session.
|
||||
* ----------------------------------------------------------------
|
||||
*/
|
||||
int
|
||||
void
|
||||
PostgresMain(int argc, char *argv[], const char *username)
|
||||
{
|
||||
const char *dbname;
|
||||
@ -3721,7 +3721,10 @@ PostgresMain(int argc, char *argv[], const char *username)
|
||||
|
||||
/* If this is a WAL sender process, we're done with initialization. */
|
||||
if (am_walsender)
|
||||
proc_exit(WalSenderMain());
|
||||
{
|
||||
WalSenderMain(); /* does not return */
|
||||
abort();
|
||||
}
|
||||
|
||||
/*
|
||||
* process any libraries that should be preloaded at backend start (this
|
||||
@ -4199,7 +4202,7 @@ PostgresMain(int argc, char *argv[], const char *username)
|
||||
/* can't get here because the above loop never exits */
|
||||
Assert(false);
|
||||
|
||||
return 1; /* keep compiler quiet */
|
||||
abort(); /* keep compiler quiet */
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user