NAME
upscli_readline, upscli_readline_timeout - Read a single response from a UPS
SYNOPSIS
| Note | Two NUT websites This version of the page reflects NUT release v2.8.3 with codebase commited c0acf09af at 2025-04-21T23:59:59+00:00 Options, features and capabilities in current development (and future releases) are detailed on the main site and may differ from ones described here. | 
        #include <upsclient.h>
        #include <time.h> /* or <sys/time.h> on some platforms */
        int upscli_readline(UPSCONN_t *ups, char *buf, size_t buflen);
        int upscli_readline_timeout(UPSCONN_t *ups, char *buf, size_t buflen,
                const time_t timeout);DESCRIPTION
The upscli_readline() and upscli_readline_timeout() functions take
the  pointer ups to a UPSCONN_t state structure, receive a single
line from the server, and copy up to buflen bytes of the response
into the buffer buf.
Some parsing of the string occurs during reception. In particular, ERR messages from upsd(8) are detected and will cause this function to return -1.
The difference between the two functions is that upscli_readline_timeout() lets the caller decide the amount of time (timeout seconds) after which it should give up and return, whereas upscli_readline() does not offer this freedom, and uses NUT default network timeout (5 seconds).
RETURN VALUE
The upscli_readline() and upscli_readline_timeout() functions return 0 on success, or -1 if an error occurs.