mirror of
https://github.com/javalsai/lidm.git
synced 2026-02-27 03:50:44 +01:00
fix: launch state off by one bug (#116)
Previously it couldn't find the currect user/session because the last newline character was present in the field
This commit is contained in:
@@ -22,16 +22,16 @@ int read_launch_state(struct LaunchState* NNULLABLE state) {
|
|||||||
|
|
||||||
size_t num = 0;
|
size_t num = 0;
|
||||||
ssize_t chars = getline(&state->username, &num, state_fd);
|
ssize_t chars = getline(&state->username, &num, state_fd);
|
||||||
if (chars < 0) goto fail;
|
if (chars <= 0) goto fail;
|
||||||
if (state->username[chars] == '\n') state->username[chars] = 0;
|
if (state->username[chars - 1] == '\n') state->username[chars - 1] = 0;
|
||||||
|
|
||||||
num = 0;
|
num = 0;
|
||||||
chars = getline(&state->session_opt, &num, state_fd);
|
chars = getline(&state->session_opt, &num, state_fd);
|
||||||
if (chars < 0) {
|
if (chars <= 0) {
|
||||||
free(state->session_opt);
|
free(state->session_opt);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
if (state->session_opt[chars] == '\n') state->session_opt[chars] = 0;
|
if (state->session_opt[chars - 1] == '\n') state->session_opt[chars - 1] = 0;
|
||||||
|
|
||||||
(void)fclose(state_fd);
|
(void)fclose(state_fd);
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
Reference in New Issue
Block a user