X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogin%2Flogind-user.c;h=4af0e90c2232d36d9c790085151d5765166eb09f;hb=a0eb2a751c6f3e9c233772cd9af8e8ee1504d27a;hp=fdbf6e3aa08ef73df5e30a283932004e49e34b45;hpb=5f41d1f10fd97e93517b6a762b1bec247f4d1171;p=elogind.git diff --git a/src/login/logind-user.c b/src/login/logind-user.c index fdbf6e3aa..4af0e90c2 100644 --- a/src/login/logind-user.c +++ b/src/login/logind-user.c @@ -494,13 +494,19 @@ static int user_remove_runtime_path(User *u) { return r; } -int user_stop(User *u) { +int user_stop(User *u, bool force) { Session *s; int r = 0, k; assert(u); + /* Stop jobs have already been queued */ + if (u->stopping) { + user_save(u); + return r; + } + LIST_FOREACH(sessions_by_user, s, u->sessions) { - k = session_stop(s); + k = session_stop(s, force); if (k < 0) r = k; } @@ -648,9 +654,12 @@ UserState user_get_state(User *u) { bool all_closing = true; LIST_FOREACH(sessions_by_user, i, u->sessions) { - if (session_is_active(i)) + SessionState state; + + state = session_get_state(i); + if (state == SESSION_ACTIVE) return USER_ACTIVE; - if (session_get_state(i) != SESSION_CLOSING) + if (state != SESSION_CLOSING) all_closing = false; }